  :root {
    --mat-red: #C0392B;
    --mat-gold: #D4A017;
    --mat-dark: #0D0D0D;
    --mat-panel: #141414;
    --mat-surface: #1C1C1C;
    --mat-border: #2A2A2A;
    --mat-text: #F0EDE8;
    --mat-muted: #888;
    --warning-color: #FF6B35;
    --danger-color: #C0392B;
    --go-color: #27AE60;
    --font-display: 'Bebas Neue', sans-serif;
    --font-ui: 'Barlow Condensed', sans-serif;
    --font-body: 'Barlow', sans-serif;
  }

  * { box-sizing: border-box; margin: 0; padding: 0; }
  body { background: var(--mat-dark); color: var(--mat-text); font-family: var(--font-body); min-height: 100vh; overflow-x: hidden; }

  /* ─── LANDING ──────────────────────────────────────────────── */
  #landing {
    display: flex; flex-direction: column; align-items: center; justify-content: center;
    min-height: 100vh; padding: 2rem;
    background: radial-gradient(ellipse at 50% 30%, #1a0a00 0%, var(--mat-dark) 70%);
    position: relative; overflow: hidden;
  }
  #landing::before {
    content: ''; position: absolute; inset: 0;
    background-image:
      repeating-linear-gradient(0deg, transparent, transparent 40px, rgba(255,255,255,.015) 40px, rgba(255,255,255,.015) 41px),
      repeating-linear-gradient(90deg, transparent, transparent 40px, rgba(255,255,255,.015) 40px, rgba(255,255,255,.015) 41px);
    pointer-events: none;
  }
  .logo-mark { width: 80px; height: 80px; margin-bottom: 1.5rem; overflow: hidden; }
  .logo-mark svg, .logo-mark img { width: 100%; height: 100%; object-fit: contain; }
  .landing-title { font-family: var(--font-display); font-size: clamp(3rem,8vw,6rem); letter-spacing: .05em; color: var(--mat-text); text-align: center; line-height: .9; margin-bottom: .5rem; }
  .landing-sub { font-family: var(--font-ui); font-size: 1.1rem; letter-spacing: .3em; color: var(--mat-muted); text-transform: uppercase; margin-bottom: 3rem; }


  .mode-cards { display: grid; grid-template-columns: 1fr 1fr; gap: 1.5rem; width: 100%; max-width: 600px; margin-bottom: 2rem; }
  .mode-card { background: var(--mat-panel); border: 1px solid var(--mat-border); border-radius: 4px; padding: 2rem 1.5rem; cursor: pointer; transition: all .2s; text-align: center; position: relative; overflow: hidden; }
  .mode-card::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 3px; background: var(--mat-gold); transform: scaleX(0); transition: transform .2s; }
  .mode-card:hover { border-color: var(--mat-gold); background: #1f1f1f; transform: translateY(-2px); box-shadow: 0 8px 32px rgba(212,160,23,.15); }
  .mode-card:hover::before { transform: scaleX(1); }
  .mode-icon { font-size: 2.5rem; margin-bottom: .75rem; display: block; }
  .mode-card h2 { font-family: var(--font-ui); font-size: 1.4rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; margin-bottom: .4rem; }
  .mode-card p { font-size: .85rem; color: var(--mat-muted); line-height: 1.4; }

  .room-input-section { width: 100%; max-width: 600px; background: var(--mat-panel); border: 1px solid var(--mat-border); border-radius: 4px; padding: 1.5rem; }
  .room-input-section h3 { font-family: var(--font-ui); font-size: 1rem; letter-spacing: .2em; text-transform: uppercase; color: var(--mat-muted); margin-bottom: 1rem; }
  .input-row { display: flex; gap: .75rem; }

  input[type="text"] { flex: 1; background: var(--mat-dark); border: 1px solid var(--mat-border); border-radius: 4px; color: var(--mat-text); font-family: var(--font-ui); font-size: 1.1rem; letter-spacing: .1em; padding: .75rem 1rem; outline: none; transition: border-color .2s; text-transform: uppercase; }
  input[type="text"]:focus { border-color: var(--mat-gold); }
  input[type="number"] { background: var(--mat-dark); border: 1px solid var(--mat-border); border-radius: 3px; color: var(--mat-text); font-family: var(--font-display); font-size: 1.4rem; text-align: center; padding: .4rem .25rem; width: 100%; outline: none; transition: border-color .2s; }
  input[type="number"]:focus { border-color: var(--mat-gold); }
  input[type="number"]::-webkit-inner-spin-button { -webkit-appearance: none; }

  /* ─── BUTTONS ──────────────────────────────────────────────── */
  .btn { font-family: var(--font-ui); font-size: 1rem; font-weight: 700; letter-spacing: .15em; text-transform: uppercase; border: none; border-radius: 4px; padding: .75rem 1.5rem; cursor: pointer; transition: all .15s; }
  .btn-gold { background: var(--mat-gold); color: #000; }
  .btn-gold:hover { background: #e8c547; transform: translateY(-1px); }
  .btn-outline { background: transparent; color: var(--mat-text); border: 1px solid var(--mat-border); }
  .btn-outline:hover { border-color: var(--mat-text); }
  .btn-red { background: var(--mat-red); color: #fff; }
  .btn-red:hover { background: #e74c3c; }
  .btn-green { background: var(--go-color); color: #fff; }
  .btn-green:hover { background: #2ecc71; }
  .btn-massive { font-size: 1.5rem; padding: 1.2rem 3rem; border-radius: 4px; min-width: 160px; }

  /* ─── STATUS BAR ───────────────────────────────────────────── */
  .status-bar { background: var(--mat-panel); border-bottom: 1px solid var(--mat-border); padding: .6rem 1.5rem; display: flex; align-items: center; justify-content: space-between; font-family: var(--font-ui); font-size: .85rem; letter-spacing: .1em; }
  .status-dot { width: 8px; height: 8px; border-radius: 50%; background: #555; display: inline-block; margin-right: .5rem; transition: background .3s; }
  .status-dot.connected { background: var(--go-color); box-shadow: 0 0 6px var(--go-color); }
  .status-dot.connecting { background: var(--mat-gold); animation: pulse-dot 1s infinite; }
  @keyframes pulse-dot { 0%,100%{opacity:1} 50%{opacity:.3} }

  /* ─── TV SLOTS ─────────────────────────────────────────────── */
  .tv-slots { display: flex; gap: .4rem; align-items: center; }
  .tv-slot { display: flex; align-items: center; gap: .35rem; background: var(--mat-surface); border: 1px solid var(--mat-border); border-radius: 3px; padding: .25rem .6rem; cursor: pointer; transition: all .15s; position: relative; min-width: 90px; }
  .tv-slot:hover { border-color: var(--mat-gold); background: #222; }
  .tv-slot.connected { border-color: rgba(39,174,96,.5); background: rgba(39,174,96,.08); }
  .tv-slot-icon { font-size: .85rem; opacity: .6; }
  .tv-slot.connected .tv-slot-icon { opacity: 1; }
  .tv-slot-label { font-family: var(--font-ui); font-size: .75rem; font-weight: 700; letter-spacing: .1em; color: var(--mat-muted); text-transform: uppercase; }
  .tv-slot.connected .tv-slot-label { color: var(--mat-text); }
  .tv-slot-code { font-family: var(--font-ui); font-size: .7rem; letter-spacing: .15em; color: var(--mat-gold); opacity: .8; }
  .tv-slot-dot { width: 6px; height: 6px; border-radius: 50%; background: var(--mat-border); flex-shrink: 0; transition: background .3s; margin-left: auto; }
  .tv-slot.connected .tv-slot-dot { background: var(--go-color); box-shadow: 0 0 5px var(--go-color); }
  .tv-slot-tooltip { position: absolute; bottom: calc(100% + 6px); left: 50%; transform: translateX(-50%); background: #000; border: 1px solid var(--mat-border); border-radius: 3px; padding: .25rem .6rem; font-family: var(--font-ui); font-size: .7rem; letter-spacing: .1em; white-space: nowrap; color: var(--mat-text); pointer-events: none; opacity: 0; transition: opacity .15s; z-index: 100; }
  .tv-slot:hover .tv-slot-tooltip { opacity: 1; }

  /* ─── CONTROLLER LAYOUT ────────────────────────────────────── */
  #controller { display: none; }
  .toggle-row { display: flex; align-items: center; justify-content: space-between; padding: .4rem 0; }
  .toggle-row span { font-family: var(--font-ui); font-size: .9rem; }
  .toggle { position: relative; width: 40px; height: 22px; cursor: pointer; }
  .toggle input { opacity: 0; width: 0; height: 0; }
  .toggle-slider { position: absolute; inset: 0; background: var(--mat-border); border-radius: 22px; transition: .2s; }
  .toggle-slider:before { content: ''; position: absolute; width: 16px; height: 16px; left: 3px; top: 3px; background: #fff; border-radius: 50%; transition: .2s; }
  .toggle input:checked + .toggle-slider { background: var(--mat-gold); }
  .toggle input:checked + .toggle-slider:before { transform: translateX(18px); }
  .msg-input { width: 100%; background: var(--mat-dark); border: 1px solid var(--mat-border); border-radius: 3px; color: var(--mat-text); font-family: var(--font-ui); font-size: 1rem; padding: .6rem .75rem; outline: none; margin-bottom: .5rem; transition: border-color .2s; }
  .msg-input:focus { border-color: var(--mat-gold); }
  .quick-msgs { display: flex; flex-wrap: wrap; gap: .4rem; margin-bottom: .5rem; }
  .quick-msg-btn { background: var(--mat-surface); border: 1px solid var(--mat-border); border-radius: 3px; color: var(--mat-muted); font-family: var(--font-ui); font-size: .78rem; letter-spacing: .05em; padding: .3rem .6rem; cursor: pointer; transition: all .15s; }
  .quick-msg-btn:hover { border-color: var(--mat-text); color: var(--mat-text); }
  .config-field { display: flex; flex-direction: column; gap: .3rem; }

  /* Audio uploads */
  .audio-uploads { display: flex; flex-direction: column; gap: .5rem; }
  .audio-upload-row { display: flex; align-items: center; gap: .4rem; }
  .audio-upload-label { font-family: var(--font-ui); font-size: .8rem; font-weight: 600; letter-spacing: .05em; color: var(--mat-muted); white-space: nowrap; width: 52px; flex-shrink: 0; }
  .audio-file-btn { flex: 1; background: var(--mat-dark); border: 1px solid var(--mat-border); border-radius: 3px; padding: .3rem .5rem; cursor: pointer; transition: border-color .15s; overflow: hidden; min-width: 0; }
  .audio-file-btn:hover { border-color: var(--mat-gold); }
  .audio-file-btn span { font-family: var(--font-ui); font-size: .75rem; letter-spacing: .03em; color: var(--mat-muted); display: block; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
  .audio-file-btn.loaded span { color: var(--mat-gold); }
  .audio-file-btn input[type="file"] { display: none; }
  .audio-play-btn, .audio-clear-btn { background: var(--mat-surface); border: 1px solid var(--mat-border); border-radius: 3px; color: var(--mat-muted); cursor: pointer; font-size: .8rem; padding: .3rem .45rem; line-height: 1; transition: all .15s; flex-shrink: 0; }
  .audio-play-btn:hover { border-color: var(--go-color); color: var(--go-color); }
  .audio-clear-btn:hover { border-color: var(--mat-red); color: var(--mat-red); }

  /* ─── CTRL MAIN (full width, phone-friendly) ──────────────────── */
  .ctrl-main { display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 1.5rem; padding: 1.5rem 1rem; background: radial-gradient(ellipse at 50% 40%, #1a0800 0%, var(--mat-dark) 70%); overflow-y: auto; }
  .ctrl-tabs { display: flex; gap: 0; border: 1px solid var(--mat-border); border-radius: 4px; overflow: hidden; width: 100%; max-width: 480px; }
  .ctrl-tab { flex: 1; background: var(--mat-surface); border: none; color: var(--mat-muted); cursor: pointer; font-family: var(--font-ui); font-size: .85rem; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; padding: .65rem .5rem; transition: all .15s; border-right: 1px solid var(--mat-border); }
  .ctrl-tab:last-child { border-right: none; }
  .ctrl-tab:hover { background: var(--mat-panel); color: var(--mat-text); }
  .ctrl-tab.active { background: var(--mat-gold); color: #000; }
  .ctrl-panel { display: flex; flex-direction: column; align-items: center; gap: 1.5rem; width: 100%; max-width: 480px; }
  .ctrl-preview { text-align: center; width: 100%; }
  .ctrl-timer-display { font-family: var(--font-display); font-size: clamp(4rem,20vw,9rem); line-height: 1; letter-spacing: .02em; color: var(--mat-text); transition: color .3s; text-shadow: 0 0 60px rgba(240,237,232,.1); }
  .ctrl-timer-display.warning { color: var(--warning-color); text-shadow: 0 0 40px rgba(255,107,53,.3); }
  .ctrl-timer-display.danger { color: var(--danger-color); text-shadow: 0 0 40px rgba(192,57,43,.4); animation: flash-red .5s infinite; }
  @keyframes flash-red { 0%,100%{opacity:1} 50%{opacity:.5} }
  .round-indicator { font-family: var(--font-ui); font-size: .9rem; letter-spacing: .3em; color: var(--mat-muted); text-transform: uppercase; margin-bottom: .25rem; }
  .phase-label { font-family: var(--font-ui); font-size: .85rem; letter-spacing: .25em; margin-top: .4rem; padding: .25rem .8rem; border-radius: 2px; text-transform: uppercase; display: inline-block; }
  .phase-label.fight { background: rgba(192,57,43,.2); color: var(--mat-red); border: 1px solid rgba(192,57,43,.3); }
  .phase-label.rest { background: rgba(39,174,96,.2); color: var(--go-color); border: 1px solid rgba(39,174,96,.3); }
  .ctrl-buttons { display: flex; gap: .75rem; justify-content: center; width: 100%; }
  .btn-massive { font-size: clamp(1rem,4vw,1.4rem); padding: 1rem 1.5rem; border-radius: 4px; flex: 1; min-width: 80px; max-width: 160px; text-align: center; }
  .sw-millis { font-size: .45em; letter-spacing: 0; opacity: .55; vertical-align: baseline; margin-left: .05em; }
  /* Duration strip */
  .duration-strip { display: flex; align-items: center; gap: .5rem; width: 100%; justify-content: center; flex-wrap: wrap; }
  .duration-label { font-family: var(--font-ui); font-size: .75rem; font-weight: 700; letter-spacing: .2em; color: var(--mat-muted); text-transform: uppercase; white-space: nowrap; }
  .duration-pills { display: flex; gap: .3rem; justify-content: center; flex-wrap: wrap; }
  .dur-pill { background: var(--mat-surface); border: 1px solid var(--mat-border); border-radius: 4px; color: var(--mat-muted); cursor: pointer; font-family: var(--font-ui); font-size: .95rem; font-weight: 700; letter-spacing: .05em; min-width: 2.4rem; padding: .45rem .5rem; text-align: center; transition: all .15s; }
  .dur-pill:hover { border-color: var(--mat-gold); color: var(--mat-gold); }
  .dur-pill.active { background: var(--mat-gold); border-color: var(--mat-gold); color: #000; }

  /* ─── DISPLAY VIEW ─────────────────────────────────────────── */
  #display { display: none; position: fixed; inset: 0; background: var(--mat-dark); flex-direction: column; }
  .display-inner { flex: 1; display: flex; flex-direction: column; align-items: center; justify-content: center; padding: 2rem; background: radial-gradient(ellipse at 50% 35%, #200d00 0%, var(--mat-dark) 65%); transition: background .5s; position: relative; }
  .display-inner.phase-rest { background: radial-gradient(ellipse at 50% 35%, #062010 0%, var(--mat-dark) 65%); }
  .display-inner::before { content: ''; position: absolute; inset: 0; background-image: repeating-linear-gradient(0deg,transparent,transparent 60px,rgba(255,255,255,.012) 60px,rgba(255,255,255,.012) 61px), repeating-linear-gradient(90deg,transparent,transparent 60px,rgba(255,255,255,.012) 60px,rgba(255,255,255,.012) 61px); pointer-events: none; }
  .display-corner { position: absolute; font-family: var(--font-ui); font-size: .75rem; letter-spacing: .25em; color: rgba(255,255,255,.4); text-transform: uppercase; }
  .display-corner.tl { top: 1.5rem; left: 1.5rem; }
  .display-corner.tr { top: 1.5rem; right: 1.5rem; display: flex; align-items: center; gap: .4rem; }
  .display-round { font-family: var(--font-ui); font-size: clamp(1rem,2.5vw,1.4rem); letter-spacing: .5em; color: rgba(255,255,255,.8); text-transform: uppercase; margin-bottom: .5rem; }
  .display-phase { font-family: var(--font-ui); font-size: clamp(1.2rem,3vw,1.8rem); letter-spacing: .4em; text-transform: uppercase; margin-bottom: 1rem; transition: color .5s; }
  .display-phase.fight { color: #fff; }
  .display-phase.rest { color: #fff; }
  .display-time { font-family: var(--font-display); font-size: clamp(10rem,32vw,28rem); line-height: .85; letter-spacing: .02em; color: #fff; transition: color .3s; position: relative; z-index: 1; }
  .display-time.warning { color: var(--warning-color); }
  .display-time.danger { color: var(--danger-color); animation: flash-red .5s infinite; }
  .display-overlay { position: absolute; inset: 0; background: rgba(0,0,0,.85); display: flex; align-items: center; justify-content: center; z-index: 100; opacity: 0; pointer-events: none; transition: opacity .3s; }
  .display-overlay.visible { opacity: 1; pointer-events: all; }
  .overlay-msg { font-family: var(--font-display); font-size: clamp(3rem,10vw,8rem); letter-spacing: .05em; text-align: center; color: var(--mat-text); animation: overlay-in .3s ease; }
  @keyframes overlay-in { from{transform:scale(.9);opacity:0} to{transform:scale(1);opacity:1} }

  /* Reconnecting banner — slim, non-blocking, sits at top of display */
  .display-reconnect {
    position: absolute;
    top: 0; left: 0; right: 0;
    background: rgba(0,0,0,.75);
    backdrop-filter: blur(4px);
    display: flex;
    align-items: center;
    justify-content: center;
    gap: .75rem;
    padding: .6rem 1.5rem;
    z-index: 200;
    border-bottom: 2px solid var(--mat-gold);
  }
  .reconnect-spinner {
    width: 16px; height: 16px;
    border: 2px solid rgba(255,255,255,.2);
    border-top-color: var(--mat-gold);
    border-radius: 50%;
    animation: spin .8s linear infinite;
    flex-shrink: 0;
  }
  .reconnect-text {
    font-family: var(--font-ui);
    font-size: clamp(.75rem,1.5vw,1rem);
    letter-spacing: .2em;
    color: rgba(255,255,255,.7);
    text-transform: uppercase;
  }
  .display-clock { position: absolute; bottom: 3.5rem; left: 1.5rem; font-family: var(--font-display); font-size: clamp(2.2rem,4.5vw,3.5rem); letter-spacing: .08em; color: rgba(255,255,255,.6); line-height: 1; }
  .display-status { position: absolute; bottom: 1rem; right: 1rem; font-family: var(--font-ui); font-size: .75rem; letter-spacing: .15em; color: rgba(255,255,255,.15); text-transform: uppercase; display: flex; align-items: center; gap: .4rem; }


  /* Back button on display screen — bottom-left, below the clock */
  .display-back-btn {
    position: absolute;
    bottom: 1rem;
    left: 1.5rem;
    background: none;
    border: none;
    border-radius: 4px;
    color: rgba(255,255,255,.2);
    cursor: pointer;
    font-family: var(--font-ui);
    font-size: .7rem;
    font-weight: 700;
    letter-spacing: .15em;
    padding: .3rem 0;
    text-transform: uppercase;
    transition: color .25s;
    z-index: 50;
  }
  .display-back-btn:hover, .display-back-btn:active {
    color: rgba(255,255,255,.75);
  }

  /* QR code bottom-right */
  .display-qr {
    position: absolute;
    bottom: 1.25rem;
    right: 1.25rem;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: .4rem;
    opacity: 0.55;
    transition: opacity .3s;
  }
  .display-qr:hover { opacity: 1; }
  .display-qr #displayQrCode { background: #fff; border-radius: 4px; padding: 6px; }
  .display-qr #displayQrCode canvas,
  .display-qr #displayQrCode img { display: block; width: clamp(70px,8vw,110px) !important; height: clamp(70px,8vw,110px) !important; }
  .display-qr-label {
    font-family: var(--font-ui);
    font-size: clamp(.5rem,.9vw,.75rem);
    letter-spacing: .08em;
    color: rgba(255,255,255,.6);
    text-align: center;
    text-transform: uppercase;
    max-width: 120px;
    word-break: break-all;
    line-height: 1.3;
  }

  /* ─── TV COLOR SCHEME ─────────────────────────────────────────── */
  :root {
    --tv1: #3B82F6;   /* blue   */
    --tv2: #10B981;   /* green  */
    --tv3: #F59E0B;   /* amber  */
    --tv4: #EC4899;   /* pink   */
    --tv-float: #8B5CF6; /* purple */
  }

  .tv-color-1 { --tv-color: var(--tv1); }
  .tv-color-2 { --tv-color: var(--tv2); }
  .tv-color-3 { --tv-color: var(--tv3); }
  .tv-color-4 { --tv-color: var(--tv4); }

  /* Landing TV cards — colored accent bar */
  .landing-tv-card.tv-color-1::before,
  .landing-tv-card.tv-color-1:hover::before { background: var(--tv1); transform: scaleX(1); }
  .landing-tv-card.tv-color-2::before,
  .landing-tv-card.tv-color-2:hover::before { background: var(--tv2); transform: scaleX(1); }
  .landing-tv-card.tv-color-3::before,
  .landing-tv-card.tv-color-3:hover::before { background: var(--tv3); transform: scaleX(1); }
  .landing-tv-card.tv-color-4::before,
  .landing-tv-card.tv-color-4:hover::before { background: var(--tv4); transform: scaleX(1); }

  .landing-tv-card.tv-color-1 .landing-tv-code { color: var(--tv1); }
  .landing-tv-card.tv-color-2 .landing-tv-code { color: var(--tv2); }
  .landing-tv-card.tv-color-3 .landing-tv-code { color: var(--tv3); }
  .landing-tv-card.tv-color-4 .landing-tv-code { color: var(--tv4); }

  .landing-tv-card.connected .landing-tv-status { background: var(--tv-color); box-shadow: 0 0 8px var(--tv-color); }
  .landing-tv-card.tv-taken { opacity: .6; cursor: not-allowed; }
  .landing-tv-card.tv-taken:hover { transform: none; box-shadow: none; }
  .landing-tv-card.connected { background: rgba(255,255,255,.04); }

  /* ─── MONITOR BAR (controller status bar) ─────────────────────── */
  .monitor-bar {
    display: flex;
    gap: .4rem;
    align-items: center;
    flex: 1;
    justify-content: center;
    flex-wrap: wrap;
  }

  .monitor-panel {
    display: flex;
    align-items: center;
    gap: .5rem;
    background: var(--mat-surface);
    border: 1px solid var(--mat-border);
    border-left: 3px solid var(--mat-border);
    border-radius: 4px;
    padding: .3rem .65rem .3rem .5rem;
    min-width: 110px;
    transition: all .2s;
    position: relative;
  }

  .monitor-panel.tv-color-1 { border-left-color: var(--tv1); }
  .monitor-panel.tv-color-2 { border-left-color: var(--tv2); }
  .monitor-panel.tv-color-3 { border-left-color: var(--tv3); }
  .monitor-panel.tv-color-4 { border-left-color: var(--tv4); }
  .monitor-panel.monitor-floating { border-left-color: var(--tv-float); }

  .monitor-panel.active { background: rgba(255,255,255,.05); }
  .monitor-panel.tv-color-1.active { background: rgba(59,130,246,.08); border-color: rgba(59,130,246,.4); border-left-color: var(--tv1); }
  .monitor-panel.tv-color-2.active { background: rgba(16,185,129,.08); border-color: rgba(16,185,129,.4); border-left-color: var(--tv2); }
  .monitor-panel.tv-color-3.active { background: rgba(245,158,11,.08); border-color: rgba(245,158,11,.4); border-left-color: var(--tv3); }
  .monitor-panel.tv-color-4.active { background: rgba(236,72,153,.08); border-color: rgba(236,72,153,.4); border-left-color: var(--tv4); }
  .monitor-panel.monitor-floating.active { background: rgba(139,92,246,.08); border-color: rgba(139,92,246,.4); border-left-color: var(--tv-float); }

  .monitor-icon { font-size: .95rem; opacity: .5; transition: opacity .2s; }
  .monitor-panel.active .monitor-icon { opacity: 1; }

  .monitor-info { display: flex; flex-direction: column; gap: .05rem; flex: 1; min-width: 0; }
  .monitor-label { font-family: var(--font-ui); font-size: .7rem; font-weight: 700; letter-spacing: .15em; color: var(--mat-muted); text-transform: uppercase; }
  .monitor-panel.active .monitor-label { color: var(--mat-text); }
  .monitor-status-text { font-family: var(--font-ui); font-size: .65rem; letter-spacing: .05em; color: var(--mat-border); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
  .monitor-panel.active .monitor-status-text { color: var(--mat-muted); }

  .monitor-badge { font-family: var(--font-ui); font-size: .65rem; letter-spacing: .1em; color: var(--mat-border); font-weight: 700; }

  .monitor-claim-btn {
    background: none;
    border: 1px solid var(--mat-border);
    border-radius: 3px;
    color: var(--mat-muted);
    cursor: pointer;
    font-family: var(--font-ui);
    font-size: .65rem;
    font-weight: 700;
    letter-spacing: .08em;
    padding: .2rem .4rem;
    white-space: nowrap;
    transition: all .15s;
    flex-shrink: 0;
  }
  .monitor-claim-btn:hover { border-color: var(--mat-text); color: var(--mat-text); }

  .monitor-conn-dot { width: 7px; height: 7px; border-radius: 50%; background: var(--mat-border); flex-shrink: 0; transition: all .3s; }
  .monitor-panel.tv-color-1.active .monitor-conn-dot { background: var(--tv1); box-shadow: 0 0 6px var(--tv1); }
  .monitor-panel.tv-color-2.active .monitor-conn-dot { background: var(--tv2); box-shadow: 0 0 6px var(--tv2); }
  .monitor-panel.tv-color-3.active .monitor-conn-dot { background: var(--tv3); box-shadow: 0 0 6px var(--tv3); }
  .monitor-panel.tv-color-4.active .monitor-conn-dot { background: var(--tv4); box-shadow: 0 0 6px var(--tv4); }
  .monitor-panel.monitor-floating.active .monitor-conn-dot { background: var(--tv-float); box-shadow: 0 0 6px var(--tv-float); animation: pulse-dot 2s infinite; }
  .landing-tv-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 1rem; width: 100%; max-width: 680px; margin-bottom: 2rem; }
  .landing-tv-card { background: var(--mat-panel); border: 1px solid var(--mat-border); border-radius: 6px; padding: 1.25rem .75rem 1rem; text-align: center; cursor: pointer; transition: all .2s; position: relative; overflow: hidden; }
  .landing-tv-card::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 3px; background: var(--mat-gold); transform: scaleX(0); transition: transform .2s; }
  .landing-tv-card:hover { border-color: var(--mat-gold); transform: translateY(-2px); box-shadow: 0 6px 24px rgba(212,160,23,.15); }
  .landing-tv-card:hover::before { transform: scaleX(1); }
  .landing-tv-card.connected { border-color: rgba(39,174,96,.5); background: rgba(39,174,96,.06); }
  .landing-tv-card.connected::before { background: var(--go-color); transform: scaleX(1); }
  .landing-tv-icon { font-size: 1.5rem; margin-bottom: .4rem; }
  .landing-tv-label { font-family: var(--font-ui); font-size: .7rem; font-weight: 700; letter-spacing: .25em; color: var(--mat-muted); text-transform: uppercase; margin-bottom: .5rem; }
  .landing-tv-code { font-family: var(--font-display); font-size: 1.5rem; letter-spacing: .1em; color: var(--mat-gold); line-height: 1; margin-bottom: .4rem; }
  .landing-tv-hint { font-family: var(--font-ui); font-size: .65rem; letter-spacing: .1em; color: var(--mat-muted); text-transform: uppercase; }
  .landing-tv-status { width: 6px; height: 6px; border-radius: 50%; background: var(--mat-border); margin: .5rem auto 0; transition: background .3s; }
  .landing-tv-card.connected .landing-tv-status { background: var(--go-color); box-shadow: 0 0 6px var(--go-color); }


  /* Controller lock button — top-left of landing, subtle */
  .ctrl-lock-btn {
    position: absolute;
    top: 1.25rem;
    left: 1.25rem;
    background: none;
    border: 1px solid var(--mat-border);
    border-radius: 4px;
    color: var(--mat-border);
    cursor: pointer;
    font-size: 1rem;
    padding: .4rem .55rem;
    line-height: 1;
    transition: all .2s;
    z-index: 10;
  }
  .ctrl-lock-btn:hover {
    border-color: var(--mat-muted);
    color: var(--mat-muted);
  }

  /* ─── SHARE PAGE ──────────────────────────────────────────────── */
  @media (max-width: 480px) {
    .landing-tv-grid { grid-template-columns: repeat(2,1fr); }
  }

  /* ─── BRANDING MODAL ───────────────────────────────────────── */
  .modal-backdrop { position: fixed; inset: 0; background: rgba(0,0,0,.75); z-index: 2000; display: flex; align-items: center; justify-content: center; padding: 1rem; }
  .modal-box { background: var(--mat-panel); border: 1px solid var(--mat-border); border-radius: 6px; width: 100%; max-width: 500px; max-height: 90vh; overflow-y: auto; display: flex; flex-direction: column; }
  .modal-header { display: flex; align-items: center; justify-content: space-between; padding: 1rem 1.25rem; border-bottom: 1px solid var(--mat-border); }
  .modal-title { font-family: var(--font-ui); font-size: 1rem; font-weight: 700; letter-spacing: .15em; text-transform: uppercase; }
  .modal-close { background: none; border: none; color: var(--mat-muted); cursor: pointer; font-size: 1.1rem; padding: .25rem .5rem; transition: color .15s; }
  .modal-close:hover { color: var(--mat-text); }
  .modal-body { padding: 1.25rem; display: flex; flex-direction: column; gap: 1.25rem; }
  .modal-footer { padding: 1rem 1.25rem; border-top: 1px solid var(--mat-border); display: flex; justify-content: flex-end; gap: .75rem; }
  .modal-field { display: flex; flex-direction: column; gap: .4rem; }
  .modal-field label { font-family: var(--font-ui); font-size: .75rem; font-weight: 700; letter-spacing: .2em; text-transform: uppercase; color: var(--mat-muted); }
  .logo-upload-row { display: flex; gap: .75rem; align-items: flex-start; }
  .logo-preview { width: 64px; height: 64px; background: var(--mat-dark); border: 1px solid var(--mat-border); border-radius: 4px; display: flex; align-items: center; justify-content: center; flex-shrink: 0; overflow: hidden; font-family: var(--font-ui); font-size: .65rem; color: var(--mat-muted); letter-spacing: .1em; }
  .brand-preview-box { background: var(--mat-dark); border: 1px solid var(--mat-border); border-radius: 4px; padding: 1.5rem; display: flex; flex-direction: column; align-items: center; gap: .5rem; }
  .brand-preview-logo { width: 52px; height: 52px; overflow: hidden; }
  .brand-preview-logo svg, .brand-preview-logo img { width: 100%; height: 100%; object-fit: contain; }
  .brand-preview-name { font-family: var(--font-display); font-size: 1.8rem; letter-spacing: .05em; color: var(--mat-text); text-align: center; line-height: 1; }
  .brand-preview-tagline { font-family: var(--font-ui); font-size: .8rem; letter-spacing: .25em; color: var(--mat-muted); text-transform: uppercase; }
  .brand-btn { background: none; border: none; color: var(--mat-muted); cursor: pointer; font-size: 1rem; padding: .3rem .5rem; transition: color .15s; line-height: 1; }
  .brand-btn:hover { color: var(--mat-gold); }

  /* ─── PROFILE GRID ────────────────────────────────────────────── */
  .profile-grid { display: grid; grid-template-columns: 1fr 1fr; gap: .6rem; }
  .profile-card { background: var(--mat-surface); border: 2px solid var(--mat-border); border-radius: 8px; padding: 1rem .75rem .85rem; cursor: pointer; transition: all .15s; text-align: center; position: relative; overflow: hidden; }
  .profile-card:hover { border-color: var(--mat-gold); transform: translateY(-2px); box-shadow: 0 6px 20px rgba(0,0,0,.4); }
  .profile-card .profile-color-bar { position: absolute; top: 0; left: 0; right: 0; height: 4px; border-radius: 2px 2px 0 0; }
  .profile-card .profile-name { font-family: var(--font-ui); font-size: .95rem; font-weight: 700; letter-spacing: .05em; color: var(--mat-text); margin: .4rem 0 .2rem; line-height: 1.2; }
  .profile-card .profile-meta { font-family: var(--font-ui); font-size: .7rem; letter-spacing: .1em; color: var(--mat-muted); text-transform: uppercase; }
  .profile-card .profile-lock { position: absolute; top: .5rem; right: .5rem; font-size: .75rem; opacity: .6; }
  .profile-card .profile-delete { position: absolute; top: .4rem; left: .4rem; background: none; border: none; color: transparent; font-size: .75rem; cursor: pointer; padding: .1rem .3rem; border-radius: 3px; transition: all .15s; }
  .profile-card:hover .profile-delete { color: var(--mat-muted); }
  .profile-card .profile-delete:hover { color: var(--mat-red) !important; background: rgba(192,57,43,.15); }

  /* ─── UTILITY ──────────────────────────────────────────────── */
  .hidden { display: none !important; }
  .connecting-overlay { position: fixed; inset: 0; background: rgba(0,0,0,.9); display: flex; flex-direction: column; align-items: center; justify-content: center; z-index: 1000; gap: 1rem; font-family: var(--font-ui); letter-spacing: .2em; text-transform: uppercase; }
  .spinner { width: 40px; height: 40px; border: 3px solid var(--mat-border); border-top-color: var(--mat-gold); border-radius: 50%; animation: spin .8s linear infinite; }
  @keyframes spin { to{transform:rotate(360deg)} }
  #toast { position: fixed; bottom: 2rem; left: 50%; transform: translateX(-50%) translateY(100px); background: var(--mat-panel); border: 1px solid var(--mat-border); border-radius: 4px; padding: .75rem 1.5rem; font-family: var(--font-ui); font-size: .9rem; letter-spacing: .1em; z-index: 9999; transition: transform .3s; white-space: nowrap; }
  #toast.show { transform: translateX(-50%) translateY(0); }

  @media (max-width:768px) {
    .mode-cards { grid-template-columns: 1fr 1fr; }
  }
  @media (max-width:480px) {
    .mode-cards { grid-template-columns: 1fr; }
    .ctrl-buttons { flex-direction: column; align-items: stretch; }
  }
