*{margin:0;padding:0;box-sizing:border-box}
:root{--accent:#7dd3fc;--hot:#f87171;--ok:#6ee7b7;--bg:#090a0d;--panel:#111318;--panel2:#171a20;--line:#2a3039;--text:#f7f4ec;--muted:#a1a1aa;--dim:#686873;--glass:rgba(255,255,255,0.04);--glass-border:rgba(255,255,255,0.08);--blur:blur(10px)}
html{overflow-x:hidden}
body{background:var(--bg);color:var(--text);font-family:'SF Pro Display',system-ui,sans-serif;min-height:100vh;min-height:100svh;overflow-x:hidden;display:flex;flex-direction:column}

/* ── Joi-style app shell ── */
.app-top{position:sticky;top:0;z-index:60;width:100%;padding-top:env(safe-area-inset-top,0);padding-left:env(safe-area-inset-left,0);padding-right:env(safe-area-inset-right,0);background:rgba(9,10,13,.92);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border-bottom:1px solid rgba(255,255,255,.06)}
.app-nav{width:min(1120px,96vw);height:58px;margin:0 auto;display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:16px}
.brand{font-weight:900;font-size:1.08rem;letter-spacing:.01em;color:#fff;white-space:nowrap}
.brand span{color:var(--accent)}
.tabs{display:flex;align-items:center;justify-content:center;gap:8px;min-width:0}
.tab{border:0;background:transparent;color:var(--muted);font:inherit;font-size:.9rem;font-weight:760;padding:9px 12px;border-radius:999px;cursor:pointer;white-space:nowrap}
.tab.active,.tab:hover{color:#fff;background:rgba(255,255,255,.08)}
.join-btn{border:0;border-radius:999px;background:#fff;color:#08090c;font-weight:900;padding:10px 15px;white-space:nowrap;cursor:pointer}
.gear-btn{display:inline-flex;align-items:center;gap:7px;border:1px solid var(--glass-border);border-radius:999px;background:var(--glass);color:var(--text);font-weight:760;font-size:.86rem;padding:8px 14px 8px 11px;white-space:nowrap;cursor:pointer;backdrop-filter:var(--blur);-webkit-backdrop-filter:var(--blur);transition:border-color .2s,background .2s,transform .12s}
.gear-btn:hover{border-color:rgba(125,211,252,.5);background:rgba(125,211,252,.08)}
.gear-btn:active{transform:scale(.97)}
.gear-ic{font-size:1.05rem;line-height:1;transition:transform .4s cubic-bezier(.34,1.56,.64,1)}
.gear-btn:hover .gear-ic{transform:rotate(75deg)}
.joi-hero{width:min(1120px,96vw);margin:10px auto 6px;display:grid;grid-template-columns:minmax(0,1fr) auto;gap:12px;align-items:center;padding:11px 14px;border:1px solid var(--line);border-radius:14px;background:linear-gradient(135deg,rgba(125,211,252,.16),rgba(248,113,113,.10)),var(--panel)}
.joi-hero h1{font-size:clamp(1.15rem,2vw,1.6rem);line-height:1.05;letter-spacing:0;margin:0 0 3px}
.joi-hero p{color:var(--muted);font-size:.82rem;line-height:1.3;max-width:52ch}
.hero-actions{display:flex;gap:8px;margin-top:12px;flex-wrap:wrap}
.hero-actions button{border:1px solid var(--line);background:var(--panel2);color:#fff;border-radius:999px;padding:9px 13px;font-weight:840;cursor:pointer;min-height:40px}
.hero-actions .primary{border-color:transparent;background:#fff;color:#08090c}
.hero-stack{display:flex;align-items:center;gap:0;padding-right:4px}
.hero-stack img{width:70px;height:70px;border-radius:18px;object-fit:cover;border:2px solid var(--panel);margin-left:-18px;box-shadow:0 12px 28px rgba(0,0,0,.35)}
.hero-stack img:first-child{margin-left:0}
.filters{width:min(1120px,96vw);margin:0 auto 8px;display:flex;gap:7px;overflow-x:auto;padding:4px 0 8px;scrollbar-width:none}
.filters:empty{display:none}
.filters::-webkit-scrollbar{display:none}
.filter-chip{flex:0 0 auto;display:inline-flex;align-items:center;gap:6px;border:1px solid var(--glass-border);background:var(--glass);color:var(--muted);border-radius:999px;padding:6px 13px;font-size:.82rem;font-weight:700;cursor:pointer;backdrop-filter:var(--blur);-webkit-backdrop-filter:var(--blur);transition:color .18s,border-color .18s,background .18s}
.filter-chip .dotcol{width:7px;height:7px;border-radius:50%;background:currentColor;opacity:.7}
.filter-chip:hover{color:var(--text);border-color:rgba(255,255,255,.22)}
.filter-chip.active{color:#08090c;background:#fff;border-color:#fff;font-weight:840}
.filter-chip.active .dotcol{opacity:0}

/* ── Avatar Inbox ── */
.stage{flex:0 0 auto;display:flex;align-items:stretch;justify-content:center;min-height:0;position:relative;overflow:visible;padding:8px 0 4px}
.stage::before{display:none}
.ring{width:min(1280px,96vw);display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:16px}
.card{position:relative;width:100%;aspect-ratio:3/4;min-height:420px;border-radius:18px;overflow:hidden;cursor:pointer;box-shadow:none;border:1px solid rgba(255,255,255,.08);background:var(--panel);display:block;align-items:stretch}
.card img{width:100%;height:100%;min-height:0;object-fit:cover;display:block;transition:opacity 0.2s,transform .25s}
.card.loading img{opacity:0.4;filter:blur(2px)}
.card:hover{border-color:rgba(125,211,252,0.45);background:var(--panel2)}
.card:hover img{transform:scale(1.035)}
.card::after{content:'';position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.9) 0%,rgba(0,0,0,.45) 34%,rgba(0,0,0,0) 68%);pointer-events:none}
.card .info{position:absolute;left:0;right:0;bottom:0;z-index:2;min-width:0;padding:12px;background:transparent;display:grid;align-content:end}
.card .nm{font-size:1rem;font-weight:860;letter-spacing:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;text-shadow:0 2px 8px #000}
.card .nm .age{font-weight:400;color:var(--muted)}
.card .tag{font-size:0.76rem;color:#fff;margin-top:4px;text-transform:none;letter-spacing:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;opacity:.92}
.produced-bubble{display:inline-flex;align-items:center;max-width:100%;width:max-content;margin-top:6px;padding:4px 8px;border-radius:999px;background:rgba(34,197,94,.88);border:1px solid rgba(187,247,208,.62);color:#04130a;font-size:.66rem;font-weight:900;line-height:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;box-shadow:0 8px 24px rgba(0,0,0,.26)}
.produced-bubble:empty{display:none}
.card .loc,.card .avatar-note{display:none}
.card-actions{position:absolute;left:10px;right:10px;bottom:76px;z-index:6;display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:6px;opacity:.96}
.card-actions button{height:38px;border:1px solid rgba(255,255,255,.18);border-radius:9px;background:rgba(8,9,12,.72);color:#fff;backdrop-filter:blur(10px);font-size:1.05rem;cursor:pointer}
.card-actions button:hover,.card-actions button:focus-visible{background:rgba(255,255,255,.16);border-color:rgba(125,211,252,.55);outline:none}
.card-actions button:active{transform:scale(.96)}
.card-stats{position:absolute;left:10px;top:10px;right:10px;z-index:3;display:flex;align-items:center;justify-content:space-between;gap:8px;font-size:.72rem;font-weight:900;color:#fff;text-shadow:0 2px 10px #000}
.card-stats span{display:inline-flex;align-items:center;gap:4px;padding:5px 7px;border-radius:999px;background:rgba(0,0,0,.42);backdrop-filter:blur(8px)}
.card.active{border-color:rgba(125,211,252,0.62);background:var(--panel2)}
.card .active-glow{position:absolute;inset:-1px;border-radius:18px;box-shadow:inset 0 0 0 2px var(--accent);opacity:0;pointer-events:none;z-index:4}
.card.active .active-glow{opacity:1}
.card .spinner{position:absolute;top:50%;left:50%;width:28px;height:28px;margin:-14px 0 0 -14px;border:3px solid rgba(255,255,255,0.1);border-top-color:var(--accent);border-radius:50%;opacity:0;animation:spin 0.8s linear infinite;z-index:5}
.card.loading .spinner{opacity:1}
.video-pill{position:absolute;top:8px;right:8px;z-index:4;display:none;align-items:center;gap:6px;padding:5px 8px;border-radius:999px;background:rgba(5,5,8,0.72);border:1px solid rgba(255,255,255,0.22);backdrop-filter:blur(14px);font-size:0.7rem;font-weight:800;color:#fff}
.card.has-video .video-pill{display:flex}
.load-ui{position:absolute;left:10px;right:10px;bottom:10px;padding:8px 10px;border-radius:8px;background:rgba(5,5,8,0.82);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border:1px solid rgba(255,255,255,0.18);opacity:0;transform:translateY(6px);pointer-events:none;z-index:5}
.card.loading .load-ui{opacity:1}
.load-head{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-bottom:8px}
.load-txt{font-size:0.82rem;line-height:1.25;color:#fff;text-shadow:0 1px 10px rgba(0,0,0,0.6);min-width:0}
.load-pct{font-size:0.78rem;font-weight:800;font-variant-numeric:tabular-nums;color:#fff;text-shadow:0 1px 10px rgba(0,0,0,0.7);flex-shrink:0}
.load-track{height:5px;border-radius:999px;background:rgba(255,255,255,0.16);overflow:hidden}
.load-bar{height:100%;width:0%;border-radius:999px;background:linear-gradient(90deg,var(--accent),var(--ok));box-shadow:0 0 20px rgba(125,211,252,0.35)}
.load-ui.theme-lipstick .load-bar{background:linear-gradient(90deg,#be123c,#fb7185,#fecdd3);box-shadow:0 0 20px rgba(244,63,94,0.75)}
.load-ui.theme-water .load-bar{background:linear-gradient(90deg,#0284c7,#38bdf8,#a7f3d0);box-shadow:0 0 20px rgba(56,189,248,0.75)}
.load-ui.theme-night .load-bar{background:linear-gradient(90deg,#4f46e5,#a78bfa,#22d3ee);box-shadow:0 0 20px rgba(129,140,248,0.75)}
.load-ui.theme-gold .load-bar{background:linear-gradient(90deg,#b45309,#f59e0b,#fde68a);box-shadow:0 0 20px rgba(245,158,11,0.75)}
@keyframes spin{to{transform:rotate(360deg)}}

/* ── Bottom Stack ── */
.bottom{display:none}
.action-dock{width:min(720px,96vw);margin:4px auto 14px;display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:8px;padding:8px;border:1px solid var(--line);border-radius:10px;background:rgba(17,19,24,.96);position:sticky;bottom:10px;z-index:52;box-shadow:0 -8px 28px rgba(0,0,0,.35)}
.action-dock .ab{width:100%;max-width:none;min-width:0;height:58px}
.action-dock .ab .ic{font-size:1.35rem}
@media(max-width:640px){.action-dock{grid-template-columns:repeat(3,minmax(0,1fr));bottom:8px}.action-dock .ab{height:54px}}
/* panel-width scales: mobile 96vw, tablet/desktop up to 720px */
.panel{width:min(720px,96vw)}

/* ── Mieze-Status (location/outfit/accessoire/last chat) ── */
.status{width:min(720px,96vw);padding:14px 18px;border-radius:8px;background:var(--panel);backdrop-filter:none;-webkit-backdrop-filter:none;border:1px solid var(--line);font-size:0.95rem;line-height:1.5}
.st-row{display:grid;grid-template-columns:20px minmax(92px,max-content) minmax(0,1fr);align-items:center;gap:8px;margin:5px 0;color:rgba(255,255,255,0.85)}
.st-row .ico{width:20px;text-align:center;font-size:1rem}
.st-row .lbl{font-size:0.72rem;text-transform:uppercase;letter-spacing:0.6px;color:rgba(255,255,255,0.7);font-weight:600;min-width:0}
.st-row .val{color:rgba(255,255,255,0.96);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}
.st-row .val.empty{color:rgba(255,255,255,0.35);font-style:italic}
.st-chat{margin-top:8px;padding-top:10px;border-top:1px solid var(--line);font-style:italic;color:var(--accent);font-size:0.92rem;min-height:1.2em}
.st-chat.empty{color:rgba(255,255,255,0.3)}

/* ── Stat-Sliders ── */
.glass{width:min(1120px,96vw);padding:12px;border-radius:18px;background:var(--panel);backdrop-filter:none;-webkit-backdrop-filter:none;border:1px solid var(--line);display:grid;grid-template-columns:minmax(190px,280px) minmax(0,1fr);gap:14px;align-items:stretch}
#stats{position:fixed;left:50%;top:50%;z-index:214;width:95vw;height:95svh;max-width:1280px;max-height:95svh;overflow:auto;display:none;opacity:0;box-shadow:0 30px 120px rgba(0,0,0,.72);grid-template-columns:minmax(320px,38%) minmax(0,1fr)}
#stats.open{display:grid}
.detail-backdrop{position:fixed;inset:0;z-index:213;background:rgba(2,3,6,.72);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);display:none;opacity:0}
.detail-backdrop.open{display:block}
.detail-close{position:absolute;right:10px;top:10px;z-index:8;width:38px;height:38px;border-radius:50%;border:1px solid rgba(255,255,255,.14);background:rgba(0,0,0,.48);color:#fff;font-size:1.25rem;cursor:pointer}
.detail-preview{position:relative;min-height:100%;border-radius:14px;overflow:hidden;background:#08090c;border:1px solid rgba(255,255,255,.08)}
.detail-preview img{width:100%;height:100%;object-fit:cover;display:block;cursor:zoom-in}
.detail-preview::after{content:'';position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.84),rgba(0,0,0,0) 58%);pointer-events:none}
.detail-name{position:absolute;left:12px;right:12px;bottom:54px;z-index:2;font-size:1.05rem;font-weight:900;text-shadow:0 2px 10px #000}
.detail-name small{display:block;margin-top:3px;color:rgba(255,255,255,.65);font-size:.78rem;font-weight:700}
.detail-preview button{position:absolute;left:12px;right:12px;bottom:12px;z-index:3;border:1px solid rgba(255,255,255,.16);background:rgba(255,255,255,.92);color:#08090c;border-radius:999px;padding:10px 12px;font-weight:900;cursor:pointer}
.detail-controls{display:grid;gap:9px;align-content:start;min-width:0;overflow:auto;padding-right:4px}
#stats .status,#stats .chat{width:100%}
.g-title{font-size:0.95rem;font-weight:800;margin-bottom:2px;display:flex;align-items:center;gap:8px}
.g-title .pulse{width:8px;height:8px;border-radius:50%;background:var(--accent);animation:pulse 2s infinite}
@keyframes pulse{0%,100%{box-shadow:0 0 0 0 rgba(125,211,252,0.5)}50%{box-shadow:0 0 0 8px rgba(125,211,252,0)}}
.sr{display:flex;align-items:center;gap:8px;margin:5px 0;cursor:pointer;padding:1px 0}
.sr:hover .sf{filter:brightness(1.4)}
.si{font-size:1rem;width:24px;text-align:center}
.sl{width:54px;font-size:0.75rem;color:rgba(255,255,255,0.75);text-transform:uppercase;letter-spacing:0.5px;font-weight:600}
.st{flex:1;height:3px;background:rgba(255,255,255,0.06);border-radius:3px;overflow:visible;position:relative}
.sf{height:100%;border-radius:3px;transition:width 0.4s cubic-bezier(0.16,1,0.3,1);position:relative}
.sf::after{content:'';position:absolute;right:-11px;top:-9px;width:22px;height:22px;border-radius:50%;background:inherit;box-shadow:0 0 0 3px rgba(5,5,8,0.85),0 0 12px currentColor;transition:transform 0.2s}
.st{touch-action:none}
.sr:hover .sf::after{transform:scale(1.3)}
.sv{width:32px;text-align:right;font-size:0.82rem;color:rgba(255,255,255,0.9);font-variant-numeric:tabular-nums;font-weight:600}
.generate-row{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:8px;margin-top:6px}
.generate-row button{border:1px solid var(--line);background:var(--panel2);color:#fff;border-radius:10px;padding:11px 10px;font-weight:900;cursor:pointer}
.generate-row .generate{grid-column:span 2;border:0;background:linear-gradient(90deg,#7dd3fc,#f472b6);color:#050508}

/* ── Action Buttons (single launcher, popup does the choosing) ── */
.acts{display:flex;gap:10px;justify-content:center;width:min(240px,72vw);position:sticky;bottom:12px;z-index:50;padding:8px;border-radius:10px;background:var(--panel);backdrop-filter:none;-webkit-backdrop-filter:none;border:1px solid var(--line);box-shadow:0 -4px 20px rgba(0,0,0,0.4)}
body{padding-bottom:18px}
.ab{flex:1 1 0;min-width:60px;max-width:220px;height:60px;border-radius:8px;display:flex;align-items:center;justify-content:center;cursor:pointer;background:var(--panel2);backdrop-filter:none;border:1px solid var(--line);transition:all 0.2s;position:relative}
.ab .ic{font-size:1.7rem;line-height:1}
.ab::after{content:attr(data-lb);position:absolute;bottom:4px;left:0;right:0;font-size:0.6rem;letter-spacing:0.4px;text-transform:uppercase;color:rgba(255,255,255,0.85);font-weight:600;pointer-events:none;white-space:nowrap;text-align:center;overflow:hidden;text-overflow:ellipsis;padding:0 2px}
.ab{padding-bottom:14px}
.ab .ic{margin-bottom:4px}
.ab:hover{background:rgba(125,211,252,0.12);border-color:var(--accent);transform:translateY(-2px)}
.ab:hover::after{color:#fff}
@media(max-width:700px){
  body{padding-bottom:18px}
  .acts{bottom:8px;width:min(220px,72vw);margin-top:8px}
}
.ab:active{transform:translateY(0) scale(0.94)}
.ab.busy{opacity:0.5;pointer-events:none}
.ab.saved{background:rgba(77,171,247,0.18);border-color:#4dabf7}
.action-modal{position:fixed;inset:0;z-index:208;background:rgba(5,5,8,0.82);backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);display:none;align-items:flex-end;justify-content:center;padding:16px env(safe-area-inset-right,16px) calc(env(safe-area-inset-bottom,16px) + 10px) env(safe-area-inset-left,16px)}
.action-modal.open{display:flex}
.action-sheet{width:min(560px,96vw);background:var(--panel);border:1px solid var(--line);border-radius:8px;box-shadow:0 24px 90px rgba(0,0,0,0.6);padding:10px}
.action-head{display:flex;align-items:center;justify-content:space-between;padding:6px 6px 12px;font-size:0.82rem;color:rgba(255,255,255,0.65);text-transform:uppercase;letter-spacing:0.08em;font-weight:700}
.action-close{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:rgba(255,255,255,0.06);border:1px solid var(--glass-border);color:#fff;cursor:pointer;font-size:1.2rem}
.action-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}
.action-grid .ab{width:100%;max-width:none;min-width:0;height:70px}
.action-grid .ab .ic{font-size:1.55rem}
@media(max-width:420px){.action-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.action-grid .ab{height:64px}}

/* ── Nav Arrows (small floating) ── */
.nav{display:flex;gap:14px;justify-content:center;padding:2px}
.na{width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.3rem;cursor:pointer;background:rgba(255,255,255,0.05);border:1px solid rgba(255,255,255,0.2);color:rgba(255,255,255,0.85);transition:all 0.2s;-webkit-tap-highlight-color:transparent}
.na:hover{color:var(--accent);border-color:var(--accent)}

/* ── Toast ── */
.toast{position:fixed;top:16px;left:50%;transform:translateX(-50%) translateY(-60px);background:rgba(0,0,0,0.82);backdrop-filter:var(--blur);padding:12px 24px;border-radius:12px;font-size:0.95rem;z-index:99;border:1px solid var(--glass-border);pointer-events:none;opacity:0;max-width:90vw;text-align:center}

/* ── Chat (WhatsApp-style) ── */
.chat{width:min(720px,96vw);padding:12px 14px;border-radius:8px;background:var(--panel);backdrop-filter:none;-webkit-backdrop-filter:none;border:1px solid var(--line)}
/* ── Preset chips (save/clone snapshot) ── */
.presets{width:min(720px,96vw);display:flex;flex-wrap:wrap;gap:6px;padding:2px 4px;min-height:0}
.presets:empty{display:none}
.chip{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border-radius:8px;background:var(--panel2);backdrop-filter:none;border:1px solid var(--line);font-size:0.78rem;color:rgba(255,255,255,0.85);cursor:pointer;transition:all 0.15s}
.chip:hover{border-color:var(--accent);color:#fff;background:rgba(125,211,252,0.12)}
.chip .chip-x{opacity:0.5;font-size:0.9rem;margin-left:4px}
.chip .chip-x:hover{opacity:1;color:var(--accent)}
.chip-title{font-size:0.7rem;color:rgba(255,255,255,0.45);text-transform:uppercase;letter-spacing:0.6px;margin-right:6px;align-self:center}
.planb{width:min(720px,96vw);display:flex;align-items:center;gap:7px;flex-wrap:wrap;padding:2px 4px}
.planb:empty{display:none}
.planb .chip{border-radius:8px}
.planb .chip.planb-open{color:#fca5a5;border-color:rgba(252,165,165,0.35)}
.chat-history{max-height:160px;overflow-y:auto;display:flex;flex-direction:column;gap:6px;margin-bottom:10px;padding-right:4px}
.chat-history::-webkit-scrollbar{width:4px}
.chat-history::-webkit-scrollbar-thumb{background:rgba(255,255,255,0.15);border-radius:2px}
.chat-history.empty::before{content:'Sag ihr was — sie hört zu.';font-size:0.88rem;color:rgba(255,255,255,0.45);font-style:italic;align-self:center}
.cm{padding:8px 13px;border-radius:14px;font-size:0.95rem;line-height:1.4;max-width:82%;word-wrap:break-word}
.cm.me{align-self:flex-end;background:rgba(74,144,226,0.25);border:1px solid rgba(74,144,226,0.38);border-bottom-right-radius:4px}
.cm.her{align-self:flex-start;background:rgba(125,211,252,0.12);border:1px solid rgba(125,211,252,0.28);border-bottom-left-radius:4px}
.cm.her.typing{font-style:italic;opacity:0.7}
.chat-input{display:flex;gap:8px;align-items:center}
.prompt-tools{width:128px;min-width:112px;border:1px solid var(--glass-border);border-radius:10px;background:rgba(255,255,255,0.08);color:#fff;padding:10px 9px;font-family:inherit;font-size:0.82rem;outline:none}
.prompt-tools option{background:#111318;color:#fff}
.chat-input input{flex:1;background:rgba(255,255,255,0.06);border:1px solid var(--glass-border);border-radius:12px;padding:10px 14px;color:#fff;font-family:inherit;font-size:1rem;outline:none;transition:border-color 0.2s}
.chat-input input:focus{border-color:var(--accent)}
.chat-input button{width:44px;border-radius:12px;background:var(--accent);border:0;color:#fff;font-size:1.2rem;cursor:pointer;transition:transform 0.15s}
.chat-input button:active{transform:scale(0.92)}

/* ── Mieze-Voice (suggestion overlay) ── */
.voice{position:fixed;top:14px;left:50%;transform:translateX(-50%);background:var(--panel2);backdrop-filter:none;-webkit-backdrop-filter:none;padding:10px 38px 10px 12px;border-radius:8px;font-size:0.9rem;z-index:48;border:1px solid rgba(125,211,252,0.35);max-width:min(360px,92vw);box-shadow:0 14px 44px rgba(0,0,0,0.45),inset 0 1px 0 rgba(255,255,255,0.08);opacity:0;pointer-events:auto;line-height:1.25;display:grid;grid-template-columns:34px 1fr;gap:10px;align-items:center}
.voice .who{font-size:0.78rem;font-weight:700;letter-spacing:1px;text-transform:uppercase;opacity:0.9;margin-bottom:6px}
.voice .x{position:absolute;top:8px;right:12px;font-size:1rem;opacity:0.7;cursor:pointer}
.voice-play{width:34px;height:34px;border-radius:50%;border:1px solid rgba(255,255,255,0.32);background:rgba(0,0,0,0.24);color:#fff;font-size:0.95rem;cursor:pointer}
.voice-main{min-width:0}
#voice-text{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sr-only{position:absolute!important;width:1px!important;height:1px!important;padding:0!important;margin:-1px!important;overflow:hidden!important;clip:rect(0,0,0,0)!important;white-space:nowrap!important;border:0!important}
.intent-pulse{animation:intentPulse 1.2s ease-in-out 4}
@keyframes intentPulse{0%,100%{box-shadow:0 10px 28px rgba(125,211,252,.15);transform:translateY(0)}50%{box-shadow:0 0 0 7px rgba(125,211,252,.18),0 18px 46px rgba(125,211,252,.25);transform:translateY(-2px)}}

input[type=file]{display:none}

/* ── Indicators ── */
.dots{display:none}
.dot{width:6px;height:6px;border-radius:50%;background:rgba(255,255,255,0.15);transition:all 0.3s}
.dot.on{background:var(--accent);width:18px;border-radius:3px}

/* ── Gallery modal (long-press card) ── */
.gal-modal{position:fixed;inset:0;background:rgba(5,5,8,0.92);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);z-index:200;display:none;flex-direction:column;padding:env(safe-area-inset-top,12px) 12px env(safe-area-inset-bottom,12px)}
.gal-modal.open{display:flex}
.gal-head{display:flex;justify-content:space-between;align-items:center;padding:8px 4px 12px;flex-shrink:0}
.gal-head h3{font-size:0.95rem;font-weight:700;color:#fff;letter-spacing:0.3px}
.gal-x{font-size:1.4rem;color:rgba(255,255,255,0.7);cursor:pointer;padding:6px 10px;border-radius:10px;background:var(--glass);border:1px solid var(--glass-border);min-width:44px;min-height:44px;display:flex;align-items:center;justify-content:center}
.gal-tabs{display:flex;gap:6px;overflow-x:auto;padding:0 4px 10px;flex-shrink:0;scrollbar-width:none}
.gal-tabs::-webkit-scrollbar{display:none}
.gal-tab{flex:0 0 auto;border:1px solid var(--glass-border);background:var(--glass);color:var(--muted);border-radius:999px;padding:6px 13px;font:700 .82rem inherit;cursor:pointer;white-space:nowrap;transition:color .15s,border-color .15s,background .15s}
.gal-tab:hover{color:var(--text);border-color:rgba(255,255,255,.22)}
.gal-tab.active{color:#08090c;background:#fff;border-color:#fff}
.gal-tab .cnt{font:700 .7rem ui-monospace,monospace;opacity:.7;margin-left:3px}
.gal-grid{flex:1;overflow-y:auto;display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:8px;padding-bottom:12px}
.gal-cell{position:relative;aspect-ratio:7/10;border-radius:10px;overflow:hidden;background:#1a1a24;transition:transform 0.18s,box-shadow .18s}
.gal-cell:hover{transform:scale(1.03)}
.gal-cell img{width:100%;height:100%;object-fit:cover;cursor:pointer;display:block}
.gal-cell.rated-star{box-shadow:0 0 0 2px #facc15}
.gal-cell.rated-like{box-shadow:0 0 0 2px #6ee7b7}
.gal-cell.rated-reject{opacity:.5}
/* Rating-Buttons pro Bild — gleiche Semantik wie Haus-Suche */
.gal-rate{position:absolute;left:6px;right:6px;bottom:6px;z-index:3;display:flex;gap:5px;justify-content:center}
.gr{flex:1;max-width:42px;height:34px;border:1px solid rgba(255,255,255,.2);border-radius:9px;background:rgba(8,9,12,.72);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);color:#fff;font-size:1rem;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;padding:0;transition:transform .12s,border-color .15s,background .15s}
.gr:hover{transform:scale(1.1)}
.gr:active{transform:scale(.92)}
.gr.on{background:rgba(255,255,255,.18)}
.gr-up.on{border-color:#6ee7b7}.gr-down.on{border-color:#f87171}.gr-star.on{border-color:#facc15}
.gal-meta{position:absolute;left:0;right:0;bottom:46px;padding:14px 8px 6px;background:linear-gradient(transparent,rgba(0,0,0,0.85));font-size:0.72rem;color:rgba(255,255,255,0.9);line-height:1.2;text-overflow:ellipsis;overflow:hidden;white-space:nowrap}
.gal-produced{position:absolute;left:6px;right:6px;top:6px;z-index:2;display:block;padding:4px 7px;border-radius:999px;background:rgba(34,197,94,.9);border:1px solid rgba(187,247,208,.66);color:#04130a;font-size:.6rem;font-weight:900;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;box-shadow:0 8px 20px rgba(0,0,0,.28)}

/* ── History modal ── */
.modal{position:fixed;inset:0;background:rgba(5,5,8,0.92);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);z-index:205;display:none;align-items:flex-start;justify-content:center;padding:env(safe-area-inset-top,12px) 12px env(safe-area-inset-bottom,12px)}
.modal.open{display:flex}
.modal-box{width:100%;max-width:720px;background:var(--glass);border:1px solid var(--glass-border);border-radius:14px;overflow:hidden;display:flex;flex-direction:column;max-height:92vh}
.modal-head{display:flex;justify-content:space-between;align-items:center;padding:10px 12px;border-bottom:1px solid var(--glass-border);font-weight:700;color:#fff}
.quote-body{padding:14px;display:grid;gap:12px;color:rgba(255,255,255,0.9)}
.quote-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}
.quote-cell{border:1px solid var(--glass-border);background:rgba(255,255,255,0.06);border-radius:10px;padding:9px 10px;min-width:0}
.quote-k{font-size:0.66rem;text-transform:uppercase;letter-spacing:0.7px;color:rgba(255,255,255,0.52);margin-bottom:4px}
.quote-v{font-size:0.96rem;font-weight:800;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.quote-price{display:flex;justify-content:space-between;align-items:center;gap:10px;border-radius:12px;background:#ffd43b;color:#151006;padding:12px 14px;font-weight:900}
.quote-price small{display:block;font-size:0.68rem;text-transform:uppercase;letter-spacing:0.8px;opacity:0.7}
.quote-price strong{font-size:1.35rem}
.quote-note{font-size:0.84rem;line-height:1.35;color:rgba(255,255,255,0.68)}
.quote-controls{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}
.quote-field{display:grid;gap:5px}
.quote-field label{font-size:0.66rem;text-transform:uppercase;letter-spacing:0.7px;color:rgba(255,255,255,0.52)}
.quote-field select,.quote-field input{width:100%;border:1px solid var(--glass-border);border-radius:10px;background:rgba(255,255,255,0.08);color:#fff;padding:10px 11px;font-family:inherit;font-size:0.95rem;outline:none}
/* ── Provider Drawer (slide-over, replaces always-on Schaltzentrale panel) ── */
.drawer-scrim{position:fixed;inset:0;z-index:70;background:rgba(5,6,10,.55);backdrop-filter:blur(3px);-webkit-backdrop-filter:blur(3px);opacity:0;visibility:hidden;transition:opacity .28s ease,visibility .28s}
.drawer-scrim.open{opacity:1;visibility:visible}
.producer-drawer{position:fixed;top:0;right:0;z-index:71;height:100dvh;width:min(420px,90vw);display:flex;flex-direction:column;gap:16px;padding:calc(env(safe-area-inset-top,0) + 22px) 22px 22px;background:linear-gradient(155deg,rgba(23,26,32,.96),rgba(15,17,22,.97));border-left:1px solid var(--glass-border);box-shadow:-24px 0 60px rgba(5,8,16,.55),inset 1px 0 0 rgba(255,255,255,.05);backdrop-filter:blur(22px);-webkit-backdrop-filter:blur(22px);transform:translateX(104%);transition:transform .34s cubic-bezier(.32,.72,0,1);overflow-y:auto}
.producer-drawer.open{transform:translateX(0)}
.drawer-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}
.drawer-title{font-size:1.35rem;font-weight:840;letter-spacing:-.01em;color:#fff;margin:0}
.drawer-sub{margin:4px 0 0;color:var(--muted);font-size:.86rem;line-height:1.4;max-width:34ch}
.drawer-x{flex:0 0 auto;width:34px;height:34px;border:1px solid var(--glass-border);border-radius:50%;background:var(--glass);color:var(--text);font-size:1.25rem;line-height:1;cursor:pointer;transition:border-color .18s,background .18s}
.drawer-x:hover{border-color:rgba(248,113,113,.5);background:rgba(248,113,113,.1)}
.producer-panel{display:grid;grid-template-columns:1fr;gap:13px;margin:0}
.producer-field{display:grid;gap:6px;min-width:0}
.producer-field label{font-size:0.66rem;text-transform:uppercase;letter-spacing:.6px;color:rgba(255,255,255,.5);font-weight:800}
.producer-field select{width:100%;min-width:0;border:1px solid var(--glass-border);border-radius:10px;background:rgba(8,9,12,.6);color:#fff;padding:12px 11px;font:inherit;font-size:.9rem;outline:none;cursor:pointer;transition:border-color .18s}
.producer-field select:hover{border-color:rgba(255,255,255,.2)}
.producer-field select:focus{border-color:var(--accent)}
.quote-actions{display:flex;gap:8px;justify-content:flex-end}
.quote-actions button{border:0;border-radius:10px;padding:10px 13px;font-family:inherit;font-weight:800;cursor:pointer;color:#fff;background:rgba(255,255,255,0.12)}
.quote-actions .go{background:#ffd43b;color:#151006}
.quote-actions button:active{transform:scale(0.97)}
#hist-body{overflow-y:auto;padding:8px 4px}
.hist-row{display:grid;grid-template-columns:110px 90px 90px 1fr;gap:8px;padding:6px 10px;font-size:0.78rem;border-bottom:1px solid rgba(255,255,255,0.04);align-items:center}
.hist-row:hover{background:rgba(255,255,255,0.03)}
.hist-ts{color:rgba(255,255,255,0.45);font-variant-numeric:tabular-nums}
.hist-type{color:var(--accent);font-weight:600}
.hist-m{color:rgba(255,255,255,0.85)}
.hist-d{color:rgba(255,255,255,0.55);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.hist-k{color:rgba(255,255,255,0.35);margin-right:3px}
.hist-empty{padding:20px;text-align:center;color:rgba(255,255,255,0.5)}
@media (max-width:560px){.hist-row{grid-template-columns:1fr;gap:2px}.hist-ts,.hist-d{grid-column:1}}

/* ── Single-image fullscreen (click active card) ── */
.img-modal{position:fixed;inset:0;background:rgba(5,5,8,0.95);backdrop-filter:blur(20px);z-index:260;display:none;align-items:center;justify-content:center;padding:20px;cursor:zoom-out}
.img-modal.open{display:flex}
.img-modal img,.img-modal video{max-width:95vw;max-height:92vh;border-radius:12px;box-shadow:0 30px 80px rgba(0,0,0,0.7)}
.img-modal .x{position:fixed;top:16px;right:16px;font-size:1.6rem;color:#fff;background:rgba(0,0,0,0.5);border:1px solid var(--glass-border);border-radius:50%;width:48px;height:48px;display:flex;align-items:center;justify-content:center;cursor:pointer}

/* ── Responsive ── Tablet landscape + Phones ── */
/* Tablet portrait: 2-col layout (carousel left, panels right) */
@media (min-width:820px) and (max-width:1280px) and (orientation:portrait){
  .stage{min-height:0;max-height:none}
}

/* Tablet landscape (short & wide): carousel shrinks hard */
@media (max-height:820px) and (min-width:768px){
  .stage{min-height:0;max-height:none}
}

/* Mobile portrait */
@media (max-width:640px){
  .app-nav{height:auto;min-height:58px;grid-template-columns:1fr auto;gap:8px;padding:8px 0}
  .brand{font-size:1rem}
  .tabs{grid-column:1/-1;justify-content:flex-start;overflow-x:auto}
  .tab{font-size:.84rem;padding:8px 10px}
  .joi-hero{grid-template-columns:1fr;border-radius:14px;margin-top:10px}
  .hero-stack{display:none}
  .stage{min-height:0;max-height:none;padding-top:8px}
  .ring{width:min(430px,96vw);grid-template-columns:1fr;gap:12px}
  .card{min-height:420px;grid-template-columns:none;border-radius:14px}
  .card img{width:100%;min-height:0}
  .card .spinner{left:50%}
  .load-ui{left:10px}
  .status,.glass,.chat,.presets{padding:10px 14px;width:min(520px,96vw)}
  .chat-input{display:grid;grid-template-columns:1fr 44px;gap:8px}
  .prompt-tools{grid-column:1/-1;width:100%}
  .glass{grid-template-columns:1fr;gap:10px}
  #stats{width:95vw;height:95svh;max-height:95svh;grid-template-columns:1fr;grid-template-rows:minmax(320px,52svh) auto}
  .detail-preview{min-height:320px}
  .st-row{margin:2px 0}
  .acts{gap:6px;width:min(220px,72vw);padding:5px}
  .ab{min-width:50px;height:56px}
  .ab .ic{font-size:1.45rem}
  .chat-history{max-height:110px}
  .bottom{padding:6px 0 14px;gap:8px}
}

/* Landscape phones / very short viewports: everything scrolls if needed */
@media (max-height:560px){
  .stage{min-height:0;max-height:none}
  .chat-history{max-height:80px}
  .acts{gap:6px}
  .ab{min-width:44px;height:44px}
  .ab .ic{font-size:1.2rem}
  .bottom{padding:4px 0 10px;gap:6px}
}

/* Narrow phones: tighter button row */
@media (max-width:400px){
  .ab{min-width:44px;height:46px}
  .ab .ic{font-size:1.3rem}
  .status,.glass,.chat,.presets{width:min(420px,96vw)}
  .card{min-height:360px;grid-template-columns:none}
  .card img{width:100%;min-height:0}
  .card .spinner{left:50%}
  .load-ui{left:10px}
}

/* Tablet landscape / desktop: more breathing room, 2-col optional */
@media (min-width:1024px){
  .status,.glass,.chat,.presets{width:min(760px,92vw)}
  .glass{width:min(1120px,96vw)}
  .acts{width:min(240px,72vw)}
  .stage{min-height:0}
  .ring{width:min(1120px,96vw)}
  #stats{grid-template-columns:minmax(380px,44%) minmax(0,1fr)}
  .ab{max-width:120px;height:64px}
  .ab .ic{font-size:1.8rem}
}

/* ── Scrubbed Bento Hero — 60vh nicht 100vh, damit Buttons above fold auf Desktop ── */
.bento-wrap{display:none;position:relative;width:100vw;height:60vh;overflow:hidden}
.bento-hero{position:relative;width:100vw;height:60vh;padding:8px;display:grid;gap:6px;grid-template-columns:repeat(4,1fr);grid-template-rows:repeat(2,1fr);background:#050508}
.bento-hero .bi{position:relative;overflow:hidden;border-radius:16px;cursor:pointer;background:#1a1a24;will-change:transform}
.bento-hero .bi img{width:100%;height:100%;object-fit:cover;display:block;transition:transform 0.4s}
.bento-hero .bi:hover img{transform:scale(1.04)}
.bento-hero .bi .meta{position:absolute;left:10px;bottom:10px;right:10px;z-index:2;pointer-events:none}
.bento-hero .bi .meta .nm{font-size:1rem;font-weight:700;letter-spacing:-0.3px;color:#fff;text-shadow:0 2px 10px rgba(0,0,0,0.9)}
.bento-hero .bi .meta .vb{font-size:0.72rem;color:var(--accent);text-transform:uppercase;letter-spacing:1px;margin-top:2px;font-weight:600;text-shadow:0 2px 6px #000}
.bento-hero .bi::after{content:'';position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,0.85) 0%,transparent 50%);pointer-events:none}
.bi-actions{position:absolute;left:6px;right:6px;bottom:6px;z-index:4;display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:4px;opacity:0;transition:opacity .15s ease-out;pointer-events:none}
.bento-hero .bi:hover .bi-actions,.bento-hero .bi:focus-within .bi-actions{opacity:1;pointer-events:auto}
.bi-actions button{height:30px;border:1px solid rgba(255,255,255,.22);border-radius:7px;background:rgba(8,9,12,.78);color:#fff;backdrop-filter:blur(10px);font-size:.92rem;cursor:pointer;padding:0;line-height:1}
.bi-actions button:hover,.bi-actions button:focus-visible{background:rgba(255,255,255,.16);border-color:rgba(125,211,252,.55);outline:none}
.bi-actions button:active{transform:scale(.94)}

/* ── tw-dock: ActionDockWidget single-source action panel ── */
.tw-dock{display:grid;gap:6px;align-items:center}
.tw-dock button{border:1px solid rgba(255,255,255,.18);border-radius:9px;background:rgba(8,9,12,.72);color:#fff;backdrop-filter:blur(10px);cursor:pointer;padding:0;line-height:1;display:inline-flex;align-items:center;justify-content:center;gap:6px;font-size:1rem;transition:transform .12s,background .15s,border-color .15s}
.tw-dock button:hover,.tw-dock button:focus-visible{background:rgba(255,255,255,.16);border-color:rgba(125,211,252,.55);outline:none}
.tw-dock button:active{transform:scale(.94)}
.tw-dock button.busy{opacity:.55;pointer-events:none}
.tw-dock button .lb{font-size:.78rem;font-weight:600;letter-spacing:.2px;opacity:.85}
.tw-dock--compact{grid-template-columns:repeat(4,minmax(0,1fr))}
.tw-dock--compact button{height:38px;font-size:1.05rem}
/* Detail-Lade-Balken: horizontal, gespiegelt von der aktiven Karte (Dee 2026-05-23) */
.detail-progress{margin:4px 0 10px;padding:10px 12px;border:1px solid var(--glass-border);border-radius:12px;background:var(--glass)}
.detail-progress[hidden]{display:none}
.dp-head{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:7px}
.dp-txt{font-size:.82rem;color:var(--text);opacity:.92;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.dp-pct{font:700 .78rem ui-monospace,monospace;color:var(--ok);flex:0 0 auto}
.dp-track{height:7px;border-radius:999px;background:rgba(255,255,255,.14);overflow:hidden}
.dp-bar{height:100%;width:0%;border-radius:999px;background:linear-gradient(90deg,var(--accent),var(--ok));box-shadow:0 0 16px rgba(110,231,183,.45);transition:width .3s ease}

/* full-dock: 5 primär (groß) + ⋯, Rest im Overflow. (Dee 2026-05-23: 14 Buttons eleganter) */
.tw-dock--full{display:block}
.tw-dock-primary{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}
.tw-dock-more{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:6px;margin-top:8px;padding-top:8px;border-top:1px solid var(--line)}
.tw-dock-more[hidden]{display:none}
.tw-dock--full .ab{height:60px;flex-direction:column;gap:3px;padding:5px 3px}
.tw-dock--full .ab .ic{font-size:1.45rem;line-height:1}
.tw-dock--full .ab .lb{font-size:.72rem;font-weight:680;letter-spacing:.05px;opacity:.88;max-width:100%;overflow:hidden;text-overflow:clip;white-space:nowrap}
/* i25-Fix: full-dock label kommt aus .lb-span → globales .ab::after (data-lb) hier killen, sonst doppelt */
.tw-dock--full .ab::after{content:none}
.tw-dock-more .ab{height:50px}
.tw-dock-more .ab .ic{font-size:1.15rem}
.ab-more{border-style:dashed!important;opacity:.85}
.ab-more.open{opacity:1;border-color:var(--accent)!important}
/* action-modal (legacy popup) wird redundant — detail-actions hat schon den full set */
.action-modal{display:none!important}
/* Dock auf Ring-Karten + Bento-Kacheln entfernt (Dee 2026-05-23: wearMe&Co waren
   15× geklont). Karten = Bild+Name, Tap öffnet Detail mit vollem Dock. */

/* hero-actions: premium action-cards (icon + data-lb label, glass, tinted shadow) */
#hero-actions .tw-dock--compact{gap:10px;margin-top:1.2rem}
#hero-actions .tw-dock--compact button{flex-direction:column;justify-content:center;gap:5px;height:66px;border-radius:14px;border:1px solid var(--glass-border);background:linear-gradient(160deg,rgba(255,255,255,.07),rgba(255,255,255,.02));font-size:1.7rem;box-shadow:0 10px 30px rgba(8,12,24,.45),inset 0 1px 0 rgba(255,255,255,.06);transition:transform .18s cubic-bezier(.34,1.56,.64,1),border-color .18s,background .18s}
#hero-actions .tw-dock--compact .ab::after{content:attr(data-lb);position:static;font-size:.72rem;font-weight:720;letter-spacing:.05px;text-transform:none;color:var(--muted);white-space:nowrap;max-width:100%;overflow:hidden;text-overflow:clip;padding:0}
#hero-actions .tw-dock--compact button:hover{transform:translateY(-4px);border-color:rgba(125,211,252,.5);background:linear-gradient(160deg,rgba(125,211,252,.14),rgba(255,255,255,.03))}
#hero-actions .tw-dock--compact .ab:hover::after{color:var(--text)}
#hero-actions .tw-dock--compact button:active{transform:translateY(-1px) scale(.97)}
@media(max-width:640px){#hero-actions .tw-dock--compact button{height:58px;font-size:1.35rem}}

/* hero-actions inside joi-hero — inline row */
.joi-hero #hero-actions{margin-top:.7rem}

/* detail-actions inside character popup */
#detail-actions.tw-dock--full,#detail-actions .tw-dock{width:100%}
#action-grid-full.tw-dock--full,#action-grid-full .tw-dock{width:100%}
.bento-hero.bento--final{grid-template-columns:repeat(2,1fr);grid-template-rows:repeat(4,1fr)}
.bento-hint{position:absolute;right:18px;bottom:14px;font-size:0.72rem;letter-spacing:2px;text-transform:uppercase;color:rgba(255,255,255,0.8);z-index:5;pointer-events:none;animation:bhint 2s ease-in-out infinite}
@keyframes bhint{0%,100%{opacity:0.55}50%{opacity:1}}
/* Mobile + Tablet + kleine Desktops: bento weg — Carousel ist primary UI.
   Nur richtige Desktops (>=1440px) bekommen das Scrubbed-Bento-Hero. */
@media (max-width:1439px){
  .bento-wrap{display:none}
}
