:root{
  --bg:#151517; --bg2:#0d0d0f;
  --remote-a:#1e1e22; --remote-b:#171719;
  --key-hi:#2f2f36; --key:#222227;
  --line:#34343c; --txt:#edeef1; --muted:#85858f;
  --accent:#d2201d; --accent-soft:#ef4540;
  --shadow:0 26px 70px rgba(0,0,0,.62);
}
*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html,body{margin:0;height:100%}
body{
  background:
    radial-gradient(120% 75% at 50% 22%, rgba(255,255,255,.028), transparent 55%),
    radial-gradient(150% 130% at 50% 50%, #1b1b1e 0%, var(--bg) 46%, var(--bg2) 100%),
    url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='180' height='180'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/><feColorMatrix type='saturate' values='0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)' opacity='0.035'/></svg>");
  background-blend-mode:overlay,normal,normal;
  color:var(--txt);font-family:-apple-system,"Segoe UI",Roboto,system-ui,sans-serif;min-height:100dvh;
}
.stage{display:flex;justify-content:center;align-items:flex-start;width:100%;padding:16px;min-height:100dvh}

.remote{
  width:min(340px,94vw);
  background:linear-gradient(180deg,var(--remote-a),var(--remote-b));
  border:1px solid #2a2a30;border-radius:42px;padding:14px 22px 18px;
  box-shadow:var(--shadow), inset 0 1px 0 rgba(255,255,255,.045), inset 0 0 0 1px rgba(0,0,0,.2);
  display:flex;flex-direction:column;gap:13px;position:relative;
}
.remote::before{content:"";position:absolute;left:14%;right:14%;top:0;height:1px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.12),transparent)}

/* Kopf — Logo links · Steuerung rechts */
.topline{display:flex;align-items:center;justify-content:space-between;min-height:30px;padding:4px 4px 2px}
.topctrls{display:flex;align-items:center;gap:9px}

/* iPii 4-Balken-Marke */
.ipii-mark{display:inline-flex;align-items:center;justify-content:center}
.ipii-mark .bar{display:block;border-radius:999px}
.ipii-mark.hd{gap:4px;height:26px;margin-left:26px}  /* roter Balken fluchtet vertikal mit dem Power-Strich darunter */
.ipii-mark.hd .bar{width:5px;height:20px;background:linear-gradient(180deg,#1b1b1f,#101013);box-shadow:inset 0 1px 1.5px rgba(0,0,0,.9), inset 0 -1px 1px rgba(255,255,255,.05)}
/* Statusanzeige im roten Balken: Standard = dunkelrot (ruht); grün-Blitz bei Erfolg, rot-Blitz bei Fehler/Aus */
.ipii-mark.hd .bar.red{height:26px;background:linear-gradient(180deg,#3e1311,#250a09);box-shadow:inset 0 1px 1.5px rgba(0,0,0,.85), inset 0 -1px 1px rgba(255,120,110,.06);transition:background .4s cubic-bezier(.4,0,.2,1),box-shadow .45s,filter .35s}
.ipii-mark.hd.flash-ok .bar.red{background:linear-gradient(180deg,#5cf58e,#16a34a);box-shadow:inset 0 1px 1px rgba(255,255,255,.3),0 0 15px rgba(54,220,110,.85),0 0 32px rgba(54,220,110,.4);filter:brightness(1.12)}
.ipii-mark.hd.flash-err .bar.red{background:linear-gradient(180deg,#ff534c,#c8150e);box-shadow:inset 0 1px 1px rgba(255,255,255,.25),0 0 15px rgba(226,52,47,.85),0 0 32px rgba(226,52,47,.4);filter:brightness(1.12)}
.ipii-mark.sm{gap:3px;height:22px}
.ipii-mark.sm .bar{width:4.5px;height:19px;background:#e3e4e8;box-shadow:0 1px 1px rgba(0,0,0,.4)}
.ipii-mark.sm .bar.red{background:var(--accent);height:23px;box-shadow:0 0 7px rgba(210,32,29,.55)}
/* Menü-Logo: 4-Balken um 90° gekippt → alle Balken waagerecht */
.ipii-mark.tilt{gap:3px;height:22px;transform:rotate(90deg)}
.ipii-mark.tilt .bar{width:4px;height:15px;background:#cfd0d6;border-radius:999px}
.ipii-mark.tilt .bar.red{height:21px;background:var(--accent);box-shadow:0 0 6px rgba(210,32,29,.5)}

/* Akzentlinie */
.accent-line{height:1px;margin:0 -22px 2px;background:linear-gradient(90deg,transparent 2%,rgba(210,32,29,.85) 32%,rgba(210,32,29,.85) 68%,transparent 98%);box-shadow:0 0 6px rgba(210,32,29,.28);opacity:.9}

.row{display:flex;align-items:center;justify-content:center;gap:14px}

/* Tasten */
.btn{border:none;cursor:pointer;color:var(--txt);background:linear-gradient(180deg,var(--key-hi),var(--key));border:1px solid #2e2e35;box-shadow:0 3px 9px rgba(0,0,0,.45), inset 0 1px 0 rgba(255,255,255,.06);display:flex;align-items:center;justify-content:center;transition:transform .08s ease, filter .12s ease, box-shadow .15s;user-select:none}
.btn:active{transform:translateY(1px) scale(.96);filter:brightness(1.3)}
.btn svg{width:20px;height:20px;fill:none;stroke:#dcdce1;stroke-width:1.85;stroke-linecap:round;stroke-linejoin:round}
/* runde Hardware-Tasten — tieffein, tastbar */
.rk{width:50px;height:50px;border-radius:50%;background:radial-gradient(circle at 50% 30%,#34343c,#1c1c21 94%);border:1px solid #2c2c33;box-shadow:0 4px 12px rgba(0,0,0,.5), inset 0 1px 0 rgba(255,255,255,.08), inset 0 0 0 1px rgba(0,0,0,.32)}
.rk:active{transform:translateY(1px) scale(.95);box-shadow:0 2px 5px rgba(0,0,0,.5), inset 0 2px 7px rgba(0,0,0,.55)}
.rk.wide{width:60px;border-radius:25px}
.row-top{justify-content:center;padding:0 16px}
/* Power: oberer Strich rot */
.power .pwr-arc{stroke:#bfc0c8}
.power .pwr-top{stroke:var(--accent);filter:drop-shadow(0 0 3px rgba(210,32,29,.6))}
/* Zurück zu iPii.TV — dezenter Web-Link im Remote-Stil (ersetzt Power 2026-06-12) */
.row-top{justify-content:space-between;gap:10px}
.backlink{display:inline-flex;align-items:center;gap:7px;height:34px;padding:0 13px 0 9px;
  border-radius:17px;text-decoration:none;color:var(--muted);
  background:linear-gradient(180deg,var(--key-hi),var(--key));border:1px solid #2c2c33;
  box-shadow:0 2px 6px rgba(0,0,0,.4), inset 0 1px 0 rgba(255,255,255,.05);
  transition:color .14s ease, filter .14s ease, transform .08s ease}
.backlink svg{width:17px;height:17px;fill:none;stroke:currentColor;stroke-width:2;
  stroke-linecap:round;stroke-linejoin:round}
.backlink-label{font-size:13px;font-weight:600;letter-spacing:.01em;line-height:1}
.backlink-label .dot{color:var(--accent)}
.backlink:hover{color:var(--txt);filter:brightness(1.12)}
.backlink:active{transform:translateY(1px) scale(.98)}
.backlink:focus-visible{outline:2px solid var(--accent);outline-offset:2px}

/* Geraete-Taste rechts in der Zurueck-Reihe — gleiche ausgegraute Optik wie .backlink, ohne Icon */
.devbtn{display:inline-flex;align-items:center;gap:7px;height:34px;padding:0 13px;
  border-radius:17px;cursor:pointer;color:var(--muted);
  background:linear-gradient(180deg,var(--key-hi),var(--key));border:1px solid #2c2c33;
  box-shadow:0 2px 6px rgba(0,0,0,.4), inset 0 1px 0 rgba(255,255,255,.05);
  font-family:inherit;transition:color .14s ease, filter .14s ease, transform .08s ease}
.devbtn .devbtn-name{font-size:13px;font-weight:600;letter-spacing:.01em;line-height:1;
  white-space:nowrap}
.devbtn .devbtn-caret{width:14px;height:14px;flex:none;fill:none;stroke:currentColor;
  stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.devbtn:hover{color:var(--txt);filter:brightness(1.12)}
.devbtn.is-switch:active{transform:translateY(1px) scale(.98)}
.devbtn:focus-visible{outline:2px solid var(--accent);outline-offset:2px}
.mic{position:relative}
.mic svg{stroke:#6fb0ff}
.mic::after{content:"";position:absolute;inset:-3px;border-radius:50%;border:1.5px solid rgba(111,176,255,.22)}

/* D-Pad */
.dpad{position:relative;width:226px;height:226px;margin:0 auto;border-radius:50%;background:radial-gradient(circle at 50% 33%,#26262c,#111115 76%);border:1px solid #2c2c33;box-shadow:inset 0 2px 18px rgba(0,0,0,.72), 0 9px 28px rgba(0,0,0,.46), inset 0 0 0 1px rgba(255,255,255,.022)}
.dpad::after{content:"";position:absolute;inset:30px;border-radius:50%;border:1px solid rgba(255,255,255,.035);pointer-events:none;transition:opacity .3s}
.dpad.screen-mode::after{opacity:0}
.dpad-core{position:absolute;inset:0;transition:opacity .35s ease, transform .35s cubic-bezier(.4,0,.2,1)}
.dpad.screen-mode .dpad-core{opacity:0;transform:scale(.82);pointer-events:none}
.dp{position:absolute;background:transparent;border:none;box-shadow:none}
.dp:active{transform:none;filter:none}
.dp svg{width:29px;height:29px;stroke:#cfcfd6;stroke-width:2.4}
.dp.up{top:8px;left:50%;transform:translateX(-50%);width:88px;height:54px;align-items:flex-start;padding-top:9px}
.dp.down{bottom:8px;left:50%;transform:translateX(-50%);width:88px;height:54px;align-items:flex-end;padding-bottom:9px}
.dp.left{left:8px;top:50%;transform:translateY(-50%);width:54px;height:88px;justify-content:flex-start;padding-left:9px}
.dp.right{right:8px;top:50%;transform:translateY(-50%);width:54px;height:88px;justify-content:flex-end;padding-right:9px}
.dp.up:active,.dp.down:active,.dp.left:active,.dp.right:active{background:radial-gradient(circle,rgba(210,32,29,.16),transparent 70%)}
.dp.ok{top:50%;left:50%;transform:translate(-50%,-50%);width:100px;height:100px;border-radius:50%;background:linear-gradient(160deg,#2b2b32,#1c1c20);border:1px solid #3a3a42;font-weight:700;font-size:18px;letter-spacing:1.5px;color:#edeef1;box-shadow:0 5px 16px rgba(0,0,0,.5), inset 0 1px 0 rgba(255,255,255,.08), inset 0 0 0 1px rgba(0,0,0,.25)}
.dp.ok:active{transform:translate(-50%,-50%) scale(.95);filter:brightness(1.28)}

/* D-Pad Mini-Screen — runder Touch-I/O-Screen (Smartwatch-Prinzip) */
.dpad-screen{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%) scale(.7);width:206px;height:206px;border-radius:50%;background:radial-gradient(circle at 50% 34%,#1c1c23,#09090d 82%);border:1px solid #2c2c34;box-shadow:inset 0 2px 24px rgba(0,0,0,.85), 0 0 0 1px rgba(210,32,29,.1), 0 6px 22px rgba(0,0,0,.5);opacity:0;pointer-events:none;transition:opacity .35s ease, transform .42s cubic-bezier(.34,1.42,.5,1);overflow:hidden}
.dpad.screen-mode .dpad-screen{opacity:1;transform:translate(-50%,-50%) scale(1);pointer-events:auto}
.dpad-screen::after{content:"";position:absolute;inset:0;border-radius:50%;background:radial-gradient(circle at 50% 8%,rgba(210,32,29,.10),transparent 62%);pointer-events:none}

/* Fortschritts-Ring */
.ds-ring{position:absolute;inset:0;width:100%;height:100%;pointer-events:none;opacity:0;transition:opacity .35s}
.dpad-screen.nowplaying .ds-ring{opacity:1}
.ds-ring-bg{fill:none;stroke:rgba(255,255,255,.07);stroke-width:2.4}
.ds-ring-fg{fill:none;stroke:var(--accent);stroke-width:2.8;stroke-linecap:round;stroke-dasharray:285.9;stroke-dashoffset:285.9;filter:drop-shadow(0 0 3px rgba(210,32,29,.6));transition:stroke-dashoffset .5s ease}
.ds-ring-knob{fill:#fff;filter:drop-shadow(0 0 5px rgba(210,32,29,.95));opacity:0;transition:opacity .35s}
.dpad-screen.nowplaying .ds-ring-knob{opacity:1}

/* Inhalt */
.ds-center{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:5px;padding:32px;text-align:center;z-index:1}
.ds-cancel{position:absolute;top:11px;left:50%;transform:translateX(-50%);width:22px;height:22px;border-radius:50%;border:1px solid #34343d;background:rgba(18,18,24,.88);color:var(--muted);font-size:11px;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:3;opacity:0;transition:opacity .3s, transform .12s}
.dpad.screen-mode .ds-cancel{opacity:.85}
.ds-cancel:active{transform:translateX(-50%) scale(.88)}

/* 4-Balken-Lade-Sequenz */
.ds-loader{display:flex;gap:6px;align-items:center;height:42px}
.ds-loader .b{width:7px;height:28px;border-radius:999px;background:#3a3a44;animation:loadbar 1.1s ease-in-out infinite}
.ds-loader .b.red{background:var(--accent);box-shadow:0 0 10px rgba(210,32,29,.6)}
.ds-loader .b:nth-child(2){animation-delay:.13s}
.ds-loader .b:nth-child(3){animation-delay:.26s}
.ds-loader .b:nth-child(4){animation-delay:.39s}
@keyframes loadbar{0%,100%{transform:scaleY(.5);opacity:.55}50%{transform:scaleY(1.25);opacity:1}}
.dpad-screen:not(.loading) .ds-loader{display:none}

.ds-kicker{font-size:8.5px;letter-spacing:2px;text-transform:uppercase;color:var(--accent-soft);font-weight:700}
.ds-title{font-size:13px;font-weight:700;letter-spacing:.2px;color:var(--txt);max-width:132px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.ds-text{font-size:10px;line-height:1.45;color:var(--muted);max-width:128px}
.ds-time{font-size:11px;font-family:ui-monospace,Menlo,monospace;color:var(--muted);letter-spacing:.5px}
.dpad-screen.nowplaying .ds-time{font-size:15px;color:var(--txt);margin-top:1px}
.ds-kicker:empty,.ds-title:empty,.ds-text:empty,.ds-time:empty{display:none}

/* Seek-Tap-Zonen (nur Now-Playing) */
.ds-seek{position:absolute;top:0;bottom:0;width:36%;background:none;border:none;color:rgba(255,255,255,0);font-size:18px;cursor:pointer;z-index:2;display:none;align-items:center;transition:color .15s, background .15s}
.dpad-screen.nowplaying .ds-seek{display:flex}
.ds-seek-l{left:0;justify-content:flex-start;padding-left:16px;border-radius:50% 0 0 50%}
.ds-seek-r{right:0;justify-content:flex-end;padding-right:16px;border-radius:0 50% 50% 0}
.ds-seek:active{color:rgba(255,255,255,.85);background:radial-gradient(circle,rgba(210,32,29,.16),transparent 72%)}

/* ── Vol-Modus: Ring zeigt Pegel, Zentrum = große %-Zahl ───────── */
.ds-vol{display:none;align-items:baseline;gap:1px;line-height:1}
.dpad-screen.vol .ds-vol{display:flex}
.dpad-screen.vol .ds-ring,.dpad-screen.vol .ds-ring-knob{opacity:1}
.ds-vol-num{font-size:38px;font-weight:800;letter-spacing:-1px;color:var(--txt);font-family:ui-monospace,Menlo,monospace}
.ds-vol-unit{font-size:15px;font-weight:700;color:var(--muted)}
/* ── Hilfe-Modus: Icon/Bild oben, Titel + Anleitungstext ───────── */
.ds-icon{display:none;width:46px;height:46px;border-radius:13px;background:radial-gradient(circle at 50% 32%,#26262e,#101015 80%);box-shadow:inset 0 1px 0 rgba(255,255,255,.08),0 4px 12px rgba(0,0,0,.5);align-items:center;justify-content:center;overflow:hidden;margin-bottom:2px}
.ds-icon svg{width:24px;height:24px;fill:none;stroke:var(--accent-soft);stroke-width:1.7}
.ds-icon img{width:100%;height:100%;object-fit:cover}
.dpad-screen.help .ds-icon{display:flex}
.dpad-screen.help .ds-text{display:block;max-width:140px;font-size:9.5px;line-height:1.5}
.dpad-screen.help .ds-title{font-size:12px}

/* Steuerzeile: Screen-Toggle + Segment-Switch */
.midrow{display:flex;align-items:center;justify-content:center;gap:12px}
.screen-toggle{width:30px;height:30px;border-radius:9px;border:1px solid #2a2a31;background:rgba(0,0,0,.28);box-shadow:inset 0 1px 4px rgba(0,0,0,.45);color:#4a4a52;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:color .25s, box-shadow .25s, background .25s}
.screen-toggle svg{width:16px;height:16px;fill:none;stroke:currentColor;stroke-width:1.7}
.screen-toggle.on{color:#b34a47;box-shadow:inset 0 1px 4px rgba(0,0,0,.45), 0 0 6px rgba(154,36,32,.35)}
.screen-toggle:active{transform:scale(.93)}

/* Segment-Switch — gleitender Indikator, glasig, icon-basiert */
.seg{position:relative;display:flex;width:118px;height:30px;border-radius:10px;background:rgba(255,255,255,.025);border:1px solid rgba(255,255,255,.06);box-shadow:inset 0 1px 5px rgba(0,0,0,.5);padding:3px;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px)}
.seg-pill{position:absolute;top:3px;left:3px;width:calc(33.333% - 2px);height:calc(100% - 6px);border-radius:8px;background:linear-gradient(180deg,#a83d3a,#7c1b18);box-shadow:0 2px 6px rgba(120,28,25,.4), inset 0 1px 0 rgba(255,255,255,.12);transition:transform .32s cubic-bezier(.34,1.5,.5,1)}
.seg[data-mode="numpad"] .seg-pill{transform:translateX(100%)}
.seg[data-mode="keyboard"] .seg-pill{transform:translateX(200%)}
.seg-opt{position:relative;z-index:1;flex:1;background:none;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--muted);transition:color .25s, transform .12s}
.seg-opt:active{transform:scale(.92)}
.seg-opt svg{width:16px;height:16px;fill:none;stroke:currentColor;stroke-width:1.8}
.seg-opt.active{color:#f0f0f2}

/* Tastatur-Eingabe IM Mini-D-Pad-Screen: Label + Live-Text + Caret. Verstecktes Input fängt die Geräte-Tastatur. */
.ds-kbd{display:none;flex-direction:column;align-items:center;gap:7px;width:100%}
.dpad-screen.kbd .ds-kbd{display:flex}
.dpad-screen.kbd .ds-loader{display:none}
.ds-kbd-label{font-size:8.5px;letter-spacing:2px;text-transform:uppercase;color:var(--accent-soft);font-weight:700}
.ds-kbd-field{display:flex;align-items:center;justify-content:center;min-height:24px;max-width:140px;padding:2px 2px;border-bottom:1.5px solid rgba(210,32,29,.5);min-width:96px}
.ds-kbd-text{font-size:15px;font-weight:600;color:var(--txt);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;direction:rtl;text-align:center;max-width:128px}
.ds-kbd-text:empty::before{content:"Tippen…";color:var(--muted);font-weight:500;font-size:13px}
.ds-kbd-caret{width:2px;height:16px;background:var(--accent-soft);margin-left:1px;animation:dskbdblink 1.05s step-end infinite;flex:none}
@keyframes dskbdblink{50%{opacity:0}}
.ds-kbd-input{position:absolute;opacity:0;width:1px;height:1px;border:0;padding:0;pointer-events:none}

/* Mittel-Block */
.midgrid{position:relative}
.controls{display:flex;flex-direction:column;gap:14px;transition:opacity .25s}
.numpad{display:none;grid-template-columns:repeat(3,1fr);gap:10px;justify-items:center}
.kbdpad{display:none;grid-template-columns:repeat(3,1fr);gap:10px;justify-items:center}
.remote.numpad-mode .controls{display:none}
.remote.numpad-mode .numpad{display:grid}
.remote.kbd-mode .controls{display:none}
.remote.kbd-mode .kbdpad{display:grid}

/* Tastatur-Aktionstasten — gleiche Optik wie die runden Tasten (.rk), im Numpad-Raster */
.btn.kb{width:64px;height:54px;border-radius:16px;background:linear-gradient(180deg,var(--key-hi),var(--key));border:1px solid #2c2c33;color:var(--txt);box-shadow:0 4px 10px rgba(0,0,0,.4), inset 0 1px 0 rgba(255,255,255,.05);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;font-size:10px;font-weight:600;letter-spacing:.2px;cursor:pointer;transition:filter .12s, transform .1s}
.btn.kb svg{width:21px;height:21px;fill:none;stroke:var(--txt);stroke-width:1.9;stroke-linecap:round;stroke-linejoin:round}
.btn.kb .kb-ic svg{width:21px;height:21px}
.btn.kb:active{transform:scale(.93);filter:brightness(1.25)}
.btn.kb.kb-ok{background:linear-gradient(180deg,#ef4540,#a5110f);border-color:var(--accent);box-shadow:0 4px 12px rgba(165,17,15,.45), inset 0 1px 0 rgba(255,255,255,.14)}
.btn.kb.kb-ok svg{stroke:#fff}
#kbTap{color:var(--accent-soft)}
#kbTap.armed{background:linear-gradient(180deg,#2a2a31,#1a1a1f);border-color:var(--accent);box-shadow:0 0 0 1px rgba(210,32,29,.4), inset 0 1px 0 rgba(255,255,255,.06)}
#kbTap.armed svg{stroke:var(--accent-soft)}
.np{width:64px;height:48px;border-radius:13px;font-size:20px;font-weight:600}
.np svg{width:22px;height:22px}
.np-ok{font-size:15px;font-weight:700;letter-spacing:1px;color:#fff;background:linear-gradient(180deg,#ef4540,#a5110f);border-color:var(--accent)}
.np-act{color:var(--muted)}

/* Recent-Band */
.rail{display:flex;gap:12px;overflow-x:auto;scroll-snap-type:x mandatory;padding:6px calc(50% - 36px);scrollbar-width:none;-webkit-overflow-scrolling:touch;-webkit-mask-image:linear-gradient(90deg,transparent,#000 14%,#000 86%,transparent);mask-image:linear-gradient(90deg,transparent,#000 14%,#000 86%,transparent)}
.rail::-webkit-scrollbar{display:none}
.rtile{flex:0 0 auto;width:84px;scroll-snap-align:center;cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:5px;background:none;border:none;padding:0;opacity:.46;transform:scale(.85);transition:opacity .28s cubic-bezier(.22,1,.36,1), transform .28s cubic-bezier(.22,1,.36,1)}
.rtile.focus{opacity:1;transform:scale(1.07)}
.rtile .logo{width:46px;height:46px;border-radius:12px;display:flex;align-items:center;justify-content:center;overflow:hidden;background:radial-gradient(circle at 50% 35%,#33333b,#16161b 78%);box-shadow:0 5px 14px rgba(0,0,0,.5), inset 0 1px 0 rgba(255,255,255,.1), inset 0 0 0 1px rgba(0,0,0,.3)}
.rtile .logo img{width:80%;height:80%;object-fit:contain;display:block}
.rtile .logo .fallback{font-weight:800;font-size:16px;color:#fff}
.rtile.focus .logo{box-shadow:0 9px 22px rgba(0,0,0,.55), 0 0 0 2px rgba(210,32,29,.72), inset 0 1px 0 rgba(255,255,255,.12)}
.rtile .rname{font-size:9.5px;font-weight:600;color:var(--muted);max-width:84px;text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;transition:color .25s}
.rtile.focus .rname{color:var(--txt)}
.rtile .rnow{font-size:8.5px;color:#62626b;max-width:84px;text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;transition:color .25s}
.rtile.focus .rnow{color:var(--muted)}
.rtile .rbar{width:46px;height:2px;border-radius:2px;background:rgba(255,255,255,.08);overflow:hidden;margin-top:1px}
.rtile .rbar i{display:block;height:100%;border-radius:2px;background:linear-gradient(90deg,var(--accent),var(--accent-soft));box-shadow:0 0 5px rgba(210,32,29,.5)}

/* Module — kleiner & feiner */
.row-mods{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.mod{height:42px;border-radius:11px;gap:7px;font-size:11.5px;font-weight:600;white-space:nowrap;background:linear-gradient(180deg,#202026,#15151a);border:1px solid #2a2a31;color:var(--txt);justify-content:flex-start;padding:0 9px 0 12px;position:relative;overflow:hidden}
.mod::before{content:"";position:absolute;left:0;top:7px;bottom:7px;width:2.5px;border-radius:0 3px 3px 0;background:var(--accent);opacity:.8;box-shadow:0 0 7px rgba(210,32,29,.4)}
.mod .m-ic{display:flex;flex:0 0 auto}
.mod .m-ic svg{width:17px;height:17px;stroke:#d4d4da;stroke-width:1.9}
.mod:active{filter:brightness(1.3)}

.kbd-toggle{height:40px;border-radius:12px;gap:8px;font-size:12px;font-weight:600;background:linear-gradient(180deg,#1f1f25,#15151a);border:1px solid #2a2a31;color:var(--muted)}
.kbd-toggle svg{width:18px;height:18px;stroke:var(--muted)}

/* Fuß */
.brandfoot{display:flex;align-items:center;justify-content:center;gap:9px;margin-top:6px;padding-top:13px;border-top:1px solid #232329}
.brandfoot .word{font-size:16px;letter-spacing:.3px;color:#cdced3}
.brandfoot .word b{color:#fff;font-weight:800}

/* Tastatur-Sheet — fein */
.kbd-sheet{position:fixed;left:0;right:0;bottom:0;z-index:20;background:linear-gradient(180deg,rgba(28,28,34,.92),rgba(14,14,18,.96));backdrop-filter:blur(18px) saturate(1.2);-webkit-backdrop-filter:blur(18px) saturate(1.2);border-top:1px solid rgba(255,255,255,.06);border-radius:22px 22px 0 0;padding:10px 16px calc(18px + env(safe-area-inset-bottom));box-shadow:0 -20px 50px rgba(0,0,0,.55);transform:translateY(115%);transition:transform .3s cubic-bezier(.22,1,.36,1)}
.kbd-sheet.open{transform:translateY(0)}
.kbd-grip{width:40px;height:4px;border-radius:999px;background:rgba(255,255,255,.16);margin:2px auto 12px}
.kbd-head{display:flex;gap:10px;align-items:center}
#kbdInput{flex:1;height:46px;border-radius:13px;border:1px solid rgba(255,255,255,.08);background:rgba(0,0,0,.35);color:var(--txt);padding:0 15px;font-size:16px;outline:none;transition:border-color .2s,box-shadow .2s}
#kbdInput:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(210,32,29,.18)}
.kbd-x{width:46px;height:46px;border-radius:13px;border:1px solid rgba(255,255,255,.08);background:rgba(255,255,255,.04);color:var(--muted);font-size:17px;cursor:pointer}
.kbd-actions{display:flex;gap:8px;margin-top:10px}
.kbd-act{flex:1;height:42px;border-radius:11px;border:1px solid rgba(255,255,255,.07);background:rgba(255,255,255,.04);color:var(--txt);font-size:15px;cursor:pointer;transition:filter .12s}
.kbd-act.primary{flex:1.8;background:linear-gradient(180deg,#ef4540,#a5110f);border-color:var(--accent);font-weight:700}
.kbd-act:active{filter:brightness(1.3)}

/* PIN-Pairing-Sheet (Server-Modus) */
.pair-body{padding:2px 2px 4px}
.pair-title{font-size:16px;font-weight:700;color:var(--txt);margin-bottom:5px}
.pair-hint{font-size:11.5px;line-height:1.5;color:var(--muted);margin-bottom:14px}
.pair-row{display:flex;gap:10px;align-items:center}
#pairInput{flex:1;height:52px;border-radius:14px;border:1px solid rgba(255,255,255,.1);background:rgba(0,0,0,.4);color:var(--txt);padding:0 16px;font-size:26px;letter-spacing:8px;text-align:center;font-family:ui-monospace,Menlo,monospace;outline:none;transition:border-color .2s,box-shadow .2s}
#pairInput:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(210,32,29,.18)}
#pairInput.err{border-color:var(--accent);animation:shake .3s}
@keyframes shake{0%,100%{transform:translateX(0)}25%{transform:translateX(-5px)}75%{transform:translateX(5px)}}
.pair-ok{height:52px;padding:0 20px;border-radius:14px;border:1px solid var(--accent);background:linear-gradient(180deg,#ef4540,#a5110f);color:#fff;font-size:15px;font-weight:700;cursor:pointer;white-space:nowrap}
.pair-ok:active{filter:brightness(1.2)}

/* Toast */
.toast{position:fixed;left:50%;bottom:22px;transform:translateX(-50%) translateY(20px);background:rgba(34,34,42,.95);backdrop-filter:blur(10px);border:1px solid #33333c;color:var(--txt);padding:9px 16px;border-radius:999px;font-size:13px;opacity:0;pointer-events:none;transition:opacity .2s,transform .2s;z-index:30}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

/* Echtzeit-Aktivieren-Button (Web-Companion / LNA): schwebt unten, erscheint nur ohne aktiven Companion */
#compBtn{position:fixed;left:50%;bottom:calc(16px + env(safe-area-inset-bottom));transform:translateX(-50%);z-index:40;display:flex;align-items:center;gap:7px;height:38px;padding:0 16px;border-radius:19px;border:1px solid var(--accent);background:linear-gradient(180deg,rgba(210,32,29,.22),rgba(124,27,24,.28));color:#fff;font:600 12.5px/1 -apple-system,"Segoe UI",Roboto,system-ui,sans-serif;letter-spacing:.2px;cursor:pointer;backdrop-filter:blur(12px) saturate(1.2);-webkit-backdrop-filter:blur(12px) saturate(1.2);box-shadow:0 6px 22px rgba(0,0,0,.5), 0 0 0 1px rgba(210,32,29,.15), inset 0 1px 0 rgba(255,255,255,.12);transition:filter .15s, transform .12s, opacity .2s;animation:compbtnin .35s cubic-bezier(.22,1,.36,1)}
#compBtn svg{stroke:var(--accent-soft)}
#compBtn:active{transform:translateX(-50%) scale(.95)}
#compBtn:hover{filter:brightness(1.12)}
#compBtn.loading{opacity:.6;pointer-events:none}
#compBtn.loading svg{animation:compspin .8s linear infinite}
@keyframes compbtnin{from{opacity:0;transform:translateX(-50%) translateY(8px)}to{opacity:1;transform:translateX(-50%) translateY(0)}}
@keyframes compspin{to{transform:rotate(360deg)}}
/* Wenn Companion aktiv: Logo-Ampel bekommt einen grünen Echtzeit-Schimmer (optisches Feedback) */
.companion-on .ipii-mark.hd .bar.red{box-shadow:0 0 8px rgba(92,245,142,.5)}

/* ════════════════════════════════════════════════════════════════════
   FEINSCHLIFF 2026-06-03 (Pass #267) — Accessibility, Touch-Targets,
   Responsiveness, Safe-Area, Active-States. Additiv, überschreibt gezielt.
   ════════════════════════════════════════════════════════════════════ */

/* #1 Sichtbarer Fokus-Ring für Tastatur-Navigation (WCAG) — Inputs + alle Buttons */
.pair-row input:focus-visible,#kbdInput:focus-visible,#pairInput:focus-visible,
.btn:focus-visible,.rk:focus-visible,.seg-opt:focus-visible,.mod:focus-visible,
.screen-toggle:focus-visible,.rtile:focus-visible,.dp:focus-visible{
  outline:2px solid var(--accent-soft);outline-offset:2px;
}

/* #4 Stärkeres Active-Feedback für runde Tasten (Helligkeit, nicht nur scale) */
.rk:active{filter:brightness(1.22)}
/* #8 D-Pad-Pfeile: sanfte Druck-Animation statt transition:none */
.dp{transition:transform .08s ease, filter .12s ease}
.dp.up:active,.dp.down:active,.dp.left:active,.dp.right:active{filter:brightness(1.2)}
/* #3 Screen-Toggle aktiv: klarer als nur Farbe */
.screen-toggle.on{background:rgba(210,32,29,.14);box-shadow:inset 0 0 0 1.5px rgba(210,32,29,.55),0 0 6px rgba(154,36,32,.35)}

/* #7 iPhone-Notch/Dynamic-Island: Stage respektiert Safe-Area (Portrait + Landscape) */
.stage{
  padding-left:max(16px,env(safe-area-inset-left));
  padding-right:max(16px,env(safe-area-inset-right));
  padding-top:max(16px,env(safe-area-inset-top));
  padding-bottom:max(16px,env(safe-area-inset-bottom));
}

/* #2 Touch-Targets: Tastatur-Buttons (.kb) und Numpad (.np) auf min. 48px Höhe vereinheitlicht */
.btn.kb{min-height:48px}
.np{min-height:48px}

/* #5/#6/#9 RESPONSIVE — sehr kleine Screens (iPhone SE / 375px) */
@media (max-width:400px){
  .remote{width:min(340px,96vw);padding:12px 16px 16px;border-radius:34px;gap:11px}
  .numpad,.kbdpad{gap:7px}
  .rail{gap:9px}
  .brandfoot{gap:6px;margin-top:3px;padding-top:10px}
  .brandfoot .word{font-size:13.5px}
}
/* sehr enge Screens: Recent-Kacheln kompakter */
@media (max-width:360px){
  .rtile{width:74px}
  .rtile .logo{width:42px;height:42px}
}
/* #5/#6 große Screens / Tablet: nicht endlos breit, Inhalt zentriert */
@media (min-width:600px){
  .numpad,.kbdpad{max-width:280px;margin:0 auto}
}

/* Reduced-Motion respektieren (Accessibility) */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms!important;transition-duration:.06s!important}
  .seg-pill,.dpad-screen,.rtile{transition-duration:.08s!important}
}
