/* SIFT KVM Viewer — Styles */

/* ── Poppins font (shared with console) ── */
@font-face{font-family:'Poppins';font-style:normal;font-weight:400;font-display:swap;
  src:local('Poppins Regular'),local('Poppins-Regular'),url('fonts/poppins-400.woff2') format('woff2')}
@font-face{font-family:'Poppins';font-style:normal;font-weight:500;font-display:swap;
  src:local('Poppins Medium'),local('Poppins-Medium'),url('fonts/poppins-500.woff2') format('woff2')}
@font-face{font-family:'Poppins';font-style:normal;font-weight:600;font-display:swap;
  src:local('Poppins SemiBold'),local('Poppins-SemiBold'),url('fonts/poppins-600.woff2') format('woff2')}
@font-face{font-family:'Poppins';font-style:normal;font-weight:700;font-display:swap;
  src:local('Poppins Bold'),local('Poppins-Bold'),url('fonts/poppins-700.woff2') format('woff2')}

/* ── Theme variables ── */
#bezel{
  --v-bg:#111;
  --v-bezel:#050505;
  --v-bezel-shadow:#3a3a3a;
  --v-chin:#0c0c0c;
  --v-chin-text:#999;
  --v-chin-brand-from:#3a3a3a;
  --v-chin-brand-mid:#5a5a5a;
  --v-btn-bg:#252525;
  --v-btn-text:#777;
  --v-btn-hover-bg:#333;
  --v-btn-hover-text:#ccc;
  --v-btn-active-text:#fff;
  --v-btn-active-bg:#333;
  --v-text:#ccc;
  --v-text-dim:#555;
  --v-text-muted:#888;
  --v-text-bright:#eee;
  --v-kpi:#666;
  --v-overlay-bg:rgba(0,0,0,0.75);
  --v-overlay-border:rgba(255,255,255,0.2);
  --v-overlay-text-bg:rgba(0,0,0,0.85);
  --v-overlay-text-border:rgba(255,255,255,0.15);
  --v-menu-bg:#1a1a1a;
  --v-menu-border:#333;
  --v-menu-item-text:#999;
  --v-menu-item-hover-bg:#2a2a2a;
  --v-modal-bg:#101010;
  --v-modal-border:#303030;
  --v-modal-head-bg:#151515;
  --v-modal-head-border:#252525;
  --v-modal-body-bg:#0d0d0d;
  --v-modal-body-text:#d4d4d4;
  --v-modal-code-bg:#151515;
  --v-modal-code-border:#232323;
  --v-modal-status-text:#9ca3af;
  --v-modal-status-border:#202020;
  --v-modal-title:#e5e5e5;
  --v-modal-btn-bg:#1f1f1f;
  --v-modal-btn-border:#353535;
  --v-modal-btn-text:#c7c7c7;
  --v-modal-btn-hover-bg:#2a2a2a;
  --v-modal-btn-hover-border:#4a4a4a;
  --v-green:#30d158;
  --v-green-idle:#1a8a3e;
  --v-orange:#ff9f0a;
  --v-red:#ff3b30;
  --v-gold:#c8a84e;
  --v-shadow:0 4px 24px rgba(0,0,0,0.6),0 1px 3px rgba(0,0,0,0.4);
  --v-menu-shadow:0 4px 16px rgba(0,0,0,0.6);
  --v-modal-shadow:0 16px 48px rgba(0,0,0,0.55);
  --v-tooltip-shadow:0 2px 8px rgba(0,0,0,0.5);
  --v-insecure-bg:rgba(0,0,0,0.85);
  --v-insecure-box-bg:#1a1a1a;
  --v-insecure-btn-border:#555;
  --v-insecure-btn-text:#888;
  --v-banner-bg:#1a1a1a;
  --v-banner-shadow:0 4px 16px rgba(0,0,0,0.5);
}

#bezel[data-theme="light"]{
  --v-bg:#f0ede8;
  --v-bezel:#e8e4de;
  --v-bezel-shadow:#c8c4be;
  --v-chin:#f5f2ed;
  --v-chin-text:#6b6058;
  --v-chin-brand-from:#b8b0a4;
  --v-chin-brand-mid:#91857a;
  --v-btn-bg:#e0dcd6;
  --v-btn-text:#7a7068;
  --v-btn-hover-bg:#d4d0ca;
  --v-btn-hover-text:#3a3228;
  --v-btn-active-text:#1c1814;
  --v-btn-active-bg:#d4d0ca;
  --v-text:#3a3228;
  --v-text-dim:#91857a;
  --v-text-muted:#6b6058;
  --v-text-bright:#1c1814;
  --v-kpi:#7a7068;
  --v-overlay-bg:rgba(255,255,255,0.88);
  --v-overlay-border:rgba(0,0,0,0.12);
  --v-overlay-text-bg:rgba(255,255,255,0.92);
  --v-overlay-text-border:rgba(0,0,0,0.1);
  --v-menu-bg:#ffffff;
  --v-menu-border:#d6cfc4;
  --v-menu-item-text:#6b6058;
  --v-menu-item-hover-bg:#f0ece6;
  --v-modal-bg:#ffffff;
  --v-modal-border:#d6cfc4;
  --v-modal-head-bg:#f5f2ed;
  --v-modal-head-border:#e0dcd6;
  --v-modal-body-bg:#faf8f5;
  --v-modal-body-text:#3a3228;
  --v-modal-code-bg:#f3efe9;
  --v-modal-code-border:#e0dcd6;
  --v-modal-status-text:#6b6058;
  --v-modal-status-border:#e0dcd6;
  --v-modal-title:#1c1814;
  --v-modal-btn-bg:#f0ece6;
  --v-modal-btn-border:#d6cfc4;
  --v-modal-btn-text:#3a3228;
  --v-modal-btn-hover-bg:#e0dcd6;
  --v-modal-btn-hover-border:#b8b0a4;
  --v-green:#0a9e7e;
  --v-green-idle:#0a9e7e;
  --v-orange:#b08808;
  --v-red:#d14a4a;
  --v-gold:#c89a10;
  --v-shadow:0 4px 24px rgba(0,0,0,0.1),0 1px 3px rgba(0,0,0,0.06);
  --v-menu-shadow:0 4px 16px rgba(0,0,0,0.12);
  --v-modal-shadow:0 16px 48px rgba(0,0,0,0.15);
  --v-tooltip-shadow:0 2px 8px rgba(0,0,0,0.12);
  --v-insecure-bg:rgba(255,255,255,0.9);
  --v-insecure-box-bg:#ffffff;
  --v-insecure-btn-border:#b8b0a4;
  --v-insecure-btn-text:#6b6058;
  --v-banner-bg:#ffffff;
  --v-banner-shadow:0 4px 16px rgba(0,0,0,0.1);
}

/* ── Reset & page ── */
*{margin:0;padding:0;box-sizing:border-box}
body{background:var(--v-bg,#111);display:flex;flex-direction:column;align-items:center;
  justify-content:center;height:100vh;font-family:'SF Mono',Monaco,monospace;
  color:var(--v-text,#ccc);overflow:hidden;-webkit-user-select:none;user-select:none}

/* ── Layout ── */
#wrap{display:flex;flex-direction:column;align-items:center;margin:30px;
  max-width:calc(100vw - 60px);max-height:calc(100vh - 60px)}
#bezel{background:var(--v-bezel);border-radius:24px;position:relative;
  box-shadow:0 0 0 1.5px var(--v-bezel-shadow),var(--v-shadow);
  display:flex;flex-direction:column;align-items:center;
  min-width:480px;visibility:hidden}
#screen{position:relative;overflow:hidden;border-radius:3px;line-height:0;
  display:flex;align-items:center;justify-content:center;background:#000}
canvas{display:block;background:#000;cursor:crosshair;border-radius:3px;transition:opacity 0.3s}
canvas.dim{opacity:0.3}
canvas.hidden{opacity:0}

/* ── Chin bar ── */
#chin{color:var(--v-chin-text);font-family:'Poppins',-apple-system,BlinkMacSystemFont,'Helvetica Neue',sans-serif;
  font-weight:400;letter-spacing:0.3px;user-select:none;
  width:100%;background:var(--v-chin);display:flex;align-items:center;
  flex-shrink:0;border-radius:0 0 24px 24px;position:relative;z-index:1;
  justify-content:space-between;overflow:hidden;white-space:nowrap;cursor:auto}
#chin-left{display:flex;align-items:center;gap:10px;min-width:0;overflow:hidden}
#chin-center{position:absolute;left:50%;transform:translateX(-50%);
  pointer-events:none;display:flex;align-items:center}
.chin-wordmark{height:10px;width:auto;
  color:var(--v-chin-brand-mid);opacity:0.7}
#chin-right{display:flex;align-items:center;gap:4px;flex-shrink:0}

/* ── Key strip (virtual keys — overlay above chin, like stats overlay) ── */
#key-strip{position:absolute;left:0;right:0;z-index:3;
  background:var(--v-chin);display:flex;
  align-items:center;justify-content:center;gap:2px;
  padding:4px 12px;overflow-x:auto;border-radius:8px 8px 0 0;
  opacity:0;visibility:hidden;
  transition:opacity 0.2s ease,visibility 0.2s ease}
#key-strip.show{opacity:1;visibility:visible}
.ks-group{display:flex;gap:2px}
.ks-sep{width:6px;flex-shrink:0}
.ks-btn{height:24px;border:none;border-radius:4px;background:var(--v-menu-bg);
  color:var(--v-btn-text);cursor:pointer;font-family:'SF Mono',Monaco,monospace;
  font-size:10px;padding:0 6px;white-space:nowrap;flex-shrink:0;
  transition:background 0.15s ease,color 0.15s ease}
.ks-btn:hover{background:var(--v-menu-item-hover-bg);color:var(--v-text)}
.ks-btn:active{background:var(--v-btn-hover-bg);color:var(--v-btn-active-text)}
.ks-wide{padding:0 10px}

/* ── Stats overlay ── */
#stats-overlay{position:absolute;left:4%;right:4%;
  background:var(--v-overlay-bg);padding:6px 10px;
  font-family:'SF Mono',Monaco,monospace;color:var(--v-text);
  display:flex;flex-direction:column;align-items:center;gap:3px;
  pointer-events:none;z-index:2;overflow:hidden;
  border:1px solid var(--v-overlay-border);border-radius:10px;
  opacity:0;visibility:hidden;
  transition:opacity 0.25s ease,visibility 0.25s ease}
.ov-row{display:flex;flex-wrap:nowrap;justify-content:center;
  align-items:center;white-space:nowrap}
.ov-row>div{margin:0 0.5em}
#stats-overlay.show{opacity:1;visibility:visible}
#ov-netv2-row{display:none}
#ov-netv2-row.visible{display:flex}
#ov-audio-row{display:none}
#ov-audio-row.visible{display:flex}
#stats-overlay .lbl{color:var(--v-text-bright);margin-right:2px;font-size:inherit}
#stats-overlay .val{color:var(--v-green);font-weight:bold;font-size:inherit}
#stats-overlay .wrn{color:var(--v-orange);font-weight:bold;font-size:inherit}
#stats-overlay .dim{color:var(--v-text-dim);font-size:inherit}

/* ── Source switch overlay ── */
#switch-overlay{position:absolute;inset:0;z-index:4;
  display:flex;align-items:center;justify-content:center;
  background:var(--v-overlay-bg);
  opacity:0;visibility:hidden;pointer-events:none;
  transition:opacity 0.2s ease,visibility 0.2s ease}
#switch-overlay.show{opacity:1;visibility:visible;pointer-events:auto}
#switch-text{color:var(--v-text);font-size:22px;font-weight:500;letter-spacing:0.3px;
  font-family:'Poppins',-apple-system,BlinkMacSystemFont,'Helvetica Neue',sans-serif;
  padding:18px 40px;min-width:280px;text-align:center;
  background:var(--v-overlay-text-bg);border:1px solid var(--v-overlay-text-border);
  border-radius:14px}
#switch-overlay.error #switch-text{color:var(--v-orange);border-color:rgba(255,159,10,0.4)}

/* ── Status text & KPIs ── */
#st{display:inline-block;overflow:hidden;white-space:nowrap;
  vertical-align:middle;color:var(--v-text-muted);font-size:inherit;transition:opacity 0.6s}
#st.fade-out{opacity:0}
#st.gone{opacity:0;display:none}
.chin-kpi{transition:opacity 0.5s;font-weight:500;opacity:0;display:none;white-space:nowrap}
.chin-kpi.visible{display:inline-flex;align-items:baseline;opacity:1}
.chin-kpi.fade-out{display:inline-flex;opacity:0}
#bps{margin-left:6px}
.kpi-num{display:inline-block;text-align:right;color:var(--v-kpi);font-weight:500}
.kpi-unit{color:var(--v-text-dim);font-weight:400;margin-left:3px}

/* ── Chin buttons (Touch Bar pill style) ── */
.chin-btn{height:30px;min-width:34px;border-radius:6px;
  border:none;background:var(--v-btn-bg);color:var(--v-btn-text);cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  transition:background 0.3s ease,color 0.3s ease;flex-shrink:0;padding:0 9px}
.chin-btn:hover{background:var(--v-btn-hover-bg);color:var(--v-btn-hover-text)}
.chin-btn.active{color:var(--v-btn-active-text);background:var(--v-btn-active-bg)}
.chin-btn svg{width:18px;height:18px}
.chin-pill{height:30px;border:none;border-radius:6px;background:var(--v-btn-bg);
  color:var(--v-btn-text);cursor:pointer;font-family:'SF Mono',Monaco,monospace;
  font-size:inherit;padding:0 10px;white-space:nowrap;flex-shrink:0;
  width:7ch;text-align:center;display:flex;align-items:center;justify-content:center;
  transition:background 0.3s ease,color 0.3s ease}
.chin-pill:hover{background:var(--v-btn-hover-bg);color:var(--v-btn-hover-text)}
.chin-pill.disabled{
  opacity:0.45;
  cursor:not-allowed;
  pointer-events:none;
}
#btn-source{display:none;width:5ch}

/* ── Shared value classes ── */
.lbl{color:var(--v-text-dim);margin-right:2px}
.val{color:var(--v-green);font-weight:bold;display:inline-block;text-align:right}
.wrn{color:var(--v-orange);font-weight:bold;display:inline-block;text-align:right}
.dim{color:var(--v-text-dim);display:inline-block;text-align:right}

/* ── Status dot ── */
.dot{width:6px;height:6px;border-radius:50%;display:inline-block;
  vertical-align:middle;transition:all 0.3s;flex-shrink:0}
.on{background:var(--v-green);box-shadow:0 0 4px rgba(52,199,89,0.5)}
.idle{background:var(--v-green-idle);box-shadow:none}
.off{background:var(--v-red)}
.neutral{background:var(--v-text-muted)}
.warn{background:var(--v-orange);box-shadow:0 0 4px rgba(255,159,10,0.5)}

/* ── Throttle warning indicator (orange triangle next to dot) ── */
.throttle-warn{display:none;color:var(--v-orange);font-size:80%;
  margin-left:-4px;opacity:0;transition:opacity 0.15s ease-in;
  vertical-align:middle;line-height:1}
.throttle-warn.active{display:inline;opacity:1}
.throttle-warn.fading{display:inline;opacity:0;transition:opacity 1.5s ease-out}

/* ── Tooltip ── */
#tooltip{position:absolute;z-index:3;pointer-events:none;
  opacity:0;visibility:hidden;transition:opacity 150ms ease,visibility 150ms ease;
  background:var(--v-menu-bg);color:var(--v-text);
  font-family:'Poppins',-apple-system,BlinkMacSystemFont,'Helvetica Neue',sans-serif;
  font-size:11px;font-weight:400;letter-spacing:0.2px;line-height:1.4;
  padding:5px 10px;border-radius:6px;border:1px solid var(--v-menu-border);
  box-shadow:var(--v-tooltip-shadow);white-space:nowrap}
#tooltip.show{opacity:1;visibility:visible}
#tooltip::after{content:'';position:absolute;top:100%;left:var(--caret,50%);
  transform:translateX(-50%);border:5px solid transparent;border-top-color:var(--v-menu-border)}
#tooltip::before{content:'';position:absolute;top:100%;left:var(--caret,50%);
  transform:translateX(-50%);margin-top:-1px;
  border:4px solid transparent;border-top-color:var(--v-menu-bg)}

/* ── Popup menus (shared) ── */
.popup-menu{position:absolute;z-index:5;
  opacity:0;visibility:hidden;transition:opacity 150ms ease,visibility 150ms ease;
  background:var(--v-menu-bg);border:1px solid var(--v-menu-border);border-radius:8px;
  box-shadow:var(--v-menu-shadow);padding:4px 0;min-width:80px;
  font-family:'SF Mono',Monaco,monospace;font-size:12px;cursor:auto}
.popup-menu.show{opacity:1;visibility:visible}
.popup-menu::after{content:'';position:absolute;top:100%;left:var(--caret,50%);
  transform:translateX(-50%);border:5px solid transparent;border-top-color:var(--v-menu-border)}
.popup-menu::before{content:'';position:absolute;top:100%;left:var(--caret,50%);
  transform:translateX(-50%);margin-top:-1px;
  border:4px solid transparent;border-top-color:var(--v-menu-bg)}
.menu-item{display:flex;align-items:center;padding:6px 14px;
  color:var(--v-menu-item-text);cursor:pointer;white-space:nowrap;gap:8px;
  transition:background 0.15s ease,color 0.15s ease}
.menu-item:first-child{border-radius:4px 4px 0 0}
.menu-item:last-child{border-radius:0 0 4px 4px}
.menu-item:hover{background:var(--v-menu-item-hover-bg);color:var(--v-text)}
.menu-item.active{color:var(--v-btn-active-text)}
.menu-item-check{width:12px;text-align:center;font-size:10px;color:var(--v-green)}

/* ── Diagnostics modal ── */
.viewer-info-modal{position:absolute;inset:0;z-index:6;
  display:flex;align-items:center;justify-content:center;
  background:var(--v-overlay-bg);opacity:0;visibility:hidden;pointer-events:none;
  transition:opacity 0.18s ease,visibility 0.18s ease;cursor:auto}
.viewer-info-modal.show{opacity:1;visibility:visible;pointer-events:auto}
.viewer-info-card{width:min(760px,calc(100% - 32px));max-height:calc(100% - 32px);
  background:var(--v-modal-bg);border:1px solid var(--v-modal-border);border-radius:14px;
  box-shadow:var(--v-modal-shadow);display:flex;flex-direction:column;
  overflow:hidden;cursor:auto}
.viewer-info-head{display:flex;align-items:center;justify-content:space-between;
  gap:12px;padding:14px 16px;border-bottom:1px solid var(--v-modal-head-border);background:var(--v-modal-head-bg)}
.viewer-info-title{font-family:'Poppins',-apple-system,BlinkMacSystemFont,'Helvetica Neue',sans-serif;
  font-size:14px;font-weight:600;color:var(--v-modal-title);letter-spacing:0.2px}
.viewer-info-actions{display:flex;align-items:center;gap:8px}
.viewer-info-btn{height:30px;padding:0 10px;border-radius:7px;border:1px solid var(--v-modal-btn-border);
  background:var(--v-modal-btn-bg);color:var(--v-modal-btn-text);cursor:pointer;
  font-family:'Poppins',-apple-system,BlinkMacSystemFont,'Helvetica Neue',sans-serif;
  font-size:12px;transition:background 0.15s ease,color 0.15s ease,border-color 0.15s ease}
.viewer-info-btn:hover{background:var(--v-modal-btn-hover-bg);color:var(--v-btn-active-text);border-color:var(--v-modal-btn-hover-border)}
.viewer-info-btn:disabled{opacity:0.45;cursor:default}
.viewer-info-btn:disabled:hover{background:var(--v-modal-btn-bg);color:var(--v-modal-btn-text);border-color:var(--v-modal-btn-border)}
.viewer-info-btn-close{min-width:64px}
.viewer-info-status{padding:10px 16px;border-bottom:1px solid var(--v-modal-status-border);
  color:var(--v-modal-status-text);font-family:'Poppins',-apple-system,BlinkMacSystemFont,'Helvetica Neue',sans-serif;
  font-size:12px}
.viewer-info-body{margin:0;padding:16px 18px 18px;overflow:auto;
  background:var(--v-modal-body-bg);color:var(--v-modal-body-text);
  font-family:'Poppins',-apple-system,BlinkMacSystemFont,'Helvetica Neue',sans-serif;
  font-size:12px;line-height:1.5;cursor:text;display:flex;flex-direction:column;gap:14px;
  font-variant-numeric:tabular-nums;-webkit-user-select:text;user-select:text}
.viewer-info-section{display:flex;flex-direction:column;gap:8px;
  padding-left:calc(var(--viewer-info-indent,0) * 14px)}
.viewer-info-heading{color:var(--v-modal-title);font-size:13px;font-weight:600;
  letter-spacing:0.18px}
.viewer-info-rows{display:flex;flex-direction:column;gap:7px}
.viewer-info-row{display:grid;grid-template-columns:minmax(120px,180px) minmax(0,1fr);
  gap:12px;align-items:start;padding-left:calc(var(--viewer-info-row-indent,0) * 12px)}
.viewer-info-row.is-block{align-items:start}
.viewer-info-label{color:var(--v-text-muted);font-size:11px;font-weight:500;
  letter-spacing:0.02em}
.viewer-info-value{color:var(--v-modal-body-text);font-size:12px;font-weight:400;
  overflow-wrap:anywhere}
.viewer-info-value.is-mono,.viewer-info-block{font-family:'SF Mono',Monaco,monospace;
  font-size:11.5px;letter-spacing:0}
.viewer-info-block{padding:8px 10px;border-radius:8px;
  border:1px solid var(--v-modal-code-border);background:var(--v-modal-code-bg);
  white-space:pre-wrap;overflow-wrap:anywhere}
.viewer-info-block-line + .viewer-info-block-line{margin-top:3px}
@media (max-width: 640px){
  .viewer-info-row{grid-template-columns:1fr;gap:4px}
  .viewer-info-block{padding:8px}
}

/* ── Value width utilities ── */
.v{display:inline-block;text-align:right}
.v4{min-width:4ch}.v5{min-width:5ch}.v6{min-width:6ch}.v7{min-width:7ch}
.v8{min-width:8ch}.v9{min-width:9ch}
.v4r{min-width:4ch;text-align:right}.v6r{min-width:5ch;text-align:right}

/* ── Bezel reveal (prevents FOUC — hidden until JS sizes it) ── */
#bezel.ready{visibility:visible}

/* ── Audio mute toggle ── */
#spk-off{display:none}
#spk-x{display:none}
#btn-audio.muted #spk-on{display:none}
#btn-audio.muted #spk-off{display:inline}
#btn-audio.unavailable #spk-on{display:none}
#btn-audio.unavailable #spk-off{display:none}
#btn-audio.unavailable #spk-x{display:inline}
#btn-audio.unavailable{opacity:0.35;cursor:default}

/* ── Insecure context warning ── */
.insecure-warning{position:fixed;inset:0;z-index:9999;
  background:var(--v-insecure-bg);display:flex;align-items:center;justify-content:center}
.insecure-box{text-align:center;max-width:420px;padding:32px;
  background:var(--v-insecure-box-bg);border:1px solid var(--v-orange);border-radius:16px}
.insecure-icon{font-size:48px;margin-bottom:12px;line-height:1}
.insecure-box h2{color:var(--v-orange);font-family:'Poppins',-apple-system,BlinkMacSystemFont,sans-serif;
  font-size:20px;margin-bottom:12px;font-weight:600}
.insecure-box p{color:var(--v-chin-text);font-family:'Poppins',-apple-system,BlinkMacSystemFont,sans-serif;
  font-size:14px;line-height:1.5;margin-bottom:20px}
.insecure-box button{background:none;border:1px solid var(--v-insecure-btn-border);border-radius:8px;
  color:var(--v-insecure-btn-text);font-family:'Poppins',-apple-system,BlinkMacSystemFont,sans-serif;
  font-size:13px;padding:8px 20px;cursor:pointer;transition:all 0.2s}
.insecure-box button:hover{border-color:var(--v-text-muted);color:var(--v-text)}

/* ── Update banner (version mismatch — production mode) ── */
.update-banner{position:fixed;top:-48px;left:50%;transform:translateX(-50%);
  z-index:9998;display:flex;align-items:center;gap:12px;
  background:var(--v-banner-bg);border:1px solid var(--v-gold);border-radius:10px;
  padding:8px 16px;font-family:'Poppins',-apple-system,BlinkMacSystemFont,sans-serif;
  font-size:13px;color:var(--v-text);box-shadow:var(--v-banner-shadow);
  transition:top 0.4s ease-out;white-space:nowrap}
.update-banner.visible{top:16px}
.update-msg{opacity:0.85}
.update-btn{background:none;border:1px solid var(--v-gold);border-radius:6px;
  color:var(--v-gold);font-family:inherit;font-size:12px;font-weight:600;
  padding:4px 12px;cursor:pointer;transition:all 0.2s}
.update-btn:hover{background:var(--v-gold);color:#111}

/* ── Fullscreen ── */
#fs-compress{display:none}
#bezel:fullscreen{background:#000;border-radius:0;box-shadow:none;
  width:100vw;height:100vh;justify-content:center}
#bezel:fullscreen #chin{border-radius:0;
  border-top:2px solid var(--v-gold)}
#bezel:fullscreen #fs-expand{display:none}
#bezel:fullscreen #fs-compress{display:inline}
