/* ════════════════════════════════════════════════════
   DefenseBoard — Main Stylesheet
   Extracted from index.php
════════════════════════════════════════════════════ */
:root{
  --bg:#050d1a;--bg2:#071020;--surface:#0b1628;--card:#0e1c33;--card-solid:#0f1e35;
  --border:#1a2e4a;--border2:#1f3657;--border-glow:rgba(6,182,212,.22);
  --accent:#38bdf8;--accent2:#06b6d4;--green:#10b981;--green2:#34d399;
  --amber:#f59e0b;--red:#ef4444;--purple:#818cf8;--cyan:#22d3ee;--pink:#f472b6;--teal:#2dd4bf;
  --text:#e0f2fe;--text2:#7dd3fc;--text3:#3b6fa0;
  --sans:'Outfit',sans-serif;--mono:'DM Mono',monospace;--r:14px;--r-s:9px;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--sans);background:var(--bg);color:var(--text);
  min-height:100vh;font-size:14px;line-height:1.6;
  background-image:
    radial-gradient(ellipse 70% 50% at 10% -5%,rgba(6,182,212,.09) 0%,transparent 100%),
    radial-gradient(ellipse 55% 45% at 90% 100%,rgba(16,185,129,.07) 0%,transparent 100%),
    url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%231a2e4a' fill-opacity='0.5'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");
}
::-webkit-scrollbar{width:5px;height:5px}
::-webkit-scrollbar-track{background:var(--surface)}
::-webkit-scrollbar-thumb{background:var(--border2);border-radius:99px}

/* ── TOPBAR ── */
#topbar{
  background:rgba(5,13,26,.94);border-bottom:1px solid var(--border);
  padding:0 28px;height:60px;display:flex;align-items:center;gap:16px;
  position:sticky;top:0;z-index:100;backdrop-filter:blur(20px);
  box-shadow:0 1px 0 rgba(6,182,212,.07);overflow:hidden;min-width:0;
}
.topbar-logo{
  width:36px;height:36px;border-radius:10px;flex-shrink:0;
  background:linear-gradient(135deg,#0ea5e9,#06b6d4,#10b981);
  display:flex;align-items:center;justify-content:center;font-size:16px;color:#fff;
  box-shadow:0 0 18px rgba(6,182,212,.35);
}
.topbar-brand{font-size:16px;font-weight:800;letter-spacing:-.3px;color:var(--text);white-space:nowrap}
.topbar-brand span{color:var(--accent)}
.topbar-sub{font-size:11px;color:var(--text3);font-family:var(--mono);margin-top:1px;letter-spacing:.3px;white-space:nowrap}
.topbar-spacer{flex:1;min-width:0}
.view-pill{
  font-family:var(--mono);font-size:11px;font-weight:500;letter-spacing:.5px;
  padding:5px 14px;border-radius:99px;
  background:rgba(6,182,212,.1);border:1px solid rgba(6,182,212,.25);color:var(--accent);
  display:flex;align-items:center;gap:7px;
  flex-shrink:0;white-space:nowrap;max-width:calc(100vw - 200px);overflow:hidden;
}
.view-pill.faculty{background:rgba(16,185,129,.1);border-color:rgba(16,185,129,.25);color:var(--green2)}

/* ── MAIN ── */
#main{padding:28px;max-width:940px;margin:0 auto;width:100%}

/* ── TABS ── */
.tabs{display:flex;gap:2px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:5px;margin-bottom:26px}
.tab{
  flex:1;padding:9px 10px;background:transparent;border:none;color:var(--text3);
  font-family:var(--sans);font-size:12px;font-weight:600;border-radius:10px;cursor:pointer;
  transition:all .2s;display:flex;align-items:center;justify-content:center;gap:7px;letter-spacing:.2px;
}
.tab i{font-size:12px}
.tab.active{background:var(--card-solid);color:var(--text);box-shadow:0 2px 12px rgba(0,0,0,.5),inset 0 1px 0 rgba(255,255,255,.04)}
.tab.active i{color:var(--accent)}
.tab:hover:not(.active){color:var(--text2)}

/* ── SECTION HEADING ── */
.section-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;flex-wrap:wrap;gap:10px}
.section-title{font-size:20px;font-weight:800;letter-spacing:-.4px}
.section-title span{color:var(--text3);font-weight:400;font-size:14px;margin-left:8px;letter-spacing:0}

/* ── CARD ── */
.card{
  background:linear-gradient(160deg,rgba(11,22,40,.98) 0%,rgba(7,16,32,.98) 100%);
  border:1px solid var(--border);border-radius:var(--r);padding:22px;margin-bottom:14px;
  box-shadow:0 4px 24px rgba(0,0,0,.4);position:relative;overflow:hidden;
}
.card::before{content:'';position:absolute;inset:0;background:linear-gradient(160deg,rgba(6,182,212,.025) 0%,transparent 50%);pointer-events:none}
.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px;gap:10px}
.card-title{font-size:14px;font-weight:700;display:flex;align-items:center;gap:10px}
.card-icon{width:32px;height:32px;border-radius:9px;display:flex;align-items:center;justify-content:center;font-size:13px;flex-shrink:0}
.icon-blue  {background:rgba(56,189,248,.12);color:var(--accent);border:1px solid rgba(56,189,248,.2)}
.icon-green {background:rgba(16,185,129,.12);color:var(--green2);border:1px solid rgba(16,185,129,.2)}
.icon-amber {background:rgba(245,158,11,.12);color:var(--amber);border:1px solid rgba(245,158,11,.2)}
.icon-purple{background:rgba(129,140,248,.12);color:var(--purple);border:1px solid rgba(129,140,248,.2)}
.icon-cyan  {background:rgba(34,211,238,.12);color:var(--cyan);border:1px solid rgba(34,211,238,.2)}
.icon-teal  {background:rgba(45,212,191,.12);color:var(--teal);border:1px solid rgba(45,212,191,.2)}

/* ── FORMS ── */
.form-row{display:flex;gap:12px;flex-wrap:wrap}
.form-group{display:flex;flex-direction:column;gap:6px;flex:1;min-width:160px}
.form-label{font-size:11px;color:var(--text3);font-weight:600;text-transform:uppercase;letter-spacing:.7px;display:flex;align-items:center;gap:6px}
.form-label i{font-size:10px}
input[type=text],input[type=date],input[type=number],select,textarea{
  background:var(--bg);border:1px solid var(--border2);color:var(--text);
  border-radius:var(--r-s);padding:10px 14px;font-family:var(--sans);font-size:13px;
  font-weight:500;outline:none;transition:border-color .2s,box-shadow .2s;width:100%;
}
select option{background:#071020;color:var(--text)}
input:focus,select:focus{border-color:rgba(6,182,212,.5);box-shadow:0 0 0 3px rgba(6,182,212,.08)}
input.err{border-color:var(--red)!important}
.field-err{font-size:11px;color:var(--red);display:flex;align-items:center;gap:5px}
.hint{font-size:11px;color:var(--green2);display:flex;align-items:center;gap:5px}

/* ── BUTTONS ── */
.btn{display:inline-flex;align-items:center;gap:8px;padding:9px 18px;border-radius:var(--r-s);font-family:var(--sans);font-size:12px;font-weight:700;border:none;cursor:pointer;transition:all .18s;letter-spacing:.2px;white-space:nowrap}
.btn i{font-size:12px}
.btn-primary{background:linear-gradient(135deg,#0ea5e9,#06b6d4);color:#fff;box-shadow:0 4px 16px rgba(6,182,212,.25)}
.btn-primary:hover{transform:translateY(-1px);box-shadow:0 6px 22px rgba(6,182,212,.4)}
.btn-success{background:linear-gradient(135deg,#10b981,#059669);color:#fff;font-weight:800}
.btn-success:hover{transform:translateY(-1px);box-shadow:0 4px 16px rgba(16,185,129,.35)}
.btn-danger{background:transparent;color:var(--red);border:1px solid rgba(239,68,68,.2)}
.btn-danger:hover{background:rgba(239,68,68,.07);border-color:rgba(239,68,68,.4)}
.btn-ghost{background:transparent;color:var(--text3);border:1px solid var(--border2)}
.btn-ghost:hover{color:var(--text);border-color:rgba(6,182,212,.3)}
.btn-green-ghost{background:transparent;color:var(--green2);border:1px solid rgba(16,185,129,.2)}
.btn-green-ghost:hover{background:rgba(16,185,129,.07);border-color:rgba(16,185,129,.4)}
.btn-sm{padding:6px 13px;font-size:11px}
.btn-icon{padding:7px;width:31px;height:31px;justify-content:center;border-radius:8px}
.btn:disabled{opacity:.38;cursor:not-allowed;transform:none!important;box-shadow:none!important}
.btn-warning{background:rgba(245,158,11,.15);color:#f59e0b;border:1px solid rgba(245,158,11,.3);border-radius:var(--r-s);padding:8px 14px;font-size:13px;font-weight:600;cursor:pointer;transition:.2s}
.btn-warning:hover{background:rgba(245,158,11,.28)}
.w-full{width:100%}

/* ── BADGES ── */
.badge{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:99px;font-size:10px;font-weight:700;font-family:var(--mono);letter-spacing:.3px}
.badge-blue  {background:rgba(56,189,248,.1);color:var(--accent);border:1px solid rgba(56,189,248,.25)}
.badge-green {background:rgba(16,185,129,.1);color:var(--green2);border:1px solid rgba(16,185,129,.25)}
.badge-amber {background:rgba(245,158,11,.1);color:var(--amber);border:1px solid rgba(245,158,11,.25)}
.badge-yellow{background:rgba(245,158,11,.12);color:#fbbf24;border:1px solid rgba(245,158,11,.3)}
.badge-purple{background:rgba(129,140,248,.1);color:var(--purple);border:1px solid rgba(129,140,248,.25)}
.badge-red   {background:rgba(239,68,68,.1);color:var(--red);border:1px solid rgba(239,68,68,.25)}
.badge-cyan  {background:rgba(34,211,238,.1);color:var(--cyan);border:1px solid rgba(34,211,238,.25)}
.badge-teal  {background:rgba(45,212,191,.1);color:var(--teal);border:1px solid rgba(45,212,191,.25)}
.input{background:var(--bg);border:1px solid var(--border2);color:var(--text);border-radius:var(--r-s);padding:10px 14px;font-family:var(--sans);font-size:13px;font-weight:500;outline:none;transition:border-color .2s;width:100%;box-sizing:border-box}
.input:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(56,189,248,.15)}

/* ── CHIPS ── */
.chip{display:inline-flex;align-items:center;gap:6px;background:rgba(11,22,40,.9);border:1px solid var(--border2);color:var(--text2);border-radius:8px;padding:5px 11px;font-size:12px;font-weight:600}
.chip.sup  {background:rgba(245,158,11,.06);border-color:rgba(245,158,11,.2);color:var(--amber)}
.chip.fac  {background:rgba(56,189,248,.06);border-color:rgba(56,189,248,.2);color:var(--accent)}
.chip.eval {background:rgba(129,140,248,.06);border-color:rgba(129,140,248,.2);color:var(--purple)}
.chip.type {background:rgba(16,185,129,.06);border-color:rgba(16,185,129,.2);color:var(--green2)}

/* ── ALERTS ── */
.alert{padding:12px 15px;border-radius:var(--r-s);font-size:12px;margin-bottom:14px;display:flex;align-items:flex-start;gap:10px;font-weight:500}
.alert i{margin-top:1px;flex-shrink:0;font-size:13px}
.alert-warn   {background:rgba(245,158,11,.06);border:1px solid rgba(245,158,11,.22);color:var(--amber)}
.alert-danger {background:rgba(239,68,68,.06);border:1px solid rgba(239,68,68,.22);color:var(--red)}
.alert-success{background:rgba(16,185,129,.06);border:1px solid rgba(16,185,129,.22);color:var(--green2)}
.alert-info   {background:rgba(56,189,248,.06);border:1px solid rgba(56,189,248,.22);color:var(--accent)}
hr{border:none;border-top:1px solid var(--border);margin:18px 0}

/* ── BOARD LIST ── */
.board-item{background:linear-gradient(135deg,rgba(11,22,40,.85),rgba(7,16,32,.85));border:1px solid var(--border);border-radius:var(--r);padding:18px 22px;display:flex;align-items:center;gap:18px;transition:border-color .2s,box-shadow .2s;margin-bottom:10px;position:relative;overflow:hidden}
.board-item::after{content:'';position:absolute;left:0;top:0;bottom:0;width:3px;background:linear-gradient(135deg,var(--accent),var(--teal));border-radius:3px 0 0 3px;opacity:0;transition:opacity .2s}
.board-item:hover{border-color:rgba(6,182,212,.3);box-shadow:0 4px 28px rgba(6,182,212,.06)}
.board-item:hover::after{opacity:1}
.b-icon{width:44px;height:44px;border-radius:12px;flex-shrink:0;background:linear-gradient(135deg,rgba(6,182,212,.14),rgba(16,185,129,.14));border:1px solid rgba(6,182,212,.18);display:flex;align-items:center;justify-content:center;color:var(--accent);font-size:18px}
.b-info{flex:1;min-width:0}
.b-name{font-size:15px;font-weight:700;margin-bottom:5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.b-meta{font-size:11px;color:var(--text3);font-family:var(--mono);display:flex;gap:14px;flex-wrap:wrap}
.b-meta span{display:flex;align-items:center;gap:5px}
.b-actions{display:flex;gap:7px;align-items:center;flex-wrap:wrap;flex-shrink:0}

/* ── TABLE ── */
.table-wrap{width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch;border-radius:var(--r-s)}
.data-table{width:100%;border-collapse:collapse;min-width:480px}
.data-table th{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:var(--text3);padding:10px 14px;text-align:left;border-bottom:1px solid var(--border);background:rgba(5,13,26,.5)}
.data-table td{padding:11px 14px;font-size:12px;border-bottom:1px solid rgba(11,22,40,.6)}
.data-table tr:last-child td{border-bottom:none}
.data-table tr:hover td{background:rgba(6,182,212,.025)}
.mark-inp{width:78px;text-align:center;background:rgba(5,13,26,.9);border:1px solid var(--border2);color:var(--text);border-radius:8px;padding:6px 9px;font-family:var(--mono);font-size:13px;font-weight:600;outline:none;transition:.18s}
.mark-inp:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(6,182,212,.1)}
.mark-inp.err{border-color:var(--red)}

/* ── URL BOX ── */
.url-box{display:flex;align-items:center;gap:10px;background:rgba(5,13,26,.8);border:1px solid var(--border2);border-radius:var(--r-s);padding:10px 14px}
.url-box code{font-family:var(--mono);font-size:11px;color:var(--accent);flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

/* ── ROLE CARDS ── */
.role-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:10px}
.role-card{background:rgba(5,13,26,.7);border:1.5px solid var(--border2);border-radius:var(--r);padding:20px 16px;cursor:pointer;transition:all .2s;text-align:center}
.role-card:hover{border-color:rgba(6,182,212,.35);background:rgba(6,182,212,.03)}
.role-card.selected{border-color:var(--accent);background:rgba(6,182,212,.07);box-shadow:0 0 0 1px rgba(6,182,212,.18),0 4px 20px rgba(6,182,212,.1)}
.rc-icon{font-size:28px;margin-bottom:9px}
.rc-name{font-weight:800;font-size:13px}
.rc-desc{font-size:11px;color:var(--text3);margin-top:4px}

/* ── EVAL / TYPE CARDS ── */
.eval-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(90px,1fr));gap:8px}
.eval-card{background:rgba(5,13,26,.6);border:1.5px solid var(--border2);border-radius:10px;padding:12px 6px;cursor:pointer;transition:all .2s;text-align:center;font-size:13px;font-weight:700;color:var(--text2)}
.eval-card:hover{border-color:var(--purple);color:var(--text);background:rgba(129,140,248,.04)}
.eval-card.selected{border-color:var(--purple);color:var(--purple);background:rgba(129,140,248,.08);box-shadow:0 0 0 1px rgba(129,140,248,.15)}
.type-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.type-card{background:rgba(5,13,26,.6);border:1.5px solid var(--border2);border-radius:10px;padding:16px;cursor:pointer;transition:all .2s;text-align:center}
.type-card:hover{border-color:var(--teal);background:rgba(45,212,191,.03)}
.type-card.selected{border-color:var(--teal);background:rgba(45,212,191,.07);box-shadow:0 0 0 1px rgba(45,212,191,.15)}
.tc-icon{font-size:22px;margin-bottom:7px;color:var(--text3)}
.type-card.selected .tc-icon{color:var(--teal)}
.tc-name{font-size:13px;font-weight:700}

/* ── STAT GRID ── */
.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:10px;margin-bottom:22px}
.stat-card{background:linear-gradient(160deg,rgba(11,22,40,.95),rgba(7,16,32,.95));border:1px solid var(--border);border-radius:var(--r);padding:18px 16px;text-align:center}
.stat-val{font-size:28px;font-weight:900;font-family:var(--mono);letter-spacing:-1px}
.stat-lbl{font-size:10px;color:var(--text3);margin-top:5px;text-transform:uppercase;letter-spacing:.7px}

/* ── MODAL ── */
.overlay{position:fixed;inset:0;background:rgba(0,0,0,.85);display:flex;align-items:center;justify-content:center;z-index:200;padding:20px;backdrop-filter:blur(6px)}
.modal{background:linear-gradient(160deg,#0b1628,#071020);border:1px solid var(--border2);border-radius:16px;padding:28px;width:100%;max-width:560px;max-height:90vh;overflow-y:auto;animation:pop .2s ease;box-shadow:0 20px 60px rgba(0,0,0,.7),0 0 0 1px rgba(6,182,212,.06)}
@keyframes pop{from{opacity:0;transform:scale(.95) translateY(12px)}to{opacity:1;transform:none}}
.modal-title{font-size:16px;font-weight:800;margin-bottom:20px;display:flex;align-items:center;gap:11px;letter-spacing:-.2px}
.modal-actions{display:flex;gap:9px;justify-content:flex-end;margin-top:22px}

/* ── CALC BOX ── */
.calc-box{background:rgba(5,13,26,.7);border:1px solid var(--border);border-radius:10px;padding:14px 16px}
.calc-row{display:flex;align-items:center;justify-content:space-between;font-size:12px;margin-bottom:6px;color:var(--text2)}
.calc-row .cv{font-family:var(--mono);font-weight:700;color:var(--text)}
.calc-total{display:flex;align-items:center;justify-content:space-between;font-size:15px;font-weight:800;border-top:1px solid var(--border);padding-top:10px;margin-top:4px}
.calc-total .cv{font-family:var(--mono);color:var(--green2)}

/* ── EMPTY STATE ── */
.empty{text-align:center;padding:40px 20px;color:var(--text3)}
.empty i{font-size:32px;margin-bottom:12px;display:block;opacity:.4}
.empty p{font-size:13px}

/* ── SUB ROW ── */
.sub-row{display:flex;align-items:center;gap:12px;padding:11px 14px;background:rgba(5,13,26,.6);border-radius:10px;margin-bottom:8px;border:1px solid var(--border);transition:border-color .18s}
.sub-row:hover{border-color:var(--border2)}

/* ── UTILS ── */
.flex{display:flex}.gap-2{gap:8px}.gap-3{gap:12px}
.items-center{align-items:center}.justify-between{justify-content:space-between}
.flex-wrap{flex-wrap:wrap}
.mt-1{margin-top:4px}.mt-2{margin-top:8px}.mt-3{margin-top:14px}.mt-4{margin-top:20px}
.mb-1{margin-bottom:4px}.mb-2{margin-bottom:8px}
.text-xs{font-size:11px}.text-sm{font-size:12px}
.text-muted{color:var(--text3)}.text-right{text-align:right}
.mono{font-family:var(--mono)}.bold{font-weight:700}
.green{color:var(--green2)}.blue{color:var(--accent)}.amber{color:var(--amber)}.red{color:var(--red)}
.purple{color:var(--purple)}.cyan{color:var(--cyan)}.teal{color:var(--teal)}

/* ── DIVIDER LABEL ── */
.divider-label{display:flex;align-items:center;gap:10px;font-size:11px;text-transform:uppercase;letter-spacing:.7px;color:var(--text3);font-weight:700;margin:16px 0 10px}
.divider-label::before,.divider-label::after{content:'';flex:1;height:1px;background:var(--border)}

/* ── LOADING SPINNER ── */
.spinner{display:inline-block;width:18px;height:18px;border:2px solid var(--border2);border-top-color:var(--accent);border-radius:50%;animation:spin .6s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.loading-center{display:flex;align-items:center;justify-content:center;gap:10px;padding:40px;color:var(--text3);font-size:13px}

/* ── PRINT ── */
@media print{
  #topbar,.tabs,.btn,.no-print{display:none!important}
  body,#main{background:#fff;color:#000}
  .card{border:1px solid #ccc;break-inside:avoid}
}

/* ── RESPONSIVE 768px ── */
@media(max-width:768px){
  #main{padding:14px}
  .section-head{flex-direction:column;align-items:flex-start;gap:8px}
  .section-head .btn{width:100%}
  .stat-grid{grid-template-columns:1fr 1fr}
  .tabs{gap:1px;padding:4px}
  .tab{font-size:11px;padding:8px 6px;gap:5px}
  .tab i{font-size:11px}
  .role-grid,.type-grid{grid-template-columns:1fr 1fr}
  .eval-grid{grid-template-columns:repeat(auto-fill,minmax(75px,1fr))}
  .data-table th,.data-table td{padding:8px 10px;font-size:11px}
  .mark-inp{width:64px;font-size:12px}
  .modal{padding:20px;border-radius:12px}
  .modal-title{font-size:14px;margin-bottom:16px}
  .modal-actions{flex-direction:column}
  .modal-actions .btn{width:100%;justify-content:center}
  .calc-box{padding:12px}
}

/* ── RESPONSIVE 640px ── */
@media(max-width:640px){
  #topbar{padding:0 12px;height:52px;gap:8px}
  .topbar-sub{display:none}
  .topbar-brand{font-size:13px}
  .topbar-logo{width:30px;height:30px;font-size:13px;border-radius:8px}
  .view-pill{font-size:10px;padding:4px 10px;gap:5px;letter-spacing:0}
  #viewBadge button{font-size:9px!important;padding:2px 7px!important;margin-left:5px!important}
  #admin-timer-badge{font-size:9px!important;margin-left:4px!important}
  #main{padding:12px}
  .board-item{flex-direction:column;align-items:flex-start;gap:12px;padding:14px 16px}
  .board-item .b-icon{width:38px;height:38px;font-size:15px;border-radius:10px}
  .b-actions{width:100%;display:flex;flex-wrap:wrap;gap:6px}
  .b-actions .btn{flex:1;min-width:0;justify-content:center;font-size:11px;padding:7px 8px}
  .b-name{font-size:14px}
  .b-meta{font-size:10px;gap:8px}
  .card{padding:16px}
  .card-header{flex-direction:column;align-items:flex-start;gap:8px}
  .card-header .btn{width:100%;justify-content:center}
  .tabs{padding:3px;gap:1px}
  .tab{font-size:10px;padding:7px 4px;gap:4px;letter-spacing:0}
  .tab i{font-size:10px}
  .section-head{flex-direction:column;align-items:flex-start;gap:8px}
  .section-head>.btn{width:100%;justify-content:center}
  .board-item .b-info{width:100%}
  .role-grid{grid-template-columns:1fr 1fr;gap:8px}
  .role-card{padding:14px 10px}
  .rc-icon{font-size:22px;margin-bottom:6px}
  .rc-name{font-size:12px}
  .eval-grid{grid-template-columns:repeat(auto-fill,minmax(70px,1fr));gap:6px}
  .eval-card{padding:10px 4px;font-size:12px}
  .type-grid{grid-template-columns:1fr 1fr;gap:8px}
  .type-card{padding:12px 10px}
  .data-table th{font-size:9px;padding:7px 8px;letter-spacing:.4px}
  .data-table td{padding:8px 8px;font-size:11px}
  .mark-inp{width:58px;font-size:12px;padding:5px 6px}
  .overlay{padding:10px;align-items:flex-end}
  .modal{padding:18px 16px;border-radius:16px 16px 0 0;max-width:100%;max-height:92vh}
  .modal-title{font-size:13px;margin-bottom:14px}
  .modal-actions{flex-direction:column;gap:7px;margin-top:16px}
  .modal-actions .btn{width:100%;justify-content:center}
  .calc-box{padding:10px 12px}
  .calc-row{font-size:11px}
  .calc-total{font-size:13px}
  .stat-grid{grid-template-columns:1fr 1fr;gap:8px}
  .stat-val{font-size:22px}
  .sub-row{padding:10px 12px;gap:8px}
  .url-box{padding:8px 12px}
  .url-box code{font-size:10px}
  .chip{font-size:11px;padding:4px 9px}
  .badge{font-size:9px;padding:2px 8px}
  .form-row{flex-direction:column;gap:10px}
  .form-group{min-width:unset}
  input[type=text],input[type=date],input[type=number],select,textarea{font-size:13px;padding:9px 12px}
  .btn{font-size:12px;padding:8px 14px}
  .btn-sm{font-size:11px;padding:6px 10px}
  .toast-el{bottom:12px!important;right:12px!important;left:12px;max-width:unset!important}
}

/* ── RESPONSIVE 380px ── */
@media(max-width:380px){
  .role-grid,.type-grid{grid-template-columns:1fr}
  .stat-grid{grid-template-columns:1fr 1fr}
  .b-actions .btn{font-size:10px;padding:6px 6px}
  .tab{font-size:9px;padding:6px 3px}
  #topbar{padding:0 10px;gap:6px}
  .topbar-brand{font-size:12px}
  .view-pill{font-size:9px;padding:3px 8px}
  #viewBadge button{font-size:8px!important;padding:2px 6px!important}
  #admin-timer-badge{display:none!important}
}
