/* ═══════════════════════════════════════
   LOISTO SIIVOUS ADMIN — admin.css
   Sky Blue theme matching main site
   ═══════════════════════════════════════ */

@import url('https://fonts.googleapis.com/css2?family=DM+Sans:ital,opsz,wght@0,9..40,300;0,9..40,400;0,9..40,500;0,9..40,600;0,9..40,700&display=swap');

:root {
  --navy:       #1E2A3B;
  --sky:        #0EA5E9;
  --sky-l:      #7DD3FC;
  --sky-pale:   #E0F2FE;
  --amber:      #F59E0B;
  --emerald:    #10B981;
  --violet:     #8B5CF6;
  --urgent:     #EF4444;
  --ok:         #10B981;
  --bg:         #F4F7FB;
  --bg-2:       #EAF0F8;
  --white:      #FFFFFF;
  --border:     rgba(14,165,233,.12);
  --border-mid: rgba(14,165,233,.22);
  --text-100:   #1E2A3B;
  --text-300:   #4A5B6E;
  --text-500:   #94A3B8;
  --shadow-sm:  0 2px 8px rgba(30,42,59,.07);
  --shadow-md:  0 4px 20px rgba(30,42,59,.10);
  --font:       'DM Sans', sans-serif;
  --r:          8px; --r-sm: 5px;
  --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(--sky);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:var(--amber);box-shadow:0 0 8px var(--amber)}
.adm-banner b{color:#fff;font-weight:600}
.adm-banner a{color:var(--sky-l);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(--sky);
  display:grid;place-items:center;font-size:1rem;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(--sky-l)}
.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;
  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(14,165,233,.18)}
.sidebar-nav-item.active::before{content:'';position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--sky);border-radius:0 2px 2px 0}
.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(30,42,59,.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:.7rem}
.topbar-burger{display:none;font-size:1.2rem;color:var(--text-300);padding:.3rem}
.topbar-title{font-size:.95rem;font-weight:700;color:var(--text-100)}
.topbar-right{display:flex;align-items:center;gap:.8rem}
.online{display:flex;align-items:center;gap:.4rem;font-size:.74rem;color:var(--text-500)}
.online .dot{width:7px;height:7px;border-radius:50%;background:var(--ok);box-shadow:0 0 6px var(--ok)}
.demo-badge{padding:.18rem .55rem;border-radius:4px;background:var(--amber);color:var(--navy);font-size:.64rem;font-weight:800;letter-spacing:.08em}
.adm-lang{display:flex;gap:.2rem}
.adm-lb{padding:.22rem .42rem;border-radius:4px;font-size:.7rem;font-weight:700;color:var(--text-500);border:1px solid transparent;transition:.15s}
.adm-lb:hover{color:var(--text-100)}
.adm-lb.adm-lb-active{color:var(--sky);border-color:var(--border-mid);background:var(--sky-pale)}
.topbar-site{display:flex;align-items:center;gap:.3rem;font-size:.76rem;font-weight:600;color:var(--sky);padding:.3rem .7rem;border-radius:var(--r-sm);border:1px solid var(--border);transition:.15s}
.topbar-site:hover{background:var(--sky-pale)}

/* ── CONTENT ── */
.content{flex:1;padding:1.4rem;display:flex;flex-direction:column;gap:1.2rem}

/* ── CARDS ── */
.card{background:var(--white);border-radius:var(--r);padding:1.2rem 1.4rem;border:1px solid var(--border);box-shadow:var(--shadow-sm)}
.card-title{font-size:.85rem;font-weight:700;color:var(--text-100);margin-bottom:1rem;display:flex;align-items:center;gap:.5rem}
.card-title i{color:var(--sky)}
.section-sub{font-size:.78rem;color:var(--text-500);background:var(--sky-pale);border:1px solid var(--border);border-radius:var(--r-sm);padding:.6rem .9rem;display:flex;align-items:center;gap:.5rem}
.section-sub i{color:var(--sky)}

/* ── STAT GRID ── */
.stat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:1rem}
.stat-card{background:var(--white);border-radius:var(--r);padding:1.2rem;border:1px solid var(--border);box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:.5rem}
.stat-card .ic{width:38px;height:38px;border-radius:var(--r-sm);display:grid;place-items:center;font-size:1.1rem;flex-shrink:0}
.stat-card-value{font-family:var(--font);font-size:1.7rem;font-weight:700;color:var(--text-100);letter-spacing:-.03em;line-height:1}
.stat-card-value small{font-size:.85rem;font-weight:500;color:var(--text-500)}
.stat-card-label{font-size:.73rem;color:var(--text-500);font-weight:500}

/* ── GRID ── */
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.an-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:1rem}
.adm-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1rem}

/* ── TOOLBAR ── */
.toolbar{display:flex;align-items:center;gap:.7rem;flex-wrap:wrap}
.search-box{display:flex;align-items:center;gap:.5rem;padding:.4rem .8rem;border-radius:var(--r-sm);border:1.5px solid var(--border-mid);background:var(--bg);flex:1;min-width:180px}
.search-box i{color:var(--text-500);font-size:.9rem}
.search-box input{border:none;background:none;outline:none;font-size:.82rem;color:var(--text-100);width:100%}
.adm-select{padding:.4rem .7rem;border-radius:var(--r-sm);border:1.5px solid var(--border-mid);background:var(--white);font-size:.8rem;color:var(--text-100);outline:none}
.filter-pills{display:flex;gap:.4rem;flex-wrap:wrap;margin-top:.4rem}
.pill{padding:.3rem .75rem;border-radius:20px;font-size:.76rem;font-weight:600;border:1.5px solid var(--border-mid);color:var(--text-300);background:var(--white);transition:.15s;cursor:pointer}
.pill:hover{border-color:var(--sky);color:var(--sky)}
.pill.active{background:var(--sky);border-color:var(--sky);color:#fff}

/* ── BUTTONS ── */
.btn-a{display:inline-flex;align-items:center;gap:.4rem;padding:.45rem 1rem;border-radius:var(--r-sm);font-size:.8rem;font-weight:600;cursor:pointer;transition:.15s;border:1.5px solid transparent}
.btn-a-primary{background:var(--sky);color:#fff;border-color:var(--sky)}
.btn-a-primary:hover{background:#0284C7;border-color:#0284C7}
.btn-a-outline{background:var(--white);color:var(--text-300);border-color:var(--border-mid)}
.btn-a-outline:hover{border-color:var(--sky);color:var(--sky)}
.btn-sm{padding:.28rem .65rem;font-size:.74rem}
.icon-btn{width:30px;height:30px;border-radius:var(--r-sm);display:grid;place-items:center;font-size:.85rem;border:1px solid var(--border);background:var(--bg);color:var(--text-300);transition:.15s;cursor:pointer}
.icon-btn:hover{background:var(--bg-2)}
.icon-btn.green{color:var(--ok);border-color:rgba(16,185,129,.2);background:rgba(16,185,129,.06)}
.icon-btn.blue{color:var(--sky);border-color:rgba(14,165,233,.2);background:rgba(14,165,233,.06)}
.icon-btn.red{color:var(--urgent);border-color:rgba(239,68,68,.2);background:rgba(239,68,68,.06)}
.row-actions{display:flex;gap:.3rem}

/* ── BADGES ── */
.badge{display:inline-flex;align-items:center;padding:.15rem .5rem;border-radius:20px;font-size:.66rem;font-weight:700;letter-spacing:.02em}
.b-new{background:#DBEAFE;color:#1E40AF}
.b-confirmed{background:#D1FAE5;color:#065F46}
.b-done{background:#F3F4F6;color:#6B7280}
.b-cancelled{background:#FEE2E2;color:#991B1B}
.b-urgent{background:rgba(239,68,68,.12);color:var(--urgent)}
.b-active{background:#D1FAE5;color:#065F46}
.b-inactive{background:#F3F4F6;color:#6B7280}

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

/* ── REV BARS ── */
.rev-row{display:flex;align-items:center;gap:.7rem;padding:.5rem 0;border-bottom:1px solid var(--border)}
.rev-row:last-child{border-bottom:none}
.rev-name{font-size:.8rem;font-weight:600;width:72px;flex-shrink:0}
.rev-bar-wrap{flex:1;height:8px;background:var(--bg-2);border-radius:4px;overflow:hidden}
.rev-bar{height:100%;border-radius:4px;transition:width .6s var(--ease)}
.rev-val{font-size:.74rem;font-weight:600;color:var(--text-300);white-space:nowrap}

/* ── CALENDAR ── */
.sch-toolbar{display:flex;align-items:center;gap:.7rem;flex-wrap:wrap;margin-bottom:1rem}
.cal-doc-tabs{display:flex;gap:.4rem;flex-wrap:wrap}
.cal-outer{display:grid;grid-template-columns:320px 1fr;gap:1.2rem;align-items:start}
.cal-wrap{background:var(--white);border-radius:var(--r);border:1px solid var(--border);padding:1rem;box-shadow:var(--shadow-sm)}
.cal-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:.7rem}
.cal-title{font-size:.9rem;font-weight:700}
.cal-arrow{width:28px;height:28px;border-radius:var(--r-sm);border:1px solid var(--border);display:grid;place-items:center;font-size:.8rem;color:var(--text-300);transition:.15s;cursor:pointer;background:var(--bg)}
.cal-arrow:hover{border-color:var(--sky);color:var(--sky)}
.cal-legend{display:flex;gap:.8rem;margin-bottom:.6rem}
.cal-legend span{font-size:.68rem;color:var(--text-500);display:flex;align-items:center;gap:.3rem}
.cal-dot{width:7px;height:7px;border-radius:50%;display:inline-block;flex-shrink:0}
.cal-dot-free{background:var(--sky)}
.cal-dot-booked{background:var(--urgent)}
.cal-dow{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;margin-bottom:4px}
.cal-dow div{text-align:center;font-size:.62rem;font-weight:700;color:var(--text-500);padding:.2rem 0}
.cal-days{display:grid;grid-template-columns:repeat(7,1fr);gap:3px}
.cal-cell{
  aspect-ratio:1;border-radius:var(--r-sm);display:flex;flex-direction:column;align-items:center;justify-content:center;
  font-size:.78rem;font-weight:500;cursor:pointer;transition:.15s;position:relative;border:1.5px solid transparent;
}
.cal-cell:hover:not(.is-empty):not(.is-past){background:var(--sky-pale);border-color:var(--border-mid)}
.cal-cell.is-today{background:var(--sky-pale);color:var(--sky);font-weight:700;border-color:var(--sky)}
.cal-cell.is-sel{background:var(--sky)!important;color:#fff!important;border-color:var(--sky)!important}
.cal-cell.is-past{color:var(--text-500);cursor:default}
.cal-cell.is-empty{cursor:default}
.cal-dots{display:flex;gap:2px;margin-top:2px}
.cal-create-month{width:100%;margin-top:.8rem;border-radius:var(--r-sm);padding:.45rem;font-size:.76rem;font-weight:600;color:var(--sky);border:1.5px dashed var(--border-mid);background:var(--sky-pale);display:flex;align-items:center;justify-content:center;gap:.4rem;transition:.15s;cursor:pointer}
.cal-create-month:hover{background:var(--sky);color:#fff;border-color:var(--sky)}

/* ── DAY PANEL ── */
.day-panel{background:var(--white);border-radius:var(--r);border:1px solid var(--border);padding:1.2rem;box-shadow:var(--shadow-sm);min-height:300px}
.dp-no-day{text-align:center;color:var(--text-500);font-size:.84rem;padding:2rem 1rem}
.dp-head{margin-bottom:.9rem;padding-bottom:.7rem;border-bottom:1px solid var(--border)}
.dp-date{font-size:1.1rem;font-weight:700}
.dp-who{font-size:.78rem;color:var(--text-500);margin:.2rem 0 .5rem}
.dp-stats{display:flex;gap:.7rem}
.dp-free,.dp-booked{font-size:.75rem;font-weight:600;display:flex;align-items:center;gap:.3rem}
.dp-free{color:var(--sky)}
.dp-booked{color:var(--urgent)}
.dp-add-row{display:flex;gap:.5rem;align-items:center;margin-bottom:.6rem}
.dp-time-input{padding:.4rem .6rem;border-radius:var(--r-sm);border:1.5px solid var(--border-mid);font-size:.84rem;font-family:inherit;outline:none;flex:1}
.dp-time-input:focus{border-color:var(--sky)}
.dp-presets{display:flex;gap:.35rem;flex-wrap:wrap;margin-bottom:.9rem}
.dp-preset{padding:.28rem .65rem;border-radius:var(--r-sm);font-size:.72rem;font-weight:600;border:1.5px solid var(--border-mid);background:var(--bg);color:var(--text-300);cursor:pointer;transition:.15s}
.dp-preset:hover{border-color:var(--sky);color:var(--sky)}
.dp-preset-clear{border-color:rgba(239,68,68,.2);color:var(--urgent)}
.dp-preset-clear:hover{background:var(--urgent);border-color:var(--urgent);color:#fff}
.dp-slots{display:flex;flex-direction:column;gap:.35rem;max-height:260px;overflow-y:auto}
.dp-slot{display:flex;align-items:center;gap:.6rem;padding:.4rem .6rem;border-radius:var(--r-sm);border:1px solid var(--border)}
.dp-slot.is-free{background:rgba(14,165,233,.04);border-color:rgba(14,165,233,.18)}
.dp-slot.is-booked{background:rgba(239,68,68,.04);border-color:rgba(239,68,68,.15)}
.dp-slot-time{font-size:.84rem;font-weight:700;min-width:42px}
.dp-slot-label{flex:1;font-size:.76rem}
.free-lbl{color:var(--sky)}
.booked-lbl{font-weight:600}
.dp-slot-del{margin-left:auto;width:22px;height:22px;border-radius:50%;background:rgba(239,68,68,.1);color:var(--urgent);display:grid;place-items:center;font-size:.7rem;cursor:pointer;border:none;transition:.15s}
.dp-slot-del:hover{background:var(--urgent);color:#fff}
.dp-no-slots{font-size:.78rem;color:var(--text-500);text-align:center;padding:.7rem}
.dp-bookings{margin-top:1rem;padding-top:.8rem;border-top:1px solid var(--border)}
.dp-bookings-label{font-size:.7rem;font-weight:700;color:var(--text-500);letter-spacing:.08em;text-transform:uppercase;margin-bottom:.5rem}
.dp-booking-row{display:flex;align-items:center;gap:.5rem;padding:.4rem 0;border-bottom:1px solid var(--border);font-size:.8rem}
.dp-booking-row:last-child{border-bottom:none}

/* ── DOCTOR / SERVICE CARDS ── */
.doc-card{background:var(--white);border-radius:var(--r);border:1px solid var(--border);overflow:hidden;box-shadow:var(--shadow-sm)}
.doc-card-photo{height:140px;background:var(--bg-2) center/cover no-repeat;position:relative}
.doc-card-photo .ovr{position:absolute;inset:0;background:rgba(30,42,59,.4);display:flex;align-items:center;justify-content:center;gap:.5rem;opacity:0;transition:.2s}
.doc-card:hover .ovr{opacity:1}
.doc-card-body{padding:1rem}
.doc-card-name{font-size:.9rem;font-weight:700;margin-bottom:.2rem}
.doc-card-role{font-size:.74rem;font-weight:600;margin-bottom:.5rem}
.doc-card-meta{display:flex;gap:.5rem;flex-wrap:wrap;font-size:.72rem;color:var(--text-300);margin-bottom:.7rem}
.doc-card-meta span{display:flex;align-items:center;gap:.25rem}
.doc-card-foot{display:flex;align-items:center;justify-content:space-between}

.svc-card-a{background:var(--white);border-radius:var(--r);border:1px solid var(--border);border-top:3px solid var(--sky);padding:1rem;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:.5rem}
.svc-card-a-head{display:flex;justify-content:space-between;align-items:flex-start;gap:.5rem}
.svc-card-a-name{font-size:.9rem;font-weight:700}
.svc-card-a-price{font-size:.9rem;font-weight:700;color:var(--sky);white-space:nowrap}
.svc-card-a-tr{font-size:.74rem;font-weight:600;display:flex;align-items:center;gap:.3rem}
.svc-card-a-desc{font-size:.78rem;color:var(--text-300);line-height:1.5;flex:1}
.svc-card-a-dur{font-size:.72rem;color:var(--text-500);display:flex;align-items:center;gap:.3rem}
.svc-card-a-foot{display:flex;align-items:center;justify-content:space-between;margin-top:.3rem}

/* ── PATIENT CARDS ── */
.pat-card{background:var(--white);border-radius:var(--r);border:1px solid var(--border);padding:1rem;box-shadow:var(--shadow-sm)}
.pat-avatar{width:40px;height:40px;border-radius:50%;display:grid;place-items:center;font-size:.78rem;font-weight:700;color:#fff;flex-shrink:0}
.pat-name{font-size:.88rem;font-weight:700}
.pat-meta{font-size:.72rem;color:var(--text-500)}
.pat-history{display:flex;flex-direction:column;gap:.3rem}
.pat-visit{display:flex;gap:.6rem;font-size:.76rem;padding:.3rem 0;border-bottom:1px solid var(--border)}
.pat-visit:last-child{border-bottom:none}

/* ── GALLERY ── */
.gal-toolbar{display:flex;gap:.6rem;margin-bottom:1rem}
.gal-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:.7rem}
.gal-item{border-radius:var(--r-sm);overflow:hidden;aspect-ratio:4/3;position:relative;background:var(--bg-2)}
.gal-item img{width:100%;height:100%;object-fit:cover}
.gal-del{position:absolute;top:.4rem;right:.4rem;width:24px;height:24px;border-radius:50%;background:rgba(239,68,68,.85);color:#fff;display:grid;place-items:center;font-size:.7rem;cursor:pointer;border:none;transition:.15s;opacity:0}
.gal-item:hover .gal-del{opacity:1}

/* ── ANALYTICS ── */
.chart-box{background:var(--white);border-radius:var(--r);border:1px solid var(--border);padding:1.2rem;box-shadow:var(--shadow-sm)}
.bars{display:flex;align-items:flex-end;gap:3px;height:120px;margin-top:.8rem}
.bar{flex:1;background:var(--sky);border-radius:3px 3px 0 0;opacity:.75;transition:opacity .2s}
.bar:hover{opacity:1}

/* ── SETTINGS ── */
.set-tabs{display:flex;gap:.5rem;margin-bottom:1.2rem}
.set-tab{padding:.4rem 1rem;border-radius:var(--r-sm);font-size:.8rem;font-weight:600;border:1.5px solid var(--border-mid);color:var(--text-300);background:var(--white);cursor:pointer;transition:.15s}
.set-tab:hover{border-color:var(--sky);color:var(--sky)}
.set-tab.active{background:var(--sky);border-color:var(--sky);color:#fff}
.set-pane{display:none}
.set-pane.active{display:flex;flex-direction:column;gap:1rem}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:.8rem;margin-bottom:1rem}

/* Insurance toggle repurposed as eco toggle */
.ins-toggle-card{background:var(--white);border-radius:var(--r);border:1px solid var(--border);padding:1rem 1.2rem;box-shadow:var(--shadow-sm)}
.ins-toggle-head{display:flex;align-items:center;justify-content:space-between;gap:1rem}
.ins-toggle-title{font-size:.85rem;font-weight:700;display:flex;align-items:center;gap:.4rem;margin-bottom:.2rem}
.ins-toggle-sub{font-size:.74rem;color:var(--text-500)}

/* Toggle switch */
.toggle{width:40px;height:22px;border-radius:11px;background:var(--text-500);position:relative;transition:.25s;flex-shrink:0;cursor:pointer}
.toggle::after{content:'';position:absolute;width:16px;height:16px;border-radius:50%;background:#fff;top:3px;left:3px;transition:.25s}
.toggle.on{background:var(--sky)}
.toggle.on::after{left:21px}

/* Integrations */
.int-card{background:var(--white);border-radius:var(--r);border:1px solid var(--border);padding:1rem 1.2rem;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:.8rem}
.int-head{display:flex;align-items:flex-start;gap:.8rem}
.int-logo{width:36px;height:36px;border-radius:var(--r-sm);display:grid;place-items:center;font-size:1.1rem;flex-shrink:0}
.int-title-row{flex:1}
.int-name{font-size:.84rem;font-weight:700;display:flex;align-items:center;gap:.5rem}
.int-status{padding:.1rem .4rem;border-radius:4px;font-size:.6rem;font-weight:700;background:var(--amber);color:var(--navy);letter-spacing:.06em}
.int-desc{font-size:.74rem;color:var(--text-500);margin-top:.15rem}
.int-fields{display:grid;grid-template-columns:1fr 1fr;gap:.6rem}
.int-fields .field{display:flex;flex-direction:column;gap:.25rem}
.int-fields label{font-size:.7rem;font-weight:600;color:var(--text-300)}
.int-fields input{padding:.38rem .6rem;border-radius:var(--r-sm);border:1.5px solid var(--border-mid);font-size:.78rem;font-family:inherit;outline:none;background:var(--bg)}
.int-fields input:focus{border-color:var(--sky)}

/* ── MODAL ── */
.modal-bg{position:fixed;inset:0;z-index:500;background:rgba(30,42,59,.55);backdrop-filter:blur(3px);display:flex;align-items:center;justify-content:center;padding:1rem}
.modal{background:var(--white);border-radius:var(--r);width:min(560px,100%);max-height:90vh;display:flex;flex-direction:column;box-shadow:0 24px 64px rgba(0,0,0,.2)}
.modal-head{padding:1rem 1.3rem;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;flex-shrink:0}
.modal-head h3{font-size:.95rem;font-weight:700}
.modal-close{font-size:1.1rem;color:var(--text-300);transition:.2s}
.modal-close:hover{color:var(--text-100)}
.modal-body{flex:1;overflow-y:auto;padding:1.2rem 1.3rem;display:flex;flex-direction:column;gap:.7rem}
.modal-foot{padding:.9rem 1.3rem;border-top:1px solid var(--border);display:flex;gap:.6rem;justify-content:flex-end;flex-shrink:0}
.mfield{display:flex;flex-direction:column;gap:.3rem}
.mfield label{font-size:.74rem;font-weight:600;color:var(--text-300)}
.minput{padding:.45rem .7rem;border-radius:var(--r-sm);border:1.5px solid var(--border-mid);font-size:.84rem;font-family:inherit;color:var(--text-100);outline:none;background:var(--bg);width:100%}
.minput:focus{border-color:var(--sky)}
.mrow{display:flex;gap:.7rem}
.mrow-2>*{flex:1;min-width:0}

/* ── DT PICKER ── */
.dt-picker{border-radius:var(--r);border:1px solid var(--border);overflow:hidden;background:var(--bg)}
.dt-picker-tabs{display:flex;border-bottom:1px solid var(--border)}
.dt-tab{flex:1;padding:.5rem;font-size:.76rem;font-weight:600;color:var(--text-300);border-bottom:2px solid transparent;background:var(--white);transition:.15s;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:.35rem}
.dt-tab.active{color:var(--sky);border-bottom-color:var(--sky);background:var(--sky-pale)}
.mini-cal{padding:.8rem}
.mini-cal-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:.6rem}
.mini-cal-title{font-size:.8rem;font-weight:700}
.mini-cal-arrow{width:24px;height:24px;border-radius:var(--r-sm);border:1px solid var(--border);display:grid;place-items:center;font-size:.75rem;cursor:pointer;background:var(--white);transition:.15s}
.mini-cal-arrow:hover{border-color:var(--sky);color:var(--sky)}
.mini-cal-dow{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;margin-bottom:4px}
.mini-cal-dow span{text-align:center;font-size:.6rem;font-weight:700;color:var(--text-500)}
.mini-cal-days{display:grid;grid-template-columns:repeat(7,1fr);gap:2px}
.mini-day{aspect-ratio:1;display:flex;align-items:center;justify-content:center;font-size:.72rem;border-radius:4px;cursor:pointer;transition:.15s}
.mini-day:hover:not(.md-past):not(.md-empty){background:var(--sky-pale);color:var(--sky)}
.mini-day.md-today{color:var(--sky);font-weight:700}
.mini-day.md-sel{background:var(--sky)!important;color:#fff!important}
.mini-day.md-past,.mini-day.md-empty{color:var(--text-500);cursor:default}
.time-grid-wrap{padding:.8rem}
.time-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:.3rem}
.tg-slot{padding:.3rem;border-radius:var(--r-sm);font-size:.72rem;font-weight:600;border:1.5px solid var(--border-mid);background:var(--white);color:var(--text-300);cursor:pointer;text-align:center;transition:.15s}
.tg-slot:hover:not(.tg-taken){border-color:var(--sky);color:var(--sky)}
.tg-slot.tg-sel{background:var(--sky);border-color:var(--sky);color:#fff}
.tg-slot.tg-taken{opacity:.35;cursor:default;text-decoration:line-through}
.dt-result{padding:.6rem .9rem;background:var(--sky-pale);border-top:1px solid var(--border);font-size:.78rem;color:var(--sky);font-weight:600;display:flex;align-items:center;gap:.4rem}

/* ── TOAST ── */
.toast{position:fixed;bottom:1.4rem;left:50%;transform:translateX(-50%) translateY(8px);background:var(--navy);color:#fff;padding:.6rem 1.2rem;border-radius:var(--r);font-size:.8rem;font-weight:500;box-shadow:0 8px 24px rgba(0,0,0,.2);opacity:0;pointer-events:none;transition:opacity .25s,transform .25s;display:flex;align-items:center;gap:.5rem;z-index:600;white-space:nowrap}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

/* ── RESPONSIVE ── */
@media(max-width:900px){
  .main{margin-left:0}
  .sidebar{transform:translateX(-100%)}
  .sidebar.open{transform:none;box-shadow:4px 0 20px rgba(0,0,0,.15)}
  .topbar-burger{display:block}
  .cal-outer{grid-template-columns:1fr}
  .grid-2{grid-template-columns:1fr}
  .form-grid{grid-template-columns:1fr}
  .int-fields{grid-template-columns:1fr}
}
@media(max-width:600px){
  .adm-grid{grid-template-columns:1fr}
  .stat-grid{grid-template-columns:1fr 1fr}
}
