/* =====================================================================
   Nizam Care - Premium Design System v2
   Oladoc-inspired, modern medical aesthetic
   ===================================================================== */

:root{
    /* Primary palette */
    --primary:#00b39f;
    --primary-50:#e6f8f5;
    --primary-100:#b3ebe2;
    --primary-600:#009684;
    --primary-700:#007a6c;

    /* Secondary */
    --secondary:#1a4f8a;
    --secondary-50:#e8eef7;
    --secondary-700:#123c6b;

    /* Accents */
    --accent-coral:#ff6b6b;
    --accent-gold:#ffc107;
    --accent-mint:#7ed7c1;

    /* Neutrals */
    --ink-900:#0a1929;
    --ink-700:#1a2b3c;
    --ink-500:#516170;
    --ink-300:#8a96a3;
    --ink-100:#e3eaf0;
    --ink-50:#f5f9fb;
    --bg-soft:#f7fafb;
    --bg-cream:#fefcf8;

    --border:#eaeff4;

    /* Radius */
    --r-sm:8px;
    --r-md:12px;
    --r-lg:20px;
    --r-xl:28px;
    --r-pill:999px;

    /* Shadow */
    --shadow-xs:0 1px 2px rgba(10,25,41,.04);
    --shadow-sm:0 2px 8px rgba(10,25,41,.06);
    --shadow-md:0 6px 20px rgba(10,25,41,.08);
    --shadow-lg:0 12px 40px rgba(10,25,41,.10);
    --shadow-xl:0 20px 60px rgba(10,25,41,.14);
    --shadow-primary:0 12px 32px rgba(0,179,159,.25);

    /* Typography */
    --font-display:'Plus Jakarta Sans','Inter','Segoe UI',sans-serif;
    --font-body:'Inter','Segoe UI',sans-serif;
}

*{box-sizing:border-box;}

html{scroll-behavior:smooth;}

body{
    font-family:var(--font-body);
    color:var(--ink-700);
    background:#fff;
    line-height:1.6;
    -webkit-font-smoothing:antialiased;
    text-rendering:optimizeLegibility;
}

html[lang="ur"] body, html[lang="fa"] body{
    font-family:'Noto Nastaliq Urdu','Inter',serif;
    direction:rtl;
}

h1,h2,h3,h4,h5,h6{font-family:var(--font-display);font-weight:800;letter-spacing:-.02em;color:var(--ink-900);}
h1{font-size:clamp(2rem,5vw,3.5rem);line-height:1.1;}
h2{font-size:clamp(1.6rem,3.5vw,2.4rem);line-height:1.2;}
h3{font-size:1.6rem;}
h4{font-size:1.3rem;}
.lead{font-size:1.125rem;color:var(--ink-500);line-height:1.7;}

a{color:var(--primary);text-decoration:none;transition:color .2s;}
a:hover{color:var(--primary-700);}

/* ========== Buttons ========== */
.btn{font-weight:600;border-radius:var(--r-md);padding:.65rem 1.25rem;transition:all .25s cubic-bezier(.4,0,.2,1);border:1.5px solid transparent;}
.btn-lg{padding:.85rem 1.75rem;font-size:1rem;}
.btn:active{transform:translateY(1px);}

.btn-primary{background:var(--primary);border-color:var(--primary);color:#fff;box-shadow:var(--shadow-primary);}
.btn-primary:hover,.btn-primary:focus{background:var(--primary-600);border-color:var(--primary-600);color:#fff;transform:translateY(-2px);box-shadow:0 16px 40px rgba(0,179,159,.35);}

.btn-outline-primary{color:var(--primary);border-color:var(--primary);background:transparent;}
.btn-outline-primary:hover{background:var(--primary);color:#fff;transform:translateY(-2px);}

.btn-dark{background:var(--ink-900);border-color:var(--ink-900);}
.btn-dark:hover{background:var(--ink-700);transform:translateY(-2px);}

.btn-light{background:#fff;border-color:var(--border);color:var(--ink-700);}
.btn-light:hover{background:var(--bg-soft);transform:translateY(-2px);}

.btn-ghost{background:transparent;color:var(--ink-700);}
.btn-ghost:hover{background:var(--bg-soft);}

.text-primary{color:var(--primary)!important;}
.text-secondary{color:var(--secondary)!important;}
.text-ink{color:var(--ink-900);}
.text-muted{color:var(--ink-500)!important;}
.bg-primary{background:var(--primary)!important;}
.bg-soft{background:var(--bg-soft);}

/* ========== Glass Navbar ========== */
.navbar{
    background:rgba(255,255,255,.85)!important;
    backdrop-filter:saturate(180%) blur(20px);
    -webkit-backdrop-filter:saturate(180%) blur(20px);
    border-bottom:1px solid rgba(234,239,244,.7);
    box-shadow:none;
    padding:.85rem 0;
    transition:all .3s;
}
.navbar.scrolled{box-shadow:var(--shadow-sm);padding:.6rem 0;}
.navbar-brand{font-family:var(--font-display);font-weight:800;font-size:1.4rem;color:var(--ink-900)!important;display:flex;align-items:center;gap:.5rem;}
.navbar-brand .logo{width:36px;height:36px;background:linear-gradient(135deg,var(--primary) 0%,var(--secondary) 100%);border-radius:10px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.2rem;box-shadow:var(--shadow-primary);}
.nav-link{font-size:.85rem;font-weight:600;letter-spacing:.01em;color:var(--ink-700)!important;padding:.4rem .7rem!important;border-radius:8px;transition:all .25s ease;display:inline-flex;align-items:center;gap:.25rem;}
.nav-link:hover{color:var(--primary)!important;background:rgba(0,179,159,.06);transform:translateY(-1px);}
.nav-link i{font-size:1.05rem;transition:transform .2s ease, color .2s ease;color:var(--ink-500);vertical-align:middle;}
.nav-link:hover i{transform:translateY(-1px);color:var(--primary);}


/* ========== Hero ========== */
.hero{
    position:relative;
    padding:40px 0 80px;
    overflow:hidden;
    background:
        radial-gradient(ellipse 70% 50% at 80% 30%,rgba(0,179,159,.10) 0%,transparent 60%),
        radial-gradient(ellipse 60% 50% at 10% 60%,rgba(26,79,138,.06) 0%,transparent 55%),
        linear-gradient(180deg,#fafdfd 0%,#fff 100%);
}
/* Subtle dot grid pattern */
.hero::before{
    content:'';
    position:absolute;inset:0;
    background-image:radial-gradient(circle, rgba(0,179,159,.18) 1px, transparent 1px);
    background-size:28px 28px;
    mask-image:radial-gradient(ellipse 70% 80% at 50% 50%,#000 30%,transparent 100%);
    -webkit-mask-image:radial-gradient(ellipse 70% 80% at 50% 50%,#000 30%,transparent 100%);
    opacity:.5;
    z-index:0;
}
.hero::after{
    content:'';
    position:absolute;
    top:-100px;right:-100px;
    width:450px;height:450px;
    background:conic-gradient(from 180deg at 50% 50%,rgba(0,179,159,.10),rgba(26,79,138,.08),rgba(0,179,159,.10));
    border-radius:50%;
    filter:blur(60px);
    z-index:0;
}
.hero .container{position:relative;z-index:1;}

.hero-badge{
    display:inline-flex;align-items:center;gap:.55rem;
    background:#fff;border:1px solid var(--border);
    padding:.4rem .9rem .4rem .45rem;border-radius:var(--r-pill);
    font-size:.78rem;font-weight:600;color:var(--ink-700);
    box-shadow:var(--shadow-xs);margin-bottom:1.5rem;
}
.hero-badge .avatars{display:flex;}
.hero-badge .avatars img{width:22px;height:22px;border-radius:50%;border:2px solid #fff;margin-left:-8px;}
.hero-badge .avatars img:first-child{margin-left:0;}
.hero-badge strong{color:var(--ink-900);}
.hero-badge .dot{width:7px;height:7px;border-radius:50%;background:#1d8e4f;animation:pulse 2s infinite;flex-shrink:0;}
@keyframes pulse{0%,100%{box-shadow:0 0 0 3px rgba(29,142,79,.25);}50%{box-shadow:0 0 0 7px rgba(29,142,79,0);}}

.hero h1{font-size:clamp(2rem,4.5vw,3.2rem);font-weight:800;letter-spacing:-.02em;line-height:1.1;color:var(--ink-900);}
.hero h1 .accent{
    color:var(--primary);
    position:relative;display:inline-block;
}
.hero h1 .accent::after{
    content:'';position:absolute;left:0;right:0;bottom:-2px;height:6px;
    background:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 200 8"><path d="M0 5 Q50 1 100 4 T200 4" fill="none" stroke="%2300b39f" stroke-width="2.5" stroke-linecap="round" opacity="0.5"/></svg>') center/100% 100% no-repeat;
}
.hero .lead{font-size:1.02rem;color:var(--ink-500);max-width:520px;line-height:1.65;}

/* Search card — refined, tab-like layout */
.search-card{
    background:#fff;
    border-radius:14px;
    box-shadow:0 8px 30px rgba(10,25,41,.10),0 1px 3px rgba(10,25,41,.04);
    padding:.4rem;
    margin-top:2rem;
    border:1px solid var(--border);
    transition:box-shadow .25s;
}
.search-card:focus-within{box-shadow:0 12px 40px rgba(0,179,159,.18),0 1px 3px rgba(10,25,41,.04);border-color:var(--primary-100);}
.search-card .input-wrap{
    position:relative;
}
.search-card .input-wrap > i{
    position:absolute;left:.85rem;top:50%;transform:translateY(-50%);
    color:var(--ink-300);font-size:1.05rem;pointer-events:none;
}
.search-card .form-control,.search-card .form-select{
    border:none;background:transparent;
    padding:.75rem .85rem .75rem 2.4rem;font-weight:500;font-size:.88rem;
    border-right:1px solid var(--border);border-radius:0;
    color:var(--ink-900);
}
.search-card .form-control::placeholder{color:var(--ink-300);}
.search-card .form-control:focus,.search-card .form-select:focus{box-shadow:none;background:var(--bg-soft);}
.search-card .btn-search{
    background:var(--primary);color:#fff;border:none;
    border-radius:10px;
    padding:.7rem 1.2rem;
    font-weight:600;font-size:.88rem;
    display:inline-flex;align-items:center;justify-content:center;gap:.35rem;
    transition:background .2s;
    height:100%;width:100%;
}
.search-card .btn-search:hover{background:var(--primary-600);color:#fff;}

/* Quick specialty chips below search */
.quick-chips{display:flex;flex-wrap:wrap;gap:.4rem;align-items:center;margin-top:1.25rem;}
.quick-chips small{color:var(--ink-500);font-weight:500;font-size:.78rem;margin-right:.25rem;}
.quick-chips a{
    background:#fff;border:1px solid var(--border);
    color:var(--ink-700);font-weight:500;font-size:.78rem;
    padding:.3rem .75rem;border-radius:var(--r-pill);
    text-decoration:none;transition:all .2s;
    display:inline-flex;align-items:center;gap:.25rem;
}
.quick-chips a i{color:var(--primary);}
.quick-chips a:hover{border-color:var(--primary);background:var(--primary-50);color:var(--primary-700);}

/* Hero stats mini-row */
.hero-mini-stats{display:flex;gap:2rem;margin-top:2rem;padding-top:1.5rem;border-top:1px solid var(--border);}
.hero-mini-stats .s{display:flex;align-items:center;gap:.6rem;}
.hero-mini-stats .s i{font-size:1.6rem;color:var(--primary);}
.hero-mini-stats .s strong{display:block;font-size:.95rem;color:var(--ink-900);font-weight:700;line-height:1.1;}
.hero-mini-stats .s small{color:var(--ink-500);font-size:.72rem;}

/* Right-column visual */
.hero-visual{position:relative;padding:1rem;}
.hero-visual .blob{
    position:absolute;inset:-20px;
    background:radial-gradient(ellipse at center,rgba(0,179,159,.18) 0%,transparent 65%);
    border-radius:50%;
    filter:blur(30px);
    z-index:0;
}
.hero-visual .main-img{
    position:relative;z-index:1;
    border-radius:24px;
    width:100%;max-width:480px;display:block;margin:0 auto;
    box-shadow:0 30px 60px rgba(10,25,41,.18),0 0 0 1px rgba(255,255,255,.5);
}

/* Floating cards — smaller, refined */
.float-card{
    position:absolute;background:#fff;
    border:1px solid var(--border);
    box-shadow:0 10px 30px rgba(10,25,41,.10);
    z-index:2;
}
.float-card.fc1{top:20px;left:-20px;padding:.65rem .9rem;border-radius:12px;display:flex;align-items:center;gap:.6rem;animation:float 5s ease-in-out infinite;}
.float-card.fc1 .ic{width:34px;height:34px;border-radius:50%;background:#e6f7ed;color:#1d8e4f;display:flex;align-items:center;justify-content:center;font-size:1rem;flex-shrink:0;}
.float-card.fc1 small{display:block;font-size:.65rem;color:var(--ink-500);line-height:1;}
.float-card.fc1 strong{font-size:.78rem;color:var(--ink-900);}

.float-card.fc2{bottom:60px;right:-20px;padding:.65rem .9rem;border-radius:12px;animation:float 5s ease-in-out infinite .8s;}
.float-card.fc2 .row1{display:flex;align-items:center;gap:.35rem;margin-bottom:.15rem;}
.float-card.fc2 .row1 .stars{color:var(--accent-gold);font-size:.85rem;}
.float-card.fc2 .row1 strong{font-size:.88rem;color:var(--ink-900);}
.float-card.fc2 small{font-size:.65rem;color:var(--ink-500);}

.float-card.fc3{bottom:40px;left:-30px;padding:.45rem .85rem;border-radius:var(--r-pill);display:flex;align-items:center;gap:.4rem;animation:float 5s ease-in-out infinite .4s;}
.float-card.fc3 i{color:var(--primary);font-size:1.1rem;}
.float-card.fc3 strong{font-size:.78rem;color:var(--ink-900);}

.float-card.fc4{top:100px;right:-30px;padding:.6rem .85rem;border-radius:12px;animation:float 5s ease-in-out infinite 1.2s;}
.float-card.fc4 .row1{display:flex;align-items:center;gap:.4rem;margin-bottom:.2rem;font-size:.7rem;color:var(--ink-500);}
.float-card.fc4 .row1 .live{width:6px;height:6px;border-radius:50%;background:#1d8e4f;animation:pulse 2s infinite;}
.float-card.fc4 strong{font-size:.85rem;color:var(--ink-900);display:block;}
.float-card.fc4 .num{font-size:1.1rem;font-weight:800;color:var(--primary);}


@media(max-width:991px){
    .hero{padding:60px 0 70px;}
    .float-card{display:none;}
}

/* Trust bar */
.trust-bar{padding:30px 0;border-top:1px solid var(--border);}
.trust-bar small{color:var(--ink-300);font-weight:500;letter-spacing:.1em;text-transform:uppercase;font-size:.75rem;}
.trust-bar .trust-logo{font-weight:700;font-size:1.1rem;color:var(--ink-300);transition:color .2s;}
.trust-bar .trust-logo:hover{color:var(--ink-700);}

/* Partner / Trusted-by bar (oladoc style) */
.partner-bar{
    background:#fff;
    padding:35px 0;
    border-top:1px solid var(--border);
    border-bottom:1px solid var(--border);
}
.partner-bar .label{
    text-align:center;
    color:var(--ink-500);
    font-size:.78rem;
    font-weight:600;
    letter-spacing:.15em;
    text-transform:uppercase;
    margin-bottom:24px;
}
.partner-bar .logos{
    display:flex;
    align-items:center;
    justify-content:space-around;
    flex-wrap:wrap;
    gap:30px;
}
.partner-bar .logos .pl{
    display:flex;align-items:center;gap:.5rem;
    color:#9ba9b6;
    font-weight:700;
    font-size:1.05rem;
    letter-spacing:-.01em;
    transition:color .25s;
    filter:grayscale(1);opacity:.65;
}
.partner-bar .logos .pl:hover{color:var(--ink-700);filter:grayscale(0);opacity:1;}
.partner-bar .logos .pl i{font-size:1.5rem;}

/* Stats row inside hero/intro section (clean, no dark band) */
.stat-inline-row{
    background:#fff;
    border:1px solid var(--border);
    border-radius:var(--r-lg);
    padding:1.5rem 1rem;
    box-shadow:var(--shadow-sm);
    display:flex;justify-content:space-around;flex-wrap:wrap;
    margin-top:-50px;position:relative;z-index:5;
}
.stat-inline-row .si{text-align:center;padding:.5rem 1rem;flex:1;min-width:140px;}
.stat-inline-row .si + .si{border-left:1px solid var(--border);}
.stat-inline-row .si-num{font-family:var(--font-display);font-size:1.9rem;font-weight:800;color:var(--ink-900);line-height:1;}
.stat-inline-row .si-num small{color:var(--primary);font-size:1rem;margin-left:2px;}
.stat-inline-row .si-lbl{color:var(--ink-500);font-size:.82rem;margin-top:.4rem;}
@media(max-width:768px){
    .stat-inline-row .si + .si{border-left:none;border-top:1px solid var(--border);}
    .stat-inline-row{margin-top:0;}
}

/* ========== Sections ========== */
section{padding:90px 0;}
.section-eyebrow{
    display:inline-block;
    color:var(--primary);font-weight:700;font-size:.85rem;
    letter-spacing:.12em;text-transform:uppercase;
    margin-bottom:.75rem;
}
.section-title{margin-bottom:.75rem;}
.section-sub{color:var(--ink-500);font-size:1.05rem;max-width:600px;margin-left:auto;margin-right:auto;}

/* Specialty tile - elevated */
.specialty-tile{
    background:#fff;
    border:1px solid var(--border);
    border-radius:var(--r-lg);
    padding:1.75rem 1rem;
    text-align:center;
    transition:all .3s cubic-bezier(.4,0,.2,1);
    cursor:pointer;height:100%;
    text-decoration:none;color:inherit;display:block;
    position:relative;overflow:hidden;
}
.specialty-tile::before{
    content:'';position:absolute;inset:0;
    background:linear-gradient(135deg,var(--primary-50) 0%,transparent 60%);
    opacity:0;transition:opacity .3s;
}
.specialty-tile:hover{
    transform:translateY(-6px);
    box-shadow:var(--shadow-lg);
    border-color:var(--primary-100);
    color:inherit;
}
.specialty-tile:hover::before{opacity:1;}
.specialty-tile .icon{
    width:64px;height:64px;border-radius:18px;
    background:linear-gradient(135deg,var(--primary-50) 0%,#d6f3ed 100%);
    color:var(--primary);
    display:flex;align-items:center;justify-content:center;
    font-size:1.8rem;margin:0 auto 1rem;
    position:relative;z-index:1;transition:all .3s;
}
.specialty-tile:hover .icon{transform:scale(1.1) rotate(-5deg);background:linear-gradient(135deg,var(--primary) 0%,var(--primary-600) 100%);color:#fff;}
.specialty-tile h6{font-weight:700;margin:0;position:relative;z-index:1;font-size:.95rem;}
.specialty-tile .count{display:block;color:var(--ink-300);font-size:.75rem;margin-top:.25rem;position:relative;z-index:1;}

/* Doctor card - compact & professional (oladoc-style) */
.doctor-card{
    background:#fff;
    border:1px solid var(--border);
    border-radius:var(--r-md);
    padding:1.15rem;
    transition:all .25s ease;
    height:100%;position:relative;
}
.doctor-card:hover{box-shadow:var(--shadow-md);border-color:var(--primary-100);}
.doctor-card .featured-flag{
    position:absolute;top:.75rem;right:.75rem;
    background:#fff7e6;color:#b8860b;
    font-size:.65rem;font-weight:600;
    padding:.15rem .5rem;border-radius:4px;
    letter-spacing:.03em;
    border:1px solid #f5e3b0;
}
.doctor-photo{
    width:64px;height:64px;border-radius:50%;
    background:#dde8f0 center/cover;flex-shrink:0;
    border:2px solid #fff;box-shadow:var(--shadow-xs);
    position:relative;
}
.doctor-photo::after{
    content:'';position:absolute;bottom:0;right:2px;
    width:12px;height:12px;border-radius:50%;
    background:#1d8e4f;border:2px solid #fff;
}
.doctor-card h5{margin-bottom:.1rem;font-weight:600;font-size:.98rem;color:var(--ink-900);}
.doctor-card .specialty{color:var(--primary);font-weight:500;font-size:.8rem;}
.doctor-card .meta{color:var(--ink-500);font-size:.75rem;line-height:1.4;}
.badge-soft{
    background:var(--primary-50);color:var(--primary-700);
    font-weight:500;padding:.2rem .55rem;border-radius:4px;
    font-size:.7rem;display:inline-flex;align-items:center;gap:.25rem;
}
.badge-soft.bg-green{background:#e6f7ed;color:#1d8e4f;}
.badge-soft.bg-blue{background:#e8eef7;color:var(--secondary);}
.rating-stars{color:var(--accent-gold);font-weight:600;font-size:.8rem;}
.fee-box{
    background:var(--bg-soft);border-radius:6px;
    padding:.45rem .65rem;text-align:left;font-size:.7rem;color:var(--ink-500);
    border:none;line-height:1.2;
}
.fee-box strong{display:block;color:var(--ink-900);font-size:.95rem;font-weight:700;font-family:var(--font-body);}

/* Compact book button inside doctor card */
.doctor-card .btn-book{
    background:var(--primary);color:#fff;border:none;
    padding:.45rem .9rem;font-size:.8rem;font-weight:600;
    border-radius:6px;display:inline-flex;align-items:center;gap:.25rem;
    transition:background .2s;text-decoration:none;
}
.doctor-card .btn-book:hover{background:var(--primary-600);color:#fff;}

/* Compact "View All" link in section header */
.btn-link-arrow{
    color:var(--primary);font-weight:600;font-size:.85rem;
    text-decoration:none;display:inline-flex;align-items:center;gap:.25rem;
    padding:0;background:none;border:none;
}
.btn-link-arrow:hover{color:var(--primary-700);gap:.4rem;}

/* ========== How it works ========== */
.steps-wrap{position:relative;}
.steps-wrap::before{
    content:'';position:absolute;top:35px;left:15%;right:15%;height:2px;
    background:repeating-linear-gradient(90deg,var(--primary-100) 0 8px,transparent 8px 16px);
    z-index:0;
}
@media(max-width:768px){.steps-wrap::before{display:none;}}
.step{text-align:center;padding:1rem;position:relative;z-index:1;}
.step .num{
    width:70px;height:70px;border-radius:50%;
    background:#fff;color:var(--primary);
    font-size:1.6rem;font-weight:800;font-family:var(--font-display);
    display:inline-flex;align-items:center;justify-content:center;
    margin-bottom:1.25rem;border:2px solid var(--primary-100);
    box-shadow:var(--shadow-md);transition:all .3s;
}
.step:hover .num{background:linear-gradient(135deg,var(--primary) 0%,var(--primary-600) 100%);color:#fff;transform:scale(1.05);}
.step h5{font-weight:700;margin-bottom:.5rem;}
.step p{color:var(--ink-500);font-size:.92rem;}

/* ========== Voice banner ========== */
.voice-banner{
    background:linear-gradient(135deg,#0a3961 0%,#00b39f 100%);
    color:#fff;border-radius:var(--r-xl);
    padding:3.5rem;position:relative;overflow:hidden;
    box-shadow:var(--shadow-xl);
}
.voice-banner::before{
    content:'';position:absolute;top:-100px;right:-100px;
    width:400px;height:400px;border-radius:50%;
    background:radial-gradient(circle,rgba(255,255,255,.15) 0%,transparent 70%);
}
.voice-banner h3{color:#fff;font-size:1.8rem;}
.voice-banner .lang-pill{
    display:inline-flex;align-items:center;gap:.4rem;
    background:rgba(255,255,255,.15);backdrop-filter:blur(10px);
    color:#fff;padding:.5rem 1rem;border-radius:var(--r-pill);
    font-weight:500;font-size:.9rem;border:1px solid rgba(255,255,255,.2);
}
.voice-icon-bg{
    width:140px;height:140px;border-radius:50%;
    background:rgba(255,255,255,.1);backdrop-filter:blur(20px);
    display:flex;align-items:center;justify-content:center;
    font-size:4rem;margin:0 auto;
    animation:float 6s ease-in-out infinite;
    position:relative;z-index:1;
}
@keyframes float{0%,100%{transform:translateY(0);}50%{transform:translateY(-15px);}}

/* ========== Trust cards ========== */
.trust-card{
    background:#fff;border-radius:var(--r-lg);padding:2rem 1.5rem;
    text-align:center;box-shadow:var(--shadow-sm);height:100%;
    border:1px solid var(--border);transition:all .3s;
}
.trust-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);}
.trust-card .icon{
    width:64px;height:64px;border-radius:18px;
    background:linear-gradient(135deg,var(--primary-50) 0%,#d6f3ed 100%);
    color:var(--primary);
    display:flex;align-items:center;justify-content:center;
    font-size:1.8rem;margin:0 auto 1rem;
}
.trust-card h6{font-weight:700;margin-bottom:.4rem;}
.trust-card small{color:var(--ink-500);}

/* ========== Testimonials ========== */
.testimonial{
    background:#fff;border-radius:var(--r-lg);padding:2rem;
    border:1px solid var(--border);height:100%;
    position:relative;transition:all .3s;
}
.testimonial:hover{box-shadow:var(--shadow-md);transform:translateY(-4px);}
.testimonial::before{
    content:'"';position:absolute;top:-10px;left:1.5rem;
    font-size:5rem;font-family:Georgia,serif;color:var(--primary);
    line-height:1;opacity:.2;
}
.testimonial .rating{color:var(--accent-gold);margin-bottom:.75rem;}
.testimonial p{color:var(--ink-700);font-style:italic;margin-bottom:1.25rem;line-height:1.7;}
.testimonial .author{display:flex;align-items:center;gap:.75rem;}
.testimonial .author img{width:48px;height:48px;border-radius:50%;}
.testimonial .author strong{display:block;color:var(--ink-900);}
.testimonial .author small{color:var(--ink-500);}

/* ========== App download ========== */
.app-section{
    background:linear-gradient(135deg,var(--primary-50) 0%,#fff 100%);
    border-radius:var(--r-xl);padding:60px;
    position:relative;overflow:hidden;
}
.app-store-btn{
    display:inline-flex;align-items:center;gap:.75rem;
    background:#0a1929;color:#fff;
    padding:.75rem 1.5rem;border-radius:var(--r-md);
    transition:all .3s;text-decoration:none;
}
.app-store-btn:hover{background:#000;color:#fff;transform:translateY(-2px);box-shadow:var(--shadow-lg);}
.app-store-btn i{font-size:2rem;}
.app-store-btn small{display:block;font-size:.7rem;opacity:.7;}
.app-store-btn strong{font-size:1.05rem;font-weight:700;}
.phone-mockup{
    position:relative;text-align:center;
    perspective:1000px;
}
.phone-mockup img{
    max-width:280px;border-radius:32px;
    box-shadow:var(--shadow-xl);
    transform:rotateY(-8deg) rotateX(5deg);
    transition:transform .5s;
}
.phone-mockup img:hover{transform:rotateY(0) rotateX(0);}

/* ========== CTA strip ========== */
.cta-strip{
    background:linear-gradient(135deg,var(--primary) 0%,var(--primary-600) 100%);
    color:#fff;border-radius:var(--r-xl);
    padding:60px;position:relative;overflow:hidden;text-align:center;
}
.cta-strip::before{
    content:'';position:absolute;inset:0;
    background:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="120" height="120"><circle cx="60" cy="60" r="2" fill="%23ffffff" opacity="0.15"/></svg>');
}
.cta-strip h2{color:#fff;position:relative;z-index:1;}
.cta-strip .lead{color:rgba(255,255,255,.85);position:relative;z-index:1;}

/* ========== FAQ ========== */
.faq-item{
    background:#fff;border:1px solid var(--border);
    border-radius:var(--r-md);margin-bottom:.75rem;
    padding:1.25rem 1.5rem;cursor:pointer;
    transition:all .3s;
}
.faq-item:hover{border-color:var(--primary-100);}
.faq-item summary{
    list-style:none;font-weight:600;color:var(--ink-900);
    display:flex;justify-content:space-between;align-items:center;
}
.faq-item summary::-webkit-details-marker{display:none;}
.faq-item summary::after{content:'+';font-size:1.5rem;color:var(--primary);transition:transform .3s;}
.faq-item[open] summary::after{transform:rotate(45deg);}
.faq-item p{margin-top:.75rem;color:var(--ink-500);margin-bottom:0;}

/* ========== Footer ========== */
footer{
    background:linear-gradient(180deg,#0a1929 0%,#04101c 100%);
    color:#8a96a3;padding:80px 0 25px;position:relative;
}
footer::before{
    content:'';position:absolute;top:0;left:0;right:0;height:1px;
    background:linear-gradient(90deg,transparent,var(--primary),transparent);
}
footer h6{color:#fff;font-weight:700;margin-bottom:1rem;font-family:var(--font-display);}
footer .brand-block .brand{font-size:1.4rem;color:#fff;font-weight:800;}
footer a{color:#8a96a3;text-decoration:none;display:block;padding:.35rem 0;transition:all .2s;}
footer a:hover{color:var(--primary);padding-left:.25rem;}
.newsletter{
    background:rgba(255,255,255,.05);
    border:1px solid rgba(255,255,255,.1);
    border-radius:var(--r-md);padding:.35rem;
    display:flex;gap:.5rem;
}
.newsletter input{
    background:transparent;border:none;color:#fff;
    padding:.5rem 1rem;flex:1;outline:none;
}
.newsletter input::placeholder{color:#5d6c7e;}
.socials a{
    width:40px;height:40px;border-radius:10px;
    background:rgba(255,255,255,.05);
    display:inline-flex;align-items:center;justify-content:center;
    color:#fff;padding:0;font-size:1.2rem;
}
.socials a:hover{background:var(--primary);padding-left:0;}
.footer-bottom{
    border-top:1px solid rgba(255,255,255,.06);
    padding-top:25px;margin-top:50px;
    color:#5d6c7e;font-size:.85rem;
}
.footer-bottom a{display:inline;}

/* ========== Voice prompt button ========== */
.voice-btn{
    background:var(--primary-50);border:1.5px solid var(--primary);color:var(--primary);
    border-radius:50%;width:36px;height:36px;
    display:inline-flex;align-items:center;justify-content:center;
    cursor:pointer;transition:all .2s;font-size:1rem;
}
.voice-btn:hover{background:var(--primary);color:#fff;transform:scale(1.08);}

/* ========== Animations on scroll ========== */
.reveal{opacity:0;transform:translateY(30px);transition:all .8s cubic-bezier(.4,0,.2,1);}
.reveal.visible{opacity:1;transform:translateY(0);}

/* ========== Responsive ========== */
@media(max-width:992px){
    .hero{padding:80px 0 60px;}
    section{padding:60px 0;}
    .app-section,.voice-banner,.cta-strip{padding:40px 30px;}
}
@media(max-width:768px){
    .search-card .form-control,.search-card .form-select{border-right:none;border-bottom:1px solid var(--border);}
    .search-card{padding:.25rem;}
    .stats-strip .stat-num{font-size:1.8rem;}
}

/* ========== Misc ========== */
.divider-fade{height:1px;background:linear-gradient(90deg,transparent,var(--border),transparent);margin:60px 0;}

/* =====================================================================
   ============ V3 EDITORIAL / PREMIUM SECTIONS ============
   ===================================================================== */

:root{
    --cream:#faf8f3;
    --cream-deep:#f4f0e6;
    --serif:'Fraunces','Cormorant Garamond',Georgia,serif;
}

/* Editorial typography helpers */
.eyebrow{
    display:inline-flex;align-items:center;gap:.6rem;
    color:var(--ink-500);font-weight:500;font-size:.8rem;
    letter-spacing:.18em;text-transform:uppercase;
    margin-bottom:1.25rem;
}
.eyebrow::before{content:'';width:24px;height:1px;background:var(--ink-300);}
.eyebrow.center::before{display:none;}
.h-display{font-family:var(--serif);font-weight:500;letter-spacing:-.015em;font-size:clamp(2rem,4vw,3rem);line-height:1.1;color:var(--ink-900);}
.h-display em{font-style:italic;color:var(--primary);font-weight:500;}

/* Section wrapper variants */
.sec-cream{background:var(--cream);}
.sec-tight{padding:80px 0;}

/* ========== V3 Inline stats (replaces dark navy strip) ========== */
.stats-inline{
    background:#fff;border:1px solid var(--border);
    border-radius:var(--r-xl);padding:2.5rem 1rem;
    box-shadow:var(--shadow-md);
    margin-top:-60px;position:relative;z-index:2;
}
.stats-inline .stat-row{display:flex;align-items:center;justify-content:space-around;flex-wrap:wrap;}
.stats-inline .stat-item{text-align:center;padding:.5rem 1.5rem;flex:1;min-width:160px;}
.stats-inline .stat-item + .stat-item{border-left:1px solid var(--border);}
.stats-inline .num{font-family:var(--serif);font-size:2.4rem;font-weight:500;color:var(--ink-900);line-height:1;display:block;}
.stats-inline .num small{font-family:var(--font-display);font-size:1rem;color:var(--primary);font-weight:700;vertical-align:top;margin-left:2px;}
.stats-inline .lbl{color:var(--ink-500);font-size:.85rem;margin-top:.5rem;letter-spacing:.02em;}
@media(max-width:768px){
    .stats-inline .stat-item + .stat-item{border-left:none;border-top:1px solid var(--border);}
}

/* ========== V3 Specialty section ========== */
.specialty-tile-v3{
    background:#fff;border:1px solid var(--border);border-radius:var(--r-lg);
    padding:1.5rem;text-decoration:none;color:inherit;
    display:flex;align-items:center;gap:1rem;
    transition:all .3s;height:100%;
}
.specialty-tile-v3:hover{border-color:var(--ink-900);background:var(--ink-900);color:#fff;transform:translateY(-2px);}
.specialty-tile-v3:hover .ic{background:#fff;color:var(--ink-900);}
.specialty-tile-v3:hover .arrow{opacity:1;transform:translateX(0);}
.specialty-tile-v3 .ic{
    width:48px;height:48px;border-radius:12px;
    background:var(--cream-deep);color:var(--ink-900);
    display:flex;align-items:center;justify-content:center;font-size:1.4rem;flex-shrink:0;
    transition:all .3s;
}
.specialty-tile-v3 h6{margin:0;font-weight:600;font-size:1rem;}
.specialty-tile-v3 small{display:block;opacity:.6;font-size:.78rem;margin-top:.2rem;}
.specialty-tile-v3 .arrow{margin-left:auto;font-size:1.5rem;opacity:0;transform:translateX(-8px);transition:all .3s;}

/* ========== V3 Doctor horizontal card ========== */
.doc-row{
    background:#fff;border:1px solid var(--border);border-radius:var(--r-lg);
    padding:1.5rem;transition:all .3s;display:flex;gap:1.5rem;align-items:center;
    height:100%;
}
.doc-row:hover{border-color:var(--ink-300);box-shadow:var(--shadow-md);}
.doc-row .ph{
    width:96px;height:96px;border-radius:50%;
    background:#dde8f0 center/cover;flex-shrink:0;
    border:1px solid var(--border);
}
.doc-row .body{flex:1;min-width:0;}
.doc-row h5{font-weight:700;font-size:1.05rem;margin-bottom:.15rem;font-family:var(--font-display);}
.doc-row .spec{color:var(--primary);font-weight:600;font-size:.85rem;margin-bottom:.35rem;}
.doc-row .qual{color:var(--ink-500);font-size:.82rem;margin-bottom:.5rem;}
.doc-row .stars{color:var(--accent-gold);font-weight:600;font-size:.85rem;}
.doc-row .stars span{color:var(--ink-500);font-weight:400;margin-left:.25rem;}
.doc-row .right{text-align:right;flex-shrink:0;min-width:120px;}
.doc-row .fee{font-family:var(--serif);font-size:1.5rem;color:var(--ink-900);line-height:1;margin-bottom:.5rem;}
.doc-row .fee small{font-family:var(--font-body);font-size:.7rem;color:var(--ink-500);display:block;text-transform:uppercase;letter-spacing:.05em;margin-top:.2rem;}
@media(max-width:576px){
    .doc-row{flex-direction:column;text-align:center;}
    .doc-row .right{text-align:center;width:100%;}
}

/* Specialty tab pills */
.spec-tabs{display:flex;gap:.5rem;flex-wrap:wrap;margin-bottom:2rem;}
.spec-tabs a{
    padding:.55rem 1.1rem;border:1px solid var(--border);
    border-radius:var(--r-pill);font-weight:500;font-size:.9rem;
    color:var(--ink-700);background:#fff;text-decoration:none;
    transition:all .2s;
}
.spec-tabs a.active,.spec-tabs a:hover{background:var(--ink-900);color:#fff;border-color:var(--ink-900);}

/* ========== V3 How it works editorial split ========== */
.how-list{position:relative;padding-left:2rem;}
.how-list::before{
    content:'';position:absolute;left:.5rem;top:.5rem;bottom:.5rem;
    width:2px;background:linear-gradient(180deg,var(--primary) 0%,transparent 100%);
}
.how-item{margin-bottom:2.5rem;position:relative;padding-left:2.5rem;}
.how-item::before{
    content:counter(step,decimal-leading-zero);counter-increment:step;
    position:absolute;left:-1.5rem;top:-2px;
    font-family:var(--serif);font-size:1.5rem;color:var(--primary);font-weight:500;
    background:#fff;padding:0 .5rem;
}
.how-list{counter-reset:step;}
.how-item h5{font-weight:700;font-size:1.15rem;margin-bottom:.5rem;font-family:var(--font-display);}
.how-item p{color:var(--ink-500);margin:0;font-size:.95rem;line-height:1.7;}
.how-mockup{
    background:linear-gradient(135deg,var(--cream) 0%,var(--cream-deep) 100%);
    border-radius:var(--r-xl);padding:2.5rem;
    position:relative;overflow:hidden;
    box-shadow:var(--shadow-md);
}
.how-mockup .ui-card{
    background:#fff;border-radius:var(--r-md);padding:1rem 1.25rem;
    box-shadow:var(--shadow-sm);margin-bottom:.75rem;
    display:flex;align-items:center;gap:.75rem;
    transition:all .4s;
}
.how-mockup .ui-card .dot{width:36px;height:36px;border-radius:50%;background:var(--primary-50);color:var(--primary);display:flex;align-items:center;justify-content:center;font-size:1.1rem;flex-shrink:0;}
.how-mockup .ui-card.success .dot{background:#e6f7ed;color:#1d8e4f;}
.how-mockup .ui-card .meta{flex:1;}
.how-mockup .ui-card .meta strong{display:block;color:var(--ink-900);font-size:.9rem;}
.how-mockup .ui-card .meta small{color:var(--ink-500);font-size:.78rem;}
.how-mockup .ui-time{font-size:.75rem;color:var(--ink-500);}

/* ========== V3 Voice section (clean cream split) ========== */
.voice-v3{
    background:var(--cream);border-radius:var(--r-xl);
    padding:4rem;position:relative;overflow:hidden;
}
.voice-v3 .lang-list{display:flex;gap:.75rem;flex-wrap:wrap;margin-top:1.5rem;}
.voice-v3 .lang-list span{
    background:#fff;color:var(--ink-900);padding:.5rem 1rem;
    border-radius:var(--r-pill);font-weight:500;font-size:.85rem;
    border:1px solid var(--border);
}
.voice-visual{
    width:200px;height:200px;border-radius:50%;
    background:#fff;display:flex;align-items:center;justify-content:center;
    font-size:5rem;color:var(--primary);margin:0 auto;
    box-shadow:var(--shadow-lg);position:relative;
}
.voice-visual::before,.voice-visual::after{
    content:'';position:absolute;inset:-20px;border-radius:50%;
    border:1.5px solid var(--primary);opacity:.3;
    animation:ripple 3s ease-out infinite;
}
.voice-visual::after{animation-delay:1.5s;}
@keyframes ripple{0%{transform:scale(.8);opacity:.4;}100%{transform:scale(1.5);opacity:0;}}

/* ========== V3 Promise / Trust ========== */
.promise-block{
    padding:2.5rem 0;
    border-bottom:1px solid var(--border);
    display:flex;gap:2rem;align-items:flex-start;
}
.promise-block:last-child{border-bottom:none;}
.promise-block .pnum{
    font-family:var(--serif);font-size:2rem;color:var(--ink-300);
    font-weight:500;width:60px;flex-shrink:0;line-height:1;
}
.promise-block .pbody{flex:1;}
.promise-block h4{font-weight:700;font-size:1.3rem;margin-bottom:.5rem;font-family:var(--font-display);}
.promise-block p{color:var(--ink-500);max-width:540px;margin:0;}
.promise-block .picon{font-size:2rem;color:var(--primary);width:60px;flex-shrink:0;}

/* ========== V3 Testimonials — featured layout ========== */
.testi-featured{
    background:#fff;border:1px solid var(--border);border-radius:var(--r-xl);
    padding:3rem;position:relative;overflow:hidden;
}
.testi-featured .quote-mark{
    font-family:var(--serif);font-size:8rem;color:var(--primary);
    line-height:.8;opacity:.15;position:absolute;top:1rem;left:2rem;
}
.testi-featured .quote{
    font-family:var(--serif);font-size:1.6rem;line-height:1.5;
    color:var(--ink-900);font-weight:500;font-style:italic;
    position:relative;z-index:1;margin-bottom:2rem;
    max-width:760px;
}
.testi-featured .who{display:flex;align-items:center;gap:1rem;position:relative;z-index:1;}
.testi-featured .who img{width:56px;height:56px;border-radius:50%;}
.testi-featured .who strong{font-family:var(--font-display);font-size:1rem;display:block;}
.testi-featured .who small{color:var(--ink-500);}

.testi-mini{
    background:transparent;padding:1.75rem 0;border-top:1px solid var(--border);
}
.testi-mini .stars{color:var(--accent-gold);font-size:.85rem;margin-bottom:.5rem;}
.testi-mini p{color:var(--ink-700);font-size:.95rem;line-height:1.6;margin-bottom:.75rem;}
.testi-mini .who{display:flex;align-items:center;gap:.6rem;}
.testi-mini .who img{width:32px;height:32px;border-radius:50%;}
.testi-mini .who strong{font-weight:600;font-size:.85rem;}

/* ========== V3 App section ========== */
.app-v3{
    padding:5rem 0;background:var(--cream);
    border-radius:var(--r-xl);overflow:hidden;
}
.app-v3 .qrbox{
    background:#fff;border-radius:var(--r-md);padding:1rem;
    width:140px;display:inline-block;text-align:center;
    box-shadow:var(--shadow-sm);
}
.app-v3 .qrbox img{width:100%;display:block;}
.app-v3 .qrbox small{display:block;margin-top:.5rem;font-size:.7rem;color:var(--ink-500);text-transform:uppercase;letter-spacing:.05em;}

.phone-frame{
    width:280px;height:560px;background:var(--ink-900);
    border-radius:42px;padding:12px;margin:0 auto;
    box-shadow:var(--shadow-xl);position:relative;
    transform:rotate(-4deg);transition:transform .5s;
}
.phone-frame:hover{transform:rotate(0deg);}
.phone-frame::before{
    content:'';position:absolute;top:18px;left:50%;transform:translateX(-50%);
    width:80px;height:6px;background:#333;border-radius:3px;
}
.phone-screen{
    background:linear-gradient(135deg,#f5f9fb 0%,#e9f7f5 100%);
    width:100%;height:100%;border-radius:32px;
    padding:50px 18px 18px;overflow:hidden;
    display:flex;flex-direction:column;gap:.5rem;
}
.phone-screen .ph-card{background:#fff;border-radius:14px;padding:.8rem;box-shadow:var(--shadow-xs);}
.phone-screen .ph-card.dark{background:var(--ink-900);color:#fff;}
.phone-screen .ph-card.dark small{color:rgba(255,255,255,.7);}
.phone-screen .ph-row{display:flex;align-items:center;gap:.6rem;}
.phone-screen .ph-row .dot{width:32px;height:32px;border-radius:50%;background:var(--primary-50);color:var(--primary);display:flex;align-items:center;justify-content:center;font-size:.9rem;}
.phone-screen strong{font-size:.78rem;display:block;color:var(--ink-900);}
.phone-screen .ph-card.dark strong{color:#fff;}
.phone-screen small{font-size:.68rem;color:var(--ink-500);}

/* ========== V3 FAQ split ========== */
.faq-v3-item{
    padding:1.5rem 0;border-bottom:1px solid var(--border);cursor:pointer;
}
.faq-v3-item summary{
    list-style:none;font-family:var(--font-display);font-weight:700;
    color:var(--ink-900);font-size:1.05rem;
    display:flex;justify-content:space-between;align-items:center;gap:1rem;
}
.faq-v3-item summary::-webkit-details-marker{display:none;}
.faq-v3-item summary::after{
    content:'→';font-size:1.3rem;color:var(--primary);
    transition:transform .3s;flex-shrink:0;
}
.faq-v3-item[open] summary::after{transform:rotate(90deg);}
.faq-v3-item p{margin:1rem 0 0;color:var(--ink-500);line-height:1.7;font-size:.95rem;}

.faq-aside{
    background:var(--ink-900);color:#fff;border-radius:var(--r-xl);
    padding:2.5rem;position:sticky;top:100px;
}
.faq-aside h4{color:#fff;font-family:var(--font-display);font-weight:700;margin-bottom:1rem;}
.faq-aside p{color:rgba(255,255,255,.7);margin-bottom:2rem;line-height:1.7;}
.faq-aside .contact-row{display:flex;align-items:center;gap:.75rem;padding:.85rem 0;border-top:1px solid rgba(255,255,255,.1);}
.faq-aside .contact-row i{font-size:1.4rem;color:var(--primary);}
.faq-aside .contact-row strong{color:#fff;display:block;font-size:.9rem;font-weight:600;}
.faq-aside .contact-row small{color:rgba(255,255,255,.6);font-size:.78rem;}

/* ========== V3 CTA - bordered editorial ========== */
.cta-v3{
    background:var(--cream);border:1px solid var(--cream-deep);
    border-radius:var(--r-xl);padding:4rem 2rem;text-align:center;position:relative;
}
.cta-v3 .h-display{margin-bottom:1rem;}
.cta-v3 p.lead{max-width:580px;margin:0 auto 2rem;color:var(--ink-500);}

/* Section spacing utilities */
.sec-pad{padding:100px 0;}
@media(max-width:768px){.sec-pad{padding:60px 0;}}

/* =====================================================================
   ============ DASHBOARD / INTERNAL PAGES — compact pro ============
   ===================================================================== */

/* Layout */
.app-shell{display:flex;min-height:100vh;background:var(--bg-soft);}
.app-sidebar{
    width:240px;flex-shrink:0;background:#fff;
    border-right:1px solid var(--border);
    padding:1.25rem 0;
    display:flex;flex-direction:column;
}
.app-sidebar .brand{
    padding:0 1.25rem 1.25rem;
    border-bottom:1px solid var(--border);
    margin-bottom:1rem;
}
.app-sidebar .brand a{
    display:flex;align-items:center;gap:.55rem;
    color:var(--ink-900);font-weight:800;font-size:1.05rem;
    font-family:var(--font-display);text-decoration:none;
}
.app-sidebar .brand .logo{
    width:30px;height:30px;
    background:linear-gradient(135deg,var(--primary) 0%,var(--secondary) 100%);
    border-radius:8px;color:#fff;
    display:flex;align-items:center;justify-content:center;font-size:1rem;
}

.app-sidebar nav{padding:0 .65rem;flex:1;}
.app-sidebar .side-section{
    color:var(--ink-300);font-size:.68rem;font-weight:600;
    letter-spacing:.12em;text-transform:uppercase;
    padding:.85rem 0.6rem .35rem;
}
.app-sidebar .side-link{
    display:flex;align-items:center;gap:.7rem;
    padding:.55rem .75rem;
    color:var(--ink-500);font-weight:500;font-size:.85rem;
    border-radius:6px;text-decoration:none;
    transition:all .15s;
    margin-bottom:.1rem;
}
.app-sidebar .side-link i{font-size:1.1rem;color:var(--ink-300);transition:color .15s;}
.app-sidebar .side-link:hover{background:var(--bg-soft);color:var(--ink-900);}
.app-sidebar .side-link:hover i{color:var(--primary);}
.app-sidebar .side-link.active{background:var(--primary-50);color:var(--primary-700);font-weight:600;}
.app-sidebar .side-link.active i{color:var(--primary);}

.app-sidebar .side-foot{padding:1rem;border-top:1px solid var(--border);}
.app-sidebar .side-foot .me{display:flex;align-items:center;gap:.55rem;margin-bottom:.75rem;}
.app-sidebar .side-foot .me .av{width:34px;height:34px;border-radius:50%;background:var(--primary) center/cover;color:#fff;display:flex;align-items:center;justify-content:center;font-size:.78rem;font-weight:700;}
.app-sidebar .side-foot .me strong{font-size:.82rem;color:var(--ink-900);display:block;line-height:1.1;}
.app-sidebar .side-foot .me small{color:var(--ink-500);font-size:.68rem;}
.app-sidebar .side-foot .btn-logout{
    width:100%;background:transparent;border:1px solid var(--border);
    padding:.45rem;border-radius:6px;
    color:var(--ink-500);font-size:.78rem;font-weight:500;
    display:flex;align-items:center;justify-content:center;gap:.3rem;
    transition:all .2s;
}
.app-sidebar .side-foot .btn-logout:hover{border-color:#e63946;color:#e63946;background:#fff;}

/* Main area */
.app-main{flex:1;min-width:0;display:flex;flex-direction:column;}
.app-topbar{
    background:#fff;border-bottom:1px solid var(--border);
    padding:.85rem 1.5rem;
    display:flex;justify-content:space-between;align-items:center;
    position:sticky;top:0;z-index:10;
}
.app-topbar .page-h{font-family:var(--font-display);font-weight:700;font-size:1.1rem;color:var(--ink-900);margin:0;}
.app-topbar .page-h small{color:var(--ink-500);font-size:.75rem;font-weight:400;display:block;margin-top:.1rem;}
.app-topbar .tb-actions{display:flex;align-items:center;gap:.85rem;}
.app-topbar .icon-btn{
    width:36px;height:36px;border-radius:8px;
    background:var(--bg-soft);color:var(--ink-700);
    display:inline-flex;align-items:center;justify-content:center;font-size:1.15rem;
    border:none;position:relative;cursor:pointer;
}
.app-topbar .icon-btn:hover{background:var(--primary-50);color:var(--primary);}
.app-topbar .icon-btn .dot{position:absolute;top:8px;right:8px;width:7px;height:7px;border-radius:50%;background:#e63946;border:2px solid #fff;}

.app-content{padding:1.5rem;flex:1;}

/* Stat tiles — compact */
.stat-tile{
    background:#fff;border:1px solid var(--border);
    border-radius:10px;padding:1rem 1.1rem;
    display:flex;align-items:center;gap:.85rem;
    transition:border-color .2s;
}
.stat-tile:hover{border-color:var(--primary-100);}
.stat-tile .ic{
    width:40px;height:40px;border-radius:10px;
    background:var(--primary-50);color:var(--primary);
    display:flex;align-items:center;justify-content:center;font-size:1.2rem;flex-shrink:0;
}
.stat-tile .ic.amber{background:#fff7e6;color:#b8860b;}
.stat-tile .ic.green{background:#e6f7ed;color:#1d8e4f;}
.stat-tile .ic.blue{background:#e8eef7;color:var(--secondary);}
.stat-tile .ic.rose{background:#fce4e8;color:#e63946;}
.stat-tile .lbl{color:var(--ink-500);font-size:.72rem;text-transform:uppercase;letter-spacing:.05em;font-weight:600;line-height:1;}
.stat-tile .val{font-family:var(--font-display);font-size:1.45rem;font-weight:800;color:var(--ink-900);line-height:1.1;margin-top:.2rem;}

/* Panel card */
.panel{
    background:#fff;border:1px solid var(--border);
    border-radius:10px;overflow:hidden;
}
.panel-head{
    padding:.85rem 1.1rem;border-bottom:1px solid var(--border);
    display:flex;justify-content:space-between;align-items:center;gap:.5rem;
}
.panel-head h6{margin:0;font-family:var(--font-display);font-weight:700;font-size:.92rem;color:var(--ink-900);}
.panel-head small{color:var(--ink-500);font-size:.75rem;}
.panel-body{padding:1.1rem;}
.panel-body.tight{padding:0;}

/* List item rows */
.row-item{
    display:flex;align-items:center;gap:.85rem;
    padding:.85rem 1.1rem;border-bottom:1px solid var(--border);
    transition:background .15s;
}
.row-item:last-child{border-bottom:none;}
.row-item:hover{background:var(--bg-soft);}
.row-item .av{width:36px;height:36px;border-radius:50%;background:var(--primary) center/cover;color:#fff;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700;flex-shrink:0;}
.row-item .meta{flex:1;min-width:0;}
.row-item .meta strong{display:block;font-size:.85rem;color:var(--ink-900);font-weight:600;}
.row-item .meta small{color:var(--ink-500);font-size:.72rem;}

/* Compact buttons */
.btn-sm-pri{
    background:var(--primary);color:#fff;border:none;
    padding:.4rem .8rem;font-size:.75rem;font-weight:600;
    border-radius:6px;display:inline-flex;align-items:center;gap:.25rem;
    text-decoration:none;transition:background .15s;
}
.btn-sm-pri:hover{background:var(--primary-600);color:#fff;}
.btn-sm-out{
    background:#fff;color:var(--ink-700);border:1px solid var(--border);
    padding:.4rem .8rem;font-size:.75rem;font-weight:600;
    border-radius:6px;display:inline-flex;align-items:center;gap:.25rem;
    text-decoration:none;transition:all .15s;cursor:pointer;
}
.btn-sm-out:hover{border-color:var(--primary);color:var(--primary);}
.btn-sm-danger{
    background:#fff;color:#e63946;border:1px solid #fce4e8;
    padding:.4rem .8rem;font-size:.75rem;font-weight:600;
    border-radius:6px;display:inline-flex;align-items:center;gap:.25rem;
    text-decoration:none;transition:all .15s;
}
.btn-sm-danger:hover{background:#e63946;color:#fff;}

/* Status chips */
.chip{
    display:inline-flex;align-items:center;gap:.25rem;
    padding:.18rem .55rem;border-radius:5px;
    font-size:.7rem;font-weight:600;letter-spacing:.01em;
}
.chip.green{background:#e6f7ed;color:#1d8e4f;}
.chip.amber{background:#fff7e6;color:#b8860b;}
.chip.blue{background:#e8eef7;color:var(--secondary);}
.chip.rose{background:#fce4e8;color:#e63946;}
.chip.grey{background:var(--bg-soft);color:var(--ink-500);}
.chip.teal{background:var(--primary-50);color:var(--primary-700);}

/* Tables */
.table-clean{width:100%;border-collapse:collapse;}
.table-clean th{
    text-align:left;padding:.75rem 1.1rem;
    font-size:.7rem;color:var(--ink-500);font-weight:600;
    text-transform:uppercase;letter-spacing:.06em;
    background:var(--bg-soft);border-bottom:1px solid var(--border);
}
.table-clean td{
    padding:.85rem 1.1rem;border-bottom:1px solid var(--border);
    font-size:.85rem;color:var(--ink-700);
    vertical-align:middle;
}
.table-clean tr:last-child td{border-bottom:none;}
.table-clean tr:hover td{background:var(--bg-soft);}

/* Forms */
.field{margin-bottom:1rem;}
.field label{
    display:block;font-size:.78rem;color:var(--ink-700);
    font-weight:600;margin-bottom:.35rem;
}
.field .ctrl{
    width:100%;padding:.6rem .85rem;
    border:1px solid var(--border);border-radius:8px;
    background:#fff;font-size:.88rem;color:var(--ink-900);
    transition:all .2s;
}
.field .ctrl:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-50);}
.field .ctrl.error{border-color:#e63946;}
.field .hint{font-size:.7rem;color:var(--ink-500);margin-top:.3rem;}
.field .err{font-size:.72rem;color:#e63946;margin-top:.3rem;}

/* Auth screen */
.auth-wrap{
    min-height:calc(100vh - 70px);
    display:flex;align-items:center;justify-content:center;
    background:linear-gradient(180deg,#fafdfd 0%,var(--bg-soft) 100%);
    padding:40px 20px;
}
.auth-card{
    background:#fff;border:1px solid var(--border);
    border-radius:14px;padding:2rem;
    box-shadow:0 4px 20px rgba(10,25,41,.04);
    width:100%;max-width:420px;
}
.auth-card .ttl{font-family:var(--font-display);font-weight:800;font-size:1.4rem;color:var(--ink-900);margin-bottom:.25rem;}
.auth-card .sub{color:var(--ink-500);font-size:.85rem;margin-bottom:1.5rem;}
.auth-card.wide{max-width:560px;}
.auth-bottom{text-align:center;margin-top:1.25rem;font-size:.82rem;color:var(--ink-500);}
.auth-bottom a{color:var(--primary);font-weight:600;}

/* Empty state */
.empty{
    text-align:center;padding:2.5rem 1rem;
    color:var(--ink-500);font-size:.85rem;
}
.empty i{font-size:2.2rem;color:var(--ink-300);display:block;margin-bottom:.5rem;}

/* Mobile sidebar */
@media(max-width:991px){
    .app-sidebar{position:fixed;left:-260px;top:0;bottom:0;z-index:100;transition:left .2s;box-shadow:0 0 20px rgba(0,0,0,.1);}
    .app-sidebar.open{left:0;}
    .app-topbar .menu-toggle{display:inline-flex;}
}
.app-topbar .menu-toggle{display:none;}
