/* =========================================================================
   Dr. Mailo® — Playable Explainer (Phaser v2) · UI-Stil (HTML-Overlay)
   ========================================================================= */
:root {
  --ink:#1a1712; --ink-soft:#2a2620; --cream:#f4ecd8; --cream-dim:#e6dcc2;
  --paper:#fbf6ea; --gold:#e0a33e; --gold-deep:#c8852a; --teal:#3a9d92; --teal-deep:#2c7a71;
  --danger:#d2563f; --shadow:0 10px 40px rgba(0,0,0,.45); --radius:16px;
  --font:"Segoe UI",system-ui,-apple-system,"Helvetica Neue",Arial,sans-serif;
  --serif:"Iowan Old Style","Palatino Linotype",Palatino,Georgia,serif;
}
* { box-sizing:border-box; margin:0; padding:0; -webkit-tap-highlight-color:transparent; }
html,body { height:100%; width:100%; background:var(--ink); color:var(--cream); font-family:var(--font); overflow:hidden; overscroll-behavior:none; }
button { font-family:inherit; cursor:pointer; border:none; }
.hidden { display:none !important; }

#stage { position:relative; width:100vw; height:100svh; height:100dvh; margin:0 auto; overflow:hidden; background:radial-gradient(120% 120% at 50% 0%,#241f18 0%,#120f0b 100%); touch-action:none; user-select:none; }
#game { position:absolute; inset:0; }
#game canvas { display:block; width:100% !important; height:100% !important; image-rendering:high-quality; image-rendering:-webkit-optimize-contrast; }
#titlebg { image-rendering:high-quality; }

#titlebg { position:absolute; inset:0; z-index:5; background:center/cover no-repeat; filter:brightness(.9); }
#titlebg::after { content:""; position:absolute; inset:0; background:rgba(10,8,6,.45); }

#hud { position:absolute; top:calc(env(safe-area-inset-top,0px) + 10px); left:calc(env(safe-area-inset-left,0px) + 12px); right:calc(env(safe-area-inset-right,0px) + 12px); display:flex; align-items:flex-start; justify-content:space-between; gap:12px; z-index:30; pointer-events:none; }
#meter { display:flex; gap:6px; flex:1; max-width:560px; background:rgba(18,15,11,.55); padding:8px; border-radius:12px; backdrop-filter:blur(6px); border:1px solid rgba(244,236,216,.12); }
.meter-seg { flex:1; }
.meter-seg span { display:block; height:8px; border-radius:6px; background:rgba(244,236,216,.16); overflow:hidden; position:relative; }
.meter-seg span::after { content:""; position:absolute; inset:0; width:var(--fill,0%); background:linear-gradient(90deg,var(--teal),var(--gold)); border-radius:6px; transition:width .9s cubic-bezier(.22,1,.36,1); }
.meter-seg.active span { box-shadow:0 0 0 1px var(--gold) inset; }
.meter-seg label { display:block; font-size:9px; letter-spacing:.04em; text-transform:uppercase; opacity:.6; margin-top:4px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
#hud-right { display:flex; align-items:center; gap:10px; pointer-events:auto; }
#charname { font-size:13px; opacity:.85; font-weight:600; text-shadow:0 1px 4px #000; }
#muteBtn { background:rgba(18,15,11,.55); color:var(--cream); width:38px; height:38px; border-radius:10px; font-size:16px; border:1px solid rgba(244,236,216,.12); backdrop-filter:blur(6px); }

#hint { position:absolute; left:50%; transform:translateX(-50%); top:calc(env(safe-area-inset-top,0px) + 64px); z-index:25; pointer-events:none; background:rgba(18,15,11,.72); color:var(--cream); padding:9px 16px; border-radius:999px; font-size:13px; border:1px solid rgba(224,163,62,.4); box-shadow:var(--shadow); max-width:90%; text-align:center; animation:pop .4s ease both; }

#dialogue { position:absolute; z-index:40; left:50%; transform:translateX(-50%); bottom:calc(env(safe-area-inset-bottom,0px) + 14px); width:min(680px,calc(100vw - 24px)); background:linear-gradient(180deg,var(--paper),var(--cream-dim)); color:var(--ink); border-radius:var(--radius); box-shadow:var(--shadow); border:1px solid rgba(0,0,0,.15); display:grid; grid-template-columns:72px 1fr; grid-template-areas:"portrait body" "portrait controls"; gap:4px 14px; padding:14px 16px; animation:rise .28s cubic-bezier(.22,1,.36,1) both; }
#dlg-portrait { grid-area:portrait; width:72px; height:72px; border-radius:12px; background:#d9cdb0 center/cover no-repeat; border:2px solid var(--gold); box-shadow:0 4px 12px rgba(0,0,0,.25); align-self:start; }
#dlg-body { grid-area:body; }
#dlg-name { font-weight:800; color:var(--gold-deep); font-size:14px; letter-spacing:.02em; margin-bottom:3px; }
#dlg-text { font-family:var(--serif); font-size:17px; line-height:1.45; min-height:2.6em; }
#dlg-controls { grid-area:controls; display:flex; justify-content:flex-end; gap:8px; margin-top:8px; }
#dlg-controls button { font-size:14px; padding:10px 18px; border-radius:10px; font-weight:700; min-height:44px; }
#dlg-skip { background:transparent; color:var(--ink); opacity:.55; }
#dlg-next { background:var(--ink); color:var(--cream); }
#dlg-next:active { transform:translateY(1px); }

#overlay { position:absolute; inset:0; z-index:60; display:flex; align-items:center; justify-content:center; padding:calc(env(safe-area-inset-top,0px) + 20px) 18px calc(env(safe-area-inset-bottom,0px) + 20px); background:rgba(10,8,6,.55); backdrop-filter:blur(7px); overflow-y:auto; }
.panel { width:min(560px,100%); background:linear-gradient(180deg,var(--paper),var(--cream-dim)); color:var(--ink); border-radius:22px; box-shadow:var(--shadow); border:1px solid rgba(0,0,0,.12); padding:26px 24px; text-align:center; animation:rise .3s cubic-bezier(.22,1,.36,1) both; max-height:100%; }
.panel .eyebrow { font-size:12px; letter-spacing:.18em; text-transform:uppercase; color:var(--gold-deep); font-weight:800; }
.panel h1 { font-family:var(--serif); font-size:clamp(26px,7vw,40px); line-height:1.05; margin:6px 0 4px; }
.panel h2 { font-family:var(--serif); font-size:clamp(20px,5.5vw,28px); margin:4px 0 10px; }
.panel p { font-size:15px; line-height:1.5; opacity:.85; margin:8px 0; }
.panel .lead { font-size:16px; }
.btn { display:inline-flex; align-items:center; justify-content:center; gap:8px; background:var(--ink); color:var(--cream); font-size:16px; font-weight:800; padding:14px 26px; border-radius:12px; box-shadow:0 6px 18px rgba(0,0,0,.25); margin-top:6px; transition:transform .08s ease; min-height:48px; touch-action:manipulation; }
.btn:active { transform:translateY(1px); }
.btn--gold { background:linear-gradient(180deg,var(--gold),var(--gold-deep)); color:#1a1712; }
.btn--teal { background:linear-gradient(180deg,var(--teal),var(--teal-deep)); color:#fff; }
.btn--ghost { background:transparent; color:var(--ink); opacity:.7; box-shadow:none; font-weight:700; font-size:14px; }
.btn-row { display:flex; flex-direction:column; gap:10px; align-items:center; margin-top:16px; }
.linkline { margin-top:14px; font-size:13px; opacity:.65; }
.linkline a { color:var(--gold-deep); font-weight:700; }

.char-grid { display:grid; grid-template-columns:1fr 1fr; gap:14px; margin:18px 0 4px; }
.char-card { background:var(--paper); border:2px solid transparent; border-radius:16px; padding:12px 10px 14px; text-align:center; transition:transform .1s,border-color .15s,box-shadow .15s; box-shadow:0 3px 10px rgba(0,0,0,.1); }
.char-card:active { transform:scale(.98); }
.char-card.selected { border-color:var(--gold); box-shadow:0 6px 20px rgba(224,163,62,.35); }
.char-card .pic { width:100%; aspect-ratio:1; border-radius:12px; background:#ddd1b4 center/contain no-repeat; }
.char-card .nm { font-weight:800; font-size:14px; margin-top:8px; }
.char-card .rl { font-size:11px; opacity:.6; }

.choice-list { display:flex; flex-direction:column; gap:9px; margin:16px 0 4px; text-align:left; }
.choice { display:flex; align-items:center; gap:12px; background:var(--paper); border:1.5px solid rgba(0,0,0,.1); border-radius:12px; padding:13px 15px; font-size:14.5px; font-weight:600; color:var(--ink); transition:border-color .15s,transform .08s; }
.choice:active { transform:scale(.99); }
.choice .ico { font-size:20px; }

.bloom { animation:bloomflash 1.2s ease both; }
@keyframes bloomflash { 0%{filter:brightness(.7);} 60%{filter:brightness(1.15);} 100%{filter:brightness(1);} }
@keyframes pop { from{opacity:0; transform:translate(-50%,-8px);} }
@keyframes rise { from{opacity:0; transform:translateY(16px);} }

#loader { position:absolute; inset:0; z-index:80; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:14px; background:var(--ink); color:var(--cream-dim); }
#loader p { font-size:13px; letter-spacing:.1em; text-transform:uppercase; opacity:.6; }
.spinner { width:42px; height:42px; border-radius:50%; border:3px solid rgba(244,236,216,.2); border-top-color:var(--gold); animation:spin 1s linear infinite; }
@keyframes spin { to{ transform:rotate(360deg);} }

/* ---- Mini-Interaktionen ---- */
#overlay.light { background:rgba(10,8,6,.28); backdrop-filter:blur(2px); align-items:flex-end; }
#overlay.light .panel { margin-bottom:max(env(safe-area-inset-bottom,0px),12px); }
.panel.mini { width:min(600px,100%); }
.mini-stat { margin-top:14px; font-weight:800; color:var(--teal-deep); background:#eafaf6; border:1px solid rgba(58,157,146,.35); border-radius:12px; padding:10px 14px; animation:rise .3s ease both; }
.mini-grid { display:grid; grid-template-columns:1fr 1fr; gap:10px; margin:16px 0 4px; }
.mini-item { position:relative; display:flex; align-items:center; gap:10px; text-align:left; background:var(--paper); border:1.5px solid rgba(0,0,0,.12); border-radius:12px; padding:14px; font-size:14px; font-weight:700; color:var(--ink); transition:transform .1s,border-color .2s,background .3s; overflow:hidden; }
.mini-item:active { transform:scale(.97); }
.mini-item .mi-ico { font-size:20px; transition:opacity .25s; }
.mini-item .mi-check { position:absolute; right:12px; opacity:0; color:var(--teal-deep); font-weight:800; transform:translateX(8px); transition:.3s; }
.mini-item.done { border-color:var(--teal); background:#eafaf6; }
.mini-item.done .mi-label { opacity:.5; text-decoration:line-through; }
.mini-item.done .mi-ico { opacity:.3; }
.mini-item.done .mi-check { opacity:1; transform:translateX(0); }
.search-box { display:flex; gap:8px; align-items:center; margin-top:8px; }
.sb-q { flex:1; background:#fff; border:1.5px solid rgba(0,0,0,.15); border-radius:12px; padding:12px 14px; font-weight:700; color:var(--ink); }
.sb-go { padding:12px 18px; }
#mi-res .res-row { margin-top:10px; background:#eafaf6; border:1px solid var(--teal); border-radius:10px; padding:11px 14px; font-weight:700; color:var(--teal-deep); animation:rise .3s ease both; }
#mi-res .res-note { margin-top:8px; font-size:13px; font-style:italic; opacity:.8; }
.wf-row { display:flex; align-items:center; justify-content:center; gap:4px; margin:20px 0 4px; flex-wrap:wrap; }
.wf-node { display:flex; flex-direction:column; align-items:center; gap:3px; position:relative; background:var(--paper); border:2px solid rgba(0,0,0,.12); border-radius:14px; padding:12px 10px; min-width:92px; font-size:12.5px; font-weight:800; color:var(--ink); transition:transform .1s,border-color .2s,box-shadow .2s; }
.wf-node .wf-ico { font-size:24px; }
.wf-node .wf-num { position:absolute; top:-8px; right:-8px; width:20px; height:20px; border-radius:50%; background:#cfc6ad; color:var(--ink); font-size:11px; display:grid; place-items:center; opacity:.5; }
.wf-node.done { border-color:var(--teal); box-shadow:0 4px 14px rgba(58,157,146,.3); }
.wf-node.done .wf-num { background:var(--teal); color:#fff; opacity:1; }
.wf-node.shake { animation:shake .4s; border-color:var(--danger); }
@keyframes shake { 0%,100%{transform:translateX(0)} 25%{transform:translateX(-6px)} 75%{transform:translateX(6px)} }
.wf-link { width:22px; height:4px; border-radius:4px; background:rgba(0,0,0,.12); flex:none; transition:background .3s; }
.wf-link.lit { background:var(--teal); }
.wf-link.flow { background:linear-gradient(90deg,var(--teal),var(--gold),var(--teal)); background-size:200% 100%; animation:flow 1s linear infinite; }
@keyframes flow { to{ background-position:200% 0; } }
.inbox { display:flex; flex-direction:column; gap:7px; margin:14px 0 4px; text-align:left; max-height:38vh; overflow-y:auto; }
.inbox-row { display:grid; grid-template-columns:88px 1fr auto; align-items:center; gap:8px; background:var(--paper); border:1.5px solid rgba(0,0,0,.1); border-radius:10px; padding:10px 12px; font-size:13px; transition:background .3s,border-color .3s,transform .1s; }
.inbox-row:active { transform:scale(.99); }
.ib-from { font-weight:800; color:var(--ink); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.ib-subj { opacity:.8; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.ib-status { font-size:11px; font-weight:800; opacity:.55; white-space:nowrap; }
.ib-status.manual { color:var(--gold-deep); opacity:1; }
.ib-status.auto { color:var(--teal-deep); opacity:1; }
.inbox-row.handled { border-color:var(--gold); background:#fff8e9; }
.inbox-row.auto { border-color:var(--teal); background:#eafaf6; animation:rise .3s ease both; }
.agent-pop { display:flex; align-items:center; gap:12px; text-align:left; margin:14px 0 2px; background:linear-gradient(180deg,#eafaf6,#dff5ef); border:1.5px solid var(--teal); border-radius:14px; padding:12px 14px; animation:rise .35s cubic-bezier(.22,1,.36,1) both; }
.agent-face { width:56px; height:56px; flex:none; border-radius:12px; background:center/contain no-repeat; filter:drop-shadow(0 0 8px rgba(224,163,62,.55)); animation:floaty 2.4s ease-in-out infinite; }
@keyframes floaty { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-5px)} }
.agent-msg { font-size:13.5px; line-height:1.4; color:var(--ink); }
.agent-msg strong { display:block; color:var(--teal-deep); font-size:13px; margin-bottom:2px; }
.cta-form { display:flex; flex-direction:column; gap:12px; margin-top:16px; text-align:left; }
.cta-form input[type=email] { width:100%; padding:14px 16px; font-size:16px; border-radius:12px; border:1.5px solid rgba(0,0,0,.18); background:#fff; color:var(--ink); }
.consent { display:flex; gap:10px; align-items:flex-start; font-size:12.5px; opacity:.85; line-height:1.4; }
.consent input { margin-top:2px; width:18px; height:18px; flex:none; }
.consent a { color:var(--teal-deep); font-weight:700; }
.cta-error { color:var(--danger); font-size:13px; font-weight:700; min-height:1em; }
.hp { position:absolute; left:-9999px; width:1px; height:1px; overflow:hidden; }

/* KEIN max-width auf Desktop — das Spielfeld füllt den vollen Bildschirm
   (Phaser-Camera-Cover-Zoom sorgt für sauberes Bild ohne Letterbox). */

/* ============ MOBILE-HÄRTUNGEN ============ */
@media (max-width:480px) {
  /* HUD-Labels schrumpfen — sonst überlappen sie */
  .meter-seg label { font-size:8px; letter-spacing:0; }
  #meter { gap:4px; padding:6px; }
  #charname { display:none; }   /* Name als HUD-Element raus, Platz sparen */
  /* Dialogbox mehr Platz für Text auf schmalen Screens */
  #dialogue { grid-template-columns:56px 1fr; padding:12px 14px; }
  #dlg-portrait { width:56px; height:56px; border-radius:10px; }
  #dlg-text { font-size:15.5px; }
  /* Panel-Padding kompakter */
  .panel { padding:22px 18px; }
  .panel h1 { line-height:1.1; }
  /* Char-Cards: Bild kleiner damit beide auf einen Bildschirm */
  .char-card { padding:8px 6px 10px; }
  .char-grid { gap:10px; }
  /* Mini-Item-Grid: bei sehr schmalem Display 1 Spalte */
  .mini-grid { grid-template-columns:1fr; }
  /* CTA-Form: iOS-Zoom-on-focus verhindern (font-size>=16px steht schon) */
  .cta-form input[type=email] { font-size:16px; }
}

/* Landscape auf Smartphone (kurze Höhe) — Dialog nicht über halben Bildschirm */
@media (max-height:500px) and (orientation:landscape) {
  #dialogue { bottom:8px; padding:8px 14px; }
  #dlg-text { font-size:14px; line-height:1.3; min-height:1.5em; }
  #dlg-portrait { width:48px; height:48px; }
  #hud { top:6px; }
  .panel { padding:16px 18px; }
  .panel p { font-size:13.5px; margin:4px 0; }
}
