:root{font-family:Inter,system-ui,Segoe UI,Roboto,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}html,body,#root{min-height:100%}body{margin:0;min-width:320px}a{text-decoration:none}:root{--bg: #f7f9fc;--bg-grad-start:#EFF6FF;--bg-grad-end:#DBEAFE;--card: rgba(255,255,255,.75);--muted:#667085;--text:#0f172a;--primary:#2563EB;--primary-600:#1D4ED8;--ring: rgba(37,99,235,.15);--success:#22c55e33;--success-text:#16a34a;--warning:#f59e0b22;--warning-text:#b45309;--danger:#ef444422;--danger-text:#b91c1c;--shadow: 0 8px 24px rgba(37,99,235,.08);--radius: 16px}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;font-family:Inter,system-ui,Segoe UI,Roboto,Arial,sans-serif;color:var(--text);background:linear-gradient(to bottom right,var(--bg-grad-start),var(--bg-grad-end)) fixed}.container{max-width:1200px;margin:0 auto;padding:24px}.container-wide{max-width:1280px;margin:0 auto;padding:32px}.center{display:flex;align-items:center;justify-content:center}.center-text{text-align:center}.mt-4{margin-top:4px}.mt-12{margin-top:12px}.mt-16{margin-top:16px}.mt-24{margin-top:24px}.row{display:flex;gap:16px;align-items:center}.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.card{background:var(--card);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--ring);border-radius:var(--radius);box-shadow:var(--shadow);padding:20px;transition:box-shadow .2s ease,transform .2s ease}.card.xl{padding:32px 28px}.w-560{width:min(560px,100%)}.btn{display:inline-flex;align-items:center;justify-content:center;border-radius:10px;height:44px;padding:0 18px;border:0;font-weight:600;cursor:pointer}.btn.primary{background:var(--primary);color:#fff}.btn.primary:hover{background:var(--primary-600)}.btn.outline{background:#fff;border:1px solid #dce3f0;color:#0f172a}.btn.outline:hover{border-color:#bcd0f7;color:var(--primary)}.btn.secondary{background:#2563eb14;color:var(--primary)}.btn.ghost{background:transparent;color:var(--primary)}.btn.slim{border-radius:8px}.input,select{width:100%;height:44px;border:1px solid #dce3f0;border-radius:10px;padding:0 14px;background:#fff}.label{font-size:14px;color:#334155;margin-bottom:6px}.badge{display:inline-flex;align-items:center;gap:8px;padding:6px 10px;border-radius:999px;font-weight:600;font-size:12px}.badge.success{background:var(--success);color:var(--success-text)}.badge.warning{background:var(--warning);color:var(--warning-text)}.badge.neutral{background:#eef2ff;color:#3b82f6}.table{width:100%;border-collapse:separate;border-spacing:0 12px}.table th{font-size:12px;color:#64748b;text-align:left;padding:8px 14px}.table td{background:var(--card);border:1px solid var(--ring);padding:14px;border-left:0;border-right:0}.table tr td:first-child{border-top-left-radius:12px;border-bottom-left-radius:12px;border-left:1px solid var(--ring)}.table tr td:last-child{border-top-right-radius:12px;border-bottom-right-radius:12px;border-right:1px solid var(--ring)}.table tbody tr:hover td{background:#f8fbff}.topbar{position:sticky;top:0;z-index:10;background:transparent}.topbar-inner{display:flex;justify-content:space-between;align-items:center;padding:4px 12px}.brand{display:flex;gap:12px;align-items:center}.logo-badge{width:42px;height:42px;border-radius:12px;background:transparent;display:flex;align-items:center;justify-content:center;font-size:22px;color:var(--primary)}.brand h1{margin:0;font-size:16px}.brand .muted{margin:0;color:#64748b;font-size:12px}.layout{display:grid;grid-template-columns:260px 1fr;min-height:100%}.sidebar{background:#fff9;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);border-right:1px solid var(--ring);padding:20px;display:flex;flex-direction:column;gap:16px}.nav{display:flex;flex-direction:column;gap:8px}.nav a{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:10px;color:#0f172a;text-decoration:none}.nav a.active,.nav a:hover{background:#2563eb1a;color:var(--primary)}.sidebar-footer{margin-top:auto}.kv{font-size:14px;color:#475569;background:#fff9;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid var(--ring);border-radius:12px;padding:12px}.logout{color:#ef4444;text-decoration:none;font-weight:600}.brand-banner{display:flex;gap:12px;align-items:center;padding:12px;border:1px solid var(--ring);border-radius:14px;background:#fff9;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.brand-logo-large{width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:22px;background:transparent;object-fit:cover}.brand-banner .title{font-weight:800}.brand-banner .subtitle{font-size:12px;color:#64748b}.stats{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.stat-card{border:1px solid #e5eaf2;background:#fff;border-radius:12px;padding:18px;display:flex;gap:12px;align-items:center;box-shadow:none}.stat-card:hover{box-shadow:0 8px 24px #2563eb14}.stat-icon{width:38px;height:38px;border-radius:12px;display:flex;align-items:center;justify-content:center;background:transparent;color:var(--primary)}.stat-title{font-size:13px;color:#64748b}.stat-value{font-weight:600;font-size:22px}.hero-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:50px;border:1px solid var(--ring);border-radius:16px;background:#fff;color:#64748b}.portal{display:flex;flex-direction:column;align-items:center;gap:10px;border:1px solid var(--ring);background:var(--card);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-radius:16px;padding:22px;text-decoration:none;color:inherit}.portal:hover{outline:2px solid #c7d2fe}.portal-icon{font-size:30px;width:56px;height:56px;border-radius:16px;display:flex;align-items:center;justify-content:center;color:var(--primary);background:transparent;border:1px solid rgba(37,99,235,.2)}.portal-icon.doctor,.portal-icon.admin,.portal-icon.recep{background:transparent}.portal-title{font-weight:700}.brand-hero{display:flex;flex-direction:column;align-items:center;gap:8px;margin-bottom:8px}.logo-hero{width:76px;height:76px}.app-name{font-size:28px;font-weight:800;color:#0f172a}.app-subtitle{color:#64748b}.w-760{max-width:760px;width:100%}.container.center{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px}.container.center>.brand-hero{margin-bottom:0}@media(max-width:900px){.container.center{gap:12px}}.portal-v2{padding:20px 18px;background:var(--card);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--ring)}.portal-v2 .portal-icon.blue{background:transparent;color:var(--primary);border:1px solid rgba(37,99,235,.2)}.portal-v2 .portal-title{color:#0f172a}.portal-v2 .portal-desc{color:#475569;font-size:13px;margin-top:4px}.portal-v2:hover{outline:2px solid #bfdbfe}.section-title{font-size:20px;font-weight:600;margin:0}.page-title{font-size:28px;font-weight:600;margin:0}.subtle{color:#64748b}.quick-actions{display:grid;grid-template-columns:1fr 1fr;gap:16px}.action-card{display:flex;gap:14px;align-items:center;border-radius:16px;padding:18px;color:#0f172a;background:var(--card);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--ring)}.action-card.blue,.action-card.green,.action-card.purple{background:var(--card)}.action-icon{width:42px;height:42px;border-radius:12px;background:transparent;border:1px solid rgba(37,99,235,.2);display:flex;align-items:center;justify-content:center;font-size:22px;color:var(--primary)}.action-title{font-weight:700}.action-card .subtle{color:#64748b}.two-col{display:grid;grid-template-columns:1fr 1fr;gap:16px}.list{list-style:none;padding:0;margin:0}.list-row{display:grid;grid-template-columns:1fr auto auto;gap:12px;align-items:center;border:1px solid var(--ring);padding:14px;border-radius:12px;background:var(--card);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.btn.sm{height:36px;padding:0 12px}.btn.pill{border-radius:999px}.btn.success{background:#16a34a;color:#fff}.btn.success:hover{background:#15803d}.btn.outline-danger{background:#fff;color:#b91c1c;border:1px solid #ef4444}.banner{padding:18px 20px}.gradient-blue{background:linear-gradient(180deg,#1d4ed8,#2563eb);color:#fff}.banner-icon{width:42px;height:42px;border-radius:12px;background:#ffffff2e;display:flex;align-items:center;justify-content:center}.banner-title{font-weight:800}.pad-24{padding:24px}.pad-16{padding:16px}.segmented{display:flex;gap:12px}.seg{background:#fff;border:2px solid var(--ring);border-radius:12px;padding:10px 14px;cursor:pointer}.seg.on{border-color:#16a34a;background:#ecfdf3}.seg.on.red{border-color:#ef4444;background:#fee2e2;color:#b91c1c}.filters .filters-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}.dept{padding:0;overflow:hidden}.dept-header{background:#fff9;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:16px;border-bottom:1px solid var(--ring)}.dept-icon{width:36px;height:36px;border-radius:12px;background:#e0ecff;display:flex;align-items:center;justify-content:center}.dept-header.purple{background:linear-gradient(180deg,#f5e9ff,#f0e5ff)}table .row-like td{background:#fff}.cards-4{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}.progress{height:8px;background:#e5e7eb;border-radius:999px;overflow:hidden}.progress>span{display:block;height:100%;background:#1d4ed8}.two-col-analytics{display:grid;grid-template-columns:1.2fr 1fr;gap:16px}.doc-row{display:grid;grid-template-columns:auto 1fr auto auto;align-items:center;gap:12px;border:1px solid var(--ring);padding:12px 14px;border-radius:12px;background:var(--card);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.doc-avatar{width:42px;height:42px;border-radius:50%;background:#e6f0ff;display:flex;align-items:center;justify-content:center;color:#fff}.doc-name{font-weight:700}.doc-actions{display:flex;gap:8px}.pill{border:1px solid var(--ring);background:#f8fafc;border-radius:20px;padding:6px 12px;cursor:pointer;font-size:12px}.pill.on{color:#fff}.pill.on.green{background:#1f9254;border-color:#1f9254}.pill.on.amber{background:#b7791f;border-color:#b7791f}.pill.on.red{background:#d64545;border-color:#d64545}.badge.available{background:#e6f7ee;color:#1f9254}.badge.onbreak{background:#fff4e5;color:#b7791f}.badge.unavail{background:#fdecea;color:#d64545}.glass{background:#ffffffb3;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.4)}.action-card,.list-row,.btn{transition:all .2s ease}
