/* ═══════════════════════════════════════════════════════════════
   HUGINN COMM v8 — Battlefield Tactical UI / Mobile-First
   ═══════════════════════════════════════════════════════════════ */
@import url('https://fonts.googleapis.com/css2?family=Rajdhani:wght@400;500;600;700&family=Share+Tech+Mono&family=Saira+Condensed:wght@400;500;600;700;800&display=swap');

:root {
    --bg:#0a0e13; --panel:rgba(10,16,22,0.94); --line:rgba(69,160,73,0.18);
    --line-strong:rgba(69,160,73,0.35); --line-subtle:rgba(255,255,255,0.04);
    --accent:#45a049; --accent-bright:#5ddb63; --accent-dim:#2d7a30;
    --accent-glow:rgba(69,160,73,0.25); --huginn-red:#e25c5c; --brand-primary:#e25c5c; --brand-primary-bright:#ff7b7b; --brand-primary-dim:#b93d3d;
    --huginn-red-glow:rgba(226,92,92,0.2); --brand-primary-glow:rgba(226,92,92,0.2); --text:#c8d6e0; --text-bright:#e8f0f4;
    --muted:#5a7a8a; --danger:#e25c5c; --danger-glow:rgba(226,92,92,0.25);
    --success:#45a049; --warn:#d4a843; --warn-glow:rgba(212,168,67,0.2);
    --shadow:0 8px 32px rgba(0,0,0,0.5);
    --font-display:'Saira Condensed','Rajdhani',sans-serif;
    --font-body:'Rajdhani',sans-serif;
    --font-mono:'Share Tech Mono',monospace;
    --cut:polygon(0 0,calc(100% - 12px) 0,100% 12px,100% 100%,12px 100%,0 calc(100% - 12px));
    --cut-sm:polygon(0 0,calc(100% - 8px) 0,100% 8px,100% 100%,8px 100%,0 calc(100% - 8px));
    --cut-xs:polygon(0 0,calc(100% - 5px) 0,100% 5px,100% 100%,5px 100%,0 calc(100% - 5px));
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:15px;-webkit-font-smoothing:antialiased}
body{font-family:var(--font-body);background:var(--bg);color:var(--text);min-height:100vh;overflow-x:hidden;letter-spacing:.02em}
a{color:inherit;text-decoration:none} button,input,select,textarea{font:inherit;color:inherit}
button{cursor:pointer;border:none;background:none} img{display:block;max-width:100%}
.hidden{display:none!important}

/* Background texture */
body::before{content:'';position:fixed;inset:0;background:repeating-linear-gradient(0deg,transparent,transparent 2px,rgba(69,160,73,.015) 2px,rgba(69,160,73,.015) 4px),linear-gradient(90deg,rgba(69,160,73,.02) 1px,transparent 1px),linear-gradient(0deg,rgba(69,160,73,.02) 1px,transparent 1px);background-size:100% 4px,48px 48px,48px 48px;pointer-events:none;z-index:0}
body::after{content:'';position:fixed;inset:0;background:radial-gradient(ellipse at 20% 0%,rgba(69,160,73,.06) 0%,transparent 50%),radial-gradient(ellipse at 80% 100%,rgba(226,92,92,.04) 0%,transparent 50%);pointer-events:none;z-index:0}

/* ── Shell ─────────────────────────────────── */
.shell{width:min(1440px,calc(100% - 24px));margin:0 auto;padding:16px 0 40px;position:relative;z-index:1}

/* ── Panel ─────────────────────────────────── */
.panel{background:var(--panel);border:1px solid var(--line);position:relative;clip-path:var(--cut);overflow:visible}
.panel::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--accent),transparent 70%);z-index:2}
.panel-header,.stage-head{display:flex;align-items:flex-start;gap:12px;padding:14px 18px 12px;border-bottom:1px solid var(--line);background:rgba(69,160,73,.03)}
.panel-header.between,.stage-head.between{justify-content:space-between;align-items:center}

/* ── Typography ────────────────────────────── */
.eyebrow{font-family:var(--font-mono);color:var(--accent);font-size:10px;font-weight:400;letter-spacing:.22em;text-transform:uppercase;opacity:.85}
h1{font-family:var(--font-display);font-weight:800;font-size:1.6rem;letter-spacing:.08em;text-transform:uppercase;color:var(--text-bright);margin:2px 0 0;line-height:1}
h2{font-family:var(--font-display);font-weight:700;font-size:1.15rem;letter-spacing:.06em;text-transform:uppercase;color:var(--text-bright);margin:2px 0 0;line-height:1.1}
h3{font-family:var(--font-display);font-weight:700;font-size:1.05rem;letter-spacing:.04em;text-transform:uppercase;color:var(--text-bright);margin:2px 0 0}
p{color:var(--muted);line-height:1.5;font-size:.93rem}

/* ── Buttons ───────────────────────────────── */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;border:1px solid var(--line);padding:10px 16px;font-family:var(--font-display);font-weight:600;font-size:.85rem;letter-spacing:.1em;text-transform:uppercase;transition:all 140ms ease;clip-path:var(--cut-xs);white-space:nowrap}
.btn:hover{transform:translateY(-1px)} .btn:active{transform:translateY(0)}
.btn-primary{background:linear-gradient(180deg,var(--accent),var(--accent-dim));color:#fff;border-color:var(--accent);box-shadow:0 4px 16px var(--accent-glow);text-shadow:0 1px 2px rgba(0,0,0,.3)}
.btn-primary:hover{background:linear-gradient(180deg,var(--accent-bright),var(--accent));box-shadow:0 6px 24px var(--accent-glow)}
.btn-secondary{background:rgba(14,22,30,.9);border-color:var(--line-strong);color:var(--text)}
.btn-secondary:hover{border-color:var(--accent);color:var(--accent-bright)}
.btn-danger{background:linear-gradient(180deg,var(--danger),#b33e3e);color:#fff;border-color:var(--danger);box-shadow:0 4px 16px var(--danger-glow)}
.btn[disabled]{opacity:.3;cursor:not-allowed;transform:none!important;box-shadow:none!important}
.btn.full{width:100%}

/* ── Forms ─────────────────────────────────── */
.field{display:grid;gap:6px}
.field span{font-family:var(--font-mono);color:var(--muted);font-size:11px;letter-spacing:.08em;text-transform:uppercase}
.field input,.field input[type="file"]{width:100%;background:rgba(6,10,16,.9);border:1px solid var(--line);padding:11px 14px;color:var(--text-bright);font-family:var(--font-body);font-size:.95rem;outline:none;transition:border-color 150ms;clip-path:var(--cut-xs)}
.field input:focus{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-glow)}
.field input::placeholder{color:var(--muted);opacity:.5}
.checkbox{display:flex;align-items:center;gap:10px} .checkbox input{width:auto;clip-path:none;accent-color:var(--accent)}
.stack-md{display:grid;gap:12px;padding:16px 18px}
.stack-inline-sm{display:flex;flex-wrap:wrap;gap:8px;align-items:center}
.field-hint{font-family:var(--font-mono);font-size:10px;color:var(--muted);letter-spacing:.04em}

/* Alerts */
.alert{margin:0 18px;padding:11px 14px;border:1px solid transparent;font-family:var(--font-mono);font-size:.8rem;letter-spacing:.04em;clip-path:var(--cut-xs)}
.alert.error{background:rgba(226,92,92,.1);border-color:rgba(226,92,92,.25);color:#f0b0b0}
.alert.success{background:rgba(69,160,73,.1);border-color:rgba(69,160,73,.25);color:#a0dfa3}

/* ════════════════ LOGIN ════════════════ */
.login-body,.install-body{display:grid;place-items:center;min-height:100vh}
.auth-panel{width:min(460px,calc(100% - 32px));margin:0 auto}
.auth-panel .panel-header{text-align:center;display:flex;flex-direction:column;align-items:center;padding:32px 24px 20px}
.logo-mark{width:96px;height:96px;margin-bottom:14px;filter:drop-shadow(0 0 24px var(--brand-primary-glow))}
.auth-panel h1{font-size:2.2rem;background:linear-gradient(180deg,var(--brand-primary-bright),var(--brand-primary-dim));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.auth-panel .eyebrow{margin-bottom:6px}
.auth-subtitle{text-align:center;max-width:300px;margin:8px auto 0;font-size:.88rem;color:var(--muted);line-height:1.5}
.wide-panel{width:min(640px,100%)}

/* ════════════════ TOPBAR ════════════════ */
.topbar{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:12px 18px;margin-bottom:14px;background:linear-gradient(180deg,rgba(10,16,22,.96),rgba(8,12,18,.98));clip-path:var(--cut)}
.topbar-left{display:flex;align-items:center;gap:14px}
.topbar-logo{width:42px;height:42px;filter:drop-shadow(0 0 10px var(--brand-primary-glow));flex-shrink:0}
.topbar-brand{display:flex;flex-direction:column}
.topbar-brand h1{font-size:1.3rem;background:linear-gradient(180deg,var(--brand-primary-bright),var(--brand-primary-dim));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.topbar-right{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.identity-card{background:rgba(255,255,255,.02);border:1px solid var(--line);padding:8px 14px;clip-path:var(--cut-xs)}
.identity-name{font-family:var(--font-display);font-weight:700;font-size:.9rem;text-transform:uppercase;letter-spacing:.04em}
.identity-meta{font-family:var(--font-mono);font-size:10px;color:var(--muted);letter-spacing:.06em;text-transform:uppercase}
.compact{padding:10px 16px} .compact .panel-header,.compact .stage-head{padding:0;border-bottom:0;background:none}

/* ════════════════ DASHBOARD ════════════════ */
.dashboard-grid{display:grid;grid-template-columns:minmax(0,1.25fr) minmax(320px,.95fr);gap:14px;align-items:start}
.lobby-panel,.side-panel{min-height:260px}
.admin-panel{min-height:0}
.side-panel{position:sticky;top:14px}
.admin-panel{grid-column:1/-1}

/* (Admin panels render as centered modal overlays — see admin-panel rules below.) */
/* Active toggle button styling */
[data-toggle-panel].panel-btn-active{background:rgba(69,160,73,.15)!important;border-color:var(--accent)!important;color:var(--accent-bright)!important;box-shadow:0 0 8px var(--accent-glow)}

.status-strip{padding:10px 18px;font-family:var(--font-mono);font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);border-bottom:1px solid var(--line-subtle);background:rgba(69,160,73,.02)}
.user-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(176px,1fr));gap:8px;padding:12px}
.user-card{background:linear-gradient(180deg,rgba(14,22,30,.95),rgba(10,16,22,.98));border:1px solid var(--line-subtle);clip-path:var(--cut-sm);padding:11px;display:grid;gap:8px;transition:border-color 200ms;position:relative}
.user-card::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,var(--accent-dim),transparent 60%);opacity:.5}
.user-card:hover{border-color:var(--line)}
.user-top{display:flex;align-items:center;justify-content:space-between;gap:8px}
.user-name{font-family:var(--font-display);font-weight:700;font-size:.95rem;text-transform:uppercase;letter-spacing:.04em;color:var(--text-bright)}
.user-meta{font-family:var(--font-mono);font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:.06em}
.status-dot{width:10px;height:10px;clip-path:polygon(50% 0%,100% 50%,50% 100%,0% 50%);flex-shrink:0}
.status-dot.online{background:var(--success)}
.status-dot.busy{background:var(--warn)} .status-dot.offline{background:rgba(255,255,255,.12)}
.status-pill{display:inline-flex;align-items:center;gap:6px;padding:4px 8px;font-family:var(--font-mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;border:1px solid var(--line-subtle);color:var(--muted);clip-path:var(--cut-xs)}
.card-actions{display:flex;gap:8px;flex-wrap:wrap}

/* ── Geo Panel / Leaflet Map ──────────────── */
.geo-panel{overflow:hidden}
.geo-panel-body{display:grid;gap:0}
.geo-map{padding:0 12px 12px}
.geo-map-container{position:relative;min-height:420px;border:1px solid var(--line-subtle);overflow:hidden;border-radius:2px}
.geo-map-container .leaflet-container{background:#0a0e13!important}
.geo-map-fallback{position:relative;min-height:420px;border:1px solid var(--line-subtle);overflow:hidden;display:flex;align-items:center;justify-content:center;background:radial-gradient(circle at 50% 50%,rgba(69,160,73,.08),rgba(4,8,12,.98) 65%);font-family:var(--font-mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}

/* Leaflet dark tactical theme overrides */
.leaflet-tile-pane{filter:brightness(0.55) contrast(1.3) saturate(0.3) hue-rotate(80deg)}
.leaflet-control-zoom{border:1px solid var(--line)!important;border-radius:0!important;overflow:hidden}
.leaflet-control-zoom a{background:rgba(10,16,22,.92)!important;color:var(--accent-bright)!important;border-color:var(--line)!important;font-family:var(--font-mono)!important;width:30px!important;height:30px!important;line-height:30px!important;font-size:16px!important;transition:background 120ms ease}
.leaflet-control-zoom a:hover{background:rgba(69,160,73,.15)!important}
.leaflet-control-attribution{background:rgba(10,16,22,.8)!important;color:var(--muted)!important;font-family:var(--font-mono)!important;font-size:8px!important;letter-spacing:.04em}
.leaflet-control-attribution a{color:var(--accent-dim)!important}
.leaflet-popup-content-wrapper{background:rgba(10,16,22,.95)!important;color:var(--text-bright)!important;border:1px solid var(--line)!important;border-radius:2px!important;box-shadow:0 4px 20px rgba(0,0,0,.6)!important;font-family:var(--font-mono)!important;font-size:11px!important;letter-spacing:.04em}
.leaflet-popup-tip{background:rgba(10,16,22,.95)!important;border:1px solid var(--line)!important}
.leaflet-popup-close-button{color:var(--muted)!important;font-size:16px!important}
.leaflet-popup-close-button:hover{color:var(--accent-bright)!important}
.huginn-popup-name{font-family:var(--font-display);font-weight:700;text-transform:uppercase;letter-spacing:.06em;font-size:12px;color:var(--text-bright);margin-bottom:4px}
.huginn-popup-loc{color:var(--muted);font-size:10px;margin-bottom:3px}
.huginn-popup-status{font-size:10px;text-transform:uppercase;letter-spacing:.1em}
.huginn-popup-status.st-online{color:var(--accent-bright)}
.huginn-popup-status.st-busy{color:var(--warn)}
.huginn-popup-status.st-offline{color:var(--muted)}
.huginn-popup-status.st-self{color:var(--accent-bright);font-weight:700}

/* Geo footer bar */
.geo-footer-bar{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;padding:10px 0 0;font-family:var(--font-mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}
.geo-footer-bar > div{border:1px solid var(--line-subtle);padding:8px 10px;clip-path:var(--cut-xs);background:rgba(255,255,255,.02);transition:border-color 200ms ease}
.geo-footer-bar > div:hover{border-color:var(--line)}
.geo-footer-bar strong{color:var(--accent-bright);font-size:13px;margin-right:6px}
@keyframes geo-ping{0%{opacity:.2;transform:translate(-50%,-50%) scale(.72)}70%{opacity:0;transform:translate(-50%,-50%) scale(1.85)}100%{opacity:0;transform:translate(-50%,-50%) scale(1.95)}}
.compact-user-card{min-height:112px}
.compact-user-top{align-items:flex-start}
.user-ident{min-width:0}
.user-card-meta-row{display:flex;align-items:center;justify-content:space-between;gap:8px}
.user-geo-mini{flex:1;min-width:0;font-family:var(--font-mono);font-size:10px;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);text-align:right;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.compact-card-actions{justify-content:flex-end}
.compact-call-btn{min-width:82px;padding:8px 12px;font-size:11px;letter-spacing:.12em}
.user-card.is-self{box-shadow:inset 0 0 0 1px rgba(69,160,73,.18)}

.event-feed{display:grid;gap:8px;padding:14px}
.feed-item{padding:10px 12px;background:rgba(255,255,255,.015);border-left:2px solid var(--accent-dim);font-size:.88rem}
.feed-item strong{display:block;font-family:var(--font-display);font-weight:700;text-transform:uppercase;letter-spacing:.04em;font-size:.82rem;margin-bottom:3px;color:var(--text-bright)}
.feed-item.muted{color:var(--muted);border-left-color:var(--line)}
.mini-list{display:grid;gap:8px;padding:14px 18px 18px}
.mini-item{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 12px;border:1px solid var(--line-subtle);clip-path:var(--cut-xs)}
.table-wrap{padding:14px;overflow:auto}
.audit-table{width:100%;border-collapse:collapse;font-size:.82rem}
.audit-table th,.audit-table td{text-align:left;padding:10px 8px;border-bottom:1px solid var(--line-subtle)}
.audit-table th{font-family:var(--font-mono);color:var(--accent);font-size:10px;letter-spacing:.1em;text-transform:uppercase;font-weight:400}
.audit-table tr:hover td{background:rgba(69,160,73,.03)}

/* Badge */
.badge{display:inline-flex;align-items:center;justify-content:center;min-height:28px;padding:5px 10px;font-family:var(--font-mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;border:1px solid var(--line);clip-path:var(--cut-xs)}
.badge-warn{background:rgba(212,168,67,.1);color:#d4a843;border-color:rgba(212,168,67,.2)}
.badge-success{background:rgba(69,160,73,.1);color:var(--accent-bright);border-color:rgba(69,160,73,.2)}
.badge-danger{background:rgba(226,92,92,.1);color:var(--huginn-red);border-color:rgba(226,92,92,.2)}

/* Modal */
.modal{position:fixed;inset:0;background:rgba(4,6,10,.85);backdrop-filter:blur(8px);display:grid;place-items:center;z-index:100;padding:20px}
.modal-card{width:min(440px,100%);padding-bottom:16px;animation:modal-card-in 280ms cubic-bezier(.34,1.56,.64,1) both}
.modal-card .eyebrow{padding:0 18px} .modal-card h3{padding:0 18px;font-size:1.3rem} .modal-card p{padding:0 18px}
.incoming-pulse::before{animation:ring-glow 1.5s ease-in-out infinite}
@keyframes ring-glow{0%,100%{background:linear-gradient(90deg,var(--accent),transparent 70%)}50%{background:linear-gradient(90deg,var(--accent-bright),var(--accent),transparent 80%)}}

/* Logo upload */
.logo-preview-row{display:flex;align-items:center;gap:14px}
.logo-preview-thumb{width:64px;height:64px;object-fit:contain;border:1px solid var(--line);padding:4px;background:rgba(0,0,0,.3);clip-path:var(--cut-xs)}

/* ════════════════════════════════════════════
   CALL PAGE — FULLSCREEN LAYOUT
   ════════════════════════════════════════════ */
.call-body{overflow:hidden;background:#000}
.call-body::before,.call-body::after{display:none}

/* Layout: main (video) + pinned chat on desktop */
.call-viewport{position:fixed;inset:0;z-index:1;background:#000}
.call-main{position:absolute;inset:0}

:root{--chatW:360px}

@media(min-width:980px){
  .call-main{right:0}
  .call-viewport.chat-open .call-main{right:var(--chatW)}
}

/* Video stage */
.video-stage{position:absolute;inset:0;z-index:0;background:#000}
.video-stage.mode-grid{display:grid;grid-template-columns:1fr 1fr}
.video-stage.swap-sides.mode-grid .tile-local{order:2}
.video-stage.swap-sides.mode-grid .tile-remote{order:1}
.video-stage.mode-screen{display:grid;grid-template-columns:minmax(0,1fr) 260px;grid-template-rows:1fr 1fr;grid-template-areas:'screen local' 'screen remote'}

.video-tile{position:relative;overflow:hidden;background:#000}
.video-tile video{width:100%;height:100%;object-fit:contain;background:#000}
.video-stage.fit-cover .video-tile video{object-fit:cover}

.video-stage.mode-grid .video-tile + .video-tile{border-left:1px solid rgba(255,255,255,.06)}
.tile-placeholder{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;color:var(--muted);font-family:var(--font-mono);font-size:12px;letter-spacing:.08em;text-transform:uppercase;background:linear-gradient(180deg,rgba(8,12,18,.95),rgba(4,6,10,.98))}

/* Screen stage + right camera rail */
.tile-screen{position:absolute;inset:0;z-index:0}
.screen-badge{position:absolute;top:14px;left:14px;z-index:2;background:rgba(0,0,0,.45);border:1px solid rgba(255,255,255,.14);color:var(--text-bright);font-family:var(--font-mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;padding:6px 10px;border-radius:4px;backdrop-filter:blur(10px)}

.video-stage.mode-screen .tile-screen{position:relative;inset:auto;grid-area:screen;border-right:1px solid rgba(255,255,255,.08)}
.video-stage.mode-screen .tile-local,
.video-stage.mode-screen .tile-remote{position:relative;inset:auto;width:auto;height:auto;z-index:1;border:0;border-radius:0;box-shadow:none}
.video-stage.mode-screen .tile-local{grid-area:local;border-bottom:1px solid rgba(255,255,255,.08)}
.video-stage.mode-screen .tile-remote{grid-area:remote}
.video-stage.swap-sides.mode-screen{grid-template-areas:'screen remote' 'screen local'}

/* Mirror helper (applied per-video) */
.mirror-x{transform:scaleX(-1)}

/* Top HUD overlay */
.call-hud-top{position:absolute;top:0;left:0;right:0;z-index:10;display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:linear-gradient(180deg,rgba(0,0,0,.7),transparent);pointer-events:auto}
.hud-left{display:flex;align-items:center;gap:12px}
.hud-back{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border:1px solid rgba(255,255,255,.15);border-radius:50%;color:#fff;transition:background 150ms}
.hud-back:hover{background:rgba(255,255,255,.1)}
.hud-info{display:flex;flex-direction:column;gap:2px}
.hud-peer{font-family:var(--font-display);font-weight:700;font-size:1.1rem;text-transform:uppercase;letter-spacing:.04em;color:#fff;text-shadow:0 1px 4px rgba(0,0,0,.6)}
.hud-meta{display:flex;align-items:center;gap:8px}
.hud-badge{font-family:var(--font-mono);font-size:9px;letter-spacing:.1em;text-transform:uppercase;padding:3px 8px;border-radius:3px}
.hud-badge-warn{background:rgba(212,168,67,.2);color:#d4a843}
.hud-badge-success{background:rgba(69,160,73,.2);color:var(--accent-bright)}
.hud-badge-danger{background:rgba(226,92,92,.2);color:var(--huginn-red)}
.hud-timer{font-family:var(--font-mono);font-size:12px;letter-spacing:.12em;color:var(--accent-bright);text-shadow:0 0 8px var(--accent-glow)}

/* Remote audio element stays hidden */
#remoteAudio{display:none}

/* ── Bottom Control Bar ───────────────────── */
.call-controls{position:absolute;bottom:0;left:0;right:0;z-index:20;display:flex;align-items:center;justify-content:center;gap:12px;padding:16px 20px 24px;background:linear-gradient(0deg,rgba(0,0,0,.75),transparent)}
@supports(padding-bottom:env(safe-area-inset-bottom)){.call-controls{padding-bottom:calc(16px + env(safe-area-inset-bottom))}}

.ctl-icon-btn{display:flex;align-items:center;justify-content:center;width:52px;height:52px;border-radius:50%;background:rgba(255,255,255,.1);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.15);color:#fff;transition:all 150ms;position:relative}
.ctl-icon-btn:hover{background:rgba(255,255,255,.18)}
.ctl-icon-btn:active{transform:scale(.92)}

/* Active state (green ring) */
.ctl-icon-btn.ctl-active{background:rgba(69,160,73,.2);border-color:var(--accent);color:var(--accent-bright);box-shadow:0 0 12px var(--accent-glow)}
/* Off state (dimmed, red strike) */
.ctl-icon-btn.ctl-off{background:rgba(226,92,92,.15);border-color:rgba(226,92,92,.3);color:var(--huginn-red)}
/* End call (big red) */
.ctl-icon-btn.ctl-end{background:var(--danger);border-color:var(--danger);width:58px;height:58px;box-shadow:0 0 16px var(--danger-glow)}
.ctl-icon-btn.ctl-end:hover{background:#c44040}

/* Icon toggle visibility */
.ctl-icon-btn .ico-off{display:none}
.ctl-icon-btn.ctl-off .ico-on{display:none}
.ctl-icon-btn.ctl-off .ico-off{display:block}
.ctl-icon-btn.ctl-active .ico-on{display:block}
.ctl-icon-btn.ctl-active .ico-off{display:none}

/* ── Chat Drawer ──────────────────────────── */
.chat-drawer{position:absolute;top:0;right:0;bottom:0;width:360px;z-index:30;background:rgba(10,16,22,.96);border-left:1px solid var(--line);display:flex;flex-direction:column;transform:translateX(100%);transition:transform 250ms ease;backdrop-filter:blur(12px)}
.chat-drawer.open{transform:translateX(0)}

/* Desktop: chat opens as a toggleable right sidebar */
@media(min-width:980px){
  .chat-drawer{width:var(--chatW)}
  .call-viewport.chat-open .call-controls{right:var(--chatW)}
  .call-viewport.chat-open .call-hud-top{right:var(--chatW)}
  .debug-float{left:12px}
}
.chat-drawer-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid var(--line);background:rgba(69,160,73,.03);flex-shrink:0}
.chat-drawer-right{display:flex;align-items:center;gap:8px}
.chat-messages{flex:1;overflow:auto;padding:14px;display:grid;gap:8px;align-content:start}
.chat-bubble{max-width:85%;padding:9px 12px;line-height:1.4;font-size:.9rem;border:1px solid var(--line-subtle);clip-path:var(--cut-xs)}
.chat-bubble.self{justify-self:end;background:rgba(69,160,73,.08);border-color:rgba(69,160,73,.15)}
.chat-bubble.peer{justify-self:start;background:rgba(226,92,92,.06);border-color:rgba(226,92,92,.12)}
.chat-meta{display:block;font-family:var(--font-mono);font-size:9px;color:var(--muted);margin-bottom:3px;text-transform:uppercase;letter-spacing:.1em}
.chat-form{display:flex;gap:8px;padding:10px 14px;border-top:1px solid var(--line);flex-shrink:0}
.chat-form input{flex:1;background:rgba(6,10,16,.9);border:1px solid var(--line);padding:10px 12px;color:var(--text-bright);font-size:.9rem;outline:none;border-radius:4px}
.chat-form input:focus{border-color:var(--accent)}
.chat-send-btn{width:40px!important;height:40px!important;border-radius:50%;background:var(--accent)!important;border-color:var(--accent)!important}
.chat-send-btn:hover{background:var(--accent-bright)!important}

/* ── Video Settings Panel ─────────────────── */
.video-settings{position:absolute;top:64px;left:16px;z-index:35;width:min(340px,calc(100vw - 32px));background:rgba(10,16,22,.96);border:1px solid var(--line);clip-path:var(--cut-sm);backdrop-filter:blur(14px);box-shadow:var(--shadow)}
.video-settings-head{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;border-bottom:1px solid var(--line);background:rgba(69,160,73,.03)}
.video-settings-body{padding:12px 14px;display:grid;gap:10px}
.vs-row{display:flex;align-items:center;gap:10px;font-family:var(--font-mono);font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--text-bright)}
.vs-row input{accent-color:var(--accent)}
.vs-stack{display:grid;gap:8px}
.vs-stack-head{display:flex;align-items:center;justify-content:space-between;font-family:var(--font-mono);font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--text-bright)}
.vs-stack strong{color:var(--accent-bright);font-weight:600}
.vs-stack input[type="range"]{width:100%;accent-color:var(--accent)}
.vs-note{padding:10px 12px;border:1px solid var(--line-subtle);background:rgba(69,160,73,.06);color:var(--muted);font-size:.86rem;line-height:1.45;border-radius:4px}
.vs-stack-locked .vs-stack-head strong{color:#9fe2a3}
.vs-select{width:100%;background:rgba(6,10,16,.9);border:1px solid var(--line);padding:10px 12px;color:var(--text-bright);font-size:.9rem;outline:none;border-radius:4px}
.vs-select:focus{border-color:var(--accent)}
.vs-select option{background:#091119;color:var(--text-bright)}
.vs-hint{font-family:var(--font-mono);font-size:10px;color:var(--muted);line-height:1.4;letter-spacing:.02em}

/* Debug floating panel */
.debug-float{position:absolute;bottom:80px;left:12px;z-index:20;font-family:var(--font-mono);font-size:10px}
.debug-toggle{background:rgba(0,0,0,.5);color:var(--muted);padding:4px 8px;border:1px solid var(--line-subtle);cursor:pointer;border-radius:3px;list-style:none;user-select:none}
.debug-toggle::-webkit-details-marker{display:none}
.debug-content{max-height:180px;max-width:380px;overflow:auto;background:rgba(0,0,0,.8);border:1px solid var(--line-subtle);padding:8px;margin-top:4px;border-radius:3px;color:var(--muted);white-space:pre-wrap;word-break:break-word;line-height:1.5}

/* ════════════════ RESPONSIVE ════════════════ */
@media(max-width:1100px){
    .dashboard-grid{grid-template-columns:1fr}
    .side-panel{position:static}
    .geo-map-container,.geo-map-fallback{min-height:360px}
}
@media(max-width:760px){
    .shell{width:calc(100% - 12px)}
    html{font-size:14px}
    .topbar{flex-direction:column;align-items:flex-start;gap:10px}
    .topbar-right{width:100%;justify-content:flex-end}
    .user-grid{grid-template-columns:1fr;padding:10px}
    .user-card-meta-row{align-items:flex-start;flex-direction:column}
    .user-geo-mini{text-align:left}
    .geo-map{padding:0 10px 10px}
    .geo-map-container,.geo-map-fallback{min-height:300px}
    .geo-footer-bar{grid-template-columns:1fr}
    h1{font-size:1.3rem}
    .topbar-logo{width:36px;height:36px}

    /* Call page mobile */
    .video-stage.mode-screen{grid-template-columns:minmax(0,1fr) 124px}
    .call-controls{gap:8px;padding:12px 12px 20px}
    .ctl-icon-btn{width:46px;height:46px}
    .ctl-icon-btn.ctl-end{width:52px;height:52px}
    .chat-drawer{width:100%}
    .hud-peer{font-size:.95rem}

    .video-settings{top:56px;left:10px}

    .debug-float{bottom:70px;left:8px}
    .debug-content{max-width:calc(100vw - 40px)}
}

/* ════════════════ TACTICAL ANIMATIONS ════════════════ */

/* ── Button micro-interactions ─────────────── */
.btn{transition:all 180ms cubic-bezier(.4,0,.2,1)}
.btn:hover{transform:translateY(-1px)}
.btn:active{transform:translateY(0) scale(.97);transition-duration:60ms}
.btn-primary:hover{box-shadow:0 6px 28px var(--accent-glow)}
.btn-primary:active{box-shadow:0 2px 8px var(--accent-glow)}
.btn-danger:hover{box-shadow:0 6px 28px var(--danger-glow)}
.btn-danger:active{box-shadow:0 2px 8px var(--danger-glow)}
.btn-secondary:hover{background:rgba(69,160,73,.06)}

/* ── Panel reveal ──────────────────────────── */
.panel{animation:panel-reveal 400ms cubic-bezier(.4,0,.2,1) both}
@keyframes panel-reveal{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}

/* ── User card stagger + hover ─────────────── */
.user-card{transition:border-color 250ms ease,box-shadow 250ms ease,transform 200ms ease}
.user-card:hover{border-color:var(--line);transform:translateY(-2px);box-shadow:0 4px 16px rgba(0,0,0,.3)}
.user-card.is-self:hover{box-shadow:inset 0 0 0 1px rgba(69,160,73,.28),0 4px 16px rgba(0,0,0,.3)}

/* ── Status dot enhanced pulse ─────────────── */
.status-dot{transition:background 300ms ease,box-shadow 300ms ease}
.status-dot.online{animation:pulse-dot 2s ease-in-out infinite;box-shadow:0 0 6px rgba(69,160,73,.4)}
.status-dot.busy{animation:pulse-dot-warn 2.4s ease-in-out infinite;box-shadow:0 0 6px rgba(212,168,67,.3)}
@keyframes pulse-dot{0%,100%{opacity:1;box-shadow:0 0 6px rgba(69,160,73,.4)}50%{opacity:.5;box-shadow:0 0 2px rgba(69,160,73,.2)}}
@keyframes pulse-dot-warn{0%,100%{opacity:1;box-shadow:0 0 6px rgba(212,168,67,.3)}50%{opacity:.6;box-shadow:0 0 2px rgba(212,168,67,.15)}}

/* ── Status pill glow ──────────────────────── */
.status-pill{transition:border-color 200ms ease,color 200ms ease}

/* ── Modal enhanced enter/exit ─────────────── */
.modal:not(.hidden){animation:modal-backdrop-in 250ms ease-out both}
@keyframes modal-backdrop-in{from{opacity:0}to{opacity:1}}
.modal-card{animation:modal-card-in 280ms cubic-bezier(.34,1.56,.64,1) both}
@keyframes modal-card-in{from{opacity:0;transform:translateY(20px) scale(.92)}to{opacity:1;transform:translateY(0) scale(1)}}

/* ── Incoming call pulse enhanced ──────────── */
.incoming-pulse{animation:incoming-glow 1.5s ease-in-out infinite}
@keyframes incoming-glow{
  0%,100%{box-shadow:0 0 0 0 rgba(69,160,73,0)}
  50%{box-shadow:0 0 24px 4px rgba(69,160,73,.18)}
}
.incoming-pulse::before{animation:ring-glow 1.5s ease-in-out infinite}

/* ── HUD badge transitions ─────────────────── */
.hud-badge{transition:background 300ms ease,color 300ms ease}
.hud-badge-success{animation:badge-connect 500ms ease-out}
@keyframes badge-connect{0%{transform:scale(.8);opacity:.5}50%{transform:scale(1.08)}100%{transform:scale(1);opacity:1}}

/* ── Call control hover glow ───────────────── */
.ctl-icon-btn{transition:all 180ms cubic-bezier(.4,0,.2,1)}
.ctl-icon-btn:hover{transform:scale(1.06);box-shadow:0 0 14px rgba(255,255,255,.1)}
.ctl-icon-btn:active{transform:scale(.92);transition-duration:60ms}
.ctl-icon-btn.ctl-active:hover{box-shadow:0 0 18px var(--accent-glow)}
.ctl-icon-btn.ctl-end:hover{box-shadow:0 0 22px var(--danger-glow);transform:scale(1.08)}

/* ── Form input focus glow ─────────────────── */
.field input{transition:border-color 200ms ease,box-shadow 200ms ease}
.field input:focus{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-glow),0 0 12px rgba(69,160,73,.1)}

/* ── Alert slide-in ────────────────────────── */
.alert{animation:alert-in 300ms ease-out both}
@keyframes alert-in{from{opacity:0;transform:translateX(-8px)}to{opacity:1;transform:translateX(0)}}

/* ── Identity card subtle glow ─────────────── */
.identity-card{transition:border-color 200ms ease,box-shadow 250ms ease}
.identity-card:hover{border-color:var(--line-strong);box-shadow:0 0 12px rgba(69,160,73,.08)}

/* ── Topbar logo hover ─────────────────────── */
.topbar-logo{transition:filter 300ms ease,transform 300ms ease}
.topbar-logo:hover{transform:scale(1.05);filter:drop-shadow(0 0 14px var(--brand-primary-glow))}

/* ── Mini-item hover ───────────────────────── */
.mini-item{transition:border-color 200ms ease,background 200ms ease}
.mini-item:hover{border-color:var(--line);background:rgba(255,255,255,.015)}

/* ── Audit table row hover ─────────────────── */
.audit-table tr{transition:background 150ms ease}

/* ── Chat bubble appear ────────────────────── */
.chat-bubble{animation:chat-pop 200ms cubic-bezier(.4,0,.2,1) both}
@keyframes chat-pop{from{opacity:0;transform:translateY(6px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}

/* ── Chat drawer slide ─────────────────────── */
.chat-drawer{transition:transform 280ms cubic-bezier(.4,0,.2,1)}

/* ── Scanline overlay (very subtle) ────────── */
.app-body .topbar::after{content:'';position:absolute;inset:0;background:repeating-linear-gradient(0deg,transparent,transparent 1px,rgba(0,0,0,.03) 1px,rgba(0,0,0,.03) 2px);pointer-events:none;z-index:3}

/* ════════════════ REDUCED MOTION ════════════════ */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}
  .admin-panel{transition:none!important}
  .admin-panel.hidden{display:none!important}
}

/* ── Sound Settings Panel ────────────────── */
.sound-field-group{display:grid;gap:8px;padding:10px 0;border-bottom:1px solid var(--line-subtle)}
.sound-field-group:last-of-type{border-bottom:none}
.sound-field-actions{justify-content:flex-end}

/* ── Admin action buttons in mini-item ────── */
.mini-item .stack-inline-sm{flex-shrink:0}
.mini-item .btn{font-size:10px;padding:6px 10px;letter-spacing:.08em}

/* Scrollbar */
::-webkit-scrollbar{width:4px;height:4px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--accent-dim)}
::-webkit-scrollbar-thumb:hover{background:var(--accent)}
::selection{background:var(--accent);color:#000}

/* iOS safe area for notch */
@supports(padding-top:env(safe-area-inset-top)){
    .call-hud-top{padding-top:calc(12px + env(safe-area-inset-top))}
}


/* ════════════════ SURGICAL UPGRADE / OPERATOR SELECT ════════════════ */
.topbar-right{display:flex;align-items:center;gap:10px}
.identity-card{display:flex;align-items:center;gap:12px}
.identity-avatar-shell{width:44px;height:44px;border:1px solid var(--line-strong);background:linear-gradient(180deg,rgba(14,22,30,.95),rgba(7,11,16,.98));display:grid;place-items:center;clip-path:var(--cut-xs);overflow:hidden;box-shadow:0 0 0 1px rgba(255,255,255,.02) inset}
.identity-avatar-img{width:100%;height:100%;object-fit:cover}
.identity-avatar-fallback{font-family:var(--font-display);font-size:1.1rem;font-weight:800;letter-spacing:.08em;color:var(--text-bright)}

.tactical-panel{overflow:hidden}
.tactical-panel-body{display:grid;gap:14px;padding:14px}
.tactical-hero-block{position:relative;padding:18px;border:1px solid var(--line-subtle);background:linear-gradient(135deg,rgba(18,28,34,.96),rgba(8,12,18,.98));clip-path:var(--cut-sm);overflow:hidden}
.tactical-hero-block::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at top right,rgba(212,168,67,.12),transparent 34%),linear-gradient(90deg,transparent,rgba(69,160,73,.06),transparent);pointer-events:none}
.tactical-hero-copy{position:relative;display:grid;gap:8px;margin-bottom:14px}
.tactical-hero-copy h3{font-family:var(--font-display);font-size:1.8rem;letter-spacing:.06em;text-transform:uppercase;color:var(--text-bright)}
.tactical-hero-copy p{max-width:40ch;color:#b8c9d3;font-size:1rem;line-height:1.45}
.tactical-summary{border:1px solid var(--line-subtle);border-bottom:none;background:rgba(255,255,255,.02)}
.tactical-stat-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}
.tactical-stat-card{padding:14px 16px;border:1px solid var(--line-subtle);background:linear-gradient(180deg,rgba(14,22,30,.92),rgba(8,12,18,.98));clip-path:var(--cut-sm);display:grid;gap:6px;position:relative;overflow:hidden}
.tactical-stat-card::after{content:'';position:absolute;left:0;right:0;bottom:0;height:1px;background:linear-gradient(90deg,var(--accent),rgba(212,168,67,.45),transparent)}
.tactical-stat-label{font-family:var(--font-mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}
.tactical-stat-card strong{font-family:var(--font-display);font-size:2rem;line-height:1;color:var(--text-bright)}
.tactical-roster-wrap{border:1px solid var(--line-subtle);background:rgba(8,12,18,.9);clip-path:var(--cut-sm);overflow:hidden}
.panel-subhead{padding:12px 14px;border-bottom:1px solid var(--line-subtle);background:rgba(69,160,73,.03)}
.tactical-roster-list{display:grid;gap:8px;padding:12px}
.tactical-roster-item{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:10px;padding:10px 12px;border:1px solid var(--line-subtle);background:rgba(255,255,255,.02);clip-path:var(--cut-xs)}
.tactical-roster-item.is-self{border-color:rgba(69,160,73,.24);background:rgba(69,160,73,.05)}
.tactical-roster-copy{display:grid;gap:2px;min-width:0}
.tactical-roster-copy strong{font-family:var(--font-display);font-size:1rem;letter-spacing:.04em;text-transform:uppercase;color:var(--text-bright)}
.tactical-roster-copy span{font-family:var(--font-mono);font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.tactical-roster-avatar{width:46px;height:46px}

.user-grid{grid-template-columns:repeat(auto-fill,minmax(305px,1fr));gap:14px;padding:14px}
.operator-card{grid-template-columns:136px 1fr;grid-template-areas:'portrait head' 'portrait telemetry' 'portrait actions';gap:12px;min-height:210px;padding:14px;border:1px solid rgba(255,255,255,.05);background:linear-gradient(160deg,rgba(15,24,32,.98),rgba(7,10,15,.99));box-shadow:0 10px 30px rgba(0,0,0,.28), inset 0 0 0 1px rgba(255,255,255,.015)}
.operator-card::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,transparent 0%,rgba(69,160,73,.03) 100%);pointer-events:none}
.operator-card.is-self{border-color:rgba(69,160,73,.34);background:linear-gradient(160deg,rgba(18,30,32,.98),rgba(7,10,15,.99));box-shadow:0 0 0 1px rgba(69,160,73,.14) inset,0 12px 32px rgba(0,0,0,.32)}
.operator-card.is-busy{border-color:rgba(212,168,67,.2)}
.operator-card-top{grid-area:head;align-items:flex-start}
.operator-card-portrait{grid-area:portrait;display:grid;align-content:space-between;gap:12px;min-width:0}
.operator-card-statuses{display:flex;flex-wrap:wrap;gap:8px}
.operator-card-telemetry{grid-area:telemetry;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}
.operator-meta-block{padding:10px 12px;border:1px solid var(--line-subtle);background:rgba(255,255,255,.025);clip-path:var(--cut-xs);min-width:0}
.operator-meta-label{display:block;margin-bottom:6px;font-family:var(--font-mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}
.operator-meta-block strong{display:block;font-size:1rem;line-height:1.35;color:var(--text-bright);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.operator-card-actions{grid-area:actions;justify-content:flex-end;align-items:end}
.operator-call-btn{min-width:124px;min-height:46px;font-size:1rem;letter-spacing:.18em}
.operator-avatar{width:100%;aspect-ratio:4/5;min-height:148px}
.avatar-shell{position:relative;display:grid;place-items:center;border:1px solid rgba(255,255,255,.07);background:radial-gradient(circle at top,rgba(69,160,73,.12),rgba(8,12,18,.98) 72%);clip-path:var(--cut-sm);overflow:hidden;box-shadow:0 0 0 1px rgba(255,255,255,.015) inset}
.avatar-shell::before{content:'';position:absolute;inset:0;border:1px solid rgba(212,168,67,.14);pointer-events:none;clip-path:inherit}
.avatar-image{width:100%;height:100%;object-fit:cover;filter:saturate(.95) contrast(1.04)}
.avatar-fallback{font-family:var(--font-display);font-size:2.2rem;font-weight:800;letter-spacing:.14em;color:var(--text-bright);text-shadow:0 3px 20px rgba(0,0,0,.45)}
.avatar-shell:not(.avatar-failed) .avatar-fallback{display:none}
.admin-user-avatar{width:58px;height:58px;flex-shrink:0}
.admin-user-main{display:flex;align-items:center;gap:12px;min-width:0}
.admin-user-item{padding:12px 14px;background:rgba(255,255,255,.015)}
.admin-user-controls{justify-content:flex-end}
.admin-panel-note{padding:12px 18px 0;font-family:var(--font-mono);font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}
.status-pill-green{color:var(--accent-bright);border-color:rgba(69,160,73,.25);background:rgba(69,160,73,.08)}
.status-pill-amber{color:#f1d385;border-color:rgba(212,168,67,.24);background:rgba(212,168,67,.09)}
.status-pill-red{color:#f0b0b0;border-color:rgba(226,92,92,.26);background:rgba(226,92,92,.08)}
.status-pill-muted{color:var(--muted);border-color:var(--line-subtle);background:rgba(255,255,255,.03)}
.status-pill-outline{color:#c4d8c8;border-color:rgba(255,255,255,.14);background:transparent}

.admin-panel{position:fixed;top:50%;left:50%;display:flex;flex-direction:column;width:min(860px,calc(100vw - 36px));height:min(84vh,900px);max-height:min(84vh,900px);overflow:hidden;z-index:96;opacity:0;transform:translate(-50%,calc(-50% + 20px)) scale(.96);pointer-events:none;margin:0!important;clip-path:var(--cut);box-shadow:0 24px 64px rgba(0,0,0,.45);animation:none!important;inset:auto auto auto auto}
#adminLogsPanel{width:min(1040px,calc(100vw - 36px))}
#adminSoundPanel{width:min(760px,calc(100vw - 36px))}
.admin-panel > .panel-header{flex:0 0 auto}
.admin-panel-scroll{flex:1 1 auto;min-height:0;overflow-y:auto;overflow-x:hidden;padding:14px 18px 18px;scrollbar-gutter:stable both-edges}
.admin-panel-scroll > :first-child{margin-top:0}
.admin-panel-scroll > :last-child{margin-bottom:0}
.admin-panel-scroll .table-wrap{overflow:auto;max-width:100%}
.admin-panel.is-visible{opacity:1;transform:translate(-50%,-50%) scale(1);pointer-events:auto;transition:opacity 180ms ease,transform 220ms cubic-bezier(.2,.9,.2,1)}
.admin-panel.is-closing{opacity:0;transform:translate(-50%,calc(-50% + 16px)) scale(.98);pointer-events:none;transition:opacity 160ms ease,transform 160ms ease}
.admin-panel.hidden{display:none!important;max-height:none;opacity:0;margin:0;border-color:var(--line);pointer-events:none;padding:0;min-height:0}
.admin-panel-backdrop{position:fixed;inset:0;background:rgba(3,5,9,.76);backdrop-filter:blur(6px);z-index:95;opacity:0;pointer-events:none}
.admin-panel-backdrop.is-visible{opacity:1;pointer-events:auto;transition:opacity 180ms ease}
.admin-panel-backdrop.is-closing{opacity:0;pointer-events:none;transition:opacity 160ms ease}
.admin-window-close{display:inline-grid;place-items:center;width:38px;height:38px;border:1px solid var(--line-strong);background:rgba(14,22,30,.92);color:var(--text-bright);font-size:1.4rem;line-height:1;clip-path:var(--cut-xs);transition:border-color 160ms ease,transform 160ms ease,background 160ms ease}
.admin-window-close:hover{border-color:rgba(212,168,67,.32);color:#f5d88b;background:rgba(212,168,67,.09);transform:translateY(-1px)}
body.admin-popup-open{overflow:hidden}

body > .admin-panel,
body > .admin-panel-backdrop{position:fixed}

body > .admin-panel{
  top:50%;
  left:50%;
  right:auto!important;
  bottom:auto!important;
  margin:0!important;
}

body > .admin-panel-backdrop{
  inset:0;
}

.operator-card,.avatar-shell,.tactical-roster-item,.tactical-stat-card,.admin-panel,.admin-panel-backdrop{transition:transform 220ms cubic-bezier(.2,.9,.2,1),opacity 220ms ease,border-color 220ms ease,box-shadow 220ms ease,background 220ms ease}
.operator-card:hover{transform:translateY(-4px) scale(1.01);border-color:rgba(69,160,73,.22);box-shadow:0 20px 36px rgba(0,0,0,.32),0 0 0 1px rgba(69,160,73,.08) inset}
.operator-card:hover .operator-avatar{box-shadow:0 0 0 1px rgba(69,160,73,.14) inset,0 0 22px rgba(69,160,73,.08)}
.operator-card:hover .avatar-image{transform:scale(1.03)}
.avatar-image{transition:transform 260ms ease,filter 260ms ease}
.operator-card:hover .status-pill{border-color:rgba(212,168,67,.24)}
.operator-call-btn:hover{letter-spacing:.22em}
.tactical-roster-item:hover{border-color:rgba(69,160,73,.2);transform:translateX(2px)}
.tactical-stat-card:hover{border-color:rgba(212,168,67,.22);transform:translateY(-2px)}

@media(max-width:1100px){
  .dashboard-grid{grid-template-columns:1fr}
  .side-panel{position:static}
}
@media(max-width:860px){
  .operator-card{grid-template-columns:1fr;grid-template-areas:'portrait' 'head' 'telemetry' 'actions'}
  .operator-avatar{width:100%;max-width:none}
  .operator-card-telemetry{grid-template-columns:1fr}
  .operator-card-actions{justify-content:stretch}
  .operator-call-btn{width:100%}
  .admin-panel{width:min(100vw - 18px,860px);height:min(88vh,900px);max-height:min(88vh,900px)}
}
@media(max-width:760px){
  .tactical-stat-grid{grid-template-columns:1fr 1fr}
  .user-grid{grid-template-columns:1fr}
  .admin-user-item,.tactical-roster-item{grid-template-columns:1fr;align-items:flex-start}
  .admin-user-main{width:100%}
  .admin-user-controls{justify-content:flex-start}
  .topbar-right{width:100%;justify-content:space-between}
  .admin-panel-scroll{padding:12px 12px 14px}
}

/* ===== 2026-04 ops refresh ===== */
.login-body-refined{
    background:
        radial-gradient(circle at top right, rgba(69,160,73,.16), transparent 32%),
        radial-gradient(circle at bottom left, rgba(226,92,92,.12), transparent 28%),
        linear-gradient(180deg,#05090d 0%,#08111a 100%);
}
.auth-shell-wide{max-width:1220px}
.auth-panel.auth-panel-refined{width:min(1180px,calc(100% - 32px));padding:28px;border-color:rgba(69,160,73,.18)}
.auth-hero-grid{display:grid;grid-template-columns:minmax(0,1.2fr) minmax(360px,.8fr);gap:28px;align-items:stretch}
.auth-panel-header{padding:0 0 10px;background:none;border-bottom:0}
.auth-logo-mark{width:74px;height:74px;margin-bottom:10px}
.auth-copy-block,.auth-form-block{display:flex;flex-direction:column;justify-content:center}
.auth-feature-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;margin-top:14px}
.auth-feature-card{padding:16px;border:1px solid var(--line);background:rgba(255,255,255,.03);clip-path:var(--cut-xs)}
.auth-feature-kicker{display:block;font-family:var(--font-mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--accent-bright);margin-bottom:8px}
.auth-feature-card strong{display:block;margin-bottom:8px;font-size:1rem}
.auth-feature-card p{margin:0;color:var(--muted);font-size:.92rem;line-height:1.5}
.remembered-user-card{display:flex;align-items:center;gap:14px;padding:16px 18px;margin-bottom:16px;border:1px solid rgba(69,160,73,.18);background:rgba(69,160,73,.06);clip-path:var(--cut-xs)}
.remembered-avatar-shell{width:64px;height:64px;border-radius:18px;overflow:hidden;position:relative;background:rgba(255,255,255,.06);display:flex;align-items:center;justify-content:center;border:1px solid var(--line)}
.remembered-avatar-img{width:100%;height:100%;object-fit:cover}
.remembered-avatar-fallback{font-size:1.05rem;font-family:var(--font-display);font-weight:700;color:var(--text-bright)}
.remembered-copy{display:grid;gap:4px}
.remembered-label{font-family:var(--font-mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--accent-bright)}
.auth-form-modern{padding:18px;border:1px solid var(--line);background:rgba(255,255,255,.025);clip-path:var(--cut-xs)}
.auth-submit-btn{margin-top:6px}
.auth-footnote{margin-top:12px;font-size:.86rem;color:var(--muted);line-height:1.5}

.topbar-ops{display:grid;grid-template-columns:minmax(240px,.85fr) minmax(260px,.7fr) minmax(420px,1fr);gap:18px;align-items:start}
.topbar-subline{margin:6px 0 0;color:var(--muted);font-size:.92rem}
.topbar-center{display:flex;align-items:stretch;justify-content:center}
.compact-stat-grid{display:grid;grid-template-columns:repeat(4,minmax(88px,1fr));gap:10px;width:100%}
.compact-stat-card{padding:14px 12px;border:1px solid var(--line);background:rgba(255,255,255,.03);clip-path:var(--cut-xs);display:grid;gap:6px;text-align:center}
.compact-stat-card span{font-family:var(--font-mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}
.compact-stat-card strong{font-family:var(--font-display);font-size:1.35rem;color:var(--text-bright)}
.topbar-right-extended{display:flex;justify-content:flex-end;gap:16px;align-items:stretch}
.general-chat-card-header{width:min(380px,100%);padding:0;display:flex;flex-direction:column;overflow:hidden}
.general-chat-messages{flex:1;min-height:162px;max-height:210px;overflow:auto;padding:12px;display:grid;gap:8px;align-content:start}
.general-chat-form{display:flex;gap:8px;padding:12px;border-top:1px solid var(--line)}
.general-chat-form input{flex:1;background:rgba(6,10,16,.9);border:1px solid var(--line);padding:10px 12px;color:var(--text-bright);font-size:.94rem;outline:none;border-radius:4px}
.general-chat-form input:focus{border-color:var(--accent)}
.profile-cluster{display:grid;gap:12px;min-width:220px}
.profile-identity-card{min-width:240px}
.profile-actions{display:flex;gap:10px;justify-content:flex-end}
.identity-avatar-shell-large{width:84px;height:84px;border-radius:24px}
.wrap-inline{flex-wrap:wrap}
.compact-panel-header{padding:14px 16px}
.panel-subcopy{margin-top:6px;color:var(--muted)}
.dashboard-grid-ops{grid-template-columns:minmax(0,1fr) 360px}
.side-panel-ops{display:grid;gap:14px;align-content:start}
.squad-list{display:grid;gap:12px;grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}
.squad-card{padding:14px;border:1px solid var(--line);background:rgba(255,255,255,.03);clip-path:var(--cut-xs);display:grid;gap:12px}
.squad-card-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}
.squad-chip-row{display:flex;flex-wrap:wrap;gap:8px}
.squad-chip{padding:6px 10px;border:1px solid rgba(69,160,73,.16);background:rgba(69,160,73,.08);font-size:.8rem;border-radius:999px;color:var(--text-bright)}
.squad-chip-muted{border-color:var(--line);background:rgba(255,255,255,.04);color:var(--muted)}
.squad-card-actions{align-items:center}
.feed-list{display:grid;gap:10px}
.checkbox-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}
.compact-checkbox-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
.checkbox-pill{display:flex;align-items:center;gap:10px;padding:10px 12px;border:1px solid var(--line);background:rgba(255,255,255,.03);clip-path:var(--cut-xs);cursor:pointer}
.checkbox-pill input{accent-color:var(--accent)}
.checkbox-pill small{display:block;color:var(--muted);font-size:.76rem}
.squad-manager-list{display:grid;gap:14px}
.squad-manage-card{display:grid;gap:14px}
.admin-user-controls-grid{display:grid;gap:10px;justify-items:end}
.compact-field{min-width:180px}
.inline-field{margin:0}
.inline-field span{font-size:10px}
.inline-field select{min-width:160px}
.admin-panel-scroll{padding:18px;overflow:auto;display:grid;gap:14px;flex:1;min-height:0}
.self-avatar-preview-row{align-items:center}
.table-compact th,.table-compact td{white-space:nowrap}

.squad-body{background:linear-gradient(180deg,#05090d 0%,#0a131d 100%)}
.squad-shell{max-width:1280px}
.squad-room-shell{padding:0;overflow:hidden}
.squad-room-header{padding:20px 24px}
.squad-room-grid{display:grid;grid-template-columns:360px minmax(0,1fr);gap:18px;padding:0 24px 24px}
.squad-audio-panel,.squad-chat-panel{padding:0;overflow:hidden;display:flex;flex-direction:column}
.squad-controls-row{display:flex;gap:10px;padding:14px 16px;border-bottom:1px solid var(--line)}
.squad-participants{display:grid;gap:10px;padding:16px;max-height:540px;overflow:auto;align-content:start}
.participant-row{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:12px;border:1px solid var(--line);background:rgba(255,255,255,.03);clip-path:var(--cut-xs)}
.participant-row.is-self{border-color:rgba(69,160,73,.22);background:rgba(69,160,73,.08)}
.participant-main{display:flex;align-items:center;gap:12px}
.squad-room-note{padding:0 16px 16px;color:var(--muted);font-size:.9rem;line-height:1.5}
.squad-chat-messages{min-height:420px;max-height:540px}
.squad-chat-form{border-top:1px solid var(--line)}

@media(max-width:1260px){
  .topbar-ops{grid-template-columns:1fr;}
  .topbar-right-extended{flex-direction:column;align-items:stretch}
  .general-chat-card-header{width:100%}
}
@media(max-width:1100px){
  .dashboard-grid-ops{grid-template-columns:1fr}
  .squad-room-grid{grid-template-columns:1fr}
}
@media(max-width:760px){
  .auth-hero-grid{grid-template-columns:1fr}
  .auth-feature-grid{grid-template-columns:1fr}
  .compact-stat-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .checkbox-grid,.compact-checkbox-grid{grid-template-columns:1fr}
  .profile-actions{justify-content:flex-start}
  .general-chat-messages{max-height:180px}
  .squad-room-grid{padding:0 12px 12px}
  .squad-room-header{padding:16px 12px}
  .participant-row{flex-direction:column;align-items:flex-start}
}

/* ════════════════════════════════════════════
   v9 OVERHAUL — OPS DASHBOARD + SQUAD ROOM
   ════════════════════════════════════════════ */

/* ── Topbar (clean 3-zone flex) ────────────── */
.ops-topbar{
    display:grid;
    grid-template-columns:minmax(220px,auto) 1fr minmax(280px,auto);
    align-items:center;
    gap:18px;
    padding:14px 20px;
    margin-bottom:14px;
}
.ops-topbar-brand{display:flex;align-items:center;gap:14px;min-width:0}
.ops-topbar-logo{
    width:46px;height:46px;
    filter:drop-shadow(0 0 10px var(--brand-primary-glow));
    flex-shrink:0;
    transition:transform 300ms ease,filter 300ms ease;
}
.ops-topbar-logo:hover{transform:scale(1.05);filter:drop-shadow(0 0 14px var(--brand-primary-glow))}
.ops-topbar-brand h1{
    font-size:1.35rem;
    background:linear-gradient(180deg,var(--brand-primary-bright),var(--brand-primary-dim));
    -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}

.ops-topbar-stats{
    display:grid;
    grid-template-columns:repeat(4,minmax(0,1fr));
    gap:10px;
    max-width:560px;
    justify-self:center;
    width:100%;
}
.ops-stat{
    padding:10px 12px;
    border:1px solid var(--line-subtle);
    background:rgba(255,255,255,.025);
    clip-path:var(--cut-xs);
    text-align:center;
    transition:border-color 200ms ease;
}
.ops-stat:hover{border-color:var(--line)}
.ops-stat span{
    display:block;
    font-family:var(--font-mono);
    font-size:9px;
    letter-spacing:.14em;
    text-transform:uppercase;
    color:var(--muted);
}
.ops-stat strong{
    display:block;
    margin-top:4px;
    font-family:var(--font-display);
    font-size:1.5rem;
    line-height:1;
    color:var(--text-bright);
}

.ops-topbar-identity{
    display:flex;
    align-items:center;
    gap:10px;
    justify-self:end;
}
.ops-topbar-identity .identity-card{
    display:flex;
    align-items:center;
    gap:12px;
    padding:8px 12px;
    background:rgba(255,255,255,.025);
    border:1px solid var(--line);
    clip-path:var(--cut-xs);
}
.identity-text{display:flex;flex-direction:column;min-width:0}
.identity-text .identity-name{
    font-family:var(--font-display);
    font-weight:700;
    font-size:.92rem;
    text-transform:uppercase;
    letter-spacing:.04em;
    color:var(--text-bright);
    white-space:nowrap;
    overflow:hidden;
    text-overflow:ellipsis;
    max-width:160px;
}
.ops-topbar-buttons{display:flex;gap:6px}

/* Icon-only button */
.btn-icon{
    width:42px;
    height:42px;
    padding:0;
    display:inline-grid;
    place-items:center;
}
.btn-icon svg{display:block}

/* ── Admin bar ─────────────────────────────── */
.ops-admin-bar{
    display:flex;
    align-items:center;
    gap:14px;
    padding:12px 18px;
    margin-bottom:14px;
    flex-wrap:wrap;
}
.ops-admin-bar > .eyebrow{flex-shrink:0}
.ops-admin-bar-buttons{
    display:flex;
    gap:8px;
    flex-wrap:wrap;
    flex:1;
    justify-content:flex-end;
}
.ops-admin-bar-buttons .btn{padding:8px 14px;font-size:.78rem}

/* ── Dashboard 3-column layout ─────────────── */
.ops-dashboard{
    display:grid;
    grid-template-columns:minmax(0,1.6fr) minmax(0,1fr) minmax(300px,360px);
    grid-template-areas:
        'directory squads chat'
        'directory squads chat';
    gap:14px;
    align-items:start;
}
.ops-directory{grid-area:directory}
.ops-squads{grid-area:squads;display:flex;flex-direction:column}
.ops-chat{
    grid-area:chat;
    display:flex;
    flex-direction:column;
    position:sticky;
    top:14px;
    max-height:calc(100vh - 28px);
}

/* Directory tweaks */
.ops-directory .user-grid{
    grid-template-columns:repeat(auto-fill,minmax(280px,1fr));
    gap:14px;
    padding:14px;
}

/* Squads list inside ops-squads */
.ops-squads .squad-list{
    display:flex;
    flex-direction:column;
    gap:12px;
    padding:14px 16px 16px;
}
.ops-squads .squad-card{
    padding:14px;
    border:1px solid var(--line-subtle);
    background:linear-gradient(160deg,rgba(15,24,32,.96),rgba(8,12,18,.99));
    clip-path:var(--cut-xs);
    display:grid;
    gap:10px;
    transition:border-color 200ms ease,transform 200ms ease;
}
.ops-squads .squad-card:hover{
    border-color:rgba(69,160,73,.28);
    transform:translateY(-2px);
}

/* General chat sidebar */
.ops-chat-messages{
    flex:1;
    overflow-y:auto;
    padding:12px 14px;
    display:flex;
    flex-direction:column;
    gap:10px;
    min-height:300px;
    border-bottom:1px solid var(--line-subtle);
    background:rgba(0,0,0,.12);
}
.ops-chat-messages .feed-item{
    border-left:2px solid var(--accent-dim);
    padding:8px 10px;
    background:rgba(255,255,255,.02);
    font-size:.86rem;
}
.ops-chat-messages .feed-item.muted{
    border-left-color:var(--line);
    color:var(--muted);
    text-align:center;
    background:transparent;
}
.ops-chat-form{
    display:flex;
    gap:8px;
    padding:12px 14px;
}
.ops-chat-form input{
    flex:1;
    min-width:0;
    background:rgba(6,10,16,.9);
    border:1px solid var(--line);
    padding:10px 12px;
    color:var(--text-bright);
    font-size:.9rem;
    outline:none;
    clip-path:var(--cut-xs);
    transition:border-color 150ms;
}
.ops-chat-form input:focus{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-glow)}
.ops-chat-form .btn{padding:10px 16px;font-size:.78rem}

/* Form 2-column grid (admin user create) */
.form-grid-2{
    display:grid;
    grid-template-columns:repeat(2,minmax(0,1fr));
    gap:12px;
    padding:14px 18px;
}
.form-grid-full{grid-column:1 / -1}
.form-grid-2 select{
    width:100%;
    background:rgba(6,10,16,.9);
    border:1px solid var(--line);
    padding:11px 14px;
    color:var(--text-bright);
    font-family:var(--font-body);
    font-size:.95rem;
    outline:none;
    clip-path:var(--cut-xs);
}
.form-grid-2 select:focus{border-color:var(--accent)}

/* Reduce squad picker checkbox grid columns inside modals */
#createSquadMemberPicker.checkbox-grid{
    grid-template-columns:repeat(2,minmax(0,1fr));
}

/* ── Self-avatar panel layout ──────────────── */
.self-avatar-preview-row{
    display:flex;
    align-items:center;
    gap:16px;
    margin-bottom:6px;
}
.self-avatar-name{
    display:block;
    font-family:var(--font-display);
    font-size:1.05rem;
    letter-spacing:.04em;
    text-transform:uppercase;
    color:var(--text-bright);
    margin-bottom:6px;
}
.identity-avatar-shell-large{
    width:84px;
    height:84px;
    flex-shrink:0;
}
.identity-avatar-shell-large .identity-avatar-fallback{font-size:1.6rem}

/* ════════════════════════════════════════════
   SQUAD ROOM v9
   ════════════════════════════════════════════ */
.squad-body{
    background:
        radial-gradient(circle at top right,rgba(69,160,73,.08),transparent 40%),
        linear-gradient(180deg,#05090d 0%,#0a131d 100%);
}
.squad-shell{max-width:1320px}

.squad-topbar{
    display:grid;
    grid-template-columns:auto 1fr auto;
    align-items:center;
    gap:18px;
    padding:16px 22px;
    margin-bottom:14px;
}
.squad-back-btn{
    width:44px;height:44px;
    display:inline-grid;
    place-items:center;
    border:1px solid var(--line-strong);
    background:rgba(14,22,30,.92);
    color:var(--text-bright);
    clip-path:var(--cut-xs);
    transition:all 160ms ease;
    flex-shrink:0;
}
.squad-back-btn:hover{
    border-color:var(--accent);
    color:var(--accent-bright);
    background:rgba(69,160,73,.08);
    transform:translateX(-2px);
}
.squad-topbar-info{min-width:0}
.squad-topbar-info h1{
    font-size:1.4rem;
    margin-top:4px;
    background:linear-gradient(180deg,var(--accent-bright),var(--accent-dim));
    -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}
.squad-topbar-sub{
    margin-top:6px;
    font-size:.85rem;
    color:var(--muted);
    line-height:1.4;
    max-width:60ch;
}
.squad-topbar-status{
    display:flex;
    flex-direction:column;
    gap:6px;
    align-items:flex-end;
}

.squad-grid{
    display:grid;
    grid-template-columns:minmax(0,1.1fr) minmax(0,1fr);
    gap:14px;
    align-items:stretch;
}

.squad-voice-panel,
.squad-chat-panel{
    display:flex;
    flex-direction:column;
    overflow:hidden;
    min-height:580px;
}

.squad-participants{
    flex:1;
    display:grid;
    gap:10px;
    padding:16px;
    overflow-y:auto;
    align-content:start;
    min-height:0;
}
.squad-participants .participant-row{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:12px;
    padding:12px 14px;
    border:1px solid var(--line-subtle);
    background:linear-gradient(160deg,rgba(15,24,32,.96),rgba(8,12,18,.99));
    clip-path:var(--cut-xs);
    transition:border-color 200ms ease,transform 200ms ease;
}
.squad-participants .participant-row:hover{
    border-color:rgba(69,160,73,.22);
    transform:translateX(2px);
}
.squad-participants .participant-row.is-self{
    border-color:rgba(69,160,73,.32);
    background:linear-gradient(160deg,rgba(18,32,24,.96),rgba(8,16,12,.99));
}
.squad-participants .participant-main{
    display:flex;
    align-items:center;
    gap:12px;
    min-width:0;
    flex:1;
}
.squad-participants .avatar-shell{
    width:46px;
    height:46px;
    flex-shrink:0;
}
.squad-participants .avatar-fallback{font-size:1rem}
.squad-participants .user-name{
    font-family:var(--font-display);
    font-size:.95rem;
    letter-spacing:.04em;
    text-transform:uppercase;
    color:var(--text-bright);
}
.squad-participants .user-meta{
    font-family:var(--font-mono);
    font-size:10px;
    color:var(--muted);
    text-transform:uppercase;
    letter-spacing:.06em;
}

/* ── Discord-style mic toggle ──────────────── */
.squad-mic-control{
    border-top:1px solid var(--line-subtle);
    padding:20px 16px 22px;
    display:flex;
    flex-direction:column;
    align-items:center;
    gap:10px;
    background:rgba(0,0,0,.18);
}
.squad-mic-btn{
    display:inline-flex;
    align-items:center;
    gap:14px;
    padding:14px 22px 14px 16px;
    border:1px solid var(--line-strong);
    background:linear-gradient(180deg,rgba(20,30,38,.95),rgba(10,16,22,.98));
    color:var(--text-bright);
    clip-path:var(--cut-sm);
    cursor:pointer;
    transition:all 200ms cubic-bezier(.4,0,.2,1);
    font-family:var(--font-display);
    font-weight:700;
    font-size:.95rem;
    letter-spacing:.1em;
    text-transform:uppercase;
}
.squad-mic-icon{
    display:inline-grid;
    place-items:center;
    width:46px;
    height:46px;
    border-radius:50%;
    background:rgba(255,255,255,.06);
    border:1px solid rgba(255,255,255,.12);
    transition:all 200ms ease;
    flex-shrink:0;
}
.squad-mic-btn .ico-mic-off{display:none}
.squad-mic-btn .ico-mic-on{display:block}

/* MIC ON state — calm, neutral green accent */
.squad-mic-btn.mic-on{
    border-color:rgba(69,160,73,.4);
}
.squad-mic-btn.mic-on .squad-mic-icon{
    background:rgba(69,160,73,.18);
    border-color:rgba(69,160,73,.4);
    color:var(--accent-bright);
    box-shadow:0 0 16px rgba(69,160,73,.18);
}
.squad-mic-btn.mic-on:hover{
    border-color:var(--accent);
    transform:translateY(-1px);
    box-shadow:0 6px 24px rgba(0,0,0,.4);
}
.squad-mic-btn.mic-on:hover .squad-mic-icon{
    background:rgba(69,160,73,.28);
    box-shadow:0 0 22px rgba(69,160,73,.28);
}

/* MIC OFF state — clear danger signal */
.squad-mic-btn.mic-off{
    border-color:rgba(226,92,92,.5);
    background:linear-gradient(180deg,rgba(38,18,18,.95),rgba(22,10,10,.98));
    color:#f5c0c0;
}
.squad-mic-btn.mic-off .ico-mic-on{display:none}
.squad-mic-btn.mic-off .ico-mic-off{display:block}
.squad-mic-btn.mic-off .squad-mic-icon{
    background:rgba(226,92,92,.22);
    border-color:rgba(226,92,92,.55);
    color:var(--huginn-red);
    box-shadow:0 0 18px rgba(226,92,92,.32);
    animation:mic-muted-pulse 2.4s ease-in-out infinite;
}
.squad-mic-btn.mic-off:hover{
    border-color:var(--huginn-red);
    transform:translateY(-1px);
    box-shadow:0 6px 24px rgba(226,92,92,.25);
}
.squad-mic-btn.mic-off:hover .squad-mic-icon{
    background:rgba(226,92,92,.32);
}
@keyframes mic-muted-pulse{
    0%,100%{box-shadow:0 0 18px rgba(226,92,92,.32)}
    50%{box-shadow:0 0 26px rgba(226,92,92,.5)}
}

.squad-mic-btn:active{transform:translateY(0) scale(.98)}

.squad-mic-hint{
    margin:0;
    text-align:center;
    font-size:.82rem;
    color:var(--muted);
    max-width:42ch;
    line-height:1.5;
}

/* Squad chat */
.squad-chat-panel .squad-chat-messages{
    flex:1;
    min-height:0;
    max-height:none;
    overflow-y:auto;
    padding:14px 16px;
    display:flex;
    flex-direction:column;
    gap:10px;
    background:rgba(0,0,0,.14);
    border-bottom:1px solid var(--line-subtle);
}
.squad-chat-messages .chat-bubble{
    padding:10px 14px;
    border-radius:14px;
    max-width:80%;
    background:rgba(255,255,255,.04);
    border:1px solid var(--line-subtle);
    font-size:.92rem;
    line-height:1.45;
    color:var(--text-bright);
    word-wrap:break-word;
}
.squad-chat-messages .chat-bubble.self{
    align-self:flex-end;
    background:linear-gradient(180deg,rgba(69,160,73,.18),rgba(45,122,48,.14));
    border-color:rgba(69,160,73,.32);
}
.squad-chat-messages .chat-bubble.peer{
    align-self:flex-start;
}
.squad-chat-messages .chat-meta{
    display:block;
    font-family:var(--font-mono);
    font-size:10px;
    letter-spacing:.08em;
    text-transform:uppercase;
    color:var(--muted);
    margin-bottom:5px;
}
.squad-chat-messages .feed-item.muted{
    text-align:center;
    border-left:none;
    background:transparent;
    color:var(--muted);
    padding:24px 12px;
}
.squad-chat-form{
    display:flex;
    gap:8px;
    padding:12px 14px;
}
.squad-chat-form input{
    flex:1;
    min-width:0;
    background:rgba(6,10,16,.9);
    border:1px solid var(--line);
    padding:11px 14px;
    color:var(--text-bright);
    font-size:.92rem;
    outline:none;
    clip-path:var(--cut-xs);
    transition:border-color 150ms;
}
.squad-chat-form input:focus{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-glow)}
.squad-chat-form .btn{padding:11px 18px;font-size:.78rem}

/* ── Responsive ────────────────────────────── */
@media(max-width:1280px){
    .ops-dashboard{
        grid-template-columns:minmax(0,1.4fr) minmax(0,1fr);
        grid-template-areas:
            'directory squads'
            'chat chat';
    }
    .ops-chat{position:static;max-height:none}
    .ops-chat-messages{min-height:200px;max-height:280px}
}
@media(max-width:1100px){
    .squad-grid{grid-template-columns:1fr}
    .squad-voice-panel,.squad-chat-panel{min-height:440px}
}
@media(max-width:980px){
    .ops-topbar{
        grid-template-columns:1fr;
        gap:14px;
        text-align:center;
    }
    .ops-topbar-brand{justify-content:center}
    .ops-topbar-stats{justify-self:stretch;max-width:none}
    .ops-topbar-identity{justify-self:center;flex-wrap:wrap;justify-content:center}
    .ops-dashboard{
        grid-template-columns:1fr;
        grid-template-areas:
            'directory'
            'squads'
            'chat';
    }
    .form-grid-2{grid-template-columns:1fr}
    .squad-topbar{
        grid-template-columns:auto 1fr;
        gap:14px;
    }
    .squad-topbar-status{
        grid-column:1 / -1;
        flex-direction:row;
        align-items:center;
        justify-content:flex-start;
        flex-wrap:wrap;
    }
}
@media(max-width:640px){
    .ops-topbar-stats{grid-template-columns:repeat(2,1fr)}
    .ops-topbar-identity{flex-direction:column;align-items:stretch}
    .ops-topbar-identity .identity-card{justify-content:center}
    .ops-admin-bar{flex-direction:column;align-items:stretch}
    .ops-admin-bar-buttons{justify-content:stretch}
    .ops-admin-bar-buttons .btn{flex:1}
    .squad-mic-btn{padding:12px 18px 12px 14px}
    .squad-mic-icon{width:40px;height:40px}
}

/* ── General chat bubbles in sidebar ──────── */
.ops-chat-messages .chat-bubble{
    padding:9px 12px;
    border-radius:12px;
    max-width:88%;
    background:rgba(255,255,255,.04);
    border:1px solid var(--line-subtle);
    font-size:.86rem;
    line-height:1.45;
    color:var(--text-bright);
    word-wrap:break-word;
}
.ops-chat-messages .chat-bubble.self{
    align-self:flex-end;
    background:linear-gradient(180deg,rgba(69,160,73,.18),rgba(45,122,48,.14));
    border-color:rgba(69,160,73,.32);
}
.ops-chat-messages .chat-bubble.peer{align-self:flex-start}
.ops-chat-messages .chat-meta{
    display:block;
    font-family:var(--font-mono);
    font-size:9px;
    letter-spacing:.08em;
    text-transform:uppercase;
    color:var(--muted);
    margin-bottom:4px;
}

/* Phase 3 / squad room */
.squad-room-chipbar{display:flex;flex-wrap:wrap;gap:8px;padding:0 20px 14px}
.participant-side{display:grid;gap:8px;justify-items:end}
.participant-actions{display:flex;flex-wrap:wrap;gap:8px;justify-content:flex-end}
.participant-action{appearance:none;border:1px solid rgba(212,168,67,.22);background:rgba(255,255,255,.04);color:var(--text);padding:6px 10px;border-radius:999px;font-size:.72rem;font-weight:700;letter-spacing:.03em;cursor:pointer;transition:border-color .2s ease,background .2s ease,transform .18s ease}
.participant-action:hover{border-color:rgba(212,168,67,.44);background:rgba(212,168,67,.12);transform:translateY(-1px)}
.btn.is-active,.participant-action.is-active{border-color:rgba(69,160,73,.35)!important;background:rgba(69,160,73,.12)!important;color:var(--accent-bright)!important}
.squad-prejoin-overlay{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;padding:20px;background:rgba(2,6,10,.76);backdrop-filter:blur(10px);z-index:1200}
.squad-prejoin-overlay.hidden{display:none}
.squad-prejoin-card{width:min(760px,100%);display:grid;gap:18px;padding:24px}
.squad-prejoin-card h2{margin:0;font-size:1.6rem}
.squad-prejoin-copy{margin:0;color:var(--muted);line-height:1.6}
.squad-prejoin-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:18px}
.squad-prejoin-section{display:grid;gap:12px;padding:16px;border:1px solid rgba(255,255,255,.07);background:rgba(255,255,255,.03);clip-path:var(--cut-xs)}
.squad-prejoin-section h3{margin:0;font-size:.95rem}
.squad-prejoin-section-head{display:flex;align-items:center;justify-content:space-between;gap:10px}
.squad-select{width:100%;padding:11px 12px;border:1px solid var(--line);background:rgba(255,255,255,.04);color:var(--text);clip-path:var(--cut-xs)}
.squad-select:focus{outline:none;border-color:var(--accent)}
.squad-meter-shell{height:10px;border:1px solid var(--line);background:rgba(255,255,255,.04);overflow:hidden;clip-path:var(--cut-xs)}
.squad-meter-bar{height:100%;width:0%;background:linear-gradient(90deg,rgba(69,160,73,.55),rgba(212,168,67,.7));transition:width .12s ease}
.squad-prejoin-status{margin:0;color:var(--muted);font-size:.9rem}
.squad-mode-option{display:flex;gap:10px;align-items:flex-start;padding:12px;border:1px solid rgba(255,255,255,.07);background:rgba(255,255,255,.03);cursor:pointer;clip-path:var(--cut-xs)}
.squad-mode-option input{margin-top:4px}
.squad-mode-option span{display:grid;gap:4px}
.squad-mode-option small{color:var(--muted);line-height:1.5}
.squad-inline-check{display:flex;gap:10px;align-items:center;padding-top:4px;color:var(--text)}
.squad-prejoin-actions{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:10px}
.btn-sm{padding:8px 12px;font-size:.72rem}
.hidden{display:none!important}
@media (max-width: 860px){
  .squad-prejoin-grid{grid-template-columns:1fr}
}
@media (max-width: 640px){
  .participant-side{justify-items:start}
  .participant-actions{justify-content:flex-start}
  .squad-room-chipbar{padding:0 14px 12px}
  .squad-prejoin-card{padding:18px}
}

/* Phase 4 / unified room surface */
.squad-grid-phase4{
    grid-template-columns:minmax(0,1.05fr) minmax(0,.95fr) minmax(320px,.72fr);
}
.squad-shell-phase4{position:relative}
.squad-side-backdrop{position:fixed;inset:0;background:rgba(2,6,10,.56);backdrop-filter:blur(6px);z-index:1040}
.squad-side-panel{
    display:flex;
    flex-direction:column;
    overflow:hidden;
    min-height:580px;
}
.squad-side-header{padding-right:12px}
.squad-side-scroll{
    flex:1;
    min-height:0;
    overflow-y:auto;
    padding:0 14px 14px;
    display:grid;
    gap:12px;
    align-content:start;
}
.squad-side-card{
    border:1px solid var(--line-subtle);
    background:linear-gradient(160deg,rgba(15,24,32,.92),rgba(8,12,18,.98));
    clip-path:var(--cut-xs);
    padding:14px;
    display:grid;
    gap:12px;
}
.squad-side-card-feed{min-height:220px}
.squad-side-card-head{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}
.squad-side-card-head h3{margin:2px 0 0;font-size:1rem}
.squad-field{gap:8px}
.squad-field input,
.squad-field textarea{
    width:100%;
    background:rgba(6,10,16,.9);
    border:1px solid var(--line);
    color:var(--text-bright);
    padding:11px 12px;
    clip-path:var(--cut-xs);
    outline:none;
    resize:vertical;
}
.squad-field input:focus,
.squad-field textarea:focus{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-glow)}
.squad-field input[readonly],
.squad-field textarea[readonly]{opacity:.82;cursor:not-allowed}
.squad-side-actions{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:8px}
.squad-quick-actions{display:grid;grid-template-columns:1fr;gap:8px}
.squad-activity-feed{display:grid;gap:8px;align-content:start}
.room-event-row{padding:11px 12px;border:1px solid var(--line-subtle);background:rgba(255,255,255,.035);clip-path:var(--cut-xs);display:grid;gap:6px}
.room-event-top{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}
.room-event-top strong{font-size:.86rem;line-height:1.45;color:var(--text-bright);font-weight:600}
.room-event-top span{font-family:var(--font-mono);font-size:10px;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);white-space:nowrap}
.room-event-meta{font-family:var(--font-mono);font-size:10px;letter-spacing:.06em;text-transform:uppercase;color:var(--muted)}
.participant-action-call{border-color:rgba(69,160,73,.22);background:rgba(69,160,73,.08)}
.participant-action-call:hover{border-color:rgba(69,160,73,.44);background:rgba(69,160,73,.14)}
.squad-room-panel-toggle{display:none}
.squad-room-panel-close{display:none}

@media(max-width:1180px){
    .squad-grid-phase4{grid-template-columns:1fr 1fr}
    .squad-side-panel{
        position:fixed;
        top:14px;
        right:14px;
        bottom:14px;
        width:min(420px,calc(100vw - 28px));
        z-index:1050;
        transform:translateX(calc(100% + 22px));
        transition:transform 220ms ease;
        min-height:auto;
    }
    .squad-side-panel.is-open{transform:translateX(0)}
    .squad-room-panel-toggle,.squad-room-panel-close{display:inline-flex}
}
@media(max-width:980px){
    .squad-grid-phase4{grid-template-columns:1fr}
}



/* Phase 5 / room memory */
.squad-inline-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.squad-span-2{grid-column:1 / -1}
.squad-link-list,.squad-task-list{display:grid;gap:10px;align-content:start}
.room-link-row,.room-task-row{display:grid;gap:10px;padding:12px;border:1px solid var(--line-subtle);background:rgba(255,255,255,.035);clip-path:var(--cut-xs)}
.room-link-row{grid-template-columns:minmax(0,1fr) auto;align-items:flex-start}
.room-link-main,.room-task-main{min-width:0;display:grid;gap:6px}
.room-link-anchor{color:var(--accent-bright);font-weight:700;text-decoration:none;word-break:break-word}
.room-link-anchor:hover{text-decoration:underline}
.room-link-meta,.room-task-meta{display:flex;flex-wrap:wrap;gap:8px 12px;font-family:var(--font-mono);font-size:10px;letter-spacing:.05em;text-transform:uppercase;color:var(--muted);word-break:break-word}
.room-link-actions,.room-task-actions{display:flex;flex-wrap:wrap;gap:8px;align-items:flex-start;justify-content:flex-end}
.room-task-row.is-done{opacity:.82}
.room-task-top{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}
.room-task-top strong{font-size:.92rem;line-height:1.4;color:var(--text-bright)}
.room-task-details{color:var(--text);line-height:1.55;white-space:pre-wrap;word-break:break-word}
@media(max-width:980px){
  .squad-inline-grid{grid-template-columns:1fr}
  .room-link-row{grid-template-columns:1fr}
  .room-link-actions,.room-task-actions{justify-content:flex-start}
}


.ops-metric-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px;margin:0 0 14px;}
.ops-metric-card{border:1px solid rgba(255,255,255,.08);background:rgba(255,255,255,.03);border-radius:14px;padding:12px 14px;display:flex;flex-direction:column;gap:4px;}
.ops-metric-card span{font-size:12px;opacity:.72;text-transform:uppercase;letter-spacing:.08em;}
.ops-metric-card strong{font-size:26px;line-height:1.1;}
.ops-metric-card small{font-size:12px;opacity:.65;}
.ops-health-note{grid-column:1/-1;font-size:12px;opacity:.78;padding:0 0 2px;}
.ops-maintenance-actions{flex-wrap:wrap;margin:0 0 10px;}
.inline-code{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:11px;white-space:normal;word-break:break-word;}

/* Phase 7 chat enhancements */
.btn-xs {
  padding: 6px 10px;
  font-size: 12px;
}

.chat-reply-bar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding: 10px 12px;
  margin: 0 0 10px;
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 12px;
  background: rgba(255,255,255,0.03);
}

.chat-reply-text {
  min-width: 0;
  font-size: 12px;
  color: rgba(255,255,255,0.82);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.chat-reply-preview {
  display: grid;
  gap: 4px;
  margin: 8px 0;
  padding: 8px 10px;
  border-left: 3px solid rgba(255,255,255,0.18);
  border-radius: 10px;
  background: rgba(255,255,255,0.04);
  font-size: 12px;
}

.chat-reply-preview strong {
  color: rgba(255,255,255,0.9);
}

.chat-reply-preview span {
  color: rgba(255,255,255,0.7);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.chat-message-text {
  white-space: pre-wrap;
  word-break: break-word;
}

.chat-message-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: 8px;
}

.chat-mini-action,
.chat-reaction-chip {
  border: 1px solid rgba(255,255,255,0.08);
  background: rgba(255,255,255,0.04);
  color: rgba(255,255,255,0.82);
  border-radius: 999px;
  cursor: pointer;
  transition: .15s ease;
}

.chat-mini-action {
  padding: 4px 8px;
  font-size: 12px;
}

.chat-reaction-row {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: 8px;
}

.chat-reaction-chip {
  padding: 4px 10px;
  font-size: 12px;
  display: inline-flex;
  align-items: center;
  gap: 6px;
}

.chat-mini-action:hover,
.chat-reaction-chip:hover,
.chat-reaction-chip.is-active {
  background: rgba(255,255,255,0.1);
  border-color: rgba(255,255,255,0.16);
}

.status-pill-danger {
  background: rgba(255, 99, 132, 0.16);
  color: #ff9cb2;
  border: 1px solid rgba(255, 99, 132, 0.35);
}

.chat-bubble.is-mentioned {
  border-color: rgba(255, 184, 77, 0.68);
  box-shadow: 0 0 0 1px rgba(255, 184, 77, 0.14), 0 10px 30px rgba(0, 0, 0, 0.2);
}

.chat-mention-tag {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  margin-left: 8px;
  padding: 2px 8px;
  border-radius: 999px;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  background: rgba(255, 184, 77, 0.16);
  color: #ffcf7d;
  border: 1px solid rgba(255, 184, 77, 0.32);
}

#generalChatUnreadBadge.is-mention,
#chatUnreadBadge.is-mention {
  background: rgba(255, 99, 132, 0.16);
  color: #ffb6c6;
  border-color: rgba(255, 99, 132, 0.35);
}

/* Phase 5 / DM + search + dashboard polish */
.topbar-btn-with-badge{position:relative}
.topbar-count-badge{position:absolute;top:-5px;right:-5px;min-width:18px;height:18px;padding:0 5px;border-radius:999px;background:rgba(196,54,61,.95);color:#fff;font-family:var(--font-mono);font-size:10px;line-height:18px;text-align:center;border:1px solid rgba(255,255,255,.12);box-shadow:0 8px 20px rgba(196,54,61,.26)}
.panel-strip-grid{display:grid;gap:10px;grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}
.panel-strip-card{padding:12px;border:1px solid var(--line-subtle);background:rgba(255,255,255,.035);clip-path:var(--cut-xs);display:grid;gap:6px}
.panel-strip-card strong{font-size:.9rem}
.panel-strip-card small,.panel-strip-card .user-meta{color:var(--muted)}
.dm-shell{display:grid;grid-template-columns:minmax(240px,.75fr) minmax(0,1.25fr);gap:14px;min-height:520px}
.dm-conversation-list{display:grid;gap:8px;align-content:start;overflow:auto;padding-right:4px}
.dm-conversation-card{padding:12px;border:1px solid var(--line-subtle);background:rgba(255,255,255,.035);clip-path:var(--cut-xs);display:grid;gap:8px;cursor:pointer;transition:border-color .18s ease,background .18s ease,transform .18s ease}
.dm-conversation-card:hover{border-color:rgba(69,160,73,.32);background:rgba(69,160,73,.08);transform:translateY(-1px)}
.dm-conversation-card.is-active{border-color:rgba(69,160,73,.42);background:rgba(69,160,73,.12);box-shadow:0 0 0 1px rgba(69,160,73,.08)}
.dm-conversation-top,.dm-thread-head{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}
.dm-conversation-main{display:flex;gap:10px;align-items:flex-start}
.dm-avatar{width:40px;height:40px;min-width:40px}
.dm-conversation-meta{display:grid;gap:4px;min-width:0}
.dm-conversation-meta .user-name,.dm-thread-head h3{margin:0;font-size:1rem}
.dm-preview{font-size:.85rem;color:var(--muted);line-height:1.45;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}
.dm-thread-shell{display:grid;grid-template-rows:auto minmax(0,1fr) auto auto auto;gap:10px;min-width:0}
.dm-thread-messages{min-height:360px;max-height:none}
.dm-upload-row{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr) auto;gap:10px;align-items:center}
.dm-upload-row input[type="text"],.dm-upload-row input[type="file"]{width:100%;padding:10px 12px;border:1px solid var(--line);background:rgba(255,255,255,.04);color:var(--text);clip-path:var(--cut-xs)}
.dm-upload-row input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-glow)}
.dm-empty-state{padding:16px;border:1px dashed var(--line-subtle);color:var(--muted);clip-path:var(--cut-xs)}
.workspace-search-form{margin-bottom:0}
.workspace-search-results{display:grid;gap:14px;align-content:start}
.search-result-section{display:grid;gap:10px}
.search-result-grid{display:grid;gap:8px;grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}
.search-result-card{padding:12px;border:1px solid var(--line-subtle);background:rgba(255,255,255,.035);clip-path:var(--cut-xs);display:grid;gap:6px}
.search-result-card code{font-size:.78rem;white-space:pre-wrap;word-break:break-word}
.search-result-card .stack-inline-sm{align-items:center}
.user-inline-avatar{display:flex;align-items:center;gap:10px}
.squad-role-row{display:grid;grid-template-columns:minmax(0,1fr) 132px;gap:8px;align-items:center}
.squad-role-select{width:100%;padding:9px 10px;border:1px solid var(--line);background:rgba(255,255,255,.04);color:var(--text);clip-path:var(--cut-xs)}
.squad-role-select:focus{outline:none;border-color:var(--accent)}
.chat-message-text a.room-link-anchor{color:var(--accent-bright);text-decoration:none}
.chat-message-text a.room-link-anchor:hover{text-decoration:underline}
@media (max-width: 960px){
  .dm-shell{grid-template-columns:1fr}
}
@media (max-width: 720px){
  .dm-upload-row{grid-template-columns:1fr}
  .panel-strip-grid,.search-result-grid{grid-template-columns:1fr}
}

/* 2026-04-09f overrides */
.profile-menu-shell{position:relative}
.profile-menu-trigger{cursor:pointer;min-width:220px;justify-content:flex-start;text-align:left}
.identity-caret{margin-left:auto;font-size:.95rem;color:var(--muted)}
.profile-dropdown{position:absolute;top:calc(100% + 10px);right:0;min-width:240px;padding:8px;background:rgba(7,11,16,.98);border:1px solid var(--line);box-shadow:var(--shadow);clip-path:var(--cut-xs);display:grid;gap:4px;z-index:90}
.profile-dropdown.hidden{display:none}
.profile-dropdown-item{appearance:none;border:0;background:transparent;color:var(--text-bright);padding:10px 12px;text-align:left;font-size:.88rem;cursor:pointer;clip-path:var(--cut-xs);text-decoration:none}
.profile-dropdown-item:hover,.profile-dropdown-item:focus{background:rgba(69,160,73,.12);outline:none}
.profile-dropdown-item.is-link{display:block}
.profile-dropdown-separator{height:1px;background:var(--line-subtle);margin:4px 0}
.profile-dropdown-label{padding:4px 12px 2px;font-family:var(--font-mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}

/* ── Directory / Operator card rebuild (revision 2026-04-10) ──
   Replaces the earlier "display:contents" trick and the !important
   single-column override. Cards are now self-contained, compact,
   and the grid is responsive without hacks. */
.ops-dashboard{
    grid-template-columns:minmax(0,1.35fr) minmax(260px,1fr) minmax(300px,340px) !important;
    gap:16px;
}
.ops-directory .user-grid,
.user-grid{
    display:grid !important;
    grid-template-columns:repeat(auto-fill,minmax(248px,1fr)) !important;
    gap:12px !important;
    padding:12px !important;
}
.operator-card{
    display:grid;
    grid-template-columns:72px minmax(0,1fr);
    grid-template-areas:
        'portrait head'
        'portrait telemetry'
        'actions actions';
    gap:10px 12px;
    min-height:0;
    padding:12px;
    align-items:start;
    border:1px solid rgba(255,255,255,.05);
    background:linear-gradient(160deg,rgba(15,24,32,.98),rgba(7,10,15,.99));
    box-shadow:0 6px 18px rgba(0,0,0,.28), inset 0 0 0 1px rgba(255,255,255,.015);
    clip-path:var(--cut-sm);
    position:relative;
    overflow:hidden;
}
.operator-card::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,transparent 0%,rgba(69,160,73,.03) 100%);pointer-events:none}
.operator-card.is-self{border-color:rgba(69,160,73,.34);background:linear-gradient(160deg,rgba(18,30,32,.98),rgba(7,10,15,.99));box-shadow:0 0 0 1px rgba(69,160,73,.14) inset,0 8px 22px rgba(0,0,0,.32)}
.operator-card.is-busy{border-color:rgba(212,168,67,.22)}
.operator-card.is-on-call{border-color:rgba(212,168,67,.34)}
.operator-card.is-offline{opacity:.78}

.operator-card-portrait{
    grid-area:portrait;
    display:flex;
    flex-direction:column;
    align-items:center;
    gap:8px;
    min-width:0;
    max-width:72px;
}
.operator-card-portrait .avatar-shell{
    width:72px;
    height:72px;
    aspect-ratio:1/1;
    min-height:0;
    border-radius:0;
    flex-shrink:0;
}
.operator-card-portrait .avatar-image{
    width:100%;
    height:100%;
    object-fit:cover;
    object-position:center center;
    display:block;
}
.operator-card-portrait .avatar-shell.avatar-failed{
    background:radial-gradient(circle at top,rgba(69,160,73,.18),rgba(8,12,18,.98) 72%);
}
.operator-card-portrait .avatar-shell:not(.avatar-failed) .avatar-fallback{display:none}
.operator-card-portrait .avatar-fallback{
    font-family:var(--font-display);
    font-size:1.2rem;
    font-weight:800;
    letter-spacing:.08em;
    color:var(--text-bright);
}
.operator-card-statuses{
    display:flex;
    flex-direction:column;
    gap:4px;
    align-items:center;
    width:100%;
}
.operator-card-statuses .status-pill{
    font-size:9px;
    padding:3px 6px;
    width:100%;
    text-align:center;
    justify-content:center;
}

.operator-card-top{
    grid-area:head;
    display:flex;
    align-items:flex-start;
    justify-content:space-between;
    gap:8px;
    min-width:0;
}
.operator-card-top .user-ident{min-width:0;flex:1}
.operator-card-top .user-name{
    font-size:.98rem;
    font-weight:700;
    line-height:1.2;
    color:var(--text-bright);
    white-space:nowrap;
    overflow:hidden;
    text-overflow:ellipsis;
}
.operator-card-top .user-meta{
    font-size:.72rem;
    color:var(--muted);
    white-space:nowrap;
    overflow:hidden;
    text-overflow:ellipsis;
    margin-top:2px;
}

.operator-card-telemetry{
    grid-area:telemetry;
    display:flex;
    flex-wrap:wrap;
    gap:6px;
    min-width:0;
}
.operator-card-telemetry .operator-meta-block{
    display:flex;
    align-items:center;
    gap:6px;
    font-size:.72rem;
    color:var(--muted);
    min-width:0;
}
.operator-card-telemetry .operator-meta-label{
    font-family:var(--font-mono);
    font-size:9px;
    letter-spacing:.08em;
    text-transform:uppercase;
    color:var(--muted);
}
.operator-card-telemetry strong{
    color:var(--text-bright);
    font-size:.78rem;
    font-weight:600;
    white-space:nowrap;
    overflow:hidden;
    text-overflow:ellipsis;
    max-width:140px;
}

.operator-card-actions{
    grid-area:actions;
    display:flex;
    gap:6px;
    flex-wrap:wrap;
    padding-top:4px;
    border-top:1px solid rgba(255,255,255,.05);
    margin-top:2px;
}
.operator-card-actions .btn{
    flex:1;
    padding:7px 10px;
    font-size:.74rem;
    min-width:0;
}

/* Hover */
.operator-card:hover{
    transform:translateY(-2px);
    border-color:rgba(69,160,73,.22);
    box-shadow:0 12px 24px rgba(0,0,0,.32),0 0 0 1px rgba(69,160,73,.08) inset;
}
.operator-card:hover .avatar-image{transform:scale(1.03)}

/* ── Availability switch (topbar) ── */
.availability-switch{
    display:flex;
    align-items:center;
    gap:4px;
    padding:3px;
    border:1px solid var(--line-subtle);
    background:rgba(0,0,0,.25);
    clip-path:var(--cut-xs);
    height:34px;
}
.availability-switch button{
    appearance:none;
    border:0;
    background:transparent;
    color:var(--muted);
    padding:4px 12px;
    font-family:var(--font-mono);
    font-size:10px;
    letter-spacing:.08em;
    text-transform:uppercase;
    font-weight:700;
    cursor:pointer;
    clip-path:var(--cut-xs);
    transition:background 160ms ease,color 160ms ease;
    white-space:nowrap;
}
.availability-switch button:hover{color:var(--text-bright)}
.availability-switch button.is-active[data-availability="available"]{
    background:rgba(69,160,73,.22);
    color:var(--accent-bright);
    box-shadow:inset 0 0 0 1px rgba(69,160,73,.4);
}
.availability-switch button.is-active[data-availability="busy"]{
    background:rgba(212,168,67,.22);
    color:#f2c96b;
    box-shadow:inset 0 0 0 1px rgba(212,168,67,.4);
}
.availability-switch.is-on-call{opacity:.55;pointer-events:none}
.availability-switch.is-on-call::after{
    content:'ON CALL';
    font-family:var(--font-mono);
    font-size:10px;
    letter-spacing:.08em;
    color:#f2c96b;
    padding:0 10px;
}

/* ── Toast / Notification center ── */
#huginnToastRoot{
    position:fixed;
    top:14px;
    right:14px;
    display:flex;
    flex-direction:column;
    gap:8px;
    z-index:10000;
    max-width:340px;
    pointer-events:none;
}
.huginn-toast{
    pointer-events:auto;
    background:rgba(10,16,22,.98);
    border:1px solid var(--line);
    border-left:3px solid var(--accent);
    clip-path:var(--cut-xs);
    padding:12px 14px;
    display:grid;
    grid-template-columns:1fr auto;
    gap:8px 10px;
    align-items:start;
    box-shadow:0 8px 24px rgba(0,0,0,.4);
    animation:huginnToastIn 220ms cubic-bezier(.2,.9,.2,1);
    max-width:100%;
}
.huginn-toast.is-leaving{animation:huginnToastOut 180ms ease forwards}
.huginn-toast-body{min-width:0}
.huginn-toast-title{
    font-family:var(--font-mono);
    font-size:10px;
    letter-spacing:.08em;
    text-transform:uppercase;
    color:var(--accent-bright);
    margin-bottom:2px;
    white-space:nowrap;
    overflow:hidden;
    text-overflow:ellipsis;
}
.huginn-toast-message{
    font-size:.82rem;
    color:var(--text-bright);
    line-height:1.35;
    word-break:break-word;
}
.huginn-toast-close{
    appearance:none;
    border:0;
    background:transparent;
    color:var(--muted);
    font-size:16px;
    cursor:pointer;
    padding:0 4px;
    line-height:1;
    align-self:start;
}
.huginn-toast-close:hover{color:var(--text-bright)}
.huginn-toast[data-kind="call"]{border-left-color:#45a049}
.huginn-toast[data-kind="call"] .huginn-toast-title{color:#73c878}
.huginn-toast[data-kind="missed"]{border-left-color:#d44a4a}
.huginn-toast[data-kind="missed"] .huginn-toast-title{color:#ff7a7a}
.huginn-toast[data-kind="dm"]{border-left-color:#d4a843}
.huginn-toast[data-kind="dm"] .huginn-toast-title{color:#f2c96b}
.huginn-toast[data-kind="mention"]{border-left-color:#ff7a7a;background:rgba(26,14,14,.98)}
.huginn-toast[data-kind="mention"] .huginn-toast-title{color:#ff9a9a}
.huginn-toast[data-kind="squad"]{border-left-color:#5ea5d6}
.huginn-toast[data-kind="squad"] .huginn-toast-title{color:#8bc0e6}
.huginn-toast[data-kind="system"]{border-left-color:var(--muted)}
@keyframes huginnToastIn{
    from{opacity:0;transform:translateX(20px)}
    to{opacity:1;transform:translateX(0)}
}
@keyframes huginnToastOut{
    from{opacity:1;transform:translateX(0)}
    to{opacity:0;transform:translateX(20px)}
}

/* Invisible host kept for any legacy addFeed() callers so app.js never
   crashes when it tries to render a stale feed target. */
#callFeed{display:none}

.dm-conversation-list{display:grid;gap:6px}
.dm-conversation-card-nick{display:flex;align-items:center;justify-content:space-between;padding:10px 12px}
.dm-conversation-card-nick .dm-nick-label{font-family:var(--font-mono);font-size:.86rem;letter-spacing:.04em;color:var(--text-bright)}

.workspace-search-form{display:grid;gap:10px;padding:4px 0 0}
.workspace-search-bar{display:flex;align-items:center;gap:10px;padding:10px 12px;border:1px solid var(--line-subtle);background:rgba(255,255,255,.03);clip-path:var(--cut-xs)}
.workspace-search-bar input{flex:1;min-width:0;background:transparent;border:0;padding:0;color:var(--text-bright);font-size:.98rem;outline:none}
.workspace-search-bar .btn{padding:9px 14px}
.workspace-search-icon{font-size:1.05rem;color:var(--muted)}
.workspace-search-shortcuts{display:flex;flex-wrap:wrap;gap:8px}
.workspace-search-shortcuts .btn{padding:7px 10px}
.search-result-grid{display:grid;gap:10px}
.search-result-card{padding:12px;border:1px solid var(--line-subtle);background:rgba(255,255,255,.03);clip-path:var(--cut-xs);display:grid;gap:8px}

.profile-tab-row{display:flex;gap:8px;margin-bottom:14px;flex-wrap:wrap}
.profile-tab-btn.is-active{background:rgba(69,160,73,.18);border-color:rgba(69,160,73,.4);color:var(--accent-bright)}
.profile-password-grid{display:grid;gap:12px}

.squad-prejoin-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}
.squad-prejoin-close{flex-shrink:0}

@media (max-width:980px){
  .profile-menu-trigger{min-width:0;width:100%}
  .profile-dropdown{left:0;right:0;min-width:0}
  .ops-dashboard{grid-template-columns:1fr !important}
  .operator-card{
    grid-template-columns:64px minmax(0,1fr);
    padding:10px;
  }
  .operator-card-portrait{max-width:64px}
  .operator-card-portrait .avatar-shell{width:64px;height:64px}
  .operator-card-actions{flex-wrap:wrap}
  .operator-card-actions .btn{flex:1}
  .availability-switch{height:30px}
  .availability-switch button{padding:3px 10px;font-size:9px}
  #huginnToastRoot{left:14px;right:14px;max-width:none}
}

@media (max-width:760px){
  .call-main{bottom:96px}
  .call-controls{position:fixed;left:0;right:0;bottom:0;padding:10px 12px calc(12px + env(safe-area-inset-bottom));background:#070b10;border-top:1px solid rgba(255,255,255,.08)}
  .call-hud-top{padding:10px 12px calc(14px + env(safe-area-inset-top));background:linear-gradient(180deg,rgba(0,0,0,.82),rgba(0,0,0,.18) 72%,transparent)}
  .video-stage.mode-grid{grid-template-columns:1fr;grid-template-rows:minmax(0,1fr) minmax(24vh,30vh)}
  .video-stage.mode-grid .tile-remote{order:1}
  .video-stage.mode-grid .tile-local{order:2;border-top:1px solid rgba(255,255,255,.06)}
  .video-stage.mode-grid .video-tile + .video-tile{border-left:0}
  .tile-local video{object-position:center top}
  .tile-remote video{object-position:center center}
}