@import url('https://fonts.googleapis.com/css2?family=Sora:wght@300;400;500;600;700;800&family=Playfair+Display:ital,wght@0,500;0,600;0,700;0,900;1,500;1,700&family=JetBrains+Mono:wght@400;500;600;700&display=swap');
:root{
  --navy:#021B41;--royal:#0549A3;--blue:#0E6FD8;--blue-mid:#3B8FEA;--blue-light:#EBF4FF;
  --teal:#0BA897;--teal-dk:#097D6F;--teal-lt:#E6FAF8;
  --gold:#F59E0B;--gold-lt:#FFFBEB;--red:#E53E3E;--red-lt:#FFF5F5;
  --green:#10B981;--green-lt:#ECFDF5;
  --ink:#050F1E;--text:#1A2B4A;--body:#2D4168;--muted:#5A7194;--subtle:#8FA3BE;
  --border:#D6E3F2;--border-lite:#EAF2FC;--bg:#F5F9FF;--cream:#EFF5FC;
  --g-hero:linear-gradient(145deg,#021B41 0%,#0549A3 50%,#0BA897 100%);
  --g-primary:linear-gradient(135deg,#0549A3,#0E6FD8);
  --g-teal:linear-gradient(135deg,#0BA897,#097D6F);
  --g-dark:linear-gradient(160deg,#021B41 0%,#0549A3 100%);
  --g-card:linear-gradient(135deg,rgba(14,111,216,.05),rgba(11,168,151,.03));
  --s-xs:0 1px 4px rgba(2,27,65,.07);--s-sm:0 4px 16px rgba(2,27,65,.09);
  --s-md:0 8px 32px rgba(2,27,65,.12);--s-lg:0 20px 60px rgba(2,27,65,.15);
  --s-xl:0 40px 100px rgba(2,27,65,.18);
  --s-blue:0 8px 32px rgba(5,73,163,.32);--s-teal:0 8px 28px rgba(11,168,151,.28);
  --r-sm:8px;--r-md:14px;--r-lg:20px;--r-xl:28px;--r-pill:999px;
  --f-display:'Playfair Display',Georgia,serif;--f-body:'Sora',system-ui,sans-serif;--f-mono:'JetBrains Mono','Courier New',monospace;
  --ease:cubic-bezier(.16,1,.3,1);
}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--f-body);background:var(--bg);color:var(--body);overflow-x:hidden;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
img{max-width:100%;height:auto;display:block}
input,select,textarea,button{font-family:var(--f-body)}
::-webkit-scrollbar{width:5px}::-webkit-scrollbar-track{background:var(--border-lite)}::-webkit-scrollbar-thumb{background:var(--blue-mid);border-radius:4px}
::selection{background:rgba(14,111,216,.15)}

/* NAV */
.dn-nav{position:fixed;top:0;left:0;right:0;z-index:1000;height:68px;display:flex;align-items:center;justify-content:space-between;padding:0 5%;background:rgba(255,255,255,.96);backdrop-filter:blur(24px);border-bottom:1px solid var(--border);transition:box-shadow .3s}
.dn-nav.scrolled{box-shadow:0 4px 32px rgba(2,27,65,.10)}
.nav-logo{display:flex;align-items:center;gap:10px}
.nav-logo-img{height:34px;width:34px}
.nav-wordmark{font-family:var(--f-display);font-size:22px;font-weight:700;color:var(--navy);letter-spacing:-.3px;line-height:1}
.nav-wordmark .nx{color:var(--blue)}
.nav-tagline{font-size:9px;color:var(--muted);letter-spacing:1.8px;text-transform:uppercase;font-weight:500}
.nav-links{display:flex;gap:2px;list-style:none}
.nav-links a{font-size:13px;font-weight:500;color:var(--body);padding:7px 14px;border-radius:var(--r-pill);transition:all .2s}
.nav-links a:hover,.nav-links a.active{color:var(--blue);background:var(--blue-light)}
.nav-right{display:flex;align-items:center;gap:10px}
.n-outline{font-size:13px;font-weight:600;color:var(--blue);padding:8px 18px;border-radius:var(--r-pill);border:1.5px solid var(--blue);background:transparent;cursor:pointer;font-family:var(--f-body);transition:all .2s;display:inline-block}
.n-outline:hover{background:var(--blue-light)}
.n-fill{font-size:13px;font-weight:700;color:#fff;padding:9px 22px;border-radius:var(--r-pill);border:none;background:var(--g-primary);cursor:pointer;box-shadow:var(--s-blue);transition:all .3s var(--ease);font-family:var(--f-body);display:inline-block}
.n-fill:hover{transform:translateY(-2px);box-shadow:0 12px 36px rgba(5,73,163,.40)}
.hamburger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:8px}
.hamburger span{width:22px;height:2px;background:var(--navy);border-radius:2px;display:block;transition:all .3s}
.mobile-nav{display:none;position:fixed;top:68px;left:0;right:0;z-index:999;background:#fff;padding:16px 5% 24px;box-shadow:var(--s-lg);border-bottom:1px solid var(--border)}
.mobile-nav.open{display:block;animation:slideDown .25s var(--ease)}
.mobile-nav a{display:block;padding:13px 0;font-size:15px;font-weight:500;color:var(--body);border-bottom:1px solid var(--border-lite)}
.mobile-nav a:last-child{border:none}
.mobile-nav a:hover{color:var(--blue)}

/* PAGE HERO */
.page-hero{background:var(--g-hero);padding:120px 5% 80px;position:relative;overflow:hidden}
.ph-mesh{position:absolute;inset:0;background:radial-gradient(ellipse 80% 60% at 80% 50%,rgba(11,168,151,.16) 0%,transparent 65%),radial-gradient(ellipse 50% 70% at 15% 85%,rgba(34,211,238,.10) 0%,transparent 60%);pointer-events:none}
.ph-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px);background-size:44px 44px;pointer-events:none}
.ph-inner{position:relative;z-index:2}
.ph-eyebrow{display:inline-flex;align-items:center;gap:8px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.18);padding:6px 16px;border-radius:var(--r-pill);font-size:10px;font-weight:700;color:rgba(255,255,255,.78);letter-spacing:2.5px;text-transform:uppercase;margin-bottom:22px}
.ph-title{font-family:var(--f-display);font-size:clamp(40px,5.5vw,72px);font-weight:700;color:#fff;line-height:1.06;letter-spacing:-.5px;margin-bottom:18px}
.ph-title em{font-style:italic;background:linear-gradient(135deg,#FCD34D,#F59E0B);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.ph-sub{font-size:17px;color:rgba(255,255,255,.52);line-height:1.82;max-width:560px;font-weight:300}

/* SECTIONS */
section{padding:96px 5%}
.eyebrow{display:inline-flex;align-items:center;gap:10px;font-size:10px;font-weight:700;letter-spacing:3px;text-transform:uppercase;color:var(--blue);margin-bottom:14px}
.eyebrow::before{content:'';width:28px;height:2px;background:linear-gradient(90deg,var(--blue),var(--teal));border-radius:2px;flex-shrink:0}
.section-title{font-family:var(--f-display);font-size:clamp(30px,4vw,54px);font-weight:700;color:var(--ink);line-height:1.08;letter-spacing:-.3px;margin-bottom:14px}
.section-title em{font-style:italic;color:var(--blue)}
.section-body{font-size:16px;color:var(--body);line-height:1.88;max-width:560px;font-weight:300}

/* BUTTONS */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-family:var(--f-body);font-weight:700;cursor:pointer;border:none;transition:all .3s var(--ease);letter-spacing:.15px;text-decoration:none}
.btn-primary{background:var(--g-primary);color:#fff;padding:13px 28px;border-radius:var(--r-pill);font-size:14px;box-shadow:var(--s-blue)}
.btn-primary:hover{transform:translateY(-3px);box-shadow:0 16px 48px rgba(5,73,163,.42)}
.btn-teal{background:var(--g-teal);color:#fff;padding:13px 28px;border-radius:var(--r-pill);font-size:14px;box-shadow:var(--s-teal)}
.btn-teal:hover{transform:translateY(-3px)}
.btn-outline{background:transparent;color:var(--blue);padding:12px 26px;border-radius:var(--r-pill);font-size:14px;border:1.5px solid var(--blue);font-weight:600}
.btn-outline:hover{background:var(--blue-light)}
.btn-ghost{background:rgba(255,255,255,.10);color:#fff;padding:12px 24px;border-radius:var(--r-pill);font-size:14px;border:1px solid rgba(255,255,255,.20);font-weight:600}
.btn-ghost:hover{background:rgba(255,255,255,.18)}
.btn-white{background:#fff;color:var(--blue);padding:13px 28px;border-radius:var(--r-pill);font-size:14px;box-shadow:0 4px 20px rgba(0,0,0,.12);font-weight:700}
.btn-white:hover{transform:translateY(-3px)}
.btn-sm{font-size:12px;padding:8px 18px}
.btn-lg{font-size:16px;padding:16px 36px}

/* CARDS */
.card{background:#fff;border-radius:var(--r-lg);padding:28px;border:1px solid var(--border);transition:all .35s var(--ease)}
.card:hover{transform:translateY(-5px);box-shadow:var(--s-md);border-color:rgba(14,111,216,.18)}

/* STAT CARD */
.stat-card{background:#fff;border-radius:var(--r-lg);padding:22px;border:1px solid var(--border);display:flex;align-items:center;gap:16px;transition:all .3s var(--ease)}
.stat-card:hover{box-shadow:var(--s-sm);transform:translateY(-3px)}
.stat-icon{width:52px;height:52px;border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;font-size:22px;flex-shrink:0}
.si-blue{background:var(--blue-light)}.si-teal{background:var(--teal-lt)}.si-green{background:var(--green-lt)}.si-gold{background:var(--gold-lt)}.si-red{background:var(--red-lt)}
.stat-val{font-family:var(--f-display);font-size:30px;font-weight:700;color:var(--ink);line-height:1}
.stat-label{font-size:12px;color:var(--muted);margin-top:4px;font-weight:500}

/* DOCTOR CARD */
.doc-card{background:#fff;border-radius:var(--r-xl);overflow:hidden;border:1px solid var(--border);transition:all .4s var(--ease)}
.doc-card:hover{transform:translateY(-10px);box-shadow:var(--s-xl);border-color:rgba(14,111,216,.22)}
.dc-head{background:var(--g-dark);padding:26px;text-align:center;position:relative;overflow:hidden}
.dc-head::after{content:'';position:absolute;width:200px;height:200px;border-radius:50%;background:rgba(11,168,151,.14);right:-50px;bottom:-50px}
.dc-head::before{content:'';position:absolute;width:130px;height:130px;border-radius:50%;background:rgba(34,211,238,.08);left:-30px;top:-30px}
.dc-avatar{width:82px;height:82px;border-radius:50%;background:rgba(255,255,255,.14);display:flex;align-items:center;justify-content:center;font-size:32px;margin:0 auto 12px;border:3px solid rgba(255,255,255,.22);position:relative;z-index:1}
.dc-name{font-family:var(--f-display);font-size:18px;font-weight:700;color:#fff;margin-bottom:4px;position:relative;z-index:1}
.dc-spec{font-size:12px;color:rgba(255,255,255,.50);position:relative;z-index:1}
.dc-verified{position:absolute;top:12px;right:12px;background:var(--green);color:#fff;font-size:10px;font-weight:700;padding:3px 9px;border-radius:var(--r-pill);z-index:2}
.dc-body{padding:20px}
.dc-meta{display:flex;justify-content:space-around;padding:11px 0;border-top:1px solid var(--border-lite);border-bottom:1px solid var(--border-lite);margin-bottom:14px}
.dc-mv{font-family:var(--f-mono);font-size:16px;font-weight:700;color:var(--ink);line-height:1;text-align:center}
.dc-ml{font-size:10px;color:var(--subtle);margin-top:3px;text-transform:uppercase;letter-spacing:.5px;text-align:center}
.dc-hosp{font-size:12px;color:var(--muted);margin-bottom:12px}
.dc-fee-row{display:flex;align-items:center;justify-content:space-between;background:var(--bg);border-radius:var(--r-sm);padding:11px 14px;margin-bottom:12px}
.dc-fee-val{font-family:var(--f-mono);font-size:20px;font-weight:700;color:var(--blue)}
.dc-btns{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.dc-book{background:var(--g-primary);color:#fff;padding:10px;border-radius:var(--r-md);font-size:13px;font-weight:700;border:none;cursor:pointer;font-family:var(--f-body);transition:all .3s}
.dc-book:hover{box-shadow:var(--s-blue);transform:translateY(-1px)}
.dc-view{background:var(--blue-light);color:var(--blue);padding:10px;border-radius:var(--r-md);font-size:13px;font-weight:600;border:none;cursor:pointer;font-family:var(--f-body);transition:all .2s}
.dc-view:hover{background:rgba(14,111,216,.15)}

/* FORMS */
.form-group{margin-bottom:18px}
.form-label{display:block;font-size:10px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--muted);margin-bottom:7px}
.form-input,.form-select,.form-textarea{width:100%;padding:13px 16px;border:1.5px solid var(--border);border-radius:var(--r-md);font-size:14px;font-family:var(--f-body);color:var(--ink);background:#fff;outline:none;transition:all .2s;line-height:1.5}
.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--blue);box-shadow:0 0 0 4px rgba(14,111,216,.08)}
.form-input::placeholder{color:var(--subtle)}
.form-textarea{resize:vertical;min-height:100px}
.form-select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%235A7194' viewBox='0 0 16 16'%3E%3Cpath d='M7.247 11.14 2.451 5.658C1.885 5.013 2.345 4 3.204 4h9.592a1 1 0 0 1 .753 1.659l-4.796 5.48a1 1 0 0 1-1.506 0z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;padding-right:42px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.form-helper{font-size:11px;color:var(--subtle);margin-top:5px}
.submit-btn{width:100%;padding:15px;background:var(--g-primary);color:#fff;border:none;border-radius:var(--r-md);font-size:15px;font-weight:700;font-family:var(--f-body);cursor:pointer;transition:all .3s var(--ease);box-shadow:var(--s-blue);letter-spacing:.3px;margin-top:6px}
.submit-btn:hover{transform:translateY(-2px);box-shadow:0 16px 48px rgba(5,73,163,.40)}
.submit-btn:disabled{opacity:.7;cursor:not-allowed;transform:none}

/* BADGES */
.badge{display:inline-flex;align-items:center;gap:4px;padding:4px 12px;border-radius:var(--r-pill);font-size:11px;font-weight:700;letter-spacing:.2px}
.badge-blue{background:var(--blue-light);color:var(--royal)}.badge-teal{background:var(--teal-lt);color:var(--teal-dk)}.badge-green{background:var(--green-lt);color:#065F46}.badge-red{background:var(--red-lt);color:#9B1C1C}.badge-gold{background:var(--gold-lt);color:#92400E}.badge-navy{background:rgba(2,27,65,.08);color:var(--navy)}

/* ALERTS */
.alert{padding:14px 18px;border-radius:var(--r-md);font-size:13px;line-height:1.65;margin-bottom:16px}
.alert-info{background:var(--blue-light);border:1px solid rgba(14,111,216,.22);color:var(--royal)}
.alert-success{background:var(--green-lt);border:1px solid rgba(16,185,129,.25);color:#065F46}
.alert-warning{background:var(--gold-lt);border:1px solid rgba(245,158,11,.25);color:#92400E}
.alert-hipaa{background:#F0FDF4;border:1px solid rgba(16,185,129,.25);color:#065F46;font-size:12px}
.alert-error{background:var(--red-lt);border:1px solid rgba(229,62,62,.25);color:#9B1C1C}
.alert-admin{background:#FFFBEB;border-left:4px solid var(--gold);padding-left:16px;color:#92400E}

/* TABLE */
.table-wrap{background:#fff;border-radius:var(--r-lg);border:1px solid var(--border);overflow:hidden;box-shadow:var(--s-xs)}
.data-table{width:100%;border-collapse:collapse}
.data-table th{text-align:left;padding:13px 16px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--subtle);background:var(--border-lite);border-bottom:1px solid var(--border)}
.data-table td{padding:14px 16px;font-size:13px;border-bottom:1px solid var(--border-lite);color:var(--body);vertical-align:middle}
.data-table tr:last-child td{border-bottom:none}
.data-table tr:hover td{background:rgba(14,111,216,.02)}

/* MODAL */
.modal-overlay{position:fixed;inset:0;background:rgba(2,27,65,.55);z-index:2000;display:flex;align-items:center;justify-content:center;padding:20px;opacity:0;visibility:hidden;transition:all .3s}
.modal-overlay.open{opacity:1;visibility:visible}
.modal{background:#fff;border-radius:var(--r-xl);padding:40px;max-width:560px;width:100%;box-shadow:var(--s-xl);transform:translateY(20px) scale(.97);transition:all .35s var(--ease);position:relative;max-height:90vh;overflow-y:auto}
.modal-overlay.open .modal{transform:translateY(0) scale(1)}
.modal-close{position:absolute;top:16px;right:16px;width:34px;height:34px;border-radius:50%;background:var(--border-lite);border:none;cursor:pointer;font-size:16px;display:flex;align-items:center;justify-content:center;color:var(--muted);transition:all .2s}
.modal-close:hover{background:var(--border);color:var(--ink)}

/* PORTAL LAYOUT */
.portal-wrap{display:flex;padding-top:68px;min-height:100vh}
.portal-sidebar{width:252px;flex-shrink:0;position:fixed;top:68px;left:0;bottom:0;background:#fff;border-right:1px solid var(--border);overflow-y:auto;z-index:90;display:flex;flex-direction:column}
.portal-main{flex:1;margin-left:252px;padding:32px 36px;background:var(--bg);min-height:calc(100vh - 68px)}
.sb-top{background:var(--g-dark);padding:22px 18px 20px}
.sb-avatar{width:46px;height:46px;border-radius:50%;background:rgba(255,255,255,.14);display:flex;align-items:center;justify-content:center;font-size:20px;margin-bottom:12px;border:2px solid rgba(255,255,255,.20)}
.sb-uid{font-family:var(--f-mono);font-size:10px;color:rgba(255,255,255,.38);letter-spacing:1.5px;margin-bottom:4px}
.sb-name{font-size:14px;font-weight:700;color:#fff;margin-bottom:2px}
.sb-role{font-size:11px;color:rgba(255,255,255,.40)}
.sb-verified{display:inline-flex;align-items:center;gap:4px;background:rgba(11,168,151,.20);border:1px solid rgba(11,168,151,.30);color:#5EEAD4;font-size:10px;font-weight:700;padding:3px 9px;border-radius:var(--r-pill);margin-top:6px}
.sb-nav{padding:12px 10px;flex:1}
.sbn-sect{font-size:9px;font-weight:700;letter-spacing:2.5px;text-transform:uppercase;color:var(--subtle);padding:10px 10px 5px;margin-top:8px}
.sbn-item{display:flex;align-items:center;gap:10px;padding:11px 12px;border-radius:var(--r-md);font-size:13px;font-weight:500;color:var(--muted);cursor:pointer;transition:all .2s;border:none;background:none;width:100%;text-align:left;font-family:var(--f-body);text-decoration:none;margin-bottom:2px}
.sbn-item:hover{background:var(--blue-light);color:var(--blue)}
.sbn-item.active{background:var(--blue-light);color:var(--blue);font-weight:700}
.sbn-item .si{font-size:16px;flex-shrink:0;width:22px;text-align:center}
.sbn-badge{margin-left:auto;background:var(--red);color:#fff;font-size:10px;font-weight:700;padding:2px 7px;border-radius:var(--r-pill)}
.sb-foot{padding:12px 10px;border-top:1px solid var(--border)}
.portal-section{display:none}.portal-section.active{display:block}

/* APT ROW */
.apt-row{background:#fff;border-radius:var(--r-lg);padding:20px 22px;border:1px solid var(--border);display:flex;align-items:center;gap:16px;margin-bottom:10px;transition:all .3s var(--ease)}
.apt-row:hover{box-shadow:var(--s-sm);border-color:rgba(14,111,216,.18)}
.apt-time-col{text-align:center;flex-shrink:0;width:62px}
.apt-time{font-family:var(--f-mono);font-size:15px;font-weight:700;color:var(--blue)}
.apt-type-lbl{font-size:10px;color:var(--muted);margin-top:3px}
.apt-sep{width:1px;background:var(--border);align-self:stretch;min-height:50px;flex-shrink:0}
.apt-info{flex:1}
.apt-patient-name{font-size:15px;font-weight:700;color:var(--ink);margin-bottom:3px}
.apt-uid{font-family:var(--f-mono);font-size:11px;color:var(--muted)}
.apt-actions{display:flex;gap:8px;flex-shrink:0;flex-wrap:wrap}
.apt-btn{padding:8px 14px;border-radius:var(--r-sm);font-size:12px;font-weight:700;cursor:pointer;border:none;font-family:var(--f-body);transition:all .2s}
.ab-primary{background:var(--g-primary);color:#fff}.ab-success{background:var(--green-lt);color:#065F46;border:1px solid rgba(16,185,129,.20)}.ab-danger{background:var(--red-lt);color:#9B1C1C;border:1px solid rgba(229,62,62,.20)}.ab-info{background:var(--blue-light);color:var(--blue);border:1px solid rgba(14,111,216,.20)}

/* REPORT CARD */
.report-card{background:#fff;border-radius:var(--r-lg);padding:18px 20px;border:1px solid var(--border);display:flex;align-items:center;gap:16px;transition:all .3s var(--ease);cursor:pointer;margin-bottom:10px}
.report-card:hover{box-shadow:var(--s-sm);border-color:rgba(14,111,216,.20);transform:translateX(4px)}
.rpt-icon{width:46px;height:46px;border-radius:var(--r-md);background:var(--blue-light);display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}
.rpt-title{font-size:14px;font-weight:600;color:var(--ink);margin-bottom:3px}
.rpt-meta{font-size:12px;color:var(--muted)}
.report-card.abnormal{border-color:rgba(229,62,62,.28);background:#FFFAFA}
.report-card.abnormal .rpt-icon{background:var(--red-lt)}

/* SLOT GRID */
.slot-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-top:12px}
.slot-btn{padding:10px 6px;border:1.5px solid var(--border);border-radius:var(--r-md);background:#fff;font-size:13px;font-weight:600;cursor:pointer;text-align:center;transition:all .2s;color:var(--body);font-family:var(--f-body)}
.slot-btn:hover:not(.booked){border-color:var(--blue);background:var(--blue-light);color:var(--blue)}
.slot-btn.selected{background:var(--blue);color:#fff;border-color:var(--blue)}
.slot-btn.booked{background:var(--border-lite);color:var(--subtle);cursor:not-allowed;font-size:11px;text-decoration:line-through}

/* AVAIL DAYS */
.avail-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:8px}
.avail-day{border:1.5px solid var(--border);border-radius:var(--r-md);padding:12px 6px;text-align:center;cursor:pointer;transition:all .2s}
.avail-day.on{background:var(--blue);border-color:var(--blue)}
.avail-day .ad-lbl{font-size:12px;font-weight:700;color:var(--muted)}
.avail-day.on .ad-lbl{color:#fff}

/* EMPTY STATE */
.empty-state{text-align:center;padding:64px 20px;color:var(--muted)}
.empty-state .es-icon{font-size:56px;margin-bottom:16px;opacity:.7;display:block}
.empty-state strong{display:block;font-size:17px;color:var(--body);margin-bottom:8px}

/* HIPAA STRIP */
.hipaa-strip{background:linear-gradient(135deg,#F0FDF4,#ECFDF5);border-top:1px solid rgba(16,185,129,.18);border-bottom:1px solid rgba(16,185,129,.18);padding:18px 5%;display:flex;align-items:center;justify-content:center;gap:36px;flex-wrap:wrap}
.hipaa-item{display:flex;align-items:center;gap:7px;font-size:12px;font-weight:700;color:#065F46}

/* FOOTER */
.dn-footer{background:var(--ink);padding:72px 5% 32px}
.footer-grid{display:grid;grid-template-columns:2.2fr 1fr 1fr 1fr;gap:48px;margin-bottom:52px}
.footer-logo-name{font-family:var(--f-display);font-size:26px;font-weight:700;color:#fff;display:block;margin-bottom:14px}
.footer-logo-name span{color:var(--blue-mid)}
.footer-tagline{font-size:13px;color:rgba(255,255,255,.32);line-height:1.82;max-width:260px;margin-bottom:22px}
.footer-security{display:flex;align-items:center;gap:10px;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.09);border-radius:var(--r-md);padding:12px 16px}
.fs-text{font-size:11px;color:rgba(255,255,255,.38);line-height:1.55}
.fch{font-size:9px;font-weight:700;letter-spacing:2.5px;text-transform:uppercase;color:rgba(255,255,255,.22);margin-bottom:18px}
.fcl{display:flex;flex-direction:column;gap:12px}
.fcl a{font-size:13px;color:rgba(255,255,255,.42);transition:color .2s}
.fcl a:hover{color:rgba(255,255,255,.80)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.07);padding-top:24px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:14px}
.fb-copy{font-size:12px;color:rgba(255,255,255,.18)}
.fb-links{display:flex;gap:20px}
.fb-links a{font-size:12px;color:rgba(255,255,255,.20);transition:color .2s}
.fb-links a:hover{color:rgba(255,255,255,.50)}

/* UPLOAD ZONE */
.upload-zone{border:2px dashed var(--border);border-radius:var(--r-lg);padding:36px;text-align:center;cursor:pointer;transition:all .3s;background:var(--bg)}
.upload-zone:hover{border-color:var(--blue);background:var(--blue-light)}

/* ANIMATIONS */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .65s var(--ease),transform .65s var(--ease)}
.reveal.visible{opacity:1;transform:translateY(0)}
.reveal-l{opacity:0;transform:translateX(-26px);transition:opacity .65s var(--ease),transform .65s var(--ease)}
.reveal-l.visible{opacity:1;transform:translateX(0)}
.reveal-r{opacity:0;transform:translateX(26px);transition:opacity .65s var(--ease),transform .65s var(--ease)}
.reveal-r.visible{opacity:1;transform:translateX(0)}
@keyframes fadeUp{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}
@keyframes slideDown{from{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes pulse-dot{0%,100%{opacity:1}50%{opacity:.4}}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
.spin-loader{display:inline-block;width:18px;height:18px;border:2px solid rgba(255,255,255,.35);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite}

/* STEP WIZARD */
.wizard-steps{display:flex;gap:0;margin-bottom:36px;background:#fff;border-radius:var(--r-lg);border:1px solid var(--border);overflow:hidden}
.wz-step{flex:1;padding:18px 14px;text-align:center;font-size:13px;font-weight:600;color:var(--muted);border-right:1px solid var(--border);cursor:pointer;transition:all .3s}
.wz-step:last-child{border-right:none}
.wz-step.active{background:var(--g-primary);color:#fff}
.wz-step.done{background:var(--green-lt);color:#065F46}
.wz-num{font-family:var(--f-mono);font-size:11px;font-weight:700;display:block;margin-bottom:3px;opacity:.6}
.step-content{display:none}.step-content.active{display:block}

/* RESPONSIVE */
@media(max-width:1024px){.portal-sidebar{display:none}.portal-main{margin-left:0}.footer-grid{grid-template-columns:1fr 1fr}}
@media(max-width:900px){.nav-links,.nav-right{display:none}.hamburger{display:flex}.form-row{grid-template-columns:1fr}}
@media(max-width:768px){section{padding:64px 5%}.footer-grid{grid-template-columns:1fr}.portal-main{padding:20px 18px}}
@media(max-width:480px){.slot-grid{grid-template-columns:repeat(3,1fr)}.avail-grid{grid-template-columns:repeat(4,1fr)}}

/* ── DoctorNext Nav v2 overrides (logo + new links) ─── */
.dn-logo-img { height: 48px; width: auto; object-fit: contain; display: block; }
body { padding-top: 70px !important; }
.btn-teal { background: linear-gradient(135deg, #0BA897, #0D9488); color: white; border: none; border-radius: var(--r-pill, 100px); padding: 12px 26px; font-size: 14px; font-weight: 700; cursor: pointer; font-family: inherit; transition: all .3s; display: inline-flex; align-items: center; gap: 8px; }
.btn-teal:hover { transform: translateY(-2px); box-shadow: 0 8px 24px rgba(11,168,151,.35); }

/* ═══════════════════════════════════════════════════════════════
   DoctorNext v12 — Complete Bug Fixes + World-Class Improvements
   © 2026 Doc Next Services Private Limited
═══════════════════════════════════════════════════════════════ */

/* ── BUG #3 FIX: Doctor portal mobile navigation ── */
@media(max-width:1024px){
  .portal-sidebar{
    display:flex!important;
    position:fixed;bottom:0;left:0;right:0;top:auto!important;
    height:auto;width:100%!important;
    flex-direction:row!important;
    overflow-x:auto;overflow-y:hidden;
    padding:0!important;
    border-right:none!important;
    border-top:1px solid var(--border);
    box-shadow:0 -4px 20px rgba(0,0,0,.08);
    z-index:200;scrollbar-width:none;
  }
  .portal-sidebar::-webkit-scrollbar{display:none}
  .sb-nav{display:flex;flex-direction:row;width:100%;padding:0}
  .sb-foot{display:none}
  .sbn-sect{display:none}
  .sbn-item{
    flex-shrink:0;flex-direction:column;gap:3px;
    padding:10px 14px 8px!important;
    font-size:9px!important;font-weight:700!important;
    min-width:60px;text-align:center;
    border-radius:0!important;
    border-bottom:none!important;
  }
  .sbn-item .si{font-size:20px;display:block;margin:0 auto}
  .sbn-badge{position:absolute;top:6px;right:6px;font-size:8px!important;min-width:14px!important;height:14px!important}
  .portal-main,.doc-portal-main{margin-left:0!important;padding-bottom:80px!important}
  .portal-content{padding-bottom:90px!important}
  .sb-profile{display:none}
}

/* ── BUG #4 FIX: Book page slot buttons mobile ── */
@media(max-width:480px){
  .slot-g{grid-template-columns:repeat(3,1fr)!important;gap:6px!important}
  .slot{font-size:11px!important;padding:9px 4px!important}
  .book-steps{gap:4px}
  .bs-step{font-size:10px;padding:8px 4px}
}

/* ── BUG #7 FIX: Loading skeleton animation ── */
.skeleton{background:linear-gradient(90deg,#F1F5F9 25%,#E2E8F0 50%,#F1F5F9 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:8px}
@keyframes shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}
.sk-card{background:white;border:1px solid var(--border);border-radius:var(--r-lg);padding:22px;display:flex;gap:16px;align-items:flex-start}
.sk-avatar{width:52px;height:52px;border-radius:14px;flex-shrink:0}
.sk-lines{flex:1;display:flex;flex-direction:column;gap:8px}
.sk-line{height:12px}
.sk-line.l80{width:80%}.sk-line.l60{width:60%}.sk-line.l40{width:40%}

/* ── BUG #9 FIX: Journal mobile ── */
@media(max-width:380px){
  .article-card,.ac-card{padding:14px!important}
  .article-title,.ac-title{font-size:14px!important}
  .ac-full{padding:0 14px 8px!important}
  .article-meta,.ac-meta{flex-wrap:wrap!important;gap:4px!important;font-size:10px!important}
}

/* ── WORLD CLASS: Enhanced card hover states ── */
.card,.doc-card,.stat-card{transition:all .35s var(--ease)}
.doc-card:hover{transform:translateY(-6px);box-shadow:0 20px 60px rgba(5,73,163,.18)!important}

/* ── WORLD CLASS: Focus states for accessibility ── */
*:focus-visible{outline:3px solid var(--blue);outline-offset:3px;border-radius:4px}
input:focus,select:focus,textarea:focus{
  box-shadow:0 0 0 3px rgba(5,73,163,.12);
  border-color:var(--blue)!important;
  outline:none;
}

/* ── WORLD CLASS: Mobile form improvements ── */
@media(max-width:768px){
  .form-row{grid-template-columns:1fr!important}
  .submit-btn,.btn-primary{min-height:48px;font-size:15px!important}
  input,select,textarea{font-size:16px!important} /* Prevents iOS zoom */
  .search-bar{grid-template-columns:1fr!important;padding:16px!important}
  .doctors-layout{grid-template-columns:1fr!important}
}

/* ── WORLD CLASS: HIPAA trust badge ── */
.hipaa-strip{
  background:linear-gradient(135deg,#022B1A,#065F46);
  padding:10px 5%;
  display:flex;align-items:center;justify-content:center;gap:24px;
  flex-wrap:wrap;gap:16px;
}
.hipaa-strip-item{display:flex;align-items:center;gap:7px;font-size:11px;font-weight:700;color:rgba(255,255,255,.75);letter-spacing:.5px;white-space:nowrap}
.hipaa-strip-item span{font-size:15px}

/* ── WORLD CLASS: Page transitions ── */
.main-content{animation:fadeInPage .35s ease}
@keyframes fadeInPage{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}

/* ── WORLD CLASS: Toast improvements ── */
.dn-toast{
  position:fixed;bottom:24px;right:20px;z-index:9999;
  padding:14px 20px;border-radius:14px;font-size:14px;font-weight:600;
  font-family:var(--f-body);box-shadow:0 8px 32px rgba(0,0,0,.18);
  animation:toastIn .35s var(--ease);max-width:340px;
  display:flex;align-items:center;gap:10px;
}
@keyframes toastIn{from{opacity:0;transform:translateY(16px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}

/* ── WORLD CLASS: Responsive table wrapper ── */
.table-responsive{overflow-x:auto;-webkit-overflow-scrolling:touch;border-radius:var(--r-lg)}
@media(max-width:768px){
  .data-table th,.data-table td{font-size:12px;padding:10px 8px!important;white-space:nowrap}
}

/* ── WORLD CLASS: Print styles ── */
@media print{
  .dn-nav,.bottom-nav,.portal-sidebar,.dn-footer,button:not(.print-show){display:none!important}
  body{padding-top:0!important;background:white!important}
  .card,.stat-card{box-shadow:none!important;border:1px solid #ccc!important}
}

/* ── WORLD CLASS: High contrast mode support ── */
@media(prefers-contrast:high){
  :root{--border:#000;--muted:#333;--subtle:#555}
  .btn-primary{background:#000!important}
}

/* ── WORLD CLASS: Reduced motion ── */
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important}
}

/* ── WORLD CLASS: Safe area for notched phones ── */
.bottom-nav,.portal-sidebar{padding-bottom:env(safe-area-inset-bottom,0px)}

/* ── WORLD CLASS: Improved mobile nav ── */
@media(max-width:900px){
  .dn-mobile-menu{
    background:white;padding:20px 5% calc(24px + env(safe-area-inset-bottom));
    gap:4px;
  }
  .dn-mobile-menu a{
    padding:14px 16px;border-radius:12px;border-bottom:none!important;
    font-size:15px;font-weight:600;
    transition:background .2s;
  }
  .dn-mobile-menu a:hover,.dn-mobile-menu a:active{background:var(--blue-light);color:var(--blue)!important}
}

/* ── WORLD CLASS: Doctor card mobile ── */
@media(max-width:600px){
  .results-grid,.docs-grid{grid-template-columns:1fr!important}
  .dc-meta{grid-template-columns:repeat(3,1fr)!important}
}

/* ── WORLD CLASS: Appointment card touch targets ── */
@media(max-width:768px){
  .apt-card,.doc-card,.stat-card{-webkit-tap-highlight-color:transparent}
  .btn,.btn-primary,.btn-outline,.n-fill,.n-outline{min-height:44px} /* Apple HIG min touch target */
}

/* ── WORLD CLASS: Error state ── */
.input-error{border-color:var(--red)!important;box-shadow:0 0 0 3px rgba(220,38,38,.12)!important}
.field-error-msg{font-size:11px;color:var(--red);margin-top:4px;display:none}
.field-error-msg.show{display:block}

/* ── WORLD CLASS: Success state ── */
.input-success{border-color:var(--green)!important;box-shadow:0 0 0 3px rgba(16,185,129,.12)!important}

/* ── WORLD CLASS: Loading button ── */
.btn-loading{pointer-events:none;opacity:.75}
.btn-loading::after{content:'';display:inline-block;width:14px;height:14px;border:2px solid rgba(255,255,255,.4);border-top-color:white;border-radius:50%;animation:spin .7s linear infinite;margin-left:8px;vertical-align:middle}

/* ── WORLD CLASS: Sticky header shadow on scroll ── */
.dn-nav.scrolled{box-shadow:0 4px 32px rgba(2,27,65,.12)!important}

/* ── WORLD CLASS: Image lazy loading blur-up ── */
img[loading="lazy"]{transition:filter .4s ease}
img[loading="lazy"].loaded{filter:none}

/* ═══════════════════════════════════════════════════════════════
   DoctorNext v12 — Complete Bug Fixes + World-Class Improvements
═══════════════════════════════════════════════════════════════ */

/* BUG #3 FIX: Doctor portal mobile nav as bottom tab bar */
@media(max-width:1024px){
  .portal-sidebar{display:flex!important;position:fixed;bottom:0;left:0;right:0;top:auto!important;height:auto;width:100%!important;flex-direction:row!important;overflow-x:auto;overflow-y:hidden;padding:0!important;border-right:none!important;border-top:1px solid var(--border);box-shadow:0 -4px 20px rgba(0,0,0,.08);z-index:200;scrollbar-width:none;}
  .portal-sidebar::-webkit-scrollbar{display:none}
  .sb-nav{display:flex;flex-direction:row;width:100%;padding:0}
  .sb-foot{display:none}
  .sbn-sect{display:none}
  .sbn-item{flex-shrink:0;flex-direction:column;gap:2px;padding:10px 14px 8px!important;font-size:9px!important;font-weight:700!important;min-width:58px;text-align:center;border-radius:0!important;border-bottom:none!important;position:relative;}
  .sbn-item .si{font-size:20px;display:block;margin:0 auto 1px}
  .sbn-badge{position:absolute;top:6px;right:4px;font-size:8px!important;min-width:14px!important;height:14px!important}
  .portal-main,.doc-portal-main{margin-left:0!important;padding-bottom:84px!important}
  .sb-profile{display:none}
}

/* BUG #4 FIX: Slot buttons on small screens */
@media(max-width:480px){
  .slot-g{grid-template-columns:repeat(3,1fr)!important;gap:6px!important}
  .slot{font-size:11px!important;padding:9px 4px!important}
}

/* BUG #9 FIX: Journal mobile tiny screens */
@media(max-width:380px){
  .article-card,.ac-card{padding:14px!important}
  .article-title,.ac-title{font-size:14px!important}
  .ac-full{padding:0 14px 8px!important}
  .article-meta,.ac-meta{flex-wrap:wrap!important;gap:4px!important;font-size:10px!important}
}

/* WORLD CLASS: Skeleton loading */
.skeleton{background:linear-gradient(90deg,#F1F5F9 25%,#E2E8F0 50%,#F1F5F9 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:8px}
@keyframes shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}
.sk-card{background:white;border:1px solid var(--border);border-radius:var(--r-lg);padding:22px;display:flex;gap:16px;align-items:flex-start;margin-bottom:14px}
.sk-avatar{width:52px;height:52px;border-radius:14px;flex-shrink:0}
.sk-lines{flex:1;display:flex;flex-direction:column;gap:9px;padding-top:6px}
.sk-line{height:11px;border-radius:6px}
.l80{width:80%}.l60{width:60%}.l40{width:40%}

/* WORLD CLASS: Input validation states */
.input-error{border-color:var(--red)!important;box-shadow:0 0 0 3px rgba(220,38,38,.12)!important}
.input-success{border-color:var(--green)!important;box-shadow:0 0 0 3px rgba(16,185,129,.12)!important}
.field-error{font-size:11px;color:var(--red);margin-top:4px;display:none}
.field-error.show{display:block}

/* WORLD CLASS: Mobile form improvements */
@media(max-width:768px){
  input,select,textarea{font-size:16px!important}
  .submit-btn,.btn-primary{min-height:48px}
  .form-row{grid-template-columns:1fr!important}
  .search-bar{grid-template-columns:1fr!important;padding:16px!important}
  .doctors-layout{grid-template-columns:1fr!important}
  .results-grid{grid-template-columns:1fr 1fr!important}
}
@media(max-width:540px){
  .results-grid{grid-template-columns:1fr!important}
}

/* WORLD CLASS: Focus accessibility */
*:focus-visible{outline:3px solid rgba(5,73,163,.5);outline-offset:3px;border-radius:4px}

/* WORLD CLASS: Touch targets */
.btn,.btn-primary,.btn-outline,.n-fill,.n-outline,.submit-btn{min-height:44px}

/* WORLD CLASS: Reduced motion */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important}
}

/* WORLD CLASS: Print */
@media print{
  .dn-nav,.portal-sidebar,.dn-footer,button{display:none!important}
  body{padding-top:0!important}
}

/* WORLD CLASS: Safe area for notched phones */
@media(max-width:1024px){
  .portal-sidebar{padding-bottom:env(safe-area-inset-bottom,0px)}
}

/* WORLD CLASS: HIPAA trust bar */
.hipaa-trust-bar{background:linear-gradient(135deg,#022B1A,#065F46);padding:8px 5%;display:flex;align-items:center;justify-content:center;gap:20px;flex-wrap:wrap}
.htb-item{display:flex;align-items:center;gap:6px;font-size:10px;font-weight:700;color:rgba(255,255,255,.7);letter-spacing:.8px;text-transform:uppercase;white-space:nowrap}

/* WORLD CLASS: Page fade-in */
body{animation:pageIn .3s ease}
@keyframes pageIn{from{opacity:0}to{opacity:1}}

/* WORLD CLASS: Mobile menu improved */
@media(max-width:900px){
  .dn-mobile-menu a{padding:14px 16px!important;border-radius:12px!important;border-bottom:none!important;margin:2px 0;font-size:15px!important;font-weight:600!important}
  .dn-mobile-menu a:active{background:var(--blue-light)!important;color:var(--blue)!important}
}

/* ══ DOCTOR CARD BUTTONS ══ */
.doc-btn-book{background:var(--g-primary,linear-gradient(135deg,#021B41,#0549A3));color:white;border:none;border-radius:10px;padding:10px 0;flex:1;font-size:13px;font-weight:700;cursor:pointer;font-family:var(--f-body);transition:all .25s}
.doc-btn-book:hover{opacity:.88;transform:translateY(-1px)}
.doc-btn-profile{background:white;color:var(--blue,#0549A3);border:1.5px solid var(--border,#E2E8F0);border-radius:10px;padding:10px 0;flex:1;font-size:12px;font-weight:700;cursor:pointer;font-family:var(--f-body);transition:all .25s}
.doc-btn-profile:hover{border-color:var(--blue,#0549A3);background:#EBF4FF}
.doc-btns{display:flex;gap:8px;margin-top:14px}
