/* ── BIRKO STYLES ─────────────────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
:root{
  --bg:#f5f3ef;--bg2:#fff;--bg3:#f0ede8;--bg4:#e8e4dc;
  --border:#e2ddd5;--border2:#d4cfc5;
  --text:#2d2a24;--text2:#6b6560;--text3:#a09890;
  --amber:#f59b2b;--al:#fef3e0;--am:#fde4b0;--ad:#c97b1a;
  --coral:#f0654a;--cl:#feeae6;
  --teal:#2ab5a0;--tl:#e0f7f4;
  --blue:#4a90d9;--bl:#e8f2fc;
  --purple:#8b6fd4;--pl:#f0ebfb;
  --green:#4caf7d;--gl:#e8f7ef;
  --fh:'Outfit',sans-serif;--fb:'Nunito',sans-serif;
}
html,body{height:100%;background:var(--bg);color:var(--text);font-family:var(--fb);font-size:14px;}
.app{display:flex;height:100vh;overflow:hidden;}

/* SIDEBAR */
.sidebar{width:228px;flex-shrink:0;background:var(--bg2);border-right:1px solid var(--border);display:flex;flex-direction:column;}
.logo-area{padding:18px 18px 14px;border-bottom:1px solid var(--border);}
.logo-row{display:flex;align-items:center;gap:12px;}
.logo-char{width:46px;height:46px;flex-shrink:0;}
.logo-text{font-family:var(--fh);font-size:21px;font-weight:800;color:var(--text);}
.logo-sub{font-size:11px;color:var(--text3);margin-top:3px;}
.nav-sec{padding:14px 14px 4px;font-size:10px;font-weight:700;color:var(--text3);letter-spacing:.08em;text-transform:uppercase;}
.nav-item{display:flex;align-items:center;gap:10px;padding:9px 12px;margin:0 8px 2px;border-radius:8px;cursor:pointer;font-size:13px;font-weight:500;color:var(--text2);transition:all .13s;user-select:none;}
.nav-item:hover{background:var(--bg3);color:var(--text);}
.nav-item.active{background:var(--al);color:var(--ad);font-weight:700;}
.nav-icon{font-size:15px;width:20px;text-align:center;}
.sb-foot{margin-top:auto;padding:14px;border-top:1px solid var(--border);}
.unit-btn{width:100%;background:var(--bg3);border:1px solid var(--border);border-radius:12px;padding:10px 13px;display:flex;align-items:center;justify-content:space-between;cursor:pointer;transition:all .13s;text-align:left;}
.unit-btn:hover{border-color:var(--amber);background:var(--al);}
.unit-name{font-family:var(--fh);font-size:13px;font-weight:700;color:var(--text);}
.unit-sub{font-size:10px;color:var(--text3);margin-top:2px;}

/* MAIN */
.main{flex:1;display:flex;flex-direction:column;overflow:hidden;}
.topbar{background:var(--bg2);border-bottom:1px solid var(--border);padding:0 24px;display:flex;align-items:center;justify-content:space-between;height:60px;flex-shrink:0;}
.page-title{font-family:var(--fh);font-size:17px;font-weight:700;color:var(--text);}
.page-sub{font-size:11px;color:var(--text3);margin-top:2px;}
.topbar-right{display:flex;align-items:center;gap:9px;}
.content{flex:1;overflow-y:auto;padding:22px 24px;display:flex;flex-direction:column;gap:18px;}

/* BUTTONS & CHIPS */
.btn{padding:0 15px;height:34px;font-size:12px;font-weight:600;cursor:pointer;border:1.5px solid var(--border2);background:var(--bg2);color:var(--text2);border-radius:8px;transition:all .13s;font-family:var(--fb);}
.btn:hover{background:var(--bg3);color:var(--text);}
.btn-amber{background:var(--amber);color:#fff;border-color:var(--amber);}
.btn-amber:hover{background:var(--ad);border-color:var(--ad);}
.btn-soft{background:var(--pl);color:var(--purple);border-color:#d4c8f5;}
.btn-soft:hover{background:#e4dafc;}
.chip{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:600;padding:5px 11px;border-radius:20px;}
.chip-live{background:var(--gl);color:var(--green);}
.chip-fair{background:var(--al);color:var(--ad);}
.chip-dot{width:6px;height:6px;border-radius:50%;background:currentColor;animation:breathe 2s infinite;}
@keyframes breathe{0%,100%{opacity:1}50%{opacity:.35}}

/* PANELS */
.panel{background:var(--bg2);border:1px solid var(--border);border-radius:16px;overflow:hidden;}
.ph{padding:13px 18px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;}
.ph-title{font-family:var(--fh);font-size:14px;font-weight:700;color:var(--text);}
.ph-act{font-size:12px;font-weight:600;color:var(--ad);cursor:pointer;}
.ph-act:hover{color:var(--amber);}

/* STAT ROW */
.stat-row{display:grid;grid-template-columns:repeat(4,1fr);gap:13px;}
.sc{background:var(--bg2);border:1px solid var(--border);border-radius:14px;padding:15px 17px;}
.sc-label{font-size:10px;font-weight:700;color:var(--text3);margin-bottom:5px;text-transform:uppercase;letter-spacing:.05em;}
.sc-val{font-family:var(--fh);font-size:28px;font-weight:700;line-height:1;}
.sc-s{font-size:11px;color:var(--text3);margin-top:4px;}

/* TABS */
.tabs{display:flex;border-bottom:1px solid var(--border);background:var(--bg3);padding:0 6px;}
.tab{padding:10px 16px;font-size:12px;font-weight:600;color:var(--text3);cursor:pointer;border-bottom:2.5px solid transparent;margin-bottom:-1px;transition:all .13s;user-select:none;}
.tab:hover{color:var(--text2);}
.tab.on{color:var(--ad);border-bottom-color:var(--amber);}

/* TIMELINE */
.tl-wrap{overflow-x:auto;}
.tl-inner{min-width:1100px;}
.tl-head{display:flex;border-bottom:2px solid var(--border);background:var(--bg3);position:sticky;top:0;z-index:4;}
.tl-label-col{width:140px;flex-shrink:0;padding:8px 12px;font-size:10px;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:.06em;border-right:1px solid var(--border);}
.tl-hours{flex:1;display:grid;grid-template-columns:repeat(24,1fr);}
.tl-hr-hd{font-size:9px;font-weight:700;color:var(--text3);padding:8px 0 8px 3px;border-right:1px solid var(--border);white-space:nowrap;overflow:hidden;}
.tl-hr-hd:last-child{border-right:none;}
.tl-hr-hd.night{color:var(--purple);background:rgba(139,111,212,.05);}
.pos-window-row{display:flex;border-bottom:1px solid var(--border);height:22px;background:var(--bg3);}
.pos-window-label{width:140px;flex-shrink:0;padding:3px 12px;font-size:9px;font-weight:700;color:var(--text3);letter-spacing:.06em;text-transform:uppercase;border-right:1px solid var(--border);display:flex;align-items:center;}
.pos-window-cells{flex:1;position:relative;display:grid;grid-template-columns:repeat(24,1fr);}
.pw-cell{border-right:1px solid var(--border);height:100%;}
.pw-cell:last-child{border-right:none;}
.pw-active{position:absolute;top:2px;bottom:2px;border-radius:3px;opacity:.35;pointer-events:none;}
.pw-label{position:absolute;top:50%;transform:translateY(-50%);font-size:9px;font-weight:700;white-space:nowrap;}
.tl-row{display:flex;border-bottom:1px solid var(--border);min-height:46px;}
.tl-row:last-child{border-bottom:none;}
.tl-row:hover{background:#faf8f5;}
.tl-person{width:140px;flex-shrink:0;padding:7px 10px 7px 14px;display:flex;align-items:center;gap:8px;border-right:1px solid var(--border);}
.av{border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;flex-shrink:0;}
.pn{font-family:var(--fh);font-size:12px;font-weight:700;color:var(--text);}
.pp{font-size:10px;color:var(--text3);}
.tl-cells{flex:1;position:relative;display:grid;grid-template-columns:repeat(24,1fr);}
.tl-cell{border-right:1px solid var(--border);height:46px;}
.tl-cell:last-child{border-right:none;}
.tl-cell.night{background:rgba(139,111,212,.04);}
.tl-block{position:absolute;top:5px;bottom:5px;border-radius:5px;display:flex;align-items:center;padding:0 5px;font-size:10px;font-weight:700;white-space:nowrap;overflow:hidden;cursor:default;z-index:2;transition:filter .1s;}
.tl-block:hover{filter:brightness(.93);z-index:3;}
.b-gate{background:var(--bl);color:#2a6bb5;}
.b-patrol{background:var(--tl);color:#1a8c7a;}
.b-command{background:var(--pl);color:#6a52b0;}
.b-bad{background:var(--cl);color:#c0402a;border-left:3px solid var(--coral);}
.inactive-zone{position:absolute;top:0;bottom:0;background:repeating-linear-gradient(45deg,rgba(0,0,0,.025) 0,rgba(0,0,0,.025) 2px,transparent 2px,transparent 6px);pointer-events:none;z-index:1;}
.legend{display:flex;align-items:center;gap:16px;padding:10px 16px;border-top:1px solid var(--border);flex-wrap:wrap;}
.li{display:flex;align-items:center;gap:5px;font-size:11px;font-weight:600;color:var(--text2);}
.ld{width:10px;height:10px;border-radius:3px;}

/* FAIRNESS */
.f-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:12px;padding:16px 18px;}
.f-card{background:var(--bg3);border-radius:8px;padding:11px;}
.f-name{font-size:11px;font-weight:700;color:var(--text2);margin-bottom:6px;font-family:var(--fh);}
.f-track{height:6px;background:var(--bg4);border-radius:3px;overflow:hidden;}
.f-fill{height:6px;border-radius:3px;}
.f-val{font-size:11px;font-weight:700;color:var(--text2);font-family:var(--fh);margin-top:5px;}
.f-flags{font-size:9px;margin-top:3px;display:flex;gap:3px;flex-wrap:wrap;}
.flag-warn{background:var(--cl);color:#c0402a;padding:1px 5px;border-radius:4px;font-weight:700;}
.flag-ok{background:var(--gl);color:#2e8a55;padding:1px 5px;border-radius:4px;font-weight:700;}

/* LEADERBOARD — 3 periods */
.lb-periods{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--border);}
.lb-period{background:var(--bg2);}
.lb-period-hd{padding:12px 16px;font-family:var(--fh);font-size:12px;font-weight:700;color:var(--text2);text-transform:uppercase;letter-spacing:.07em;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:8px;}
.lb-item{display:flex;align-items:center;gap:10px;padding:9px 14px;border-bottom:1px solid var(--border);transition:background .12s;}
.lb-item:last-child{border-bottom:none;}
.lb-item:hover{background:var(--bg3);}
.lb-rank{font-family:var(--fh);font-size:16px;font-weight:800;width:26px;text-align:center;}
.r1{color:var(--amber);}.r2{color:#9ca8b5;}.r3{color:#c49a72;}.rr{color:var(--text3);font-size:12px;}
.lb-info{flex:1;min-width:0;}
.lb-name{font-family:var(--fh);font-size:12px;font-weight:700;color:var(--text);display:flex;align-items:center;gap:5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.lb-stat{font-size:10px;color:var(--text3);margin-top:1px;}
.pill{font-size:9px;font-weight:700;padding:1px 6px;border-radius:8px;white-space:nowrap;flex-shrink:0;}
.pg{background:var(--gl);color:var(--green);}.pa{background:var(--al);color:var(--ad);}.pc{background:var(--cl);color:var(--coral);}
.lb-bar{width:50px;height:3px;background:var(--bg3);border-radius:2px;overflow:hidden;flex-shrink:0;}
.lb-fill{height:3px;border-radius:2px;}

/* HISTORY / MEMORY */
.mh-row{background:var(--bg3);border:1px solid var(--border);border-radius:10px;padding:11px 14px;margin-bottom:8px;}
.mh-top{display:flex;align-items:center;gap:10px;margin-bottom:8px;}
.mh-name{font-family:var(--fh);font-size:13px;font-weight:700;color:var(--text);flex:1;}
.mh-score{font-family:var(--fh);font-size:13px;font-weight:700;}
.score-good{color:var(--green);}.score-warn{color:var(--amber);}.score-bad{color:var(--coral);}
.mh-bars{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:8px;}
.mh-bar-label{font-size:10px;font-weight:700;color:var(--text2);margin-bottom:3px;display:flex;align-items:center;justify-content:space-between;}
.mh-bar-val{color:var(--text3);}
.mh-track{height:5px;background:var(--bg4);border-radius:3px;overflow:hidden;}
.mh-fill{height:5px;border-radius:3px;}
.mh-flags{display:flex;gap:5px;flex-wrap:wrap;}
.mh-flag{font-size:10px;font-weight:700;padding:2px 8px;border-radius:8px;}
.fl-grv{background:var(--cl);color:#c0402a;}
.fl-ok{background:var(--gl);color:#2e8a55;}
.fl-heavy{background:var(--al);color:var(--ad);}
.fl-due{background:var(--pl);color:var(--purple);}
.mh-timeline{height:14px;background:var(--bg4);border-radius:4px;position:relative;overflow:hidden;margin-top:6px;}
.mh-blk{position:absolute;top:1px;bottom:1px;border-radius:3px;}

/* POSITIONS SETTINGS */
.pos-settings-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;padding:18px;}
.pos-set-card{background:var(--bg3);border:1px solid var(--border);border-radius:14px;padding:18px;}
.ps-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;}
.ps-name{font-family:var(--fh);font-size:16px;font-weight:700;color:var(--text);}
.badge{font-size:10px;font-weight:700;padding:3px 8px;border-radius:10px;}
.bh{background:var(--cl);color:#c0402a;}.bm{background:var(--al);color:var(--ad);}.be{background:var(--gl);color:#2e8a55;}
.ps-ratio{font-family:var(--fh);font-size:44px;font-weight:800;line-height:1;margin-bottom:2px;}
.ps-rl{font-size:10px;color:var(--text3);font-weight:600;margin-bottom:14px;}
.window-editor{background:var(--bg2);border:1px solid var(--border);border-radius:10px;padding:14px;margin-top:2px;}
.we-title{font-size:11px;font-weight:700;color:var(--text2);margin-bottom:10px;text-transform:uppercase;letter-spacing:.06em;}
.we-row{display:flex;align-items:center;gap:10px;margin-bottom:8px;}
.we-label{font-size:11px;color:var(--text3);width:60px;font-weight:600;}
.we-input{font-family:var(--fb);font-size:12px;font-weight:600;color:var(--text);background:var(--bg3);border:1px solid var(--border2);border-radius:6px;padding:5px 8px;width:90px;outline:none;}
.we-input:focus{border-color:var(--amber);}
.we-toggle{display:flex;align-items:center;gap:7px;font-size:12px;font-weight:600;color:var(--text2);cursor:pointer;}
.we-check{width:16px;height:16px;border-radius:4px;border:1.5px solid var(--border2);background:var(--bg3);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .13s;}
.we-check.checked{background:var(--amber);border-color:var(--amber);color:#fff;font-size:11px;}
.pos-tl-preview{height:18px;background:var(--bg4);border-radius:4px;margin-top:10px;position:relative;overflow:hidden;}
.ptl-active{position:absolute;top:2px;bottom:2px;border-radius:3px;opacity:.7;}
.ptl-label{position:absolute;top:50%;transform:translateY(-50%);font-size:9px;font-weight:700;white-space:nowrap;padding:0 4px;}
.ps-meta{display:grid;grid-template-columns:1fr 1fr;gap:10px;padding-top:12px;border-top:1px solid var(--border);margin-top:4px;}
.pm-l{font-size:10px;color:var(--text3);font-weight:700;text-transform:uppercase;letter-spacing:.04em;}
.pm-v{font-family:var(--fh);font-size:14px;font-weight:700;color:var(--text2);margin-top:2px;}
.ps-save{width:100%;margin-top:12px;height:34px;font-size:12px;font-weight:700;cursor:pointer;border:none;background:var(--amber);color:#fff;border-radius:8px;transition:all .13s;font-family:var(--fb);}
.ps-save:hover{background:var(--ad);}

/* MEMBERS */
.members-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(196px,1fr));gap:12px;padding:16px;}
.mc{background:var(--bg3);border:1px solid var(--border);border-radius:14px;padding:14px;cursor:pointer;transition:box-shadow .13s;}
.mc:hover{box-shadow:0 4px 14px rgba(0,0,0,.08);}
.mc-top{display:flex;align-items:center;gap:10px;margin-bottom:12px;}
.mc-name{font-family:var(--fh);font-size:13px;font-weight:700;color:var(--text);}
.mc-pts{font-size:10px;color:var(--text3);font-weight:600;margin-top:2px;}
.micro{font-size:10px;font-weight:700;color:var(--text3);letter-spacing:.06em;text-transform:uppercase;margin-bottom:5px;}
.pref-row{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:10px;}
.pchip{font-size:10px;font-weight:700;padding:2px 7px;border-radius:6px;}
.pcl{background:var(--gl);color:#2e8a55;}.pca{background:var(--cl);color:#c0402a;}
.day-row{display:flex;gap:3px;margin-bottom:11px;}
.dd{width:21px;height:21px;border-radius:5px;display:flex;align-items:center;justify-content:center;font-size:8px;font-weight:700;}
.don{background:var(--al);color:var(--ad);}.doff{background:var(--bg4);color:var(--text3);}
.mc-foot{display:flex;align-items:center;justify-content:space-between;padding-top:9px;border-top:1px solid var(--border);}
.son{font-size:11px;font-weight:600;color:var(--green);}.soff{font-size:11px;font-weight:600;color:var(--text3);}
.add-card{background:var(--bg2);border:1.5px dashed var(--border2);border-radius:14px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;cursor:pointer;min-height:165px;color:var(--text3);font-size:13px;font-weight:600;transition:all .15s;}
.add-card:hover{border-color:var(--amber);color:var(--ad);background:var(--al);}

/* AI PAGE */
.ai-wrap{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:20px;padding:48px 40px;min-height:400px;}
.ai-orb{width:76px;height:76px;border-radius:50%;background:var(--pl);border:2px solid #d4c8f5;display:flex;align-items:center;justify-content:center;font-size:32px;animation:float 3s ease-in-out infinite;}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-6px)}}
.ai-title{font-family:var(--fh);font-size:22px;font-weight:700;color:var(--text);text-align:center;}
.ai-sub{font-size:13px;color:var(--text2);text-align:center;max-width:420px;line-height:1.8;}
.c-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;width:100%;max-width:520px;}
.ci{background:var(--bg3);border:1px solid var(--border);border-radius:12px;padding:12px 14px;display:flex;gap:10px;}
.ci-icon{font-size:17px;margin-top:1px;flex-shrink:0;}
.ci-title{font-family:var(--fh);font-size:13px;font-weight:700;color:var(--text);}
.ci-sub{font-size:11px;color:var(--text3);margin-top:2px;line-height:1.6;}

/* SMS */
.sms-info{background:var(--al);border:1.5px solid var(--am);border-radius:12px;padding:13px 16px;display:flex;gap:12px;margin-bottom:14px;}
.sms-txt{font-size:12px;color:var(--text2);line-height:1.8;}
.sms-list{display:flex;flex-direction:column;gap:8px;}
.sms-row{display:flex;align-items:center;justify-content:space-between;padding:10px 15px;background:var(--bg3);border-radius:12px;border:1px solid var(--border);}
.sms-l{display:flex;align-items:center;gap:11px;}
.sms-mn{font-family:var(--fh);font-size:13px;font-weight:700;color:var(--text);}
.sms-ph{font-size:10px;color:var(--text3);margin-top:2px;}
.toggle{width:40px;height:22px;cursor:pointer;position:relative;border:none;outline:none;border-radius:11px;flex-shrink:0;transition:background .2s;}
.toggle.on{background:var(--amber);}.toggle.off{background:var(--border2);}
.toggle::after{content:'';position:absolute;top:3px;width:16px;height:16px;border-radius:50%;background:#fff;transition:left .2s;box-shadow:0 1px 3px rgba(0,0,0,.2);}
.toggle.on::after{left:21px;}.toggle.off::after{left:3px;}

/* TOAST */
.toast{position:fixed;bottom:22px;right:22px;background:var(--text);color:#fff;padding:12px 20px;border-radius:12px;font-size:13px;font-weight:600;z-index:999;animation:tin .25s ease;}
@keyframes tin{from{transform:translateY(10px);opacity:0}to{transform:translateY(0);opacity:1}}

/* PAGE VISIBILITY */
.page{display:none;}
.page.show{display:flex;flex-direction:column;gap:18px;}

/* ── AUTH / LOGIN ── */
#login-screen{position:fixed;inset:0;background:var(--bg);display:flex;align-items:center;justify-content:center;z-index:100;}
.login-wrap{display:flex;flex-direction:column;align-items:center;gap:24px;}
.login-logo{display:flex;flex-direction:column;align-items:center;gap:10px;}
.login-app-name{font-family:var(--fh);font-size:28px;font-weight:800;color:var(--text);}
.login-tagline{font-size:12px;color:var(--text3);}
#login-card{background:var(--bg2);border:1px solid var(--border);border-radius:20px;padding:32px;width:380px;display:flex;flex-direction:column;gap:16px;box-shadow:0 8px 32px rgba(0,0,0,.08);}
.login-title{font-family:var(--fh);font-size:18px;font-weight:700;color:var(--text);margin-bottom:4px;}
.login-label{font-size:11px;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:.06em;margin-bottom:5px;}
.login-select,.login-input{width:100%;padding:10px 14px;border:1.5px solid var(--border);border-radius:10px;font-size:14px;font-family:var(--fb);color:var(--text);background:var(--bg3);outline:none;transition:border-color .13s;}
.login-select:focus,.login-input:focus{border-color:var(--amber);}
.login-btn{width:100%;height:44px;background:var(--amber);color:#fff;border:none;border-radius:10px;font-family:var(--fh);font-size:15px;font-weight:700;cursor:pointer;transition:background .13s;}
.login-btn:hover{background:var(--ad);}
.login-error{font-size:12px;color:var(--coral);font-weight:600;text-align:center;display:none;}
.login-hint{font-size:11px;color:var(--text3);text-align:center;line-height:1.7;}
@keyframes shake{0%,100%{transform:translateX(0)}20%,60%{transform:translateX(-6px)}40%,80%{transform:translateX(6px)}}

/* ── SESSION INFO (sidebar footer) ── */
.session-info{background:var(--bg3);border-radius:10px;padding:10px 12px;margin-bottom:10px;}
.session-name{font-family:var(--fh);font-size:13px;font-weight:700;color:var(--text);}
.session-role{font-size:10px;color:var(--text3);margin-top:2px;}
.logout-btn{width:100%;height:30px;background:transparent;border:1px solid var(--border2);border-radius:8px;font-size:11px;font-weight:600;color:var(--text3);cursor:pointer;transition:all .13s;font-family:var(--fb);}
.logout-btn:hover{border-color:var(--coral);color:var(--coral);}

/* ── ROLE BADGES ── */
.role-badge{display:inline-block;font-size:10px;font-weight:700;padding:2px 8px;border-radius:8px;margin-right:3px;margin-bottom:3px;}

/* ── MEMBER PORTAL ── */
.mp-shift-block{display:flex;align-items:center;padding:10px 14px;border-radius:10px;font-size:13px;font-weight:700;margin-bottom:6px;}
.av-day-toggle{width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;cursor:pointer;transition:all .13s;user-select:none;}
.av-on{background:var(--al);color:var(--ad);}
.av-off{background:var(--bg4);color:var(--text3);}
.blocked-row{display:flex;align-items:center;gap:10px;padding:10px 0;border-bottom:1px solid var(--border);}
.blocked-row:last-child{border-bottom:none;}
.pref-pos-card{background:var(--bg3);border:1px solid var(--border);border-radius:12px;padding:14px;}
.pref-btn{padding:5px 12px;font-size:11px;font-weight:700;border-radius:8px;cursor:pointer;border:1.5px solid var(--border2);background:var(--bg2);color:var(--text2);transition:all .13s;font-family:var(--fb);}
.pref-btn:hover{border-color:var(--border2);background:var(--bg3);}
.pb-liked{background:var(--gl);color:#2e8a55;border-color:#a8d8a8;}
.pb-avoided{background:var(--cl);color:#c0402a;border-color:#f0a090;}
.pb-neutral{background:var(--bg4);color:var(--text2);}

/* ── ROLES MANAGER ── */
.role-mgr-row{display:flex;align-items:center;gap:10px;padding:10px 18px;border-bottom:1px solid var(--border);}
.role-mgr-row:last-child{border-bottom:none;}
.palette-dot{width:26px;height:26px;border-radius:50%;cursor:pointer;transition:transform .13s;flex-shrink:0;}
.palette-dot:hover{transform:scale(1.15);}
.palette-selected{outline:3px solid var(--text);outline-offset:2px;}
.role-assign-chip{display:inline-block;font-size:11px;font-weight:700;padding:4px 10px;border-radius:8px;cursor:pointer;border:1.5px solid var(--border2);background:var(--bg4);color:var(--text2);transition:all .13s;user-select:none;}
.role-assign-chip:hover{border-color:var(--border2);filter:brightness(.96);}
.rac-on{font-weight:700;}
.rac-off{background:var(--bg4);color:var(--text3);border-color:var(--border);}
