/* ====================================================================
   styles.css – GIT Agentic OS PWA  ·  CI 2026.01  ·  2026-06-05
   Mobile-first "Command Console". Bottom-Navigation, Dashboard mit
   grossen Aktions-Kacheln, Logging auf System-Seite. Dark = Default.
   ==================================================================== */

:root {
  --accent: #0c4da2; --accent-cyan: #26bdef;
  --danger: #ef4444; --warning: #f59e0b; --success: #22c55e;
  --font-ui: 'Syne', system-ui, sans-serif;
  --font-body: 'Manrope', system-ui, sans-serif;
  --font-data: 'JetBrains Mono', monospace;
  --radius: 16px; --radius-sm: 10px;
}
[data-theme="dark"] {
  --bg-primary: #0f1117; --bg-secondary: #1a1f2e; --bg-card: #1e2538; --bg-card-2: #232c44;
  --text-primary: #f1f5f9; --text-secondary: #94a3b8; --text-muted: #64748b; --border: #2d3748;
  --glow: 0 0 30px rgba(38,189,239,.10); color-scheme: dark;
}
[data-theme="light"] {
  --bg-primary: #f4f7fc; --bg-secondary: #ffffff; --bg-card: #ffffff; --bg-card-2: #f0f4fb;
  --text-primary: #111111; --text-secondary: #555555; --text-muted: #888888; --border: #d0daea;
  --glow: 0 8px 30px rgba(12,77,162,.08);
  --success: #1a7a5e; --warning: #cc8800; --danger: #c0392b; color-scheme: light;
}
* { box-sizing: border-box; }
html { font-size: 15px; -webkit-text-size-adjust: 100%; }
body { margin: 0; min-height: 100vh; font-family: var(--font-body); background: var(--bg-primary);
  color: var(--text-primary); -webkit-font-smoothing: antialiased; overflow-x: hidden; }
.hidden { display: none !important; }
h1, h2, h3 { font-family: var(--font-ui); letter-spacing: -.01em; }
em { font-style: normal; color: var(--accent-cyan); }
i[data-lucide] { width: 1em; height: 1em; vertical-align: -.125em; }

.bg-fx { position: fixed; inset: 0; z-index: -1; pointer-events: none;
  background: radial-gradient(900px 500px at 78% -8%, rgba(38,189,239,.13), transparent 60%),
              radial-gradient(800px 600px at 12% 108%, rgba(12,77,162,.16), transparent 60%); }

/* --- Brand / Topbar ---------------------------------------------- */
.brand { display: flex; align-items: center; gap: .7rem; }
.brand-mark { width: 30px; height: 30px; border-radius: 8px; flex: none;
  background: radial-gradient(circle at 30% 30%, var(--accent-cyan), var(--accent) 70%);
  box-shadow: 0 0 0 1px rgba(255,255,255,.08) inset, var(--glow); position: relative; }
.brand-mark::after { content: ""; position: absolute; inset: 0; border-radius: 8px; opacity: .85;
  background: radial-gradient(2.5px 2.5px at 50% 28%, #fff, transparent),
             radial-gradient(2.5px 2.5px at 30% 70%, #fff, transparent),
             radial-gradient(2.5px 2.5px at 72% 68%, #fff, transparent); }
.brand-text { display: flex; flex-direction: column; line-height: 1.05; }
.brand-text strong { font-family: var(--font-ui); font-weight: 800; font-size: 1rem; }
.brand-sub { font-family: var(--font-data); font-size: .62rem; letter-spacing: .16em; text-transform: uppercase; color: var(--text-muted); }
.topbar { position: sticky; top: 0; z-index: 30; display: flex; align-items: center; justify-content: space-between;
  padding: .7rem clamp(.8rem, 4vw, 1.4rem); background: color-mix(in srgb, var(--bg-secondary) 88%, transparent);
  backdrop-filter: blur(10px); border-bottom: 1px solid var(--border); }
.topbar-actions { display: flex; gap: .5rem; }
.icon-btn { width: 40px; height: 40px; border-radius: 11px; cursor: pointer; display: grid; place-items: center;
  background: var(--bg-card); color: var(--text-secondary); border: 1px solid var(--border); font-size: 1.05rem; transition: .15s; }
.icon-btn:hover { color: var(--accent-cyan); border-color: var(--accent-cyan); }

/* --- Pages / Layout ---------------------------------------------- */
.pages { max-width: 760px; margin: 0 auto; padding: 1rem clamp(.8rem, 4vw, 1.4rem) calc(86px + env(safe-area-inset-bottom)); }
.page { animation: rise .35s both; }
@keyframes rise { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: none; } }
.sec-title { font-size: .78rem; font-weight: 700; text-transform: uppercase; letter-spacing: .12em;
  color: var(--text-muted); margin: 1.4rem 0 .7rem; display: flex; align-items: center; gap: .5rem; }
.sec-title:first-child { margin-top: .4rem; }
.hint-text { color: var(--text-secondary); font-size: .85rem; margin: 0 0 .9rem; }

/* --- Anlagen-Status (Dashboard-Kopf) ----------------------------- */
.anlage { display: flex; align-items: center; gap: .8rem; padding: 1rem 1.1rem; border-radius: var(--radius);
  background: linear-gradient(180deg, var(--bg-card), var(--bg-card-2)); border: 1px solid var(--border); box-shadow: var(--glow); }
.anlage-led { display: grid; place-items: center; }
.anlage-led .dot { width: 14px; height: 14px; }
.anlage-txt { display: flex; flex-direction: column; min-width: 0; }
.anlage-txt strong { font-family: var(--font-ui); font-size: 1.05rem; }
.anlage-sub { font-family: var(--font-data); font-size: .68rem; color: var(--text-muted); }
.anlage-more { margin-left: auto; display: flex; align-items: center; gap: .2rem; color: var(--accent-cyan);
  text-decoration: none; font-size: .78rem; white-space: nowrap; }

/* --- Steuer-Kacheln ---------------------------------------------- */
.controls { display: grid; grid-template-columns: 1fr 1fr; gap: .7rem; }
.ctl { grid-column: span 1; display: flex; flex-direction: column; align-items: flex-start; gap: .35rem;
  min-height: 104px; padding: 1rem; border-radius: var(--radius); cursor: pointer; text-align: left;
  background: var(--bg-card); border: 1px solid var(--border); color: var(--text-primary);
  font-family: var(--font-body); transition: transform .12s, border-color .15s, box-shadow .15s; }
.ctl:active { transform: scale(.97); }
.ctl i[data-lucide] { width: 26px; height: 26px; color: var(--accent-cyan); }
.ctl-name { font-family: var(--font-ui); font-weight: 700; font-size: 1.02rem; }
.ctl-hint { font-family: var(--font-data); font-size: .64rem; color: var(--text-muted); }
.ctl--primary { grid-column: 1 / -1; min-height: 116px;
  background: linear-gradient(135deg, var(--accent), var(--accent-cyan)); border-color: transparent; color: #fff;
  box-shadow: 0 12px 30px -12px var(--accent-cyan); }
.ctl--primary i[data-lucide] { color: #fff; width: 30px; height: 30px; }
.ctl--primary .ctl-hint { color: rgba(255,255,255,.85); }
.ctl--primary:hover { filter: brightness(1.05); }
.ctl--soon { opacity: .62; }
.ctl--soon i[data-lucide] { color: var(--text-muted); }

/* --- Bottom-Navigation ------------------------------------------- */
.bottomnav { position: fixed; left: 0; right: 0; bottom: 0; z-index: 40; display: flex;
  padding: .4rem .4rem calc(.4rem + env(safe-area-inset-bottom)); gap: .2rem;
  background: color-mix(in srgb, var(--bg-secondary) 94%, transparent); backdrop-filter: blur(12px);
  border-top: 1px solid var(--border); }
.navitem { flex: 1; display: flex; flex-direction: column; align-items: center; gap: .15rem;
  padding: .5rem 0; border-radius: 12px; text-decoration: none; color: var(--text-muted);
  font-size: .64rem; font-weight: 600; transition: .15s; }
.navitem i[data-lucide] { width: 22px; height: 22px; }
.navitem.active { color: var(--accent-cyan); background: color-mix(in srgb, var(--accent-cyan) 12%, transparent); }
.navitem:active { transform: scale(.95); }

/* --- Status-/Endpunkt-Liste -------------------------------------- */
.dot { width: 10px; height: 10px; border-radius: 50%; flex: none; background: var(--text-muted); display: inline-block; }
.dot--ok { background: var(--success); animation: pulse 2.4s ease-out infinite; }
.dot--down { background: var(--danger); animation: pulse-d 1.3s ease-out infinite; }
.dot--stale { background: var(--warning); }
.dot--config { background: var(--accent-cyan); }
.dot--open { background: var(--text-muted); opacity: .55; }
.dot--pending { background: var(--text-muted); animation: pulse 1.6s ease-out infinite; }
@keyframes pulse { 0% { box-shadow: 0 0 0 0 color-mix(in srgb, var(--success) 55%, transparent); } 70%,100% { box-shadow: 0 0 0 7px transparent; } }
@keyframes pulse-d { 0% { box-shadow: 0 0 0 0 color-mix(in srgb, var(--danger) 60%, transparent); } 70%,100% { box-shadow: 0 0 0 7px transparent; } }
.status-list { list-style: none; margin: 0; padding: 0; }
.status-list li { display: flex; align-items: center; gap: .6rem; padding: .55rem .2rem; border-bottom: 1px dashed var(--border); }
.status-list li:last-child { border-bottom: 0; }
.sl-label { font-weight: 600; font-size: .88rem; }
.sl-detail { margin-left: auto; font-family: var(--font-data); font-size: .66rem; color: var(--text-muted); text-align: right; }
.sl-badge { font-family: var(--font-data); font-size: .58rem; text-transform: uppercase; letter-spacing: .08em; padding: .12rem .42rem; border-radius: 6px; }
.b-ok { color: var(--success); background: color-mix(in srgb, var(--success) 16%, transparent); }
.b-down { color: var(--danger); background: color-mix(in srgb, var(--danger) 16%, transparent); }
.b-stale { color: var(--warning); background: color-mix(in srgb, var(--warning) 18%, transparent); }
.b-config { color: var(--accent-cyan); background: color-mix(in srgb, var(--accent-cyan) 14%, transparent); }
.b-open { color: var(--text-muted); background: color-mix(in srgb, var(--text-muted) 14%, transparent); }

/* --- Counts / Feeds ---------------------------------------------- */
.counts { display: grid; grid-template-columns: repeat(4, 1fr); gap: .5rem; margin-bottom: .6rem; }
.count { text-align: center; padding: .6rem .2rem; border-radius: var(--radius-sm); background: var(--bg-card); border: 1px solid var(--border); }
.count b { display: block; font-family: var(--font-data); font-size: 1.3rem; font-weight: 700; }
.count span { font-size: .6rem; text-transform: uppercase; letter-spacing: .08em; color: var(--text-muted); }
.feed { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: .4rem; }
.feed li { display: flex; align-items: center; gap: .55rem; font-size: .82rem; padding: .5rem .6rem;
  background: var(--bg-card); border: 1px solid var(--border); border-radius: var(--radius-sm); }
.feed .mono { font-family: var(--font-data); font-size: .68rem; color: var(--text-muted); }
.feed-empty { color: var(--text-muted); font-size: .82rem; font-style: italic; }
.audit li { align-items: flex-start; }
.au { display: flex; flex-direction: column; gap: .12rem; min-width: 0; }
.au-main { font-size: .82rem; }
.au-meta { font-family: var(--font-data); font-size: .62rem; color: var(--text-muted); }

/* --- Fortschritt / Roadmap --------------------------------------- */
.tile-tag { font-family: var(--font-data); font-size: .58rem; letter-spacing: .1em; color: var(--text-muted);
  border: 1px solid var(--border); padding: .15rem .45rem; border-radius: 20px; text-transform: none; }
.progress { height: 9px; background: var(--bg-card); border: 1px solid var(--border); border-radius: 20px; overflow: hidden; margin: .2rem 0 1rem; }
.progress-bar { height: 100%; width: 0; border-radius: 20px; transition: width .7s cubic-bezier(.2,.8,.2,1);
  background: linear-gradient(90deg, var(--accent), var(--accent-cyan)); box-shadow: 0 0 12px color-mix(in srgb, var(--accent-cyan) 55%, transparent); }
.roadmap { display: flex; flex-direction: column; }
.rm-phase { font-family: var(--font-data); font-size: .6rem; letter-spacing: .16em; text-transform: uppercase;
  color: var(--accent-cyan); margin: 1rem 0 .3rem; padding-bottom: .25rem; border-bottom: 1px solid var(--border); }
.rm-phase:first-child { margin-top: 0; }
.rm-row { display: flex; align-items: center; gap: .6rem; padding: .5rem .15rem; border-bottom: 1px dashed var(--border); }
.rm-row:last-child { border-bottom: 0; }
.rm-title { font-weight: 600; font-size: .85rem; display: flex; flex-direction: column; gap: .08rem; }
.rm-detail { font-family: var(--font-data); font-size: .64rem; color: var(--text-muted); font-weight: 400; }
.rm-row .sl-badge { margin-left: auto; white-space: nowrap; }

/* --- Schnell-Eingang --------------------------------------------- */
.qi-text { width: 100%; resize: vertical; font-family: var(--font-body); font-size: .95rem; padding: .75rem .8rem;
  background: var(--bg-card); color: var(--text-primary); border: 1px solid var(--border); border-radius: 12px; }
.qi-text:focus { outline: none; border-color: var(--accent-cyan); box-shadow: 0 0 0 3px color-mix(in srgb, var(--accent-cyan) 20%, transparent); }
.qi-row { display: flex; gap: .5rem; margin-top: .7rem; }
.qi-type { background: var(--bg-card); color: var(--text-primary); border: 1px solid var(--border); border-radius: 12px; padding: .6rem; font-family: var(--font-body); }
.qi-row .btn { flex: 1; }

/* --- Buttons ----------------------------------------------------- */
.btn { font-family: var(--font-ui); font-weight: 700; font-size: .92rem; cursor: pointer; border-radius: 12px;
  padding: .8rem 1rem; border: 1px solid transparent; transition: .15s; }
.btn--block { width: 100%; }
.btn--primary { background: linear-gradient(180deg, var(--accent-cyan), var(--accent)); color: #fff; box-shadow: 0 8px 24px -10px var(--accent-cyan); }
.btn--primary:hover { filter: brightness(1.06); }
.btn--ghost { background: var(--bg-secondary); color: var(--text-primary); border-color: var(--border); }
.btn--danger { background: linear-gradient(180deg, #ff5d5d, var(--danger)); color: #fff; }
.btn:disabled { opacity: .5; cursor: progress; }
.msg { min-height: 1.1em; font-size: .82rem; margin: .5rem 0 0; }
.msg.err { color: var(--danger); } .msg.ok { color: var(--success); }

/* --- Modal (sensible Aktionen) ----------------------------------- */
.modal { position: fixed; inset: 0; z-index: 60; display: grid; place-items: center; padding: 1.2rem;
  background: rgba(5,8,15,.6); backdrop-filter: blur(4px); }
.modal-card { width: min(380px, 100%); background: linear-gradient(180deg, var(--bg-card), var(--bg-card-2));
  border: 1px solid var(--border); border-radius: 18px; padding: 1.6rem 1.4rem 1.3rem; text-align: center;
  box-shadow: 0 30px 60px -20px rgba(0,0,0,.6); animation: rise .25s both; }
.modal-ic { width: 54px; height: 54px; margin: 0 auto .8rem; border-radius: 50%; display: grid; place-items: center;
  background: color-mix(in srgb, var(--warning) 18%, transparent); color: var(--warning); }
.modal-ic i[data-lucide] { width: 28px; height: 28px; }
.modal-card h3 { margin: 0 0 .4rem; font-size: 1.15rem; }
.modal-card p { margin: 0 0 1.2rem; color: var(--text-secondary); font-size: .9rem; }
.modal-actions { display: flex; gap: .6rem; }
.modal-actions .btn { flex: 1; }

/* --- Toast ------------------------------------------------------- */
.toast { position: fixed; left: 50%; transform: translateX(-50%); bottom: calc(82px + env(safe-area-inset-bottom));
  z-index: 70; max-width: 90%; padding: .7rem 1.1rem; border-radius: 999px; font-size: .85rem; font-weight: 600;
  background: var(--bg-card); border: 1px solid var(--border); color: var(--text-primary); box-shadow: 0 10px 30px -10px rgba(0,0,0,.5); }
.toast--ok { border-color: var(--success); color: var(--success); }
.toast--warn { border-color: var(--warning); color: var(--warning); }
.toast--info { border-color: var(--accent-cyan); }

/* --- Login ------------------------------------------------------- */
.view.login { min-height: 100vh; display: grid; place-items: center; padding: 1.2rem; }
.login-card { width: min(420px, 100%); background: linear-gradient(180deg, var(--bg-card), var(--bg-card-2));
  border: 1px solid var(--border); border-radius: 20px; padding: 1.8rem 1.6rem 1.4rem; box-shadow: var(--glow), 0 30px 60px -30px rgba(0,0,0,.6); animation: rise .4s both; }
.brand--login { margin-bottom: 1.4rem; } .brand--login .brand-mark { width: 44px; height: 44px; border-radius: 12px; }
.brand--login h1 { font-size: 1.5rem; margin: 0; font-weight: 800; }
.login-body { display: flex; flex-direction: column; gap: .8rem; }
.field { display: flex; flex-direction: column; gap: .3rem; }
.field span { font-family: var(--font-data); font-size: .64rem; letter-spacing: .12em; text-transform: uppercase; color: var(--text-muted); }
.field input { font-family: var(--font-body); font-size: .95rem; padding: .75rem .8rem; background: var(--bg-secondary);
  color: var(--text-primary); border: 1px solid var(--border); border-radius: 10px; outline: none; transition: .15s; }
.field input:focus { border-color: var(--accent-cyan); box-shadow: 0 0 0 3px color-mix(in srgb, var(--accent-cyan) 22%, transparent); }
.register { margin-top: .4rem; border-top: 1px dashed var(--border); padding-top: .6rem; }
.register summary { cursor: pointer; font-size: .82rem; color: var(--text-secondary); }
.register-body { display: flex; flex-direction: column; gap: .7rem; margin-top: .8rem; }
.login-foot { text-align: center; color: var(--text-muted); font-family: var(--font-data); font-size: .62rem; margin: 1.3rem 0 0; }

@media (prefers-reduced-motion: reduce) { * { animation: none !important; } }
@media (min-width: 720px) { .controls { grid-template-columns: repeat(2, 1fr); } }


/* ---- Licht-Panel (Hue via HA) - CI 2026.01 Dark ---- */
.light-panel { background: var(--bg-card,#1e2538); border:1px solid var(--border,#2d3748); border-radius:12px; margin:1rem 0; overflow:hidden; animation:lpSlide .2s ease; }
@keyframes lpSlide { from{opacity:0;transform:translateY(-8px);} to{opacity:1;transform:none;} }
.light-panel.hidden { display:none; }
.light-panel-header { display:flex; align-items:center; justify-content:space-between; padding:.75rem 1rem; border-bottom:1px solid var(--border,#2d3748); }
.light-panel-header h3 { margin:0; font-size:.95rem; font-weight:600; color:var(--accent-cyan,#26bdef); display:flex; align-items:center; gap:.45rem; }
.light-panel-header .icon-btn { background:none; border:none; color:var(--text-muted,#64748b); cursor:pointer; padding:.25rem; }
.light-list { padding:.4rem 0; }
.light-row { display:flex; align-items:center; gap:.75rem; padding:.65rem 1rem; border-bottom:1px solid var(--border,#2d3748); }
.light-row:last-child { border-bottom:none; }
.light-bulb { width:26px; height:26px; flex-shrink:0; }
.bulb--on { color:#f5b301; filter:drop-shadow(0 0 6px rgba(245,179,1,.6)); }
.bulb--off { color:var(--text-muted,#64748b); }
.bulb--na { color:var(--danger,#ef4444); opacity:.55; }
.light-info { flex:1; min-width:0; display:flex; flex-direction:column; }
.light-name { font-size:.9rem; font-weight:600; color:var(--text-primary,#f1f5f9); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.light-state { font-size:.75rem; font-family:'JetBrains Mono',monospace; }
.state-on { color:var(--accent-cyan,#26bdef); }
.state-off { color:var(--text-muted,#64748b); }
.light-actions { display:flex; align-items:center; gap:.6rem; flex-shrink:0; }
.brightness-slider { -webkit-appearance:none; appearance:none; width:90px; height:4px; border-radius:2px; background:var(--border,#2d3748); outline:none; }
.brightness-slider::-webkit-slider-thumb { -webkit-appearance:none; width:16px; height:16px; border-radius:50%; background:var(--accent-cyan,#26bdef); cursor:pointer; }
.brightness-slider::-moz-range-thumb { width:16px; height:16px; border:none; border-radius:50%; background:var(--accent-cyan,#26bdef); cursor:pointer; }
.toggle-btn { display:inline-flex; background:none; border:1px solid var(--border,#2d3748); border-radius:8px; padding:.4rem .55rem; cursor:pointer; color:var(--text-muted,#64748b); transition:all .15s; }
.toggle-btn.btn--on { border-color:var(--accent-cyan,#26bdef); color:var(--accent-cyan,#26bdef); box-shadow:0 0 10px rgba(38,189,239,.3); }
.toggle-btn:disabled { opacity:.4; cursor:default; }
.light-empty,.light-error { text-align:center; padding:1.3rem; font-size:.85rem; color:var(--text-muted,#64748b); }
.light-error { color:var(--danger,#ef4444); }


/* ---- Jarvis-Chat (Hermes) – CI 2026.01 Dark ---- */
.jarvis-chat { background: var(--bg-card,#1e2538); border:1px solid var(--border,#2d3748); border-radius:12px; margin:1rem 0; overflow:hidden; display:flex; flex-direction:column; }
.jarvis-chat-header { display:flex; align-items:center; gap:.45rem; padding:.7rem 1rem; border-bottom:1px solid var(--border,#2d3748); font-weight:600; color:var(--accent-cyan,#26bdef); }
.jarvis-messages { display:flex; flex-direction:column; gap:.5rem; padding:.8rem 1rem; max-height:46vh; overflow-y:auto; min-height:60px; }
.jmsg { max-width:85%; padding:.55rem .8rem; border-radius:12px; font-size:.9rem; line-height:1.4; white-space:pre-wrap; word-wrap:break-word; }
.jmsg--user { align-self:flex-end; background:var(--accent,#0c4da2); color:#fff; border-bottom-right-radius:4px; }
.jmsg--bot { align-self:flex-start; background:var(--bg-secondary,#1a1f2e); color:var(--text-primary,#f1f5f9); border:1px solid var(--border,#2d3748); border-bottom-left-radius:4px; }
.jmsg--pending { opacity:.6; font-style:italic; }
.jmsg--err { color:var(--danger,#ef4444); border-color:var(--danger,#ef4444); }
.jarvis-input { display:flex; gap:.5rem; padding:.7rem 1rem; border-top:1px solid var(--border,#2d3748); }
.jarvis-input input { flex:1; background:var(--bg-primary,#0f1117); border:1px solid var(--border,#2d3748); border-radius:8px; padding:.6rem .8rem; color:var(--text-primary,#f1f5f9); font-size:.9rem; outline:none; }
.jarvis-input input:focus { border-color:var(--accent-cyan,#26bdef); }
.jarvis-input button { background:var(--accent,#0c4da2); border:none; border-radius:8px; padding:0 .9rem; color:#fff; cursor:pointer; display:flex; align-items:center; }
.jarvis-input button:disabled { opacity:.5; cursor:default; }

.jarvis-hint { padding: 0 1rem .55rem; font-size:.72rem; color:var(--text-muted,#64748b); min-height:1em; }

.jarvis-mic { background:none; border:1px solid var(--border,#2d3748); border-radius:8px; padding:0 .7rem; color:var(--text-muted,#64748b); cursor:pointer; display:flex; align-items:center; }
.jarvis-mic.mic--on { border-color:var(--accent-cyan,#26bdef); color:var(--accent-cyan,#26bdef); box-shadow:0 0 10px rgba(38,189,239,.4); animation:micpulse 1.4s infinite; }
@keyframes micpulse { 0%,100%{opacity:1;} 50%{opacity:.55;} }


/* ---- Desktop-App-Layout: links Steuerung, rechts Chat  ·  CI 2026.01 ---- */
.heim-grid { display: block; }
@media (min-width: 980px) {
  .pages { max-width: 1180px; }
  .heim-grid { display: grid; grid-template-columns: minmax(330px, 1fr) minmax(0, 1.5fr); gap: 1.3rem; align-items: start; }
  .heim-col { min-width: 0; }
  .heim-col--right { position: sticky; top: 4.8rem; }
  #page-heim .heim-col--left .sec-title:first-of-type { margin-top: .2rem; }
  #page-heim .jarvis-chat { margin: 0; }
  #page-heim .jarvis-messages { max-height: calc(100vh - 300px); min-height: 340px; }
}


/* ============ Jarvis Mobile-Redesign  ·  CI 2026.01 ============ */
.brand--app { gap: .55rem; align-items: center; }
.jarvis-logo { display: inline-flex; filter: drop-shadow(0 0 10px rgba(38,189,239,.35)); }
.jarvis-wordmark { font-family: var(--font-ui); font-weight: 800; font-size: 1.3rem; letter-spacing: -.01em; color: var(--accent-cyan); }
[data-theme="light"] .jarvis-wordmark { color: var(--accent); }
.icon-btn--mic.mic--on { color: var(--accent-cyan); border-color: var(--accent-cyan); box-shadow: 0 0 12px rgba(38,189,239,.45); animation: micpulse 1.4s infinite; }

/* Vollbild-Popup (Strom/Solar + generisch) und Licht-Panel als Vollbild */
.fullsheet, .light-panel { position: fixed; inset: 0; z-index: 80; margin: 0; border: 0; border-radius: 0;
  background: var(--bg-primary); display: flex; flex-direction: column; animation: sheetUp .22s cubic-bezier(.2,.8,.2,1) both; }
.fullsheet.hidden, .light-panel.hidden { display: none; }
@keyframes sheetUp { from { opacity: 0; transform: translateY(14px); } to { opacity: 1; transform: none; } }
.fullsheet-head, .light-panel-header { display: flex; align-items: center; justify-content: space-between; gap: .8rem;
  padding: 1rem clamp(.9rem,4vw,1.3rem); position: sticky; top: 0;
  background: color-mix(in srgb, var(--bg-secondary) 92%, transparent); border-bottom: 1px solid var(--border); }
.fullsheet-head h2, .light-panel-header h3 { margin: 0; font-size: 1.15rem; color: var(--text-primary); }
.fullsheet-body, .light-list { flex: 1; overflow-y: auto; padding: 1rem clamp(.9rem,4vw,1.3rem) calc(1.4rem + env(safe-area-inset-bottom)); }
.fullsheet-body { max-width: 760px; margin: 0 auto; width: 100%; }
.sheet-placeholder { text-align: center; color: var(--text-secondary); padding: 2.6rem 1rem; }
.sheet-placeholder i[data-lucide] { width: 46px; height: 46px; color: var(--accent-cyan); opacity: .85; }
.sheet-placeholder h3 { margin: .8rem 0 .35rem; font-size: 1.15rem; color: var(--text-primary); }

/* Mobile: Banner weg, Steuerung oben / Jarvis-Chat unten je 50% feste Hoehe */
@media (max-width: 979px) {
  .anlage { display: none; }
  .pages { padding-top: .55rem; padding-bottom: calc(64px + env(safe-area-inset-bottom)); }
  .heim-grid { display: flex; flex-direction: column; gap: .55rem;
    height: calc(100dvh - 60px - 64px - env(safe-area-inset-bottom)); }
  .heim-col { min-height: 0; }
  .heim-col--left { flex: 1 1 0; overflow-y: auto; }
  .heim-col--right { flex: 1 1 0; display: flex; flex-direction: column; min-height: 0; }
  #page-heim .jarvis-chat { margin: 0; flex: 1 1 0; min-height: 0; }
  #page-heim .jarvis-messages { max-height: none; flex: 1 1 0; }
}


/* ---- Verbrauchs-/Kosten-Leiste oben im Heim-Dashboard  ·  CI 2026.01 ---- */
.usage-bar { display: flex; gap: .5rem; margin: 0 0 .7rem; }
.usage-item { flex: 1; display: flex; flex-direction: column; align-items: center; gap: .15rem;
  padding: .5rem .3rem; border-radius: var(--radius-sm); background: var(--bg-card); border: 1px solid var(--border); }
.usage-label { font-family: var(--font-data); font-size: .56rem; letter-spacing: .1em; text-transform: uppercase; color: var(--text-muted); }
.usage-val { font-family: var(--font-data); font-weight: 700; font-size: 1rem; color: var(--accent-cyan); line-height: 1.1; }
.usage-val.usage-low { color: var(--danger); }
@media (max-width: 979px) {
  .heim-grid { height: calc(100dvh - 60px - 64px - env(safe-area-inset-bottom)); }
}


/* ---- Restguthaben in der Topbar  ·  CI 2026.01 ---- */
.topbar-usage { font-family: var(--font-data); font-weight: 700; font-size: .92rem; color: var(--accent-cyan);
  padding: .35rem .7rem; border-radius: 999px; border: 1px solid var(--border); background: var(--bg-card);
  white-space: nowrap; align-self: center; margin-right: .2rem; }
.topbar-usage--low { color: var(--danger); border-color: var(--danger); }
@media (max-width: 520px) { .topbar-usage { font-size: .8rem; padding: .3rem .55rem; } }

/* ---------- Backend-Umschalter (Abo/API) in der Topbar ------------- */
.topbar-backend{display:inline-flex;align-items:center;gap:.34rem;height:34px;padding:0 .62rem;
  border-radius:8px;border:1px solid var(--border);background:var(--bg-card);
  color:var(--text-secondary);font-family:var(--font-data,monospace);font-weight:700;
  font-size:.78rem;line-height:1;cursor:pointer;white-space:nowrap;transition:border-color .15s,color .15s;}
.topbar-backend i{width:15px;height:15px;}
.topbar-backend:hover{border-color:var(--accent);}
.topbar-backend--abo{color:var(--accent-cyan);border-color:var(--accent-cyan);}
.topbar-backend--api{color:var(--warning);border-color:var(--warning);}
@media (max-width:360px){.topbar-backend{padding:0 .45rem;}.topbar-backend #topbar-backend-label{display:none;}}
