:root{--primary:#0f766e;--primary2:#14b8a6;--primary3:#0b5d57;--nav:#07101f;--nav2:#0d1730;--bg:#eef4f8;--card:#fff;--text:#0f172a;--muted:#64748b;--line:#e2e8f0;--soft:#f8fafc;--danger:#dc2626;--warning:#d97706;--success:#059669;--shadow:0 20px 52px rgba(15,23,42,.09);--shadow2:0 10px 28px rgba(15,23,42,.07)}
*{box-sizing:border-box}html{font-size:15px}body{margin:0;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",Arial,sans-serif;background:linear-gradient(180deg,#f8fbfd 0,#edf3f8 100%);color:var(--text)}
a{text-decoration:none;color:inherit}.layout{display:flex;min-height:100vh}.sidebar{width:302px;background:radial-gradient(circle at 20% 0,rgba(20,184,166,.22),transparent 34%),linear-gradient(180deg,var(--nav) 0%,var(--nav2) 100%);color:white;padding:20px 16px;position:fixed;height:100vh;overflow:auto;box-shadow:18px 0 38px rgba(15,23,42,.18);z-index:20}.brand{display:flex;align-items:center;gap:12px;padding:10px 8px 20px;margin-bottom:12px;border-bottom:1px solid rgba(255,255,255,.1)}.brand-copy{min-width:0}.brand strong{display:block;font-size:20px;letter-spacing:.2px;line-height:1.15}.brand span{display:block;color:#9db0c9;font-size:12px;margin-top:5px}.brand-logo{width:116px;max-width:116px;height:auto;display:block;border-radius:14px;background:#fff;padding:7px;box-shadow:0 16px 34px rgba(0,0,0,.18)}.nav a{display:flex;align-items:center;gap:32px;padding:12px 12px;border-radius:16px;margin:6px 0;color:#d8e4f2;font-weight:700;font-size:14px;transition:.18s;border:1px solid transparent}.nav a.active,.nav a:hover{background:rgba(255,255,255,.11);color:#fff;transform:translateX(2px);border-color:rgba(255,255,255,.08)}.nav-icon{width:36px;height:36px;flex:0 0 36px;margin-right:18px;display:grid;place-items:center;border-radius:13px;background:rgba(255,255,255,.08);font-size:14px;color:#7dd3fc;box-shadow:inset 0 0 0 1px rgba(255,255,255,.05)}.nav a span:last-child{display:block;line-height:1.2;padding-left:6px}.nav a.active .nav-icon,.nav a:hover .nav-icon{background:linear-gradient(135deg,rgba(20,184,166,.36),rgba(59,130,246,.24));color:#fff}.main{margin-left:302px;flex:1;min-width:0}.topbar{min-height:88px;background:rgba(255,255,255,.88);backdrop-filter:blur(14px);border-bottom:1px solid rgba(226,232,240,.86);display:flex;align-items:center;justify-content:space-between;padding:17px 32px;position:sticky;top:0;z-index:10;gap:16px}.topbar h1{font-size:21px;margin:0 0 4px;font-weight:900;letter-spacing:-.02em}.top-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap;justify-content:flex-end}.quick,.logout,.user-chip{border:1px solid var(--line);background:#fff;border-radius:999px;padding:10px 14px;font-size:13px;font-weight:750;display:inline-flex;align-items:center;gap:8px;box-shadow:var(--shadow2)}.quick{color:#0f766e}.logout{color:#dc2626}.user-chip{color:#0f172a}.content{padding:30px}.mobilebar{display:none!important}.menu-toggle{display:none!important}.grid{display:grid;gap:18px}.grid-4{grid-template-columns:repeat(4,minmax(0,1fr))}.grid-3{grid-template-columns:repeat(3,minmax(0,1fr))}.grid-2{grid-template-columns:repeat(2,minmax(0,1fr))}.card{background:rgba(255,255,255,.97);border:1px solid rgba(226,232,240,.94);border-radius:24px;padding:23px;box-shadow:var(--shadow)}.card h3{margin:0 0 16px;font-size:17px;font-weight:900;letter-spacing:-.01em}.stat{position:relative;overflow:hidden;min-height:118px}.stat:after{content:"";position:absolute;right:-26px;top:-28px;width:112px;height:112px;border-radius:999px;background:linear-gradient(135deg,rgba(20,184,166,.17),rgba(59,130,246,.08))}.stat .num{font-size:32px;font-weight:950;letter-spacing:-.9px;margin-top:10px}.muted{color:var(--muted);font-size:13px}.btn{border:0;border-radius:14px;padding:11px 16px;background:linear-gradient(135deg,var(--primary),var(--primary2));color:white;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:8px;font-weight:850;box-shadow:0 14px 28px rgba(15,118,110,.20);transition:.15s}.btn:hover{transform:translateY(-1px)}.btn.secondary{background:#334155}.btn.light{background:#f1f5f9;color:#0f172a;box-shadow:none}.btn.danger{background:#dc2626}.input,select,textarea{width:100%;padding:12px 13px;border:1px solid var(--line);border-radius:14px;background:white;outline:0;transition:.15s;font:inherit}.input:focus,select:focus,textarea:focus{border-color:#14b8a6;box-shadow:0 0 0 4px rgba(20,184,166,.12)}label{display:block;font-size:13px;font-weight:850;margin-bottom:7px;color:#334155}.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:15px}.table-wrap{overflow:auto;border-radius:18px;border:1px solid var(--line);background:#fff}table{width:100%;border-collapse:separate;border-spacing:0;background:white}th,td{padding:14px 15px;border-bottom:1px solid var(--line);text-align:left;font-size:14px;vertical-align:middle}th{color:#475569;background:#f8fafc;font-size:12px;text-transform:uppercase;letter-spacing:.05em}tr:last-child td{border-bottom:0}.badge{display:inline-flex;align-items:center;padding:6px 10px;border-radius:999px;background:#ecfeff;color:#155e75;font-size:12px;font-weight:900}.badge.pending,.badge.online_pending{background:#fff7ed;color:#9a3412}.badge.scheduled{background:#eff6ff;color:#1d4ed8}.badge.completed,.badge.confirmed{background:#ecfdf5;color:#047857}.badge.cancelled{background:#fef2f2;color:#b91c1c}.alert{padding:13px 15px;border-radius:16px;margin-bottom:16px;font-weight:750}.alert.success{background:#ecfdf5;color:#065f46}.alert.error{background:#fef2f2;color:#991b1b}.section-title{display:flex;align-items:center;justify-content:space-between;gap:15px;margin-bottom:14px}.filters{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:14px}.filters a{padding:9px 13px;border-radius:999px;background:white;border:1px solid var(--line);font-size:13px;font-weight:850}.filters a.active{background:#0f766e;color:white;border-color:#0f766e}.appointment-card{display:grid;grid-template-columns:82px 1fr auto;gap:14px;align-items:center;padding:15px;border:1px solid var(--line);border-radius:18px;background:#fff;margin-bottom:10px}.timebox{background:#f0fdfa;color:#0f766e;border-radius:15px;padding:10px;text-align:center;font-weight:950}.timebox small{display:block;color:#64748b;font-size:11px;margin-top:2px}.patient-link{border:0;background:transparent;padding:0;margin:0;text-align:left;color:#0f766e;font:inherit;font-weight:900;cursor:pointer}.patient-link:hover{text-decoration:underline}.modal-backdrop{position:fixed;inset:0;background:rgba(15,23,42,.52);display:none;align-items:center;justify-content:center;z-index:80;padding:18px}.modal-backdrop.open{display:flex}.modal-card{width:560px;max-width:96vw;background:white;border-radius:26px;box-shadow:0 35px 80px rgba(15,23,42,.35);overflow:hidden}.modal-head{padding:22px 24px;background:linear-gradient(135deg,#0f766e,#14b8a6);color:white;display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.modal-head h3{margin:0;font-size:21px}.modal-body{padding:22px 24px}.modal-close{border:0;background:rgba(255,255,255,.18);color:white;width:36px;height:36px;border-radius:12px;cursor:pointer}.info-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.info-item{padding:13px;border:1px solid var(--line);border-radius:16px;background:#f8fafc}.info-item span{display:block;color:#64748b;font-size:12px;font-weight:800;margin-bottom:4px}.calendar-toolbar{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:16px}.calendar-nav{display:flex;align-items:center;gap:10px}.calendar{display:grid;grid-template-columns:repeat(7,1fr);gap:10px}.calendar-day-name{font-size:12px;font-weight:900;color:#64748b;text-transform:uppercase;padding:0 6px}.calendar-cell{min-height:130px;border:1px solid var(--line);border-radius:18px;background:#fff;padding:10px;box-shadow:0 8px 20px rgba(15,23,42,.035)}.calendar-cell.muted-day{background:#f8fafc;color:#94a3b8}.calendar-date{font-weight:950;margin-bottom:8px}.calendar-event{display:block;background:#f0fdfa;border:1px solid #ccfbf1;color:#0f766e;border-radius:12px;padding:7px 8px;margin-bottom:6px;font-size:12px;font-weight:800;line-height:1.25}.calendar-event.online_pending{background:#fff7ed;border-color:#fed7aa;color:#9a3412}.calendar-event.confirmed{background:#ecfdf5;border-color:#bbf7d0;color:#047857}.calendar-event.cancelled{background:#fef2f2;border-color:#fecaca;color:#b91c1c}.login{min-height:100vh;display:grid;place-items:center;background:radial-gradient(circle at 20% 0,#ccfbf1 0,#eff6ff 32%,#f8fafc 70%)}.login-card{width:445px;max-width:92vw}.login-logo{text-align:center;margin-bottom:20px}.login-brand-logo{width:224px;max-width:100%;height:auto;border-radius:18px;background:#fff;padding:10px;box-shadow:0 18px 42px rgba(15,23,42,.12);margin:0 auto 14px}.login-brand-title{font-size:24px;font-weight:950;color:#0f172a;margin-bottom:4px}.public-page{min-height:100vh;padding:38px 18px;background:radial-gradient(circle at top,#baf7eb,#f8fafc 45%,#fff)}.public-shell{max-width:1040px;margin:0 auto}.public-hero{display:grid;grid-template-columns:1.02fr .98fr;gap:24px;align-items:stretch;margin-bottom:24px}.hero-card{padding:36px;border-radius:30px;background:radial-gradient(circle at 25% 0,rgba(255,255,255,.18),transparent 30%),linear-gradient(135deg,#064e3b,#0f766e);color:white;box-shadow:0 30px 70px rgba(15,118,110,.28);display:flex;flex-direction:column;justify-content:space-between}.hero-card h1{font-size:40px;line-height:1.04;margin:26px 0 12px;letter-spacing:-.04em}.hero-card p{color:#d1fae5;font-size:16px;line-height:1.65}.public-brand{display:flex;align-items:center;gap:14px;font-weight:950}.public-brand-logo{width:170px;height:auto;border-radius:18px;background:#fff;padding:8px}.public-points{display:grid;gap:10px;margin-top:24px}.public-point{display:flex;align-items:center;gap:10px;color:#ecfeff;font-weight:800}.public-point i{width:32px;height:32px;border-radius:12px;background:rgba(255,255,255,.14);display:grid;place-items:center}.public-form{background:white;border:1px solid var(--line);border-radius:30px;padding:28px;box-shadow:var(--shadow)}.public-form h3{font-size:22px;margin-top:0}.public-form .btn{width:100%;font-size:15px;padding:14px 16px}
@media(max-width:1180px){.grid-4{grid-template-columns:repeat(2,minmax(0,1fr))}.grid-3{grid-template-columns:1fr}.public-hero{grid-template-columns:1fr}.calendar{grid-template-columns:repeat(2,1fr)}.calendar-day-name{display:none}}@media(max-width:900px){.layout{display:block}.sidebar{position:relative;width:100%;height:auto;transform:none}.main{margin-left:0}.grid-4,.grid-3,.grid-2,.form-grid,.info-grid{grid-template-columns:1fr}.topbar{padding:14px 16px;min-height:74px;align-items:flex-start;flex-direction:column;justify-content:center}.top-actions{width:100%;justify-content:flex-start}.content{padding:16px}.appointment-card{grid-template-columns:1fr}.public-page{padding:16px}.hero-card h1{font-size:30px}.brand-logo{width:96px}.calendar{grid-template-columns:1fr}.calendar-cell{min-height:auto}.calendar-toolbar{align-items:flex-start;flex-direction:column}}


/* FINAL MENU SPACING FIX */
.sidebar .nav a,
.nav a{
    display:flex !important;
    align-items:center !important;
    gap:0 !important;
    column-gap:0 !important;
}
.sidebar .nav .nav-icon,
.nav .nav-icon{
    flex:0 0 42px !important;
    width:42px !important;
    min-width:42px !important;
    max-width:42px !important;
    height:34px !important;
    margin-right:18px !important;
    display:inline-flex !important;
    align-items:center !important;
    justify-content:center !important;
    text-align:center !important;
}
.sidebar .nav .nav-label,
.nav .nav-label{
    display:inline-block !important;
    padding-left:8px !important;
    white-space:nowrap !important;
    line-height:1.2 !important;
}
.mobilebar .menu-toggle,
button[data-menu-toggle]{
    display:none !important;
}
.mobilebar{
    justify-content:flex-start !important;
}


/* Patient detail professional layout */
.patient-hero{
    display:flex;
    align-items:center;
    gap:18px;
    background:linear-gradient(135deg,rgba(255,255,255,.98),rgba(240,253,250,.98));
}
.patient-avatar{
    width:76px;
    height:76px;
    border-radius:24px;
    background:linear-gradient(135deg,#0f766e,#14b8a6);
    color:white;
    display:grid;
    place-items:center;
    font-size:24px;
    font-weight:900;
    box-shadow:0 18px 38px rgba(15,118,110,.22);
}
.patient-main{flex:1;min-width:0}
.patient-main h2{margin:4px 0 10px;font-size:25px;letter-spacing:-.5px}
.patient-meta{display:flex;flex-wrap:wrap;gap:10px 16px;color:#475569;font-weight:600;font-size:13px}
.patient-meta i{color:#0f766e;margin-right:5px}
.patient-actions{display:flex;gap:10px;flex-wrap:wrap;justify-content:flex-end}
.note-item{
    padding:13px 14px;
    border:1px solid var(--line);
    border-radius:15px;
    background:#fff;
    margin-bottom:10px;
}
.note-item strong{display:block;font-size:13px}
.note-item span{display:block;color:var(--muted);font-size:12px;margin-top:2px}
.note-item p{margin:8px 0 0;color:#334155}
@media(max-width:900px){
    .patient-hero{align-items:flex-start;flex-direction:column}
    .patient-actions{width:100%;justify-content:flex-start}
}


/* Final full package visual refinements */
.offer-row{grid-template-columns:2fr 1fr 1fr;margin-bottom:8px}
ol.muted li{margin:8px 0}
@media(max-width:900px){.offer-row{grid-template-columns:1fr}}


/* Final Plus modules */
.calendar-grid{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:10px}
.calendar-cell{min-height:150px;background:#fff;border:1px solid var(--line);border-radius:18px;padding:10px;box-shadow:0 10px 25px rgba(15,23,42,.04)}
.calendar-cell.today{outline:2px solid #14b8a6}
.calendar-day{font-weight:900;margin-bottom:8px}
.cal-event{display:block;border-radius:12px;padding:8px;margin:6px 0;background:#eff6ff;color:#1e40af;font-size:12px}
.cal-event.online_pending{background:#fff7ed;color:#9a3412}
.cal-event.confirmed,.cal-event.completed{background:#ecfdf5;color:#047857}
.cal-event.cancelled{background:#fef2f2;color:#b91c1c}
.cal-event small{display:block;opacity:.8;margin-top:3px}
.pipeline-board{display:flex;gap:14px;overflow:auto;padding-bottom:12px}
.pipeline-column{min-width:280px;background:#f8fafc;border:1px solid var(--line);border-radius:20px;padding:12px}
.pipeline-title{display:flex;align-items:center;justify-content:space-between;font-weight:900;margin-bottom:10px}
.pipeline-title span{background:#e2e8f0;border-radius:999px;padding:3px 8px;font-size:12px}
.pipeline-card{background:#fff;border:1px solid var(--line);border-radius:16px;padding:13px;margin-bottom:10px;box-shadow:0 10px 25px rgba(15,23,42,.05)}
.inline-wa-form{display:flex;gap:8px;align-items:center}
.teeth-row{display:grid;grid-template-columns:repeat(16,minmax(0,1fr));gap:8px;margin-bottom:12px}
.tooth{border:1px solid var(--line);background:#fff;border-radius:14px;padding:10px 5px;cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:4px;color:#334155}
.tooth i{font-size:18px;color:#0f766e}
.tooth span{font-weight:900}
.tooth small{font-size:10px;color:#64748b}
.tooth.marked{background:#ecfdf5;border-color:#99f6e4}
@media(max-width:1100px){.calendar-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.teeth-row{grid-template-columns:repeat(8,minmax(0,1fr))}}
@media(max-width:700px){.calendar-grid{grid-template-columns:1fr}.teeth-row{grid-template-columns:repeat(4,minmax(0,1fr))}.inline-wa-form{flex-direction:column;align-items:stretch}}


/* Consultation chat */
.consultation-layout{grid-template-columns:340px 1fr}
.thread-list{display:flex;flex-direction:column;gap:10px}
.thread-item{display:block;border:1px solid var(--line);border-radius:16px;padding:12px;background:#fff}
.thread-item.active,.thread-item:hover{border-color:#14b8a6;background:#f0fdfa}
.thread-item strong,.thread-item span,.thread-item small{display:block}
.thread-item span{margin-top:4px;color:#334155}
.thread-item small{margin-top:5px;color:#64748b}
.chat-head{display:flex;justify-content:space-between;gap:14px;align-items:flex-start;border-bottom:1px solid var(--line);padding-bottom:14px;margin-bottom:14px}
.chat-status{display:flex;gap:8px;align-items:center}
.chat-box{max-height:520px;overflow:auto;background:#f8fafc;border:1px solid var(--line);border-radius:18px;padding:14px}
.message-bubble{max-width:78%;padding:13px 14px;border-radius:18px;margin-bottom:12px;border:1px solid var(--line);background:#fff}
.message-bubble.doctor{margin-left:auto;background:#ecfdf5;border-color:#99f6e4}
.message-bubble.consultant{background:#eff6ff;border-color:#bfdbfe}
.message-meta{font-size:12px;color:#64748b;margin-bottom:6px}
.message-bubble p{margin:0 0 8px;line-height:1.55}
.chat-form{margin-top:14px}
@media(max-width:1000px){.consultation-layout{grid-template-columns:1fr}.message-bubble{max-width:100%}.chat-head{flex-direction:column}.chat-status{width:100%;flex-wrap:wrap}}
