@import url('https://fonts.googleapis.com/css2?family=Share+Tech+Mono&family=Barlow:wght@400;600&family=Barlow+Condensed:wght@600;700&display=swap');
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#0d1117;--card:#111827;--up:#1a2332;--b1:#1f2937;--b2:#2d3748;
  --fg:#e5e7eb;--mu:#6b7280;--di:#4b5563;
  --blu:#60a5fa;--blu-bg:#1e3a5f;--blu-bd:#2563eb;
  --grn:#4ade80;--grn-bg:#14532d;--grn-bd:#16a34a;
  --org:#fb923c;--org-bg:#431407;--org-bd:#ea580c;
  --red:#f87171;--red-bg:#450a0a;--red-bd:#dc2626;
  --pur:#c084fc;--pur-bg:#3b0764;--pur-bd:#7e22ce;
  --gray-bg:#1f2937;--gray-bd:#374151;
  --hh:64px;--nh:68px;
  --mono:'Share Tech Mono',monospace;
  --main:'Barlow',sans-serif;
  --cond:'Barlow Condensed',sans-serif;
  --r:12px;--rp:999px;--sh:0 4px 16px rgba(0,0,0,.4);
}
html,body{height:100%;background:var(--bg);color:var(--fg);font-family:var(--main);font-size:15px;line-height:1.5;-webkit-font-smoothing:antialiased;-webkit-tap-highlight-color:transparent;overscroll-behavior:none}

/* HEADER */
header{position:fixed;top:0;left:0;right:0;height:var(--hh);background:linear-gradient(135deg,#0a1628,#0d2244 60%,#0a1a35);border-bottom:1.5px solid var(--blu-bd);z-index:100;box-shadow:0 2px 20px rgba(37,99,235,.2)}
header::after{content:'';position:absolute;inset:0;background:repeating-linear-gradient(90deg,transparent,transparent 48px,rgba(96,165,250,.04) 48px,rgba(96,165,250,.04) 49px);pointer-events:none}
.h-inner{display:flex;align-items:center;justify-content:space-between;height:100%;padding:0 16px}
.h-left{display:flex;align-items:center;gap:10px}

/* Logo – svxlink.ico aus dem Original */
.logo{width:42px;height:42px;object-fit:contain;border-radius:8px;flex-shrink:0;filter:drop-shadow(0 0 6px rgba(96,165,250,.5))}
.logo-fb{width:40px;height:40px;background:linear-gradient(135deg,#dc2626,#b91c1c);border-radius:10px;display:flex;align-items:center;justify-content:center;font-family:var(--cond);font-size:13px;font-weight:700;color:#fff;flex-shrink:0;border:1.5px solid rgba(255,255,255,.2);box-shadow:0 2px 8px rgba(220,38,38,.4)}

.cs{font-family:var(--cond);font-size:20px;font-weight:700;letter-spacing:1.5px;color:#fff;line-height:1.1;text-shadow:0 0 20px rgba(96,165,250,.4)}
.rf{font-family:var(--mono);font-size:10px;color:var(--blu);opacity:.8;letter-spacing:.3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:180px}

/* Connection Badge */
.badge{display:inline-flex;align-items:center;gap:6px;padding:5px 10px;border-radius:var(--rp);font-family:var(--cond);font-size:10px;font-weight:700;letter-spacing:1px}
.badge.connected{background:var(--grn-bg);color:var(--grn);border:1px solid var(--grn-bd)}
.badge.disconnected{background:var(--red-bg);color:var(--red);border:1px solid var(--red-bd)}
.bdot{width:7px;height:7px;border-radius:50%;background:currentColor;animation:pulse 1.8s infinite}

/* Pulse Dot (card headers) */
.d{display:inline-block;width:7px;height:7px;border-radius:50%;animation:pulse 1.8s infinite;flex-shrink:0}
.d.grn{background:var(--grn);box-shadow:0 0 6px var(--grn)}
.d.blue{background:var(--blu);box-shadow:0 0 6px var(--blu)}
.d.org{background:var(--org);box-shadow:0 0 6px var(--org)}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.3;transform:scale(.8)}}

/* MAIN / PAGES */
main{margin-top:var(--hh);margin-bottom:var(--nh);padding:10px;overflow-y:auto;-webkit-overflow-scrolling:touch;height:calc(100vh - var(--hh) - var(--nh))}
.page{display:none;animation:fi .2s ease}
.page.active{display:block}
@keyframes fi{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}

/* Live Status Bar */
.livebar{display:flex;background:var(--card);border:1px solid var(--b1);border-radius:var(--r);margin-bottom:10px;overflow:hidden;box-shadow:var(--sh)}
.lc{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:10px 6px;gap:3px}
.ll{font-family:var(--cond);font-size:9px;font-weight:700;letter-spacing:1px;color:var(--mu);text-transform:uppercase}
.lv{font-family:var(--mono);font-size:14px;color:var(--fg);transition:color .3s}
.lv.red{color:var(--red);text-shadow:0 0 8px var(--red)}
.lv.grn{color:var(--grn)}
.lv.blue{color:var(--blu)}
.ls{width:1px;background:var(--b1);margin:8px 0}

/* Cards */
.card{background:var(--card);border:1px solid var(--b1);border-radius:var(--r);margin-bottom:10px;overflow:hidden;box-shadow:var(--sh)}
.ch{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;background:linear-gradient(90deg,var(--blu-bg),transparent);border-bottom:1px solid var(--b1)}
.ct{display:flex;align-items:center;gap:8px;font-family:var(--cond);font-size:13px;font-weight:700;letter-spacing:1px;color:var(--blu);text-transform:uppercase}
.ltag{font-family:var(--cond);font-size:10px;color:var(--grn);font-weight:700;letter-spacing:1px;animation:pulse 1.8s infinite}

/* Activity List */
.alist{}
.ai{display:grid;grid-template-columns:62px 1fr auto;gap:6px;align-items:center;padding:10px 14px;border-bottom:1px solid var(--b1);transition:background .18s}
.ai:last-child{border-bottom:none}
.ai:nth-child(even){background:rgba(255,255,255,.015)}
.ai.ai-on{background:rgba(74,222,128,.07);border-left:3px solid var(--grn)}
.at{font-family:var(--mono);font-size:11px;color:var(--mu);white-space:nowrap}
.ad{font-size:9px;color:var(--di);margin-top:1px}
.acs{display:block;font-family:var(--cond);font-size:14px;font-weight:700;color:var(--blu);letter-spacing:.5px}
.an{display:block;font-size:11px;color:var(--mu)}
.onair{display:inline-block;background:var(--red);color:#fff;font-size:9px;font-weight:700;padding:1px 5px;border-radius:3px;margin-left:4px;letter-spacing:.5px;animation:pulse 1s infinite}
.ai2{}

/* Badges */
.badge{display:inline-block;padding:2px 7px;border-radius:4px;font-family:var(--mono);font-size:10px;white-space:nowrap}
.org-b{background:var(--org-bg);color:var(--org);border:1px solid var(--org-bd)}
.blu-b{background:var(--blu-bg);color:var(--blu);border:1px solid var(--blu-bd)}
.grn-b{background:var(--grn-bg);color:var(--grn);border:1px solid var(--grn-bd)}

.empty{padding:24px;text-align:center;color:var(--mu);font-size:13px}

/* Info Rows (Reflector Status) */
.rows{}
.row{display:flex;justify-content:space-between;align-items:center;padding:9px 14px;border-bottom:1px solid var(--b1)}
.row:last-child{border-bottom:none}
.rl{font-size:12px;color:var(--mu)}
.rv{font-family:var(--mono);font-size:12px;color:var(--fg);text-align:right;max-width:220px;word-break:break-all}
.rv.ok{color:var(--grn)}
.rv.red{color:var(--red)}
.rv.blue{color:var(--blu)}

/* Hardware Grid */
.hwg{display:grid;grid-template-columns:1fr 1fr}
.hw{display:flex;justify-content:space-between;align-items:center;padding:9px 14px;border-bottom:1px solid var(--b1);border-right:1px solid var(--b1)}
.hw:nth-child(even){border-right:none}
.hw:nth-last-child(-n+2){border-bottom:none}
.hl{font-size:11px;color:var(--mu)}
.hv{font-family:var(--mono);font-size:12px;color:var(--fg);transition:color .3s}
.hv.ok{color:var(--grn)}
.hv.red{color:var(--red)}

/* TG List */
.tglist{}
.tgrow{display:flex;align-items:center;gap:12px;padding:12px 14px;border-bottom:1px solid var(--b1);cursor:pointer;transition:background .18s}
.tgrow:last-child{border-bottom:none}
.tgrow:active{background:var(--blu-bg)}
.tgn{font-family:var(--mono);font-size:16px;color:var(--blu);min-width:60px}
.tgname{flex:1;font-size:14px;color:var(--fg)}
.tgarr{color:var(--di);font-size:20px}
.tgman{padding:12px 14px;display:flex;gap:10px;align-items:center;flex-wrap:nowrap}
.txti{flex:1;min-width:0;background:var(--up);border:1px solid var(--b2);border-radius:8px;padding:10px 12px;color:var(--fg);font-family:var(--mono);font-size:16px;outline:none}
.txti:focus{border-color:var(--blu-bd)}
.tgman .btn{flex-shrink:0}
.arow{display:flex;gap:10px;padding:12px 14px}

/* Buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;padding:10px 16px;border-radius:8px;border:1px solid transparent;font-family:var(--cond);font-size:13px;font-weight:700;letter-spacing:.5px;cursor:pointer;transition:.18s ease;white-space:nowrap;min-height:42px;-webkit-tap-highlight-color:transparent}
.btn:active{transform:scale(.96);filter:brightness(.85)}
.btn.blue{background:var(--blu-bg);color:var(--blu);border-color:var(--blu-bd)}
.btn.green{background:var(--grn-bg);color:var(--grn);border-color:var(--grn-bd)}
.btn.orange{background:var(--org-bg);color:var(--org);border-color:var(--org-bd)}
.btn.red{background:var(--red-bg);color:var(--red);border-color:var(--red-bd)}
.btn.purple{background:var(--pur-bg);color:var(--pur);border-color:var(--pur-bd)}
.btn.gray{background:var(--gray-bg);color:var(--fg);border-color:var(--gray-bd)}

/* Quick DTMF Grid */
.qgrid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;padding:12px 14px}
.qgrid .btn{width:100%;font-size:12px;padding:10px 4px}

/* DTMF Keyboard */
.ddisp{margin:0 14px 12px;background:#000;border:1px solid var(--b2);border-radius:8px;padding:12px 16px;font-family:var(--mono);font-size:24px;color:var(--grn);text-align:center;min-height:52px;letter-spacing:4px;text-shadow:0 0 10px var(--grn)}
.dkeys{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;padding:0 14px 12px;max-width:600px;margin:0 auto}
.dkey{background:var(--up);border:1px solid var(--b2);border-radius:8px;aspect-ratio:1/1;width:100%;font-family:var(--cond);font-size:22px;font-weight:700;color:var(--fg);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:.18s;-webkit-tap-highlight-color:transparent;min-height:64px}
.dkey:active{background:var(--blu-bg);border-color:var(--blu-bd);color:var(--blu);transform:scale(.94)}
.dact{display:flex;gap:10px;padding:0 14px 14px}
.dact .btn{flex:1}

/* Misc */
.backlink{display:block;text-align:center;padding:12px;color:var(--mu);font-size:12px;text-decoration:none;margin-bottom:4px}
.backlink:active{color:var(--blu)}
.note{text-align:center;font-size:11px;color:var(--di);padding:8px;margin-bottom:4px}

/* Bottom Nav */
nav{position:fixed;bottom:0;left:0;right:0;height:var(--nh);background:var(--card);border-top:1.5px solid var(--b1);display:flex;z-index:100;padding-bottom:env(safe-area-inset-bottom,0);box-shadow:0 -4px 20px rgba(0,0,0,.3)}
.nb{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;background:none;border:none;cursor:pointer;padding:8px 4px;color:var(--di);position:relative;-webkit-tap-highlight-color:transparent;font-size:10px;font-family:var(--cond);font-weight:600;letter-spacing:.5px;text-transform:uppercase}
.nb>span:first-child{font-size:22px;line-height:1}
.nb.active{color:var(--blu)}
.nb.active::before{content:'';position:absolute;top:0;left:20%;right:20%;height:2px;background:var(--blu);border-radius:0 0 2px 2px}

/* Toast */
.toast{position:fixed;bottom:calc(var(--nh) + 12px);left:50%;transform:translateX(-50%) translateY(20px);background:#1f2937;border:1px solid var(--b2);color:var(--fg);padding:10px 20px;border-radius:var(--rp);font-size:13px;font-weight:600;opacity:0;transition:opacity .3s,transform .3s;z-index:999;white-space:nowrap;pointer-events:none;box-shadow:var(--sh)}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.toast.success{border-color:var(--grn-bd);color:var(--grn)}
.toast.error{border-color:var(--red-bd);color:var(--red)}

/* Responsive */
@media(max-width:360px){.livebar .ll{font-size:8px}.lv{font-size:12px}.dkeys{grid-template-columns:repeat(4,1fr)}}
@media(orientation:landscape) and (max-height:500px){:root{--hh:48px;--nh:52px}.rf{display:none}.nb>span:last-child{display:none}.nb>span:first-child{font-size:18px}}


/* square-dtmf-keys */
.dtmf-pad{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;}
.dtmf-key{aspect-ratio:1/1;width:100%;display:flex;align-items:center;justify-content:center;font-size:22px;border-radius:10px;}

.shortcuts-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;}
.shortcut-btn{padding:14px 12px;border-radius:10px;border:0;color:#fff;font-size:16px;}
.card{background:#16213a;margin:10px;padding:12px;border-radius:12px;}
.page-header{display:flex;align-items:center;gap:10px;padding:10px;margin:10px;}
.back-link{text-decoration:none;color:#9ad;}
.muted{opacity:.75;font-size:13px;}

/* force-tg-blue */
.tg, .tg-badge, .tg-pill, .tg-tag { background:#2b6cb0 !important; color:#fff !important; }

.byline{font-size:12px;opacity:.75;margin-top:6px;text-align:center;}

/* square-dtmf-keys-index */
#p-dtmf .kpad .btn{aspect-ratio:1/1;}

/* reflector status dot colors */
.dot-green{background:#22c55e !important;}
.dot-orange{background:#f59e0b !important;}
.dot-red{background:#ef4444 !important;}

/* red dot background */
.rd{background:var(--red);box-shadow:0 0 6px var(--red)}

/* ── LIGHT MODE (gesteuert durch Handy-Betriebssystem) ─────────────────────── */
@media (prefers-color-scheme: light) {
  :root {
    --bg:#f0f4f8;--card:#ffffff;--up:#e8edf2;--b1:#d1d9e0;--b2:#b8c4ce;
    --fg:#1a202c;--mu:#4a5568;--di:#718096;
    --blu:#1d4ed8;--blu-bg:#dbeafe;--blu-bd:#93c5fd;
    --grn:#15803d;--grn-bg:#dcfce7;--grn-bd:#86efac;
    --org:#c2410c;--org-bg:#ffedd5;--org-bd:#fdba74;
    --red:#b91c1c;--red-bg:#fee2e2;--red-bd:#fca5a5;
    --pur:#7e22ce;--pur-bg:#f3e8ff;--pur-bd:#d8b4fe;
    --gray-bg:#e2e8f0;--gray-bd:#cbd5e0;
    --sh:0 4px 16px rgba(0,0,0,.10);
  }

  /* Header hell */
  header {
    background: linear-gradient(135deg,#1e3a8a,#1d4ed8 60%,#1e40af);
    border-bottom-color: #3b82f6;
    box-shadow: 0 2px 20px rgba(29,78,216,.25);
  }
  header::after {
    background: repeating-linear-gradient(90deg,transparent,transparent 48px,rgba(255,255,255,.08) 48px,rgba(255,255,255,.08) 49px);
  }

  /* Nav unten */
  nav { box-shadow: 0 -4px 20px rgba(0,0,0,.08); }

  /* Toast */
  .toast { background:#ffffff; }

  /* DTMF Display */
  .ddisp { background:#1a1a1a; }

  /* DTMF Keys */
  .dkey { background:#e2e8f0; border-color:#cbd5e0; color:#1a202c; }
  .dkey:active { background:var(--blu-bg); border-color:var(--blu-bd); color:var(--blu); }

  /* Activity */
  .ai:nth-child(even) { background:rgba(0,0,0,.025); }
  .ai.ai-on { background:rgba(21,128,61,.07); }

  /* Card Header Gradient */
  .ch { background: linear-gradient(90deg,var(--blu-bg),transparent); }

  /* Input */
  .txti { background:var(--up); border-color:var(--b2); color:var(--fg); }

  /* TG Row */
  .tgrow:active { background:var(--blu-bg); }

  /* Shortcuts & DTMF standalone page */
  .card { background:#ffffff; }
}


/* ── THEME OVERRIDES ─────────────────────────────────────────────────────────
   body.theme-dark  = immer Dark
   body.theme-light = immer Light
   (kein class = system → @media greift wie gehabt) */
body.theme-dark{
  --bg:#0d1117;--card:#111827;--up:#1a2332;--b1:#1f2937;--b2:#2d3748;
  --fg:#e5e7eb;--mu:#6b7280;--di:#4b5563;
  --blu:#60a5fa;--blu-bg:#1e3a5f;--blu-bd:#2563eb;
  --grn:#4ade80;--grn-bg:#14532d;--grn-bd:#16a34a;
  --org:#fb923c;--org-bg:#431407;--org-bd:#ea580c;
  --red:#f87171;--red-bg:#450a0a;--red-bd:#dc2626;
  --pur:#c084fc;--pur-bg:#3b0764;--pur-bd:#7e22ce;
  --gray-bg:#1f2937;--gray-bd:#374151;
}
body.theme-light{
  --bg:#f0f4f8;--card:#ffffff;--up:#e8edf2;--b1:#d1d9e0;--b2:#b8c4ce;
  --fg:#1a202c;--mu:#4a5568;--di:#718096;
  --blu:#1d4ed8;--blu-bg:#dbeafe;--blu-bd:#93c5fd;
  --grn:#15803d;--grn-bg:#dcfce7;--grn-bd:#86efac;
  --org:#c2410c;--org-bg:#ffedd5;--org-bd:#fdba74;
  --red:#b91c1c;--red-bg:#fee2e2;--red-bd:#fca5a5;
  --pur:#7e22ce;--pur-bg:#f3e8ff;--pur-bd:#d8b4fe;
  --gray-bg:#e2e8f0;--gray-bd:#cbd5e0;
  --sh:0 4px 16px rgba(0,0,0,.10);
}
body.theme-light header{background:linear-gradient(135deg,#1e3a8a,#1d4ed8 60%,#1e40af);border-bottom-color:#3b82f6}
body.theme-light nav{box-shadow:0 -4px 20px rgba(0,0,0,.08)}
body.theme-light .ddisp{background:#1a1a1a}
body.theme-light .dkey{background:#e2e8f0;border-color:#cbd5e0;color:#1a202c}
body.theme-light .dkey:active{background:var(--blu-bg);border-color:var(--blu-bd);color:var(--blu)}
body.theme-light .card{background:#ffffff}
body.theme-light .ch{background:linear-gradient(90deg,var(--blu-bg),transparent)}
body.theme-light .txti{background:var(--up);border-color:var(--b2);color:var(--fg)}

/* ── SETTINGS MODAL ─────────────────────────────────────────────────────────*/
.settings-overlay{position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:200;
  display:flex;align-items:flex-end;justify-content:center;
  opacity:0;pointer-events:none;transition:opacity .25s}
.settings-overlay.open{opacity:1;pointer-events:all}
.settings-modal{background:var(--card);border-radius:20px 20px 0 0;width:100%;max-width:480px;
  padding:0 0 calc(env(safe-area-inset-bottom,0px) + 20px);
  box-shadow:0 -8px 40px rgba(0,0,0,.4);
  transform:translateY(40px);transition:transform .25s;
  border-top:1.5px solid var(--b1)}
.settings-overlay.open .settings-modal{transform:translateY(0)}
.settings-header{display:flex;align-items:center;justify-content:space-between;
  padding:16px 20px 12px;border-bottom:1px solid var(--b1)}
.settings-title{font-family:var(--cond);font-size:15px;font-weight:700;
  letter-spacing:1px;color:var(--blu);text-transform:uppercase}
.settings-close-btn{background:none;border:none;color:var(--mu);font-size:22px;
  cursor:pointer;padding:2px 8px;border-radius:6px;line-height:1}
.settings-close-btn:active{background:var(--up)}
.settings-section{padding:14px 20px 6px}
.settings-label{font-family:var(--cond);font-size:11px;font-weight:700;
  letter-spacing:1px;color:var(--mu);text-transform:uppercase;margin-bottom:10px}
.settings-row{display:flex;gap:10px;flex-wrap:wrap}
.sopt-btn{flex:1;min-width:80px;padding:10px 12px;
  background:var(--up);border:1.5px solid var(--b2);border-radius:10px;
  color:var(--fg);font-family:var(--cond);font-size:13px;font-weight:700;
  letter-spacing:.5px;cursor:pointer;transition:.15s;
  -webkit-tap-highlight-color:transparent;white-space:nowrap;text-align:center}
.sopt-btn:active{filter:brightness(.85)}
.sopt-btn.active{background:var(--blu-bg);border-color:var(--blu-bd);color:var(--blu)}
