/* ============================================================
   Alhafi CLINIC — Medical White Theme
   Design: Clean, trustworthy, professional healthcare
   ============================================================ */

/* ── CSS Custom Properties ─────────────────────────────────── */
:root {
    --cl-primary:    #0EA5E9;   /* Sky Blue  */
    --cl-secondary:  #10B981;   /* Teal Green*/
    --cl-accent:     #8B5CF6;   /* Violet    */
    --cl-warning:    #F59E0B;   /* Amber     */
    --cl-danger:     #EF4444;
    --cl-bg:         #F8FAFC;   /* Off white */
    --cl-bg-card:    #FFFFFF;
    --cl-bg-section: #F0F9FF;
    --cl-border:     #E2E8F0;
    --cl-text:       #0F172A;
    --cl-text-muted: #64748B;
    --cl-shadow-sm:  0 1px 3px rgba(14,165,233,.12);
    --cl-shadow-md:  0 4px 20px rgba(14,165,233,.15);
    --cl-shadow-lg:  0 12px 40px rgba(14,165,233,.18);
    --cl-radius:     16px;
    --cl-radius-sm:  10px;
    --cl-font:       'Cairo', sans-serif;
}

/* ── Base ───────────────────────────────────────────────────── */
.clinic-body {
    font-family: var(--cl-font);
    background: var(--cl-bg);
    color: var(--cl-text);
}

/* ── Platform Bar ────────────────────────────────────────────── */
.cl-platform-bar {
    position: fixed; top: 0; inset-inline: 0; z-index: 1100;
    padding: .4rem 0;
    background: rgba(255,255,255,.95);
    backdrop-filter: blur(12px);
    border-bottom: 1px solid #E2E8F0;
    transition: background .3s, border-color .3s;
}
.cl-pbar-back {
    color: #64748B; font-size: .8rem; font-weight: 700; transition: color .2s;
}
.cl-pbar-back:hover { color: var(--cl-primary); }
.cl-pbar-label { font-size: .72rem; color: #94A3B8; }
.cl-pbar-current {
    display: inline-flex; align-items: center; gap: .4rem;
    background: rgba(14,165,233,.1); border: 1px solid rgba(14,165,233,.3);
    border-radius: 50px; padding: .2rem .8rem;
    font-size: .72rem; font-weight: 700; color: #0EA5E9;
}
.cl-pbar-switch {
    display: inline-flex; align-items: center; gap: .4rem;
    background: rgba(0,0,0,.04); border: 1px solid #E2E8F0;
    border-radius: 50px; padding: .2rem .8rem;
    font-size: .72rem; font-weight: 600; color: #94A3B8;
    text-decoration: none; transition: color .2s, border-color .2s;
}
.cl-pbar-switch:hover { color: #00D4AA; border-color: rgba(0,212,170,.4); }

/* Dark mode — matches HR platformBar exactly */
[data-theme="dark"] .cl-platform-bar {
    background: rgba(5,10,20,.92);
    border-bottom-color: rgba(255,255,255,.08);
}
[data-theme="dark"] .cl-pbar-back   { color: rgba(255,255,255,.7); }
[data-theme="dark"] .cl-pbar-back:hover { color: #fff; }
[data-theme="dark"] .cl-pbar-label  { color: rgba(255,255,255,.35); }
[data-theme="dark"] .cl-pbar-current {
    background: rgba(14,165,233,.12);
    border-color: rgba(14,165,233,.3);
    color: #0EA5E9;
}
[data-theme="dark"] .cl-pbar-switch {
    background: rgba(255,255,255,.05);
    border-color: rgba(255,255,255,.10);
    color: rgba(255,255,255,.45);
}
[data-theme="dark"] .cl-pbar-switch:hover { color: #00D4AA; border-color: rgba(0,212,170,.4); }

/* ── Navbar ─────────────────────────────────────────────────── */
.cl-navbar {
    position: fixed; top: 0; inset-inline: 0; z-index: 1000;
    padding: .85rem 0;
    background: rgba(255,255,255,.92);
    backdrop-filter: blur(16px);
    border-bottom: 1px solid var(--cl-border);
    transition: box-shadow .3s;
}
.cl-navbar.scrolled { box-shadow: var(--cl-shadow-md); }
.cl-brand-badge {
    display: inline-flex; align-items: center; gap: .5rem;
    font-weight: 800; font-size: 1.25rem;
    color: var(--cl-primary);
}
.cl-brand-badge .badge-icon {
    width: 36px; height: 36px; border-radius: 10px;
    background: linear-gradient(135deg, var(--cl-primary), var(--cl-secondary));
    display: grid; place-items: center; color: #fff; font-size: .9rem;
}
.cl-nav-link {
    color: var(--cl-text-muted) !important;
    font-weight: 600; font-size: .9rem;
    padding: .4rem .85rem !important;
    border-radius: 8px;
    transition: color .2s, background .2s;
}
.cl-nav-link:hover { color: var(--cl-primary) !important; background: #F0F9FF; }
.cl-product-switch {
    font-size: .8rem; font-weight: 700;
    border: 2px solid var(--cl-border);
    border-radius: 50px; padding: .3rem .9rem;
    color: var(--cl-text-muted); text-decoration: none;
    transition: all .2s;
}
.cl-product-switch:hover { border-color: var(--cl-primary); color: var(--cl-primary); }

/* ── Buttons ─────────────────────────────────────────────────── */
.cl-btn-primary {
    background: linear-gradient(135deg, var(--cl-primary), var(--cl-secondary));
    color: #fff; border: none;
    padding: .8rem 2rem; border-radius: 50px;
    font-weight: 700; font-size: 1rem;
    transition: transform .2s, box-shadow .2s;
    cursor: pointer; text-decoration: none; display: inline-block;
}
.cl-btn-primary:hover { transform: translateY(-2px); box-shadow: 0 8px 24px rgba(14,165,233,.4); color: #fff; }

.cl-btn-ghost {
    background: transparent; color: var(--cl-primary);
    border: 2px solid var(--cl-primary);
    padding: .75rem 1.75rem; border-radius: 50px;
    font-weight: 700; font-size: 1rem;
    transition: all .2s; text-decoration: none; display: inline-block;
}
.cl-btn-ghost:hover { background: var(--cl-primary); color: #fff; }

/* ── Hero ────────────────────────────────────────────────────── */
.cl-hero {
    padding: 173px 0 80px;
    background: linear-gradient(160deg, #F0F9FF 0%, #E0F2FE 40%, #F0FDF4 100%);
    position: relative; overflow: hidden;
}
.cl-hero-wave {
    position: absolute; bottom: -1px; inset-inline: 0;
}
.cl-trust-badge {
    display: inline-flex; align-items: center; gap: .5rem;
    background: #fff; border: 1px solid var(--cl-border);
    border-radius: 50px; padding: .4rem 1rem;
    font-size: .82rem; font-weight: 600; color: var(--cl-primary);
    box-shadow: var(--cl-shadow-sm);
    margin-bottom: 1.5rem;
}
.cl-trust-dot {
    width: 8px; height: 8px; border-radius: 50%;
    background: var(--cl-secondary);
    animation: clPulse 2s infinite;
}
@keyframes clPulse {
    0%,100% { transform: scale(1); opacity: 1; }
    50%      { transform: scale(1.4); opacity: .7; }
}
.cl-hero h1 {
    font-size: clamp(2.2rem, 5vw, 3.4rem);
    font-weight: 900; line-height: 1.25;
    color: var(--cl-text);
}
.cl-hero h1 span {
    background: linear-gradient(135deg, var(--cl-primary), var(--cl-secondary));
    -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text;
}
.cl-hero p.lead { font-size: 1.15rem; color: var(--cl-text-muted); line-height: 1.8; }
.cl-client-chips { display: flex; flex-wrap: wrap; gap: .5rem; margin-top: .75rem; }
.cl-chip {
    background: #fff; border: 1px solid var(--cl-border);
    border-radius: 50px; padding: .3rem .9rem;
    font-size: .78rem; font-weight: 600; color: var(--cl-text-muted);
    box-shadow: var(--cl-shadow-sm);
}

/* ── Dashboard Mockup (Clinic) ──────────────────────────────── */
.cl-dashboard-mock {
    background: #fff;
    border-radius: 20px;
    box-shadow: var(--cl-shadow-lg);
    overflow: hidden;
    border: 1px solid var(--cl-border);
}
.cl-mock-header {
    background: linear-gradient(135deg, var(--cl-primary), var(--cl-secondary));
    padding: 1rem 1.25rem;
    display: flex; align-items: center; gap: .75rem; color: #fff;
    font-weight: 700; font-size: .9rem;
}
.cl-mock-body { padding: 1.25rem; }
.cl-mock-stat-row { display: flex; gap: .75rem; margin-bottom: 1rem; }
.cl-mock-stat {
    flex: 1; background: var(--cl-bg-section);
    border-radius: var(--cl-radius-sm); padding: .75rem .6rem; text-align: center;
    border: 1px solid var(--cl-border);
}
.cl-mock-stat .val { font-size: 1.1rem; font-weight: 800; color: var(--cl-primary); }
.cl-mock-stat .lbl { font-size: .65rem; color: var(--cl-text-muted); margin-top: .1rem; }
.cl-appointment-row {
    display: flex; align-items: center; gap: .6rem;
    padding: .5rem .6rem; border-radius: 8px;
    background: var(--cl-bg-section); margin-bottom: .45rem;
    font-size: .75rem; font-weight: 600;
}
.cl-appointment-row .status-dot {
    width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0;
}
.status-confirmed { background: var(--cl-secondary); }
.status-waiting   { background: var(--cl-warning); }
.status-done      { background: var(--cl-primary); }

/* ── Section Headers ─────────────────────────────────────────── */
.cl-section { padding: 90px 0; }
.cl-section-alt { padding: 90px 0; background: var(--cl-bg-section); }
.cl-section-tag {
    display: inline-block; background: #EFF6FF; color: var(--cl-primary);
    border: 1px solid #BFDBFE; border-radius: 50px;
    font-size: .8rem; font-weight: 700; padding: .3rem 1rem; margin-bottom: 1rem;
}
.cl-section-tag.green { background: #ECFDF5; color: var(--cl-secondary); border-color: #A7F3D0; }
.cl-section-tag.violet { background: #F5F3FF; color: var(--cl-accent); border-color: #DDD6FE; }
.cl-section-tag.amber { background: #FFFBEB; color: var(--cl-warning); border-color: #FDE68A; }
.cl-section-title {
    font-size: clamp(1.8rem, 3.5vw, 2.6rem);
    font-weight: 900; color: var(--cl-text); margin-bottom: .75rem;
}
.cl-section-sub { font-size: 1.05rem; color: var(--cl-text-muted); max-width: 600px; margin: 0 auto; }

/* ── Stats Strip ─────────────────────────────────────────────── */
.cl-stats { padding: 50px 0; background: linear-gradient(135deg, var(--cl-primary), var(--cl-secondary)); }
.cl-stat-card { text-align: center; color: #fff; padding: 1.5rem; }
.cl-stat-card .stat-icon { font-size: 2rem; opacity: .85; margin-bottom: .5rem; }
.cl-stat-card .stat-val { font-size: 2.4rem; font-weight: 900; line-height: 1; }
.cl-stat-card .stat-lbl { font-size: .9rem; font-weight: 600; opacity: .9; margin-top: .25rem; }
.cl-stat-card .stat-sub { font-size: .78rem; opacity: .75; margin-top: .15rem; }

/* ── Pain Points ─────────────────────────────────────────────── */
.cl-pain-card {
    background: #fff; border-radius: var(--cl-radius);
    padding: 1.75rem; border: 1px solid var(--cl-border);
    box-shadow: var(--cl-shadow-sm);
    transition: box-shadow .3s, transform .3s;
    height: 100%;
}
.cl-pain-card:hover { box-shadow: var(--cl-shadow-md); transform: translateY(-4px); }
.cl-pain-icon {
    width: 52px; height: 52px; border-radius: 14px;
    display: grid; place-items: center; font-size: 1.4rem;
    margin-bottom: 1rem; color: #fff;
}
.cl-pain-card .problem-area {
    padding: 1rem; background: #FFF7F7; border-radius: 10px;
    border-inline-start: 3px solid #EF4444; margin-bottom: 1rem;
}
.cl-pain-card .problem-area h6 { color: #EF4444; font-weight: 700; margin-bottom: .25rem; font-size: .85rem; }
.cl-pain-card .problem-area p  { font-size: .82rem; color: var(--cl-text-muted); margin: 0; }
.cl-pain-card .arrow-divider {
    text-align: center; color: var(--cl-secondary); font-size: 1.3rem; margin: .5rem 0;
}
.cl-pain-card .solution-area {
    padding: 1rem; background: #F0FDF4; border-radius: 10px;
    border-inline-start: 3px solid var(--cl-secondary);
}
.cl-pain-card .solution-area h6 { color: var(--cl-secondary); font-weight: 700; margin-bottom: .25rem; font-size: .85rem; }
.cl-pain-card .solution-area p  { font-size: .82rem; color: var(--cl-text-muted); margin: 0; }

/* ── Feature Modules ─────────────────────────────────────────── */
.cl-module-card {
    background: #fff; border-radius: var(--cl-radius);
    padding: 2rem 1.75rem;
    border: 1px solid var(--cl-border);
    box-shadow: var(--cl-shadow-sm);
    transition: box-shadow .3s, transform .3s;
    height: 100%; position: relative; overflow: hidden;
}
.cl-module-card::before {
    content: ''; position: absolute; top: 0; inset-inline-start: 0;
    width: 4px; height: 100%; background: var(--module-accent, var(--cl-primary));
    border-radius: 4px 0 0 4px;
}
.cl-module-card:hover { box-shadow: var(--cl-shadow-md); transform: translateY(-5px); }
.cl-module-icon {
    width: 56px; height: 56px; border-radius: 14px;
    display: grid; place-items: center; font-size: 1.5rem; margin-bottom: 1.25rem;
    color: #fff;
}
.cl-module-card h5 { font-weight: 800; font-size: 1.05rem; margin-bottom: .4rem; }
.cl-module-card .benefit { font-weight: 600; font-size: .85rem; color: var(--cl-primary); margin-bottom: .5rem; }
.cl-module-card p  { font-size: .85rem; color: var(--cl-text-muted); line-height: 1.6; margin: 0; }
.cl-module-badge {
    position: absolute; top: 1rem; inset-inline-end: 1rem;
    background: linear-gradient(135deg, var(--cl-primary), var(--cl-secondary));
    color: #fff; font-size: .7rem; font-weight: 700;
    padding: .2rem .65rem; border-radius: 50px;
}

/* ── Security Section ────────────────────────────────────────── */
.cl-security { padding: 90px 0; background: linear-gradient(160deg, #0F172A 0%, #1E3A5F 100%); color: #fff; }
.cl-security .cl-section-title { color: #fff; }
.cl-security .cl-section-sub   { color: #94A3B8; }
.cl-security-card {
    background: rgba(255,255,255,.06);
    border: 1px solid rgba(255,255,255,.12);
    border-radius: var(--cl-radius); padding: 2rem 1.75rem;
    transition: background .3s, transform .3s;
    height: 100%;
}
.cl-security-card:hover { background: rgba(255,255,255,.1); transform: translateY(-4px); }
.cl-security-icon {
    width: 56px; height: 56px; border-radius: 14px;
    display: grid; place-items: center; font-size: 1.5rem;
    color: #fff; margin-bottom: 1.25rem;
}
.cl-security-card h5 { font-weight: 800; font-size: 1.05rem; color: #fff; margin-bottom: .5rem; }
.cl-security-card p  { font-size: .85rem; color: #94A3B8; line-height: 1.6; margin: 0; }

/* ── Workflow Steps ──────────────────────────────────────────── */
.cl-workflow { padding: 90px 0; }
.cl-step-card {
    background: #fff; border-radius: var(--cl-radius);
    padding: 2rem; border: 1px solid var(--cl-border);
    box-shadow: var(--cl-shadow-sm); position: relative;
    transition: box-shadow .3s, transform .3s;
}
.cl-step-card:hover { box-shadow: var(--cl-shadow-md); transform: translateY(-4px); }
.cl-step-number {
    width: 52px; height: 52px; border-radius: 50%;
    display: grid; place-items: center; font-weight: 900; font-size: 1.2rem;
    color: #fff; margin-bottom: 1.25rem; flex-shrink: 0;
}
.cl-step-connector {
    display: none;
}
@media (min-width: 992px) {
    .cl-step-connector {
        display: block; position: absolute;
        top: 2.5rem; inset-inline-end: -30px;
        width: 60px; height: 2px;
        background: repeating-linear-gradient(90deg, var(--cl-border) 0 6px, transparent 6px 12px);
    }
    .cl-step-wrapper:last-child .cl-step-connector { display: none; }
}
.cl-step-card h5 { font-weight: 800; font-size: 1rem; margin-bottom: .5rem; }
.cl-step-card p  { font-size: .85rem; color: var(--cl-text-muted); line-height: 1.6; margin: 0; }

/* ── Testimonials ────────────────────────────────────────────── */
.cl-testimonial-card {
    background: #fff; border-radius: var(--cl-radius);
    padding: 2rem; border: 1px solid var(--cl-border);
    box-shadow: var(--cl-shadow-sm); height: 100%;
    transition: box-shadow .3s, transform .3s;
}
.cl-testimonial-card:hover { box-shadow: var(--cl-shadow-md); transform: translateY(-4px); }
.cl-quote-icon { font-size: 2.5rem; color: var(--cl-primary); opacity: .25; line-height: 1; margin-bottom: .75rem; }
.cl-stars { color: #F59E0B; font-size: .9rem; margin-bottom: .75rem; }
.cl-testimonial-card .quote-text { font-size: .9rem; line-height: 1.75; color: var(--cl-text); font-style: italic; margin-bottom: 1.5rem; }
.cl-avatar {
    width: 46px; height: 46px; border-radius: 50%;
    display: grid; place-items: center; font-weight: 800; font-size: .9rem;
    color: #fff; flex-shrink: 0;
}
.cl-testimonial-card .author-name  { font-weight: 700; font-size: .9rem; }
.cl-testimonial-card .author-title { font-size: .78rem; color: var(--cl-text-muted); }
.cl-testimonial-card .company-name { font-size: .78rem; color: var(--cl-primary); font-weight: 600; }

/* ── Pricing ─────────────────────────────────────────────────── */
.cl-pricing { padding: 90px 0; background: var(--cl-bg-section); }
.cl-price-card {
    background: #fff; border-radius: var(--cl-radius);
    padding: 2.25rem; border: 1px solid var(--cl-border);
    box-shadow: var(--cl-shadow-sm); height: 100%; position: relative;
    transition: box-shadow .3s, transform .3s;
}
.cl-price-card:hover { box-shadow: var(--cl-shadow-md); transform: translateY(-6px); }
.cl-price-card.popular {
    border-color: var(--cl-primary); border-width: 2px;
    box-shadow: 0 0 0 4px rgba(14,165,233,.08), var(--cl-shadow-md);
}
.cl-price-card.enterprise { border-color: var(--cl-accent); }
.cl-popular-ribbon {
    position: absolute; top: -1px; inset-inline-end: 1.5rem;
    background: linear-gradient(135deg, var(--cl-primary), var(--cl-secondary));
    color: #fff; font-size: .72rem; font-weight: 700;
    padding: .35rem .9rem; border-radius: 0 0 10px 10px;
}
.cl-price-card h4 { font-weight: 800; font-size: 1.2rem; margin-bottom: .25rem; }
.cl-price-card .desc { font-size: .85rem; color: var(--cl-text-muted); margin-bottom: 1.5rem; }
.cl-price-val { font-size: 2.5rem; font-weight: 900; color: var(--cl-text); line-height: 1; }
.cl-price-val span { font-size: 1rem; font-weight: 600; color: var(--cl-text-muted); }
.cl-price-note { font-size: .78rem; color: var(--cl-text-muted); margin-bottom: 1.5rem; }
.cl-feature-list { list-style: none; padding: 0; margin: 0 0 1.75rem; }
.cl-feature-list li { display: flex; align-items: center; gap: .6rem; font-size: .85rem; padding: .4rem 0; border-bottom: 1px solid var(--cl-border); }
.cl-feature-list li:last-child { border-bottom: none; }
.cl-feature-list .bi-check-circle-fill { color: var(--cl-secondary); }
.cl-feature-list .bi-x-circle-fill     { color: #CBD5E1; }

/* ── Final CTA ───────────────────────────────────────────────── */
.cl-final-cta {
    padding: 100px 0;
    background: linear-gradient(135deg, #0EA5E9 0%, #10B981 100%);
    color: #fff; text-align: center;
}
.cl-final-cta h2 { font-size: clamp(1.8rem, 3.5vw, 2.8rem); font-weight: 900; margin-bottom: 1rem; }
.cl-final-cta p  { font-size: 1.05rem; opacity: .9; max-width: 650px; margin: 0 auto 2.5rem; line-height: 1.8; }
.cl-btn-white {
    background: #fff; color: var(--cl-primary);
    border: none; padding: .9rem 2.5rem; border-radius: 50px;
    font-weight: 800; font-size: 1.05rem;
    transition: transform .2s, box-shadow .2s;
    text-decoration: none; display: inline-block;
}
.cl-btn-white:hover { transform: translateY(-3px); box-shadow: 0 10px 30px rgba(0,0,0,.2); color: var(--cl-primary); }

/* ── Lead Form ───────────────────────────────────────────────── */
.cl-lead-form {
    background: #fff; border-radius: var(--cl-radius);
    padding: 2.5rem; box-shadow: var(--cl-shadow-lg);
    border: 1px solid var(--cl-border);
}
.cl-input {
    width: 100%; padding: .8rem 1.1rem;
    border: 1.5px solid var(--cl-border); border-radius: 10px;
    font-family: var(--cl-font); font-size: .95rem; background: #F8FAFC;
    transition: border-color .2s, box-shadow .2s; outline: none;
    color: var(--cl-text);
}
.cl-input:focus { border-color: var(--cl-primary); box-shadow: 0 0 0 3px rgba(14,165,233,.15); background: #fff; }
.cl-input::placeholder { color: #94A3B8; }
label.cl-label { font-weight: 600; font-size: .88rem; color: var(--cl-text); margin-bottom: .35rem; display: block; }

/* ── Footer ──────────────────────────────────────────────────── */
.cl-footer {
    background: #0F172A; color: #94A3B8;
    padding: 3.5rem 0 1.5rem;
}
.cl-footer .brand-row { margin-bottom: 2.5rem; }
.cl-footer .footer-title { color: #F8FAFC; font-weight: 700; font-size: 1rem; margin-bottom: 1rem; }
.cl-footer a { color: #94A3B8; text-decoration: none; font-size: .88rem; transition: color .2s; }
.cl-footer a:hover { color: var(--cl-primary); }
.cl-footer .social-icon {
    width: 38px; height: 38px; border-radius: 10px;
    background: rgba(255,255,255,.08); display: grid; place-items: center;
    color: #94A3B8; transition: background .2s, color .2s;
    font-size: 1rem;
}
.cl-footer .social-icon:hover { background: var(--cl-primary); color: #fff; }
.cl-footer hr { border-color: rgba(255,255,255,.08); }
.cl-footer .copyright { font-size: .82rem; }

/* ── Hero Orbs & Grid Overlay ────────────────────────────────── */
.cl-orb {
    position: absolute;
    border-radius: 50%;
    pointer-events: none;
    opacity: 0;
    transition: opacity .4s;
    filter: blur(80px);
    animation: clOrbFloat 8s ease-in-out infinite;
}
.cl-orb-1 {
    width: 520px; height: 520px;
    background: radial-gradient(circle, rgba(14,165,233,0.20) 0%, transparent 70%);
    top: -120px; inset-inline-end: -120px;
    animation-delay: 0s;
}
.cl-orb-2 {
    width: 400px; height: 400px;
    background: radial-gradient(circle, rgba(16,185,129,0.16) 0%, transparent 70%);
    bottom: 60px; inset-inline-start: -80px;
    animation-delay: 3s;
}
.cl-orb-3 {
    width: 280px; height: 280px;
    background: radial-gradient(circle, rgba(139,92,246,0.14) 0%, transparent 70%);
    top: 40%; inset-inline-end: 30%;
    animation-delay: 6s;
}
@keyframes clOrbFloat {
    0%, 100% { transform: translate(0,0) scale(1); }
    50%       { transform: translate(16px,-16px) scale(1.04); }
}
[data-theme="dark"] .cl-orb { opacity: 1; }
.cl-grid-overlay {
    position: absolute;
    inset: 0;
    pointer-events: none;
    opacity: 0;
    background-image:
        linear-gradient(rgba(255,255,255,0.03) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255,255,255,0.03) 1px, transparent 1px);
    background-size: 50px 50px;
    transition: opacity .4s;
}
[data-theme="dark"] .cl-grid-overlay { opacity: 1; }

/* ── Utilities ───────────────────────────────────────────────── */
@media (max-width: 768px) {
    .cl-hero { padding: 120px 0 60px; }
    .cl-section, .cl-section-alt, .cl-workflow, .cl-pricing { padding: 60px 0; }
}

/* ================================================================
   DARK MODE for Clinic  (html[data-theme="dark"] .clinic-body)
   Glassmorphism style — matches Alhafi HR dark theme
   ================================================================ */
[data-theme="dark"] .clinic-body {
    --cl-bg:         #0A0F1E;
    --cl-bg-card:    #0D1226;
    --cl-bg-section: #131929;
    --cl-glass:      rgba(255,255,255,0.05);
    --cl-glass-b:    rgba(255,255,255,0.08);
    --cl-border:     rgba(255,255,255,0.08);
    --cl-text:       #E2E8F0;
    --cl-text-muted: #94A3B8;
    --cl-shadow-sm:  0 1px 3px rgba(0,0,0,.6);
    --cl-shadow-md:  0 8px 32px rgba(0,0,0,0.4);
    --cl-shadow-lg:  0 12px 40px rgba(0,0,0,.6);
    background: var(--cl-bg);
    color: var(--cl-text);
}

/* Navbar */
[data-theme="dark"] .cl-navbar {
    background: rgba(10,15,30,0.85);
    backdrop-filter: blur(20px);
    border-bottom: 1px solid var(--cl-border);
}
[data-theme="dark"] .cl-nav-link { color: #94A3B8 !important; }
[data-theme="dark"] .cl-nav-link:hover { color: var(--cl-primary) !important; background: rgba(14,165,233,0.07); }
[data-theme="dark"] .cl-product-switch { color: #94A3B8; border-color: rgba(255,255,255,0.08); }
[data-theme="dark"] .cl-brand-badge { color: var(--cl-primary); }

/* Hero */
[data-theme="dark"] .cl-hero {
    background: var(--cl-bg);
    position: relative;
    overflow: hidden;
}
[data-theme="dark"] .cl-hero::before {
    content: '';
    position: absolute;
    width: 550px; height: 550px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(14,165,233,0.16) 0%, transparent 70%);
    top: -100px; inset-inline-end: -120px;
    filter: blur(70px);
    pointer-events: none;
}
[data-theme="dark"] .cl-hero::after {
    content: '';
    position: absolute;
    width: 400px; height: 400px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(16,185,129,0.13) 0%, transparent 70%);
    bottom: 60px; inset-inline-start: -80px;
    filter: blur(70px);
    pointer-events: none;
}
[data-theme="dark"] .cl-hero-wave path { fill: var(--cl-bg-section); }
[data-theme="dark"] .cl-hero h1 { color: #fff; }
[data-theme="dark"] .cl-hero h1 span {
    background: linear-gradient(135deg, var(--cl-primary), var(--cl-secondary));
    -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text;
}
[data-theme="dark"] .cl-hero p.lead { color: #94A3B8; }
[data-theme="dark"] .cl-trust-badge {
    background: rgba(14,165,233,0.08);
    border-color: rgba(14,165,233,0.2);
    color: var(--cl-primary);
    box-shadow: none;
}
[data-theme="dark"] .cl-chip {
    background: rgba(255,255,255,0.05);
    border-color: rgba(255,255,255,0.10);
    color: #94A3B8;
}

/* Dashboard mockup */
[data-theme="dark"] .cl-dashboard-mock {
    background: rgba(13,18,38,0.85);
    backdrop-filter: blur(24px);
    border: 1px solid rgba(255,255,255,0.08);
    box-shadow: 0 8px 32px rgba(0,0,0,0.5), 0 0 40px rgba(14,165,233,0.12);
}
[data-theme="dark"] .cl-mock-body { background: transparent; }
[data-theme="dark"] .cl-mock-stat {
    background: rgba(255,255,255,0.04);
    border-color: rgba(255,255,255,0.08);
}
[data-theme="dark"] .cl-appointment-row {
    background: rgba(255,255,255,0.04);
    color: #E2E8F0;
}

/* Stats strip */
[data-theme="dark"] .cl-stats {
    background: linear-gradient(135deg, rgba(14,165,233,0.85) 0%, rgba(16,185,129,0.85) 100%);
}

/* Sections */
[data-theme="dark"] .cl-section  { background: var(--cl-bg); }
[data-theme="dark"] .cl-section-alt { background: var(--cl-bg-section); }
[data-theme="dark"] .cl-workflow  { background: var(--cl-bg); }
[data-theme="dark"] .cl-pricing   { background: var(--cl-bg-section); }
[data-theme="dark"] .cl-security  {
    background: linear-gradient(160deg, #0A0F1E 0%, #0D1A2D 100%);
}

/* Section tags */
[data-theme="dark"] .cl-section-tag {
    background: rgba(14,165,233,0.10);
    color: #7DD3FC;
    border-color: rgba(14,165,233,0.25);
}
[data-theme="dark"] .cl-section-tag.green {
    background: rgba(16,185,129,0.10);
    color: #6EE7B7;
    border-color: rgba(16,185,129,0.25);
}
[data-theme="dark"] .cl-section-tag.violet {
    background: rgba(139,92,246,0.10);
    color: #C4B5FD;
    border-color: rgba(139,92,246,0.25);
}
[data-theme="dark"] .cl-section-tag.amber {
    background: rgba(245,158,11,0.10);
    color: #FCD34D;
    border-color: rgba(245,158,11,0.25);
}
[data-theme="dark"] .cl-section-title { color: #fff; }
[data-theme="dark"] .cl-section-sub   { color: #94A3B8; }

/* Pain cards */
[data-theme="dark"] .cl-pain-card {
    background: rgba(255,255,255,0.05);
    border: 1px solid rgba(255,255,255,0.08);
    box-shadow: 0 8px 32px rgba(0,0,0,0.4);
}
[data-theme="dark"] .cl-pain-card:hover {
    background: rgba(255,255,255,0.07);
    box-shadow: 0 12px 40px rgba(0,0,0,0.5);
    border-color: rgba(255,255,255,0.13);
}
[data-theme="dark"] .cl-pain-card .problem-area {
    background: rgba(239,68,68,0.08);
    border-inline-start-color: #f87171;
}
[data-theme="dark"] .cl-pain-card .problem-area h6 { color: #f87171; }
[data-theme="dark"] .cl-pain-card .problem-area p  { color: #94A3B8; }
[data-theme="dark"] .cl-pain-card .arrow-divider   { color: #6EE7B7; }
[data-theme="dark"] .cl-pain-card .solution-area {
    background: rgba(16,185,129,0.08);
    border-inline-start-color: #6EE7B7;
}
[data-theme="dark"] .cl-pain-card .solution-area h6 { color: #6EE7B7; }
[data-theme="dark"] .cl-pain-card .solution-area p  { color: #94A3B8; }

/* Module / Feature cards */
[data-theme="dark"] .cl-module-card {
    background: rgba(255,255,255,0.05);
    border: 1px solid rgba(255,255,255,0.08);
    box-shadow: 0 8px 32px rgba(0,0,0,0.4);
}
[data-theme="dark"] .cl-module-card:hover {
    background: rgba(255,255,255,0.08);
    border-color: rgba(255,255,255,0.14);
    box-shadow: 0 12px 40px rgba(0,0,0,0.5);
}
[data-theme="dark"] .cl-module-card h5  { color: #fff; }
[data-theme="dark"] .cl-module-card p   { color: #94A3B8; }
[data-theme="dark"] .cl-module-card .benefit { color: #7DD3FC; }

/* Security cards — already dark, just polish */
[data-theme="dark"] .cl-security-card {
    background: rgba(255,255,255,0.05);
    border-color: rgba(255,255,255,0.10);
}
[data-theme="dark"] .cl-security-card:hover {
    background: rgba(255,255,255,0.09);
    border-color: rgba(255,255,255,0.18);
}

/* Step cards */
[data-theme="dark"] .cl-step-card {
    background: rgba(255,255,255,0.05);
    border: 1px solid rgba(255,255,255,0.08);
    box-shadow: 0 8px 32px rgba(0,0,0,0.4);
}
[data-theme="dark"] .cl-step-card:hover {
    background: rgba(255,255,255,0.08);
    border-color: rgba(255,255,255,0.14);
    box-shadow: 0 12px 40px rgba(0,0,0,0.5);
}
[data-theme="dark"] .cl-step-card h5 { color: #fff; }
[data-theme="dark"] .cl-step-card p  { color: #94A3B8; }
[data-theme="dark"] .cl-step-connector {
    background: repeating-linear-gradient(90deg, rgba(255,255,255,0.10) 0 6px, transparent 6px 12px);
}

/* Testimonials */
[data-theme="dark"] .cl-testimonial-card {
    background: rgba(255,255,255,0.05);
    border: 1px solid rgba(255,255,255,0.08);
    box-shadow: 0 8px 32px rgba(0,0,0,0.4);
}
[data-theme="dark"] .cl-testimonial-card:hover {
    background: rgba(255,255,255,0.07);
    border-color: rgba(255,255,255,0.13);
    box-shadow: 0 12px 40px rgba(0,0,0,0.5);
}
[data-theme="dark"] .cl-testimonial-card .quote-text { color: #E2E8F0; }
[data-theme="dark"] .cl-testimonial-card .author-name { color: #fff; }
[data-theme="dark"] .cl-testimonial-card .author-title { color: #94A3B8; }
[data-theme="dark"] .cl-testimonial-card .company-name { color: #7DD3FC; }

/* Pricing cards */
[data-theme="dark"] .cl-price-card {
    background: rgba(255,255,255,0.05);
    border: 1px solid rgba(255,255,255,0.08);
    box-shadow: 0 8px 32px rgba(0,0,0,0.4);
}
[data-theme="dark"] .cl-price-card:hover {
    background: rgba(255,255,255,0.07);
    box-shadow: 0 12px 40px rgba(0,0,0,0.5);
}
[data-theme="dark"] .cl-price-card.popular {
    background: rgba(14,165,233,0.07);
    border-color: var(--cl-primary);
    box-shadow: 0 0 60px rgba(14,165,233,0.15), 0 8px 32px rgba(0,0,0,0.4);
}
[data-theme="dark"] .cl-price-card.enterprise {
    background: rgba(139,92,246,0.07);
    border-color: var(--cl-accent);
}
[data-theme="dark"] .cl-price-card h4   { color: #fff; }
[data-theme="dark"] .cl-price-card .desc { color: #94A3B8; }
[data-theme="dark"] .cl-price-val        { color: #fff; }
[data-theme="dark"] .cl-price-val span   { color: #94A3B8; }
[data-theme="dark"] .cl-price-note       { color: #94A3B8; }
[data-theme="dark"] .cl-feature-list li  { color: #E2E8F0; border-bottom-color: rgba(255,255,255,0.06); }
[data-theme="dark"] .cl-feature-list .bi-x-circle-fill { color: rgba(255,255,255,0.20); }

/* Contact / Lead form */
[data-theme="dark"] .cl-lead-form {
    background: rgba(255,255,255,0.04);
    backdrop-filter: blur(20px);
    border: 1px solid rgba(255,255,255,0.08);
    box-shadow: 0 8px 32px rgba(0,0,0,0.4);
}
[data-theme="dark"] .cl-input {
    background: rgba(255,255,255,0.05);
    border-color: rgba(255,255,255,0.10);
    color: #E2E8F0;
}
[data-theme="dark"] .cl-input:focus {
    border-color: var(--cl-primary);
    background: rgba(14,165,233,0.04);
    box-shadow: 0 0 0 3px rgba(14,165,233,0.12);
}
[data-theme="dark"] .cl-input::placeholder { color: #94A3B8; }
[data-theme="dark"] label.cl-label { color: #E2E8F0; }

/* Final CTA */
[data-theme="dark"] .cl-final-cta {
    background: linear-gradient(135deg, #0369a1 0%, #065f46 100%);
}

/* Offcanvas mobile */
[data-theme="dark"] .offcanvas {
    background: #0D1226;
    color: #E2E8F0;
    border-color: rgba(255,255,255,0.08) !important;
}
[data-theme="dark"] .offcanvas a { color: #94A3B8; }
[data-theme="dark"] .offcanvas a:hover { color: var(--cl-primary); }
[data-theme="dark"] .offcanvas hr { border-color: rgba(255,255,255,0.08); }

/* Platform bar in dark */
[data-theme="dark"] #platformBar {
    background: rgba(10,15,30,0.92);
    border-bottom-color: rgba(255,255,255,0.08);
}
[data-theme="dark"] #platformBar span,
[data-theme="dark"] #platformBar a { color: #94A3B8; }

/* ================================================================
   LIGHT MODE for Clinic  (html[data-theme="light"] .clinic-body)
   Matches Alhafi HR light theme: soft blue-grey palette
   ================================================================ */
[data-theme="light"] .clinic-body {
    --cl-bg:         #EEF4FF;
    --cl-bg-card:    rgba(255,255,255,0.85);
    --cl-bg-section: #E8F0FC;
    --cl-border:     rgba(0,0,0,0.09);
    --cl-text:       #1E293B;
    --cl-text-muted: #475569;
    --cl-shadow-sm:  0 1px 3px rgba(0,0,0,.08);
    --cl-shadow-md:  0 4px 20px rgba(0,0,0,.10);
    --cl-shadow-lg:  0 12px 40px rgba(0,0,0,.12);
    background: var(--cl-bg);
    color: var(--cl-text);
}
[data-theme="light"] .cl-navbar {
    background: rgba(255,255,255,0.90);
    border-bottom-color: rgba(0,0,0,0.08);
}
[data-theme="light"] .cl-nav-link { color: #334155 !important; }
[data-theme="light"] .cl-nav-link:hover { color: var(--cl-primary) !important; background: #EFF6FF; }
[data-theme="light"] .cl-hero {
    background: linear-gradient(160deg, #EEF4FF 0%, #F0F9FF 40%, #ECFDF5 100%);
}
[data-theme="light"] .cl-section-alt  { background: var(--cl-bg-section); }
[data-theme="light"] .cl-workflow      { background: var(--cl-bg); }
[data-theme="light"] .cl-pricing       { background: var(--cl-bg-section); }
[data-theme="light"] .cl-pain-card,
[data-theme="light"] .cl-module-card,
[data-theme="light"] .cl-step-card,
[data-theme="light"] .cl-testimonial-card,
[data-theme="light"] .cl-price-card {
    background: rgba(255,255,255,0.80);
    border-color: rgba(0,0,0,0.08);
    box-shadow: 0 4px 24px rgba(0,0,0,0.07);
}
[data-theme="light"] .cl-lead-form {
    background: rgba(255,255,255,0.85);
    border-color: rgba(0,0,0,0.08);
}

/* ── Clinic Theme Toggle ─────────────────────────────────────── */
.cl-theme-btn {
    width: 36px; height: 36px;
    border-radius: 50%;
    border: 1px solid var(--cl-border);
    background: transparent;
    color: var(--cl-text-muted);
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 1rem;
    transition: 0.3s;
}
.cl-theme-btn:hover { border-color: var(--cl-primary); color: var(--cl-primary); }
[data-theme="dark"]  .cl-theme-btn .cl-icon-sun  { display: none; }
[data-theme="light"] .cl-theme-btn .cl-icon-moon { display: none; }

/* ── Clinic Language Switcher ────────────────────────────────── */
.cl-lang-btn {
    padding: 0.25rem 0.7rem;
    border-radius: 50px;
    border: 1px solid var(--cl-border);
    background: transparent;
    color: var(--cl-text-muted);
    font-family: var(--cl-font);
    font-size: 0.78rem;
    font-weight: 700;
    cursor: pointer;
    transition: 0.3s;
    letter-spacing: 0.05em;
    text-transform: uppercase;
}
.cl-lang-btn:hover { border-color: var(--cl-primary); color: var(--cl-primary); }

/* LTR overrides for Clinic in English */
html[lang="en"] .clinic-body { font-family: 'Inter', 'Cairo', sans-serif; }
html[lang="en"] .cl-hero-title { text-align: left; }

