/* ═══════════════════════════════════════
   LUMIDENT ADMIN — admin.css
   Light clinical theme matching main site
   ═══════════════════════════════════════ */

@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@300;400;500;600;700&family=Inter:wght@300;400;500;600&display=swap');

:root {
  --navy:       #0A1628;
  --blue:       #2B7FD4;
  --blue-light: #64B5F6;
  --blue-pale:  #E8F4FF;
  --teal:       #38B2AC;
  --violet:     #9F7AEA;
  --rose:       #E53E6D;
  --urgent:     #E53E3E;
  --green:      #38A169;
  --bg:         #F4F7FB;
  --bg-2:       #EEF3FA;
  --white:      #FFFFFF;
  --border:     rgba(43,127,212,.10);
  --border-mid: rgba(43,127,212,.20);
  --text-100:   #0D1F35;
  --text-300:   #3D5A7A;
  --text-500:   #7A96B3;
  --shadow-sm:  0 2px 8px rgba(43,127,212,.07);
  --shadow-md:  0 4px 20px rgba(43,127,212,.10);
  --font:       'Plus Jakarta Sans', 'Inter', sans-serif;
  --r:          10px; --r-sm: 6px;
  --sidebar-w:  220px;
  --topbar-h:   56px;
  --banner-h:   34px;
  --ease:       cubic-bezier(.16,1,.3,1);
}

*{box-sizing:border-box;margin:0;padding:0}
body{font-family:var(--font);background:var(--bg);color:var(--text-100);-webkit-font-smoothing:antialiased;overflow-x:hidden}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
input,select,textarea{font-family:inherit}
a{color:inherit;text-decoration:none}
::selection{background:var(--blue);color:#fff}

/* ── BANNER ── */
.adm-banner{
  position:fixed;top:0;left:0;right:0;z-index:200;height:var(--banner-h);
  background:var(--navy);border-bottom:1px solid rgba(255,255,255,.06);
  display:flex;align-items:center;justify-content:center;gap:14px;
  font-size:.74rem;color:rgba(255,255,255,.6);flex-wrap:wrap;padding:0 16px;
}
.adm-banner .dot{width:6px;height:6px;border-radius:50%;background:#4ADE80;box-shadow:0 0 8px #4ADE80}
.adm-banner b{color:#fff;font-weight:600}
.adm-banner a{color:var(--blue-light);display:inline-flex;align-items:center;gap:4px;transition:.2s}
.adm-banner a:hover{color:#fff}
.adm-banner .bn-sep{opacity:.3}

/* ── SHELL ── */
.adm-shell{display:flex;padding-top:var(--banner-h);min-height:100vh}

/* ── SIDEBAR ── */
.sidebar{
  position:fixed;top:var(--banner-h);left:0;bottom:0;width:var(--sidebar-w);
  background:var(--navy);display:flex;flex-direction:column;z-index:100;
  transition:transform .3s var(--ease),box-shadow .3s;
}
.sidebar-logo{
  display:flex;align-items:center;gap:.7rem;
  padding:1.1rem 1rem;border-bottom:1px solid rgba(255,255,255,.06);flex-shrink:0;
}
.logo-mark{
  width:34px;height:34px;border-radius:8px;background:var(--blue);
  display:grid;place-items:center;font-size:.72rem;font-weight:700;color:#fff;flex-shrink:0;
}
.sidebar-logo-name{color:#fff;font-size:1.05rem;font-weight:700;letter-spacing:-.01em;line-height:1.1}
.sidebar-logo-name b{color:var(--blue-light)}
.sidebar-logo-sub{font-size:.6rem;color:rgba(255,255,255,.35);letter-spacing:.1em;text-transform:uppercase;margin-top:1px}
.sidebar-nav{flex:1;padding:.6rem 0;overflow-y:auto}
.sidebar-nav-item{
  display:flex;align-items:center;gap:.7rem;
  width:100%;padding:.65rem 1rem;border-radius:0;
  font-size:.82rem;font-weight:500;color:rgba(255,255,255,.5);
  transition:background .15s,color .15s;position:relative;
}
.sidebar-nav-item i{font-size:1rem;flex-shrink:0}
.sidebar-nav-item:hover{background:rgba(255,255,255,.05);color:rgba(255,255,255,.85)}
.sidebar-nav-item.active{color:#fff;background:rgba(43,127,212,.2)}
.sidebar-nav-item.active::before{content:'';position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--blue);border-radius:0 2px 2px 0}
.sidebar-nav-sep{height:1px;background:rgba(255,255,255,.05);margin:.4rem .8rem}
.sidebar-foot{padding:.8rem 1rem;font-size:.66rem;color:rgba(255,255,255,.2);border-top:1px solid rgba(255,255,255,.05);flex-shrink:0}
.sidebar-overlay{position:fixed;inset:0;z-index:99;background:rgba(10,22,40,.5);display:none}
.sidebar-overlay.show{display:block}

/* ── MAIN ── */
.main{margin-left:var(--sidebar-w);flex:1;display:flex;flex-direction:column;min-height:100vh}

/* ── TOPBAR ── */
.topbar{
  position:sticky;top:var(--banner-h);z-index:50;height:var(--topbar-h);
  background:var(--white);border-bottom:1px solid var(--border);
  display:flex;align-items:center;justify-content:space-between;padding:0 1.4rem;
  box-shadow:var(--shadow-sm);
}
.topbar-left{display:flex;align-items:center;gap:.8rem}
.topbar-burger{display:none;width:36px;height:36px;border-radius:var(--r-sm);border:1px solid var(--border);place-items:center;font-size:1.1rem;color:var(--text-300)}
.topbar-title{font-size:.95rem;font-weight:700;color:var(--text-100)}
.topbar-right{display:flex;align-items:center;gap:.7rem}
.online{display:flex;align-items:center;gap:.4rem;font-size:.72rem;color:var(--green);font-weight:600}
.online .dot{width:7px;height:7px;border-radius:50%;background:var(--green);animation:pulse 2s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}
.demo-badge{font-size:.66rem;font-weight:700;padding:.22rem .6rem;border-radius:4px;background:rgba(229,62,62,.1);color:var(--urgent);letter-spacing:.1em}
.adm-lang{display:flex;gap:2px;background:var(--bg-2);border:1px solid var(--border);border-radius:var(--r-sm);padding:2px}
.adm-lb{font-size:.68rem;font-weight:600;padding:4px 8px;border-radius:4px;color:var(--text-500);transition:.2s;letter-spacing:.05em}
.adm-lb.adm-lb-active{background:var(--blue);color:#fff}
.topbar-site{display:flex;align-items:center;gap:.35rem;font-size:.78rem;font-weight:500;color:var(--blue);padding:.38rem .8rem;border-radius:var(--r-sm);border:1px solid var(--border-mid);transition:.2s}
.topbar-site:hover{background:var(--blue-pale)}

/* ── CONTENT ── */
.content{flex:1;padding:1.4rem;max-width:1400px}

/* ── CARDS & COMMON ── */
.card{background:var(--white);border-radius:var(--r);border:1px solid var(--border);box-shadow:var(--shadow-sm);padding:1.2rem}
.card-title{font-size:.78rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--text-500);margin-bottom:1rem;display:flex;align-items:center;gap:.5rem}
.card-title i{font-size:1rem;color:var(--blue)}
.section-sub{font-size:.8rem;color:var(--text-500);background:var(--blue-pale);border:1px solid var(--border);border-radius:var(--r-sm);padding:.65rem .9rem;margin-bottom:1rem;display:flex;align-items:center;gap:.5rem}
.section-sub i{color:var(--blue)}

/* ── STAT GRID ── */
.stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:.8rem;margin-bottom:1.2rem}
.stat-card{background:var(--white);border-radius:var(--r);border:1px solid var(--border);box-shadow:var(--shadow-sm);padding:1.1rem;display:flex;flex-direction:column;gap:.5rem}
.stat-card .ic{width:36px;height:36px;border-radius:var(--r-sm);background:var(--blue-pale);color:var(--blue);display:grid;place-items:center;font-size:1.1rem}
.stat-card-value{font-size:1.7rem;font-weight:700;color:var(--text-100);line-height:1}
.stat-card-value small{font-size:.9rem;color:var(--text-500);font-weight:400}
.stat-card-label{font-size:.72rem;color:var(--text-500);font-weight:500}

/* ── GRID ── */
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:.8rem}
.adm-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.8rem}

/* ── TABLE ── */
.table-wrap{overflow-x:auto;border-radius:var(--r-sm);border:1px solid var(--border)}
table{width:100%;border-collapse:collapse;font-size:.82rem}
th{background:var(--bg);padding:.65rem .9rem;text-align:left;font-size:.7rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--text-500);border-bottom:1px solid var(--border);white-space:nowrap}
td{padding:.65rem .9rem;border-bottom:1px solid var(--border);color:var(--text-100);vertical-align:middle}
tr:last-child td{border-bottom:none}
tr:hover td{background:var(--bg)}
td.empty{text-align:center;color:var(--text-500);padding:2rem}
.cell-name{font-weight:600}
.cell-sub{font-size:.72rem;color:var(--text-500);margin-top:1px}
.cell-doc{display:flex;align-items:center;gap:.5rem}
.d-avatar{width:28px;height:28px;border-radius:50%;display:grid;place-items:center;font-size:.62rem;font-weight:700;color:#fff;flex-shrink:0}

/* ── BADGES ── */
.badge{font-size:.66rem;font-weight:600;padding:.22rem .6rem;border-radius:20px;letter-spacing:.06em;text-transform:uppercase;white-space:nowrap}
.b-new{background:rgba(43,127,212,.1);color:var(--blue)}
.b-confirmed{background:rgba(56,178,172,.1);color:var(--teal)}
.b-done{background:rgba(56,161,105,.1);color:var(--green)}
.b-cancelled{background:rgba(229,62,62,.1);color:var(--urgent)}
.b-active{background:rgba(56,161,105,.1);color:var(--green)}
.b-inactive{background:rgba(122,150,179,.1);color:var(--text-500)}
.b-urgent{background:rgba(229,62,62,.1);color:var(--urgent)}

/* ── BUTTONS ── */
.btn-a{display:inline-flex;align-items:center;gap:.4rem;font-size:.8rem;font-weight:600;padding:.55rem 1.1rem;border-radius:var(--r-sm);transition:.2s;white-space:nowrap;cursor:pointer;font-family:inherit}
.btn-a i{font-size:.95rem}
.btn-a-primary{background:var(--blue);color:#fff;border:none}
.btn-a-primary:hover{background:#1A6DC2;transform:translateY(-1px)}
.btn-a-outline{background:transparent;border:1.5px solid var(--border-mid);color:var(--text-300)}
.btn-a-outline:hover{border-color:var(--blue);color:var(--blue);background:var(--blue-pale)}
.btn-sm{padding:.38rem .75rem;font-size:.74rem}
.btn-urgent-a{background:rgba(229,62,62,.08);color:var(--urgent);border:1px solid rgba(229,62,62,.2)}
.btn-urgent-a:hover{background:rgba(229,62,62,.15)}
.icon-btn{width:30px;height:30px;border-radius:var(--r-sm);display:grid;place-items:center;font-size:.85rem;border:1px solid var(--border);color:var(--text-500);transition:.2s;cursor:pointer;flex-shrink:0}
.icon-btn:hover{border-color:var(--blue);color:var(--blue);background:var(--blue-pale)}
.icon-btn.blue{color:var(--blue);border-color:rgba(43,127,212,.2)}
.icon-btn.green{color:var(--green);border-color:rgba(56,161,105,.2)}
.icon-btn.red{color:var(--urgent);border-color:rgba(229,62,62,.2)}
.icon-btn.red:hover{background:rgba(229,62,62,.08);border-color:var(--urgent)}
.row-actions{display:flex;gap:.3rem}

/* ── TOOLBAR ── */
.toolbar{display:flex;align-items:center;gap:.6rem;flex-wrap:wrap;margin-bottom:1rem}
.search-box{display:flex;align-items:center;gap:.5rem;background:var(--white);border:1px solid var(--border);border-radius:var(--r-sm);padding:.45rem .8rem;flex:1;min-width:180px}
.search-box i{color:var(--text-500);font-size:1rem;flex-shrink:0}
.search-box input{border:none;background:none;font-size:.82rem;color:var(--text-100);width:100%;outline:none}
.search-box input::placeholder{color:var(--text-500)}
.adm-select{padding:.5rem .8rem;border-radius:var(--r-sm);border:1px solid var(--border);background:var(--white);font-size:.82rem;color:var(--text-100);font-family:inherit;outline:none;cursor:pointer}
.filter-pills{display:flex;gap:.4rem;flex-wrap:wrap}
.pill{font-size:.74rem;font-weight:500;padding:.38rem .8rem;border-radius:20px;border:1px solid var(--border);background:var(--white);color:var(--text-300);cursor:pointer;transition:.2s;font-family:inherit}
.pill:hover{border-color:var(--blue);color:var(--blue)}
.pill.active{background:var(--blue);color:#fff;border-color:var(--blue)}

/* ── FORM ── */
.mfield{display:flex;flex-direction:column;gap:.35rem;margin-bottom:.8rem}
.mfield label{font-size:.74rem;font-weight:600;color:var(--text-300);letter-spacing:.04em}
.minput{padding:.6rem .85rem;border-radius:var(--r-sm);border:1.5px solid var(--border);background:var(--bg);color:var(--text-100);font-family:inherit;font-size:.84rem;transition:.2s;outline:none;width:100%}
.minput:focus{border-color:var(--blue);background:var(--white)}
.minput::placeholder{color:var(--text-500)}
select.minput{cursor:pointer}
textarea.minput{resize:vertical;min-height:65px}
.mrow{display:grid;gap:.7rem}
.mrow-2{grid-template-columns:1fr 1fr}
.mrow-3{grid-template-columns:1fr 1fr 1fr}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:.7rem}

/* ── MODAL ── */
.modal-bg{position:fixed;inset:0;z-index:300;background:rgba(10,22,40,.5);backdrop-filter:blur(4px);display:flex;align-items:flex-end;justify-content:center;padding:0}
@media(min-width:600px){.modal-bg{align-items:center;padding:1rem}}
.modal{background:var(--white);border-radius:var(--r) var(--r) 0 0;width:100%;max-width:560px;max-height:90dvh;display:flex;flex-direction:column;box-shadow:0 20px 60px rgba(10,22,40,.3)}
@media(min-width:600px){.modal{border-radius:var(--r);max-height:85vh}}
.modal-head{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.2rem;border-bottom:1px solid var(--border);flex-shrink:0}
.modal-head h3{font-size:.95rem;font-weight:700;color:var(--text-100)}
.modal-close{font-size:1.1rem;color:var(--text-500);width:30px;height:30px;border-radius:var(--r-sm);display:grid;place-items:center;transition:.2s}
.modal-close:hover{background:var(--bg);color:var(--text-100)}
.modal-body{flex:1;overflow-y:auto;padding:1.2rem}
.modal-foot{display:flex;justify-content:flex-end;gap:.6rem;padding:.9rem 1.2rem;border-top:1px solid var(--border);flex-shrink:0}

/* ── TOAST ── */
.toast{position:fixed;bottom:20px;left:50%;transform:translate(-50%,120%);z-index:500;background:var(--navy);border:1px solid rgba(255,255,255,.1);color:#fff;padding:.7rem 1.2rem;border-radius:var(--r-sm);font-size:.82rem;box-shadow:var(--shadow-md);transition:transform .35s var(--ease);display:flex;align-items:center;gap:.5rem;white-space:nowrap}
.toast.show{transform:translate(-50%,0)}
.toast i{color:var(--blue-light)}

/* ── TOGGLE ── */
.toggle{width:38px;height:21px;border-radius:20px;background:var(--border-mid);position:relative;transition:.25s;cursor:pointer;flex-shrink:0}
.toggle::after{content:'';position:absolute;left:2px;top:2px;width:17px;height:17px;border-radius:50%;background:#fff;transition:.25s;box-shadow:0 1px 4px rgba(0,0,0,.15)}
.toggle.on{background:var(--blue)}
.toggle.on::after{left:19px}
.toggle-wrap{display:flex;align-items:center;gap:.8rem;padding:.7rem 0;border-bottom:1px solid var(--border)}
.toggle-wrap:last-child{border-bottom:none}
.toggle-label{display:flex;align-items:center;gap:.5rem;font-size:.84rem;color:var(--text-100)}

/* ── DOCTOR CARDS (admin) ── */
.doc-card{background:var(--white);border:1px solid var(--border);border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow-sm)}
.doc-card-photo{height:180px;background-size:cover;background-position:center top;position:relative}
.doc-card-photo .ovr{position:absolute;inset:0;background:rgba(10,22,40,.5);opacity:0;transition:.2s;display:flex;align-items:center;justify-content:center;gap:.5rem}
.doc-card:hover .doc-card-photo .ovr{opacity:1}
.doc-card-body{padding:1rem}
.doc-card-name{font-weight:700;font-size:.9rem;margin-bottom:.2rem}
.doc-card-role{font-size:.72rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;margin-bottom:.6rem}
.doc-card-meta{font-size:.74rem;color:var(--text-500);display:flex;gap:.8rem;margin-bottom:.7rem;flex-wrap:wrap}
.doc-card-meta span{display:flex;align-items:center;gap:.3rem}
.doc-card-foot{display:flex;align-items:center;justify-content:space-between;gap:.5rem}

/* ── SERVICE CARDS (admin) ── */
.svc-card-a{background:var(--white);border:1px solid var(--border);border-radius:var(--r);padding:1rem;box-shadow:var(--shadow-sm)}
.svc-card-a-head{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:.3rem}
.svc-card-a-name{font-weight:700;font-size:.88rem;color:var(--text-100)}
.svc-card-a-price{font-size:1.2rem;font-weight:700;color:var(--blue)}
.svc-card-a-kela{font-size:.72rem;color:var(--teal);margin-bottom:.3rem}
.svc-card-a-tr{font-size:.74rem;color:var(--text-500);display:flex;align-items:center;gap:.3rem;margin-bottom:.4rem}
.svc-card-a-desc{font-size:.78rem;color:var(--text-300);margin-bottom:.6rem;line-height:1.5}
.svc-card-a-dur{font-size:.72rem;color:var(--text-500);display:flex;align-items:center;gap:.3rem;margin-bottom:.7rem}
.svc-card-a-foot{display:flex;align-items:center;justify-content:space-between;gap:.4rem}

/* ── REVENUE BARS ── */
.rev-row{display:flex;align-items:center;gap:.7rem;margin-bottom:.7rem;font-size:.82rem}
.rev-name{min-width:70px;font-weight:500;color:var(--text-100)}
.rev-bar-wrap{flex:1;background:var(--bg-2);border-radius:4px;height:8px;overflow:hidden}
.rev-bar{height:100%;border-radius:4px;transition:width .6s var(--ease)}
.rev-val{min-width:80px;text-align:right;font-size:.78rem;color:var(--text-500)}

/* ── ANALYTICS ── */
.an-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:.8rem;margin-bottom:1rem}
.chart-box{background:var(--white);border-radius:var(--r);border:1px solid var(--border);padding:1.2rem;box-shadow:var(--shadow-sm);margin-bottom:.8rem}
.bars{display:flex;align-items:flex-end;gap:3px;height:80px;margin-top:.8rem}
.bar{flex:1;background:var(--blue-pale);border-radius:3px 3px 0 0;transition:background .2s;min-height:4px}
.bar:hover{background:var(--blue)}
.src-row{display:flex;align-items:center;gap:.7rem;margin-bottom:.7rem;font-size:.82rem}
.src-bar-wrap{flex:1;background:var(--bg-2);border-radius:4px;height:7px;overflow:hidden}
.src-bar{height:100%;background:var(--blue);border-radius:4px}

/* ── GALLERY ── */
.gal-toolbar{display:flex;gap:.6rem;align-items:center;margin-bottom:.9rem;flex-wrap:wrap}
.gal-toolbar input{flex:1;min-width:200px}
.gal-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:.6rem}
.gal-item{border-radius:var(--r-sm);overflow:hidden;position:relative;aspect-ratio:4/3;background:var(--bg-2)}
.gal-item img{width:100%;height:100%;object-fit:cover}
.gal-del{position:absolute;top:5px;right:5px;width:24px;height:24px;border-radius:50%;background:rgba(10,22,40,.7);color:#fff;display:grid;place-items:center;font-size:.75rem;transition:.2s;cursor:pointer}
.gal-del:hover{background:var(--urgent)}

/* ══ CALENDAR (Lumière style) ══ */
.cal-outer{display:grid;grid-template-columns:1fr 340px;gap:1rem;align-items:start}
.cal-left{display:flex;flex-direction:column;gap:.8rem}
.cal-doc-tabs{display:flex;flex-wrap:wrap;gap:.4rem}
.cal-wrap{background:var(--white);border:1px solid var(--border);border-radius:var(--r);padding:1.2rem;box-shadow:var(--shadow-sm)}
.cal-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}
.cal-title{font-weight:700;font-size:.95rem;color:var(--text-100)}
.cal-arrow{width:30px;height:30px;border-radius:50%;border:1px solid var(--border);display:grid;place-items:center;font-size:.9rem;color:var(--text-300);cursor:pointer;transition:.2s}
.cal-arrow:hover{background:var(--blue);color:#fff;border-color:var(--blue)}
.cal-dow{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;margin-bottom:6px}
.cal-dow div{text-align:center;font-size:.66rem;font-weight:600;color:var(--text-500);padding:.25rem 0;letter-spacing:.06em}
.cal-days{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;margin-bottom:.9rem}
.cal-cell{aspect-ratio:1;border-radius:50%;display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;border:2px solid transparent;transition:background .15s,border-color .15s;font-size:.82rem;color:var(--text-300);position:relative;user-select:none}
.cal-cell:hover{background:var(--blue-pale);color:var(--blue)}
.cal-cell.is-today{color:var(--blue);font-weight:700}
.cal-cell.is-sel{background:var(--blue);color:#fff;font-weight:700}
.cal-cell.is-sel:hover{background:#1A6DC2}
.cal-cell.is-empty{cursor:default;pointer-events:none}
.cal-cell.is-past{opacity:.4}
.cal-dots{display:flex;gap:2px;position:absolute;bottom:3px}
.cal-dot{width:5px;height:5px;border-radius:50%}
.cal-dot-free{background:var(--blue)}
.cal-dot-booked{background:var(--urgent)}
.cal-legend{display:flex;gap:1rem;font-size:.72rem;color:var(--text-500);flex-wrap:wrap;margin-bottom:.8rem}
.cal-legend span{display:flex;align-items:center;gap:.35rem}
.cal-legend .cal-dot{position:static}
.cal-create-month{width:100%;justify-content:center;font-size:.78rem}

/* ── DAY PANEL ── */
.day-panel{background:var(--white);border:1px solid var(--border);border-radius:var(--r);padding:1.2rem;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:.9rem;position:sticky;top:calc(var(--banner-h) + var(--topbar-h) + 1rem)}
.dp-head{padding-bottom:.8rem;border-bottom:1px solid var(--border)}
.dp-date{font-size:1rem;font-weight:700;color:var(--text-100)}
.dp-who{font-size:.76rem;color:var(--text-500);margin-top:.2rem}
.dp-stats{display:flex;gap:.8rem;margin-top:.4rem;font-size:.76rem}
.dp-free{color:var(--blue);font-weight:600}
.dp-booked{color:var(--urgent);font-weight:600}
.dp-add-row{display:flex;gap:.5rem;align-items:center}
.dp-time-input{flex:1;padding:.5rem .7rem;border-radius:var(--r-sm);border:1.5px solid var(--border);font-size:.84rem;font-family:inherit;outline:none;background:var(--bg);transition:.2s}
.dp-time-input:focus{border-color:var(--blue);background:var(--white)}
.dp-presets{display:flex;flex-wrap:wrap;gap:.35rem}
.dp-preset{font-size:.72rem;padding:.3rem .65rem;border-radius:var(--r-sm);border:1px solid var(--border);background:var(--bg);color:var(--text-300);cursor:pointer;transition:.2s;font-family:inherit}
.dp-preset:hover{border-color:var(--blue);color:var(--blue);background:var(--blue-pale)}
.dp-preset-clear{color:rgba(229,62,62,.7);border-color:rgba(229,62,62,.2)}
.dp-preset-clear:hover{background:rgba(229,62,62,.06);border-color:var(--urgent);color:var(--urgent)}
.dp-slots{display:flex;flex-direction:column;gap:.3rem;max-height:300px;overflow-y:auto}
.dp-slot{display:flex;align-items:center;gap:.5rem;padding:.42rem .65rem;border-radius:var(--r-sm);background:var(--bg);font-size:.8rem;border:1.5px solid var(--border);transition:.15s}
.dp-slot.is-booked{background:rgba(229,62,62,.04);border-color:rgba(229,62,62,.15)}
.dp-slot.is-free:hover{border-color:var(--blue);background:var(--blue-pale)}
.dp-slot-time{font-weight:700;color:var(--text-100);min-width:44px}
.dp-slot-label{flex:1;font-size:.76rem}
.dp-slot-label.free-lbl{color:var(--text-500);font-style:italic}
.dp-slot-label.booked-lbl{color:var(--urgent)}
.dp-slot-del{width:20px;height:20px;border-radius:4px;display:grid;place-items:center;font-size:.7rem;color:rgba(229,62,62,.4);cursor:pointer;transition:.2s}
.dp-slot-del:hover{background:rgba(229,62,62,.1);color:var(--urgent)}
.dp-no-slots{color:var(--text-500);font-size:.82rem;text-align:center;padding:1rem;border:1.5px dashed var(--border);border-radius:var(--r-sm)}
.dp-no-day{color:var(--text-500);font-size:.84rem;text-align:center;padding:2.5rem 1rem}
.dp-bookings{border-top:1px solid var(--border);padding-top:.8rem}
.dp-bookings-label{font-size:.68rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--text-500);margin-bottom:.5rem}
.dp-booking-row{display:flex;align-items:center;gap:.5rem;padding:.38rem 0;border-bottom:1px solid var(--border);font-size:.78rem}
.dp-booking-row:last-child{border-bottom:none}

/* ── PATIENTS ── */
.pat-card{background:var(--white);border:1px solid var(--border);border-radius:var(--r);padding:1rem;box-shadow:var(--shadow-sm)}
.pat-avatar{width:42px;height:42px;border-radius:50%;display:grid;place-items:center;font-weight:700;font-size:.88rem;color:#fff;flex-shrink:0}
.pat-name{font-weight:700;font-size:.88rem}
.pat-meta{font-size:.74rem;color:var(--text-500)}
.pat-history{margin-top:.8rem;display:flex;flex-direction:column;gap:.3rem}
.pat-visit{display:flex;align-items:center;justify-content:space-between;font-size:.76rem;padding:.35rem .6rem;background:var(--bg);border-radius:var(--r-sm)}

/* ── SETTINGS ── */
.set-tabs{display:flex;gap:.4rem;flex-wrap:wrap;margin-bottom:1rem}
.set-tab{font-size:.78rem;font-weight:600;padding:.48rem .9rem;border-radius:var(--r-sm);border:1.5px solid var(--border);background:var(--white);color:var(--text-300);cursor:pointer;transition:.2s;font-family:inherit}
.set-tab:hover{border-color:var(--blue);color:var(--blue)}
.set-tab.active{background:var(--blue);color:#fff;border-color:var(--blue)}
.set-pane{display:none}
.set-pane.active{display:block}
.int-card{background:var(--white);border:1px solid var(--border);border-radius:var(--r);padding:1rem;margin-bottom:.8rem;box-shadow:var(--shadow-sm)}
.int-head{display:flex;align-items:flex-start;gap:.8rem;margin-bottom:.8rem}
.int-logo{width:38px;height:38px;border-radius:var(--r-sm);display:grid;place-items:center;font-size:1.2rem;flex-shrink:0}
.int-title-row{flex:1}
.int-name{font-weight:700;font-size:.86rem;color:var(--text-100);display:flex;align-items:center;gap:.5rem}
.int-desc{font-size:.76rem;color:var(--text-500);margin-top:.15rem}
.int-status{font-size:.62rem;font-weight:600;padding:.15rem .5rem;border-radius:4px;background:rgba(56,161,105,.1);color:var(--green);letter-spacing:.08em}
.int-fields{display:grid;grid-template-columns:1fr 1fr;gap:.6rem}
.int-fields .field{display:flex;flex-direction:column;gap:.3rem}
.int-fields label{font-size:.7rem;font-weight:600;color:var(--text-500)}
.int-fields input{padding:.5rem .7rem;border-radius:var(--r-sm);border:1.5px solid var(--border);font-size:.8rem;font-family:inherit;background:var(--bg);outline:none;transition:.2s}
.int-fields input:focus{border-color:var(--blue);background:var(--white)}
/* Kela toggle special */
.kela-toggle-card{background:var(--blue-pale);border:1.5px solid var(--border-mid);border-radius:var(--r);padding:1rem;margin-bottom:1rem}
.kela-toggle-head{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:.6rem}
.kela-toggle-title{font-weight:700;font-size:.9rem;color:var(--text-100)}
.kela-toggle-sub{font-size:.78rem;color:var(--text-300)}
.kela-fields{display:grid;grid-template-columns:1fr 1fr;gap:.6rem;margin-top:.8rem}
.kela-fields .mfield{margin-bottom:0}

/* ── SCH TOOLBAR ── */
.sch-toolbar{display:flex;align-items:center;gap:.6rem;flex-wrap:wrap;margin-bottom:.8rem}

/* ── RESPONSIVE ── */
@media(max-width:1200px){.stat-grid,.an-grid{grid-template-columns:repeat(2,1fr)}.adm-grid{grid-template-columns:repeat(2,1fr)}.grid-2{grid-template-columns:1fr}.cal-outer{grid-template-columns:1fr}.day-panel{position:static}}
@media(max-width:860px){
  .sidebar{transform:translateX(-100%);transition:transform .3s var(--ease)}
  .sidebar.open{transform:none;box-shadow:4px 0 30px rgba(10,22,40,.3)}
  .sidebar-overlay.show{display:block}
  .main{margin-left:0}
  .topbar-burger{display:grid}
  .mrow-2,.mrow-3,.form-grid,.int-fields,.kela-fields{grid-template-columns:1fr}
  .content{padding:1rem}
}
@media(max-width:600px){
  .stat-grid,.an-grid{grid-template-columns:1fr 1fr}
  .adm-grid{grid-template-columns:1fr}
  .gal-grid{grid-template-columns:repeat(2,1fr)}
  .topbar-site span{display:none}
  .demo-badge{display:none}
  .table-wrap{font-size:.76rem}
  th,td{padding:.5rem .6rem}
}
