/* =====================================================================
   POM in 90 Sekunden — Demo styles
   Brand: Olive #8BA83A · Pink #D81B60 · Navy #0F172A · Outfit + Inter
   Mobile-first. Pure static. No external requests (fonts self-hosted).
   ===================================================================== */

/* ---------- Fonts (self-hosted woff2, GDPR-clean) ---------- */
@font-face{font-family:Outfit;font-style:normal;font-weight:600;font-display:swap;src:url(assets/fonts/outfit-600.woff2) format('woff2')}
@font-face{font-family:Outfit;font-style:normal;font-weight:700;font-display:swap;src:url(assets/fonts/outfit-700.woff2) format('woff2')}
@font-face{font-family:Outfit;font-style:normal;font-weight:800;font-display:swap;src:url(assets/fonts/outfit-800.woff2) format('woff2')}
@font-face{font-family:Inter;font-style:normal;font-weight:400;font-display:swap;src:url(assets/fonts/inter-400.woff2) format('woff2')}
@font-face{font-family:Inter;font-style:normal;font-weight:500;font-display:swap;src:url(assets/fonts/inter-500.woff2) format('woff2')}
@font-face{font-family:Inter;font-style:normal;font-weight:600;font-display:swap;src:url(assets/fonts/inter-600.woff2) format('woff2')}
@font-face{font-family:Inter;font-style:normal;font-weight:700;font-display:swap;src:url(assets/fonts/inter-700.woff2) format('woff2')}

/* ---------- Tokens ---------- */
:root{
  --olive:#8BA83A; --olive-d:#7a9633; --olive-dd:#69822b;
  --pink:#D81B60;
  --navy:#0F172A;
  --bg:#F8FAFC; --bg2:#FDFDFD;
  --s100:#F1F5F9; --s200:#E2E8F0; --s300:#CBD5E1; --s400:#94A3B8; --s500:#64748B; --s600:#475569;
  --ink:#0F172A;
  --display:Outfit, ui-sans-serif, system-ui, sans-serif;
  --body:Inter, ui-sans-serif, system-ui, sans-serif;
  --shadow-card:0 1px 2px rgba(15,23,42,.04), 0 12px 30px -12px rgba(15,23,42,.18);
  --shadow-frame:0 30px 70px -28px rgba(15,23,42,.45), 0 8px 24px -12px rgba(15,23,42,.30);
  --shadow-olive:0 10px 22px -8px rgba(139,168,58,.55);
  --cam-ease:cubic-bezier(.45,.05,.2,1);
}

*{box-sizing:border-box}
html,body{height:100%;margin:0}
body{
  font-family:var(--body);
  color:var(--ink);
  background:#EAF0E6;
  background:
    radial-gradient(120% 80% at 50% -10%, #F4F8EF 0%, #EFF3EA 40%, #E7ECE2 100%);
  display:grid; place-items:center;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
  overflow:hidden;
}

/* ---------- Stage ---------- */
.demo{
  position:relative;
  width:100%;
  height:100dvh;
  overflow:hidden;
  background:
    radial-gradient(130% 90% at 50% 0%, #FFFFFF 0%, var(--bg2) 36%, var(--bg) 100%);
  isolation:isolate;
  user-select:none;
  -webkit-tap-highlight-color:transparent;
}
@media (min-width:700px){
  .demo{
    width:min(430px, 94vw);
    height:min(932px, 94dvh);
    border-radius:30px;
    box-shadow:0 50px 120px -40px rgba(15,23,42,.5), 0 0 0 1px rgba(15,23,42,.05);
  }
}

/* ---------- Scenes (crossfade) ---------- */
.scene{
  position:absolute; inset:0;
  opacity:0; visibility:hidden;
  transition:opacity .5s ease, visibility .5s ease;   /* trailer pace — snappier cuts */
  z-index:1;
  display:flex; align-items:center; justify-content:center;
}
.scene.is-active{opacity:1; visibility:visible; z-index:2}
.scene.is-active.is-front{z-index:3}

/* ---------- Camera + frames ---------- */
.camera{
  position:absolute; inset:0;
  transform-origin:0 0;
  transform:translate(0,0) scale(1);
  transition:transform var(--dur,3.2s) var(--cam-ease);
  will-change:transform;
}
.frame{ position:absolute; top:0; left:0; }

/* Browser window (editor / modal) */
.browser{ border-radius:18px; overflow:hidden; box-shadow:var(--shadow-frame); background:#fff; }
.browser__bar{
  height:64px; background:linear-gradient(#F3F5F7,#EBEEF2);
  border-bottom:1px solid #E2E6EB;
  display:flex; align-items:center; gap:18px; padding:0 22px;
}
.browser__dots{display:flex; gap:11px}
.browser__dots i{width:15px;height:15px;border-radius:50%;display:block}
.browser__dots i:nth-child(1){background:#FF5F57}
.browser__dots i:nth-child(2){background:#FEBC2E}
.browser__dots i:nth-child(3){background:#28C840}
.browser__addr{
  flex:1; max-width:640px; margin:0 auto; height:38px;
  background:#fff; border:1px solid #E2E6EB; border-radius:10px;
  display:flex; align-items:center; justify-content:center; gap:9px;
  font-family:var(--body); font-size:18px; color:var(--s500); font-weight:500;
}
.browser__addr svg{width:15px;height:15px;color:var(--olive)}
.browser__screen{ position:relative; display:block; }
.browser__screen>img{ position:absolute; inset:0; width:100%; height:100%; display:block; object-fit:cover; }
.browser__screen>img.layer-b{opacity:0; transition:opacity 1.1s ease}

/* ---------- Cursor + press glow (live, in frame coords) ---------- */
.cursor{
  position:absolute; top:0; left:0; width:46px; height:46px;
  margin:-6px 0 0 -6px; z-index:40; opacity:0;
  transform:translate(0,0) scale(1); transform-origin:6px 6px;
  transition:transform 1.05s cubic-bezier(.5,.08,.25,1), opacity .4s ease;
  filter:drop-shadow(0 4px 6px rgba(15,23,42,.35));
  pointer-events:none;
}
.cursor.is-press{transition:transform .14s ease}
.cursor svg{width:100%;height:100%;display:block}

.glow{
  position:absolute; top:0; left:0; z-index:35;
  width:120px; height:120px; margin:-60px 0 0 -60px; border-radius:999px;
  background:radial-gradient(circle, rgba(139,168,58,.45) 0%, rgba(139,168,58,0) 65%);
  opacity:0; transform:translate(0,0) scale(.5); pointer-events:none;
}
.glow.is-on{animation:glowpop .7s ease-out}
@keyframes glowpop{
  0%{opacity:0;transform:translate(var(--gx),var(--gy)) scale(.4)}
  35%{opacity:1;transform:translate(var(--gx),var(--gy)) scale(1)}
  100%{opacity:0;transform:translate(var(--gx),var(--gy)) scale(1.5)}
}

/* press ripple on a target rectangle (button feedback) */
.press-rect{
  position:absolute; z-index:34; border-radius:14px;
  box-shadow:0 0 0 0 rgba(139,168,58,.5); opacity:0; pointer-events:none;
}
.press-rect.is-on{animation:pressrect .55s ease-out}
@keyframes pressrect{
  0%{opacity:.9; box-shadow:0 0 0 0 rgba(139,168,58,.55); transform:scale(.985)}
  100%{opacity:0; box-shadow:0 0 0 16px rgba(139,168,58,0); transform:scale(1)}
}

/* plan card (inserted by JS) */
.pcard{display:block;position:relative;opacity:1;background:#fff;border:1px solid #EDF1F5;border-radius:15px;box-shadow:var(--shadow-card);padding:10px}
.pcard__top{display:flex;align-items:center;gap:9px}
.pcnum{width:18px;height:18px;border-radius:999px;background:#F1F5F9;color:var(--s500);font-weight:700;font-size:10.5px;display:grid;place-items:center;flex:0 0 auto}
.pcthumbs{display:flex;gap:3px;flex:0 0 auto}
.pcthumbs img{width:36px;height:36px;border-radius:8px;object-fit:cover;background:#E9EEF3;display:block}
.pctitle{flex:1;min-width:0}
.pctitle b{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;font-weight:700;font-size:14px;line-height:1.24;color:var(--navy)}
.pcard__bot{display:flex;align-items:center;gap:8px;margin-top:9px;padding-top:9px;border-top:1px solid #F1F5F9}
.pcdos{display:inline-flex;align-items:center;gap:5px;color:var(--olive-d);font-weight:600;font-size:12px}
.pcdos i{width:7px;height:7px;border-radius:2px;background:var(--olive);display:inline-block}
.pcghost{margin-left:auto;display:flex;gap:4px}
.pcghost i{width:26px;height:26px;border-radius:7px;background:#F5F7FA;color:var(--s400);display:grid;place-items:center}
.pcghost i svg{width:14px;height:14px}
.pcedit{display:inline-flex;align-items:center;gap:5px;background:var(--navy);color:#fff;border-radius:9px;padding:7px 12px;font-weight:700;font-size:12.5px}
.pcedit svg{width:13px;height:13px}

/* card enter (spring) + impact flash — cards rest VISIBLE (opacity:1 base);
   the enter animation is a pure spring (no 'both' fill → never leaves a card stuck invisible),
   and the flash lives on ::after so it can't override the enter animation. */
.pcard.enter{animation:pcardIn .55s cubic-bezier(.2,1.35,.35,1)}
@keyframes pcardIn{
  0%{transform:translateY(-16px) scale(.9)}
  55%{transform:translateY(2px) scale(1.02)}
  100%{transform:none}
}
.pcard.flash::after{content:""; position:absolute; inset:0; border-radius:15px; pointer-events:none;
  animation:pcardFlash .6s ease-out}
@keyframes pcardFlash{0%{box-shadow:0 0 0 3px rgba(139,168,58,.6),0 14px 30px -12px rgba(139,168,58,.5)}100%{box-shadow:0 0 0 0 rgba(139,168,58,0)}}

/* fly chip (screen space) — pops up, then tosses toward the plan */
.fly{position:fixed;z-index:80;border-radius:14px;overflow:hidden;pointer-events:none;
  box-shadow:0 22px 44px -16px rgba(15,23,42,.5);will-change:transform,filter,opacity;background:#fff;
  transform-origin:center}
.fly img{width:100%;height:100%;object-fit:cover;display:block}
.fly.go{animation:flyaway var(--fdur,.66s) cubic-bezier(.42,0,.2,1) forwards}
@keyframes flyaway{
  0%{transform:translate(0,0) scale(1) rotate(0);filter:blur(0);opacity:1}
  18%{transform:translate(calc(var(--tx)*.05), calc(var(--ty)*.05 - 12px)) scale(1.1) rotate(-3deg);filter:blur(0);opacity:1}
  100%{transform:translate(var(--tx),var(--ty)) scale(.2) rotate(11deg);filter:blur(2.5px);opacity:0}
}

/* +1 flash chip (screen space) */
.plusflash{position:fixed;z-index:82;display:inline-flex;align-items:center;gap:6px;
  background:var(--olive);color:#fff;font-family:var(--display);font-weight:800;font-size:15px;
  padding:7px 13px;border-radius:999px;box-shadow:0 12px 26px -10px rgba(139,168,58,.7);
  opacity:0;pointer-events:none;transform:translate(-50%,-50%) scale(.4)}
.plusflash.pop{animation:plusPop .7s cubic-bezier(.2,1.4,.4,1) forwards}
@keyframes plusPop{0%{opacity:0;transform:translate(-50%,-50%) scale(.4)}
  35%{opacity:1;transform:translate(-50%,-120%) scale(1.05)}
  100%{opacity:0;transform:translate(-50%,-210%) scale(1)}}

/* ===================================================================
   SCENE: EDITOR — mobile configurator (Beats 1+2)
   phone frame + browser address bar + configurator, fills the portrait
   stage 1:1 (no Ken-Burns → nothing clips left/right)
   =================================================================== */
.edphone{position:relative; height:min(94%, 848px); aspect-ratio:390/844; width:auto; flex:0 0 auto;
  background:#0B0E13; border-radius:44px; padding:10px; box-shadow:var(--shadow-frame), inset 0 0 0 2px #20262F}
.edphone__screen{position:relative; height:100%; width:100%; border-radius:34px; overflow:hidden;
  background:var(--bg); display:flex; flex-direction:column; font-family:var(--body); color:var(--navy)}
.edbar{height:34px; flex:0 0 auto; background:#EBEEF2; border-bottom:1px solid #E2E6EB; display:flex;
  align-items:center; justify-content:center; gap:7px; font-size:12px; color:var(--s500); font-weight:500}
.edbar svg{width:12px; height:12px; color:var(--olive)}
.edtop{height:50px; flex:0 0 auto; background:#fff; border-bottom:1px solid #EEF2F6; display:flex;
  align-items:center; justify-content:space-between; padding:0 18px}
.edtop__logo{height:24px; width:auto; display:block}
.edtop__burger{display:flex; flex-direction:column; gap:4px}
.edtop__burger i{width:22px; height:2px; border-radius:2px; background:var(--navy); display:block}
.edseg{display:flex; gap:6px; padding:11px 13px; background:#fff; border-bottom:1px solid #EEF2F6; flex:0 0 auto}
.edseg__t{flex:1; text-align:center; padding:10px; border-radius:11px; font-weight:700; font-size:13.5px; color:var(--s500); background:#F1F5F9;
  transition:background .3s ease, color .3s ease, box-shadow .3s ease}
.edseg__t.on{background:var(--olive); color:#fff; box-shadow:var(--shadow-olive)}

.edview{flex:1 1 auto; overflow-y:auto; overflow-x:hidden; padding:15px 14px 18px}
.edview[hidden]{display:none}

.edplan__head{margin-bottom:12px}
.edplan__h1{font-family:var(--display); font-weight:800; font-size:26px; letter-spacing:-.02em; color:var(--navy); line-height:1}
.edplan__sub{font-size:12.5px; color:var(--s400); margin-top:5px}
.edcta{width:100%; display:inline-flex; align-items:center; justify-content:center; gap:9px; background:var(--olive); color:#fff;
  border:none; border-radius:14px; padding:14px; font-family:var(--body); font-weight:800; font-size:15.5px; box-shadow:var(--shadow-olive); margin-bottom:18px}
.edcta svg{width:18px; height:18px}

.edday{margin-bottom:8px}
.edday.is-hidden{display:none}
.edday__head{display:flex; align-items:center; gap:9px; margin:4px 0 11px}
.edbadge{width:30px; height:32px; border-radius:9px; display:grid; place-items:center; color:#fff; font-weight:900; font-size:15px; flex:0 0 auto}
.edbadge.o{background:var(--olive)} .edbadge.n{background:var(--navy)}
.edday__t{font-family:var(--display); font-weight:800; font-size:18px; letter-spacing:-.01em; white-space:nowrap; flex:0 0 auto}
.edday[data-day="1"] .edday__t{color:var(--olive-dd)} .edday[data-day="2"] .edday__t{color:var(--navy)}
.edday__c{font-size:11.5px; color:var(--s400); white-space:nowrap; flex:0 0 auto}
.edday__acts{margin-left:auto; display:flex; gap:5px}
.edday__acts .eda{width:26px; height:26px; border-radius:8px; border:1px solid #E7ECF1; background:#fff; color:var(--s400);
  display:grid; place-items:center; font-size:12px; font-style:normal; line-height:1}

/* library (Bibliothek view) */
.edlib__search{margin-bottom:10px; padding:12px 13px; background:#fff; border:1px solid #EEF2F6; border-radius:11px; color:var(--s400); font-size:13px; display:flex; align-items:center; gap:8px}
.edlib__search svg{width:15px; height:15px; color:var(--olive)}
.edlib__filters{display:flex; flex-wrap:wrap; gap:5px; margin-bottom:12px}   /* wraps to 2 rows — all 9 filters fit even on narrow phone frames */
.edlib__filters span{white-space:nowrap; padding:5px 10px; border-radius:999px; background:#F1F5F9; color:var(--s500); font-size:11.5px; font-weight:600}
.edlib__filters .on{background:var(--olive); color:#fff}
.ltile{display:flex; align-items:center; gap:11px; background:#fff; border:1px solid #EDF1F5; border-radius:14px; box-shadow:var(--shadow-card); padding:9px; margin-bottom:9px}
.ltile .lt{position:relative; width:58px; height:48px; border-radius:9px; overflow:hidden; flex:0 0 auto; background:#E9EEF3}
.ltile .lt img{width:100%; height:100%; object-fit:cover; display:block}
.ltile .lt .vb{position:absolute; bottom:4px; left:4px; background:rgba(15,23,42,.8); color:#fff; font-size:7.5px; font-weight:700; letter-spacing:.04em; padding:1px 4px; border-radius:4px}
.ltile .ln{flex:1; min-width:0}
.ltile .ln b{display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; font-weight:700; font-size:13.5px; line-height:1.25; color:var(--navy)}
.ltile .ladd{flex:0 0 auto; background:var(--olive); color:#fff; border:none; border-radius:9px; padding:9px 11px; font-family:var(--body); font-weight:800; font-size:11px; letter-spacing:.02em; box-shadow:var(--shadow-olive); transition:transform .12s ease, filter .12s ease}
.ltile.press .ladd{transform:scale(.94); filter:brightness(.92)}

/* main app bottom nav */
.edbtm{flex:0 0 auto; height:56px; background:#fff; border-top:1px solid #EEF2F6; display:flex}
.edbtm a{flex:1; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:3px; color:var(--s400); font-size:10px; font-weight:700; letter-spacing:.04em}
.edbtm a.on{color:var(--olive)}
.edbtm svg{width:20px; height:20px}

/* ===================================================================
   SCENE: QR (Beat 3a)
   =================================================================== */
.scene--qr{padding:24px}
.qr-wrap{position:relative; transform:translateY(34px) scale(.66); transition:transform .75s cubic-bezier(.2,1.45,.35,1); will-change:transform}
.qr-wrap.in{transform:translateY(0) scale(1)}                     /* rises + springs up on entry */
.qr-wrap.zoom{transform:scale(1.1); transition:transform 4.5s var(--cam-ease)}  /* (unused in trailer cut) */
.qr-wrap.out{transform:translateY(90px) scale(.32); opacity:0;   /* shrink + drop toward the phone */
  transition:transform .55s cubic-bezier(.5,0,.3,1), opacity .5s ease}
.qr-card{
  width:min(78vw, 340px); border-radius:26px; background:#fff;
  box-shadow:var(--shadow-frame); overflow:hidden; position:relative;
}
.qr-card img{width:100%; display:block}
.qr-card.ok{animation:qrok .55s ease-out}          /* "scanned!" success pulse */
@keyframes qrok{
  0%{box-shadow:var(--shadow-frame); transform:scale(1)}
  35%{box-shadow:0 0 0 5px rgba(139,168,58,.75), 0 0 46px rgba(139,168,58,.55), var(--shadow-frame); transform:scale(1.03)}
  100%{box-shadow:var(--shadow-frame); transform:scale(1)}
}
.qr-scan{
  position:absolute; left:8%; right:8%; height:18%;
  top:22%; border-radius:10px;
  background:linear-gradient(180deg, rgba(139,168,58,0) 0%, rgba(139,168,58,.30) 80%, rgba(139,168,58,.85) 100%);
  mix-blend-mode:multiply; opacity:0;
}
.qr-wrap.scan .qr-scan{animation:qrscan 1.15s cubic-bezier(.4,0,.3,1) forwards}  /* single fast sweep */
@keyframes qrscan{
  0%{opacity:0; transform:translateY(0)}
  12%{opacity:.9}
  88%{opacity:.9}
  100%{opacity:0; transform:translateY(150%)}
}

/* ===================================================================
   SCENE: PHONE (Beat 3b) — fully live UI
   =================================================================== */
.scene--phone{}
.phone{
  position:relative; height:min(92%, 800px); aspect-ratio:390/844;
  width:auto; min-width:0; min-height:0; flex:0 0 auto;
  background:#0B0E13; border-radius:46px; padding:11px;
  box-shadow:var(--shadow-frame), inset 0 0 0 2px #20262F;
  transform:scale(1.35); opacity:0;
  transition:opacity .4s ease, transform .6s cubic-bezier(.2,.85,.3,1), filter .55s ease;  /* zooms OUT — emerges from the QR portal-zoom */
}
.phone__screen,.papp__list,.papp__header,.exrow,.exrow .meta{min-width:0}
.scene--phone.is-active .phone{opacity:1; transform:scale(1)}
/* Transition A — camera pulls back off the patient phone as the €-chip lifts off */
.scene--phone.is-active .phone.pull{transform:translateY(-6px) scale(.9); opacity:.5; filter:brightness(.72) saturate(.9)}
.phone__island{
  position:absolute; top:20px; left:50%; transform:translateX(-50%);
  width:34%; height:26px; background:#000; border-radius:999px; z-index:5;
}
.phone__screen{
  position:relative; height:100%; width:100%; border-radius:36px; overflow:hidden;
  background:var(--bg); display:flex; flex-direction:column;
}
.papp__header{
  background:#10141B; color:#fff; padding:26px 20px 18px; flex:0 0 auto; position:relative;
}
.papp__brandrow{display:flex; align-items:center; gap:11px; position:relative;
  width:fit-content; max-width:100%;                 /* wrap logo+name only → spotlight ring fits on the right */
  margin:-6px; padding:6px; border-radius:16px; transform-origin:left center;
  transition:transform .55s cubic-bezier(.2,1.35,.35,1), box-shadow .55s ease, background .55s ease}
/* JOINT branding spotlight: logo + name together, dim + light pool + centred headline */
.papp__brandrow.spot{z-index:23; transform:scale(1.07); background:rgba(139,168,58,.14);
  box-shadow:0 0 0 2.5px rgba(139,168,58,.95), 0 0 55px 6px rgba(139,168,58,.6), 0 16px 40px -10px rgba(0,0,0,.65)}
.pdim{position:absolute; inset:0; z-index:20; background:rgba(9,13,20,.82); opacity:0; pointer-events:none; transition:opacity .5s ease}
.pdim.on{opacity:1}
.pspot{position:absolute; left:0; right:0; top:-20px; height:200px; z-index:21; opacity:0; pointer-events:none; transition:opacity .55s ease;
  background:radial-gradient(56% 72% at 27% 52%, rgba(255,255,255,.18), rgba(255,255,255,0) 72%),
             radial-gradient(62% 82% at 27% 52%, rgba(168,198,90,.26), rgba(168,198,90,0) 74%)}
.pspot.on{opacity:1}
.pheadline{position:absolute; z-index:24; left:20px; right:20px; top:200px; text-align:center; pointer-events:none}
.pheadline .l{font-family:var(--display); font-weight:800; font-size:36px; line-height:1.12; letter-spacing:-.02em; color:#fff}
.pheadline .l .g{color:#a8c65a}
.pheadline .w{display:inline-block; opacity:0; transform:translateY(16px) scale(.8);
  transition:opacity .4s ease, transform .55s cubic-bezier(.2,1.5,.35,1)}
.pheadline.on .w{opacity:1; transform:none}
.pheadline .l:nth-child(1) .w:nth-child(2){transition-delay:.12s}
.pheadline .l:nth-child(2) .w:nth-child(1){transition-delay:.24s}
.pheadline .l:nth-child(2) .w:nth-child(2){transition-delay:.36s}
/* branding call-out: "Dein Branding. Dein Name." */
.brandtag{
  position:absolute; top:22px; right:16px; z-index:9; max-width:150px; text-align:right;
  background:var(--olive); color:#fff; font-family:var(--display); font-weight:700;
  font-size:12.5px; line-height:1.18; padding:8px 12px; border-radius:12px;
  box-shadow:0 14px 28px -10px rgba(139,168,58,.85);
  opacity:0; transform:translateY(-6px) scale(.7); transform-origin:top right;
  transition:opacity .3s ease, transform .5s cubic-bezier(.2,1.5,.4,1); pointer-events:none;
}
.brandtag b{display:block; font-weight:800}
.brandtag.show{opacity:1; transform:translateY(0) scale(1)}
.papp__mark{border-radius:11px;background:#fff;display:flex;align-items:center;padding:7px 10px;flex:0 0 auto}
.papp__mark img{height:34px;width:auto;display:block}     /* FULL logo incl. dark wordmark */
.papp__who b{display:block;font-family:var(--display);font-weight:700;font-size:16px;line-height:1.1}
.papp__who span{display:block;color:#9aa4b2;font-size:12.5px;margin-top:2px}
.papp__kicker{color:#9fc35a;font-weight:700;font-size:11px;letter-spacing:.14em;margin:16px 0 4px}
.papp__stats{color:#c7c; color:#aab4c0; font-size:14px; font-weight:500}
.papp__stats b{color:#fff;font-weight:700}
.papp__tabs{display:flex; gap:8px; padding:14px 16px 6px; background:var(--bg)}
.papp__tab{
  flex:1; text-align:center; padding:11px; border-radius:12px; font-weight:600; font-size:14px;
  background:#fff; color:var(--ink); box-shadow:var(--shadow-card);
}
.papp__tab.dim{background:transparent; color:var(--s500); box-shadow:none}
.papp__tab .badge{display:inline-grid;place-items:center;min-width:20px;height:20px;padding:0 5px;margin-left:7px;border-radius:999px;background:var(--s200);color:var(--s600);font-size:12px;font-weight:700;vertical-align:middle}
.papp__days{display:flex; align-items:center; gap:16px; padding:8px 18px 2px; background:var(--bg)}
.dtab{font-family:var(--display); font-weight:700; font-size:15px; color:var(--s400); padding:6px 2px}
.dtab.active{color:#fff; background:var(--olive); padding:7px 17px; border-radius:11px; box-shadow:var(--shadow-olive)}
.papp__list{position:relative; flex:1 1 auto; overflow-y:auto; overflow-x:hidden; padding:12px 16px 18px}

.exrow{
  background:#fff; border-radius:16px; margin-bottom:11px; box-shadow:var(--shadow-card);
  overflow:hidden; opacity:0; transform:translateY(14px);
}
.exrow.show{opacity:1; transform:none; transition:opacity .5s ease, transform .55s var(--cam-ease)}
.exrow__head{display:flex; align-items:center; gap:12px; padding:11px 12px}
.exrow .n{width:26px;height:26px;border-radius:999px;background:var(--s100);color:var(--s500);font-weight:700;font-size:13px;display:grid;place-items:center;flex:0 0 auto}
.exrow .th{width:48px;height:48px;border-radius:11px;object-fit:cover;flex:0 0 auto;background:var(--s200)}
.exrow .meta{flex:1; min-width:0}
.exrow .meta b{display:block;font-weight:600;font-size:14.5px;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.exrow .dos{display:inline-flex;align-items:center;gap:5px;color:var(--olive-d);font-weight:600;font-size:12.5px;margin-top:3px}
.exrow .dos svg{width:15px;height:15px;flex:0 0 auto}
.exrow .chev{width:26px;height:26px;border-radius:999px;background:var(--s100);color:var(--s500);display:grid;place-items:center;flex:0 0 auto;transition:transform .45s var(--cam-ease), background .3s ease, color .3s ease}
.exrow .chev svg{width:16px;height:16px}

/* expandable card body (grid-rows trick) */
.exrow__body{display:grid; grid-template-rows:0fr; transition:grid-template-rows .55s var(--cam-ease)}
.exrow__inner{overflow:hidden; min-height:0}
.exrow--exp.open{box-shadow:0 0 0 2px var(--olive), 0 16px 32px -12px rgba(139,168,58,.4)}
.exrow--exp.open .n{background:var(--navy); color:#fff}
.exrow--exp.open .exrow__body{grid-template-rows:1fr}
.exrow--exp.open .chev{transform:rotate(180deg); background:var(--olive); color:#fff}

.vplayer{position:relative; margin:2px 12px 0; border-radius:13px; overflow:hidden; background:#000; aspect-ratio:16/9}
.vplayer video{width:100%; height:100%; object-fit:contain; display:block; background:#000}
.vbar{position:absolute; left:0; right:0; bottom:0; display:flex; align-items:center; gap:9px; padding:10px 11px 10px; background:linear-gradient(transparent, rgba(0,0,0,.6))}
.vbar .vplay{color:#fff; display:grid; place-items:center; flex:0 0 auto}
.vbar .vplay svg{width:15px; height:15px; filter:drop-shadow(0 1px 2px rgba(0,0,0,.5))}
.vtrack{position:relative; flex:1; height:4px; border-radius:3px; background:rgba(255,255,255,.34)}
.vfill{position:absolute; left:0; top:0; bottom:0; width:20%; border-radius:3px; background:#fff}
.vtime{color:#fff; font-size:11px; font-weight:600; font-variant-numeric:tabular-nums}
.vfs{color:#fff; display:grid; place-items:center; flex:0 0 auto}
.vfs svg{width:15px; height:15px}

.dosbox{margin:13px 12px 0; padding:11px 14px; border-radius:12px; background:#f5f7f1; border:1px solid #e7ecdd}
.dosbox span{display:block; color:var(--s500); font-size:10.5px; font-weight:700; letter-spacing:.12em}
.dosbox b{display:block; color:var(--ink); font-family:var(--display); font-weight:700; font-size:16px; margin-top:3px}
.exdesc{margin:12px 12px 15px; color:var(--s500); font-size:12.5px; line-height:1.55}

/* ===================================================================
   SCENES: MODAL (Plan vergeben) + QR success — live mobile in a phone
   frame with a dim scrim (no desktop bleed)
   =================================================================== */
.scene--modal, .scene--qr{padding:0}
.mframe{position:relative; height:min(94%,848px); aspect-ratio:390/844; width:auto; flex:0 0 auto;
  background:#0B0E13; border-radius:44px; padding:10px; box-shadow:var(--shadow-frame), inset 0 0 0 2px #20262F}
.mscreen{position:relative; height:100%; width:100%; border-radius:34px; overflow:hidden;
  background:var(--bg); font-family:var(--body); color:var(--navy)}
.mscrim{position:absolute; inset:0; background:rgba(15,23,42,.5)}

/* ---- Plan-vergeben bottom sheet ---- */
.msheet{position:absolute; left:0; right:0; bottom:0; max-height:94%; overflow-y:auto;
  background:#fff; border-radius:24px 24px 0 0; padding:10px 18px 16px; box-shadow:0 -20px 50px -20px rgba(0,0,0,.4);
  opacity:0}                                        /* instant reveal — motion comes from the container morph */
.msheet.show{opacity:1}
/* morph box: green button dilates into the white modal card */
.morph{position:absolute; left:0; top:0; width:0; height:0; z-index:40; opacity:0; pointer-events:none;
  box-shadow:var(--shadow-frame); will-change:left,top,width,height}
.msheet__grab{width:40px; height:5px; border-radius:3px; background:var(--s200); margin:2px auto 12px}
.msheet__head{display:flex; align-items:flex-start; justify-content:space-between; margin-bottom:14px}
.msheet__title{font-family:var(--display); font-weight:800; font-size:23px; letter-spacing:-.02em; color:var(--navy); line-height:1}
.msheet__sub{font-size:12.5px; color:var(--s400); margin-top:4px}
.msheet__x{color:var(--s400); font-size:22px; line-height:1}
.mlabel{display:flex; align-items:center; gap:9px; font-weight:800; font-size:12.5px; letter-spacing:.08em; color:var(--navy); margin:15px 0 9px}
.mchk,.mnum{width:22px; height:22px; border-radius:7px; background:var(--olive); color:#fff; display:grid; place-items:center; flex:0 0 auto}
.mchk svg{width:14px; height:14px}
.mnum{font-weight:800; font-size:13px}
.mrow{display:flex; align-items:center; gap:12px; background:#FAFBF7; border:1px solid #EEF1E9; border-radius:14px; padding:11px 13px}
.mav{width:38px; height:38px; border-radius:999px; background:#FBE3EC; color:var(--pink); font-weight:800; font-size:13px; display:grid; place-items:center; flex:0 0 auto}
.mgrid{width:38px; height:38px; border-radius:11px; background:#fff; border:1px solid #EAEFE0; color:var(--navy); display:grid; place-items:center; flex:0 0 auto}
.mgrid svg{width:20px; height:20px}
.mmeta{flex:1; min-width:0}
.mmeta b{display:block; font-weight:700; font-size:15px; color:var(--navy)}
.mmeta span{display:block; font-size:12px; color:var(--s400); margin-top:2px; line-height:1.35}
.mchg{font-size:11px; font-weight:700; letter-spacing:.05em; color:var(--s400); flex:0 0 auto}
.mtoggle{display:flex; gap:9px}
.mtog{flex:1; text-align:center; padding:13px; border-radius:12px; font-weight:700; font-size:14px; color:var(--s500); background:#fff; border:1px solid #E7ECF1}
.mtog.on{color:var(--olive-dd); background:#F3F7EA; border-color:var(--olive)}
.mpay{margin-top:12px; background:#F7F9F3; border:1px solid #EEF1E9; border-radius:14px; padding:13px}
.mpl{font-size:10.5px; font-weight:700; letter-spacing:.1em; color:var(--s400); margin-bottom:8px}
.mopts{display:flex; gap:8px; margin-bottom:12px}
.mopt{flex:1; text-align:center; padding:12px 6px; border-radius:11px; font-weight:600; font-size:13.5px; background:#fff; border:1px solid #E7ECF1; color:var(--navy)}
.mopt.dim{color:var(--s300)}
.mopt.on{background:#F3F7EA; border-color:var(--olive); color:var(--olive-dd)}
.mamt{background:#fff; border:1px solid #E7ECF1; border-radius:11px; padding:13px 15px; font-weight:700; font-size:16px; color:var(--navy); display:flex; justify-content:space-between}
.mamt span{color:var(--s400)}
.msheet__foot{display:flex; align-items:center; gap:12px; margin-top:18px}
.mcancel{font-weight:700; font-size:14px; color:var(--s500); padding:12px}
.msell{flex:1; display:inline-flex; align-items:center; justify-content:center; gap:8px; background:var(--olive); color:#fff; border:none;
  border-radius:13px; padding:14px; font-family:var(--body); font-weight:800; font-size:14px; box-shadow:var(--shadow-olive); line-height:1.1}
.msell svg{width:17px; height:17px; flex:0 0 auto}

/* ---- QR success modal (centred card) ---- */
.qmodal{position:absolute; left:16px; right:16px; top:50%; transform:translateY(-50%); opacity:0;
  background:#fff; border-radius:24px; padding:24px 20px 18px; text-align:center;
  box-shadow:0 30px 70px -24px rgba(0,0,0,.5)}   /* instant reveal — motion comes from the container morph */
.qmodal.show{opacity:1}
.qcheck{width:56px; height:56px; border-radius:999px; background:#EAF1D9; color:var(--olive-dd); display:grid; place-items:center; margin:0 auto 14px}
.qcheck svg{width:30px; height:30px; stroke-dasharray:32; stroke-dashoffset:32}
.qmodal.show .qcheck svg{animation:qrdraw .5s ease-out .15s forwards}
@keyframes qrdraw{to{stroke-dashoffset:0}}
.qtitle{font-family:var(--display); font-weight:800; font-size:22px; letter-spacing:-.02em; color:var(--navy)}
.qsub{font-size:13px; color:var(--s400); margin-top:4px}
.qcard{border:1px solid #EEF2F6; border-radius:18px; padding:16px; margin-top:16px}
.qimgwrap{position:relative; width:min(58%,186px); aspect-ratio:1; margin:0 auto; overflow:hidden; border-radius:6px}
.qimg{width:100%; height:100%; object-fit:contain; display:block}
.qscan{position:absolute; left:0; right:0; top:0; height:45%; pointer-events:none; opacity:0;
  background:linear-gradient(180deg, rgba(139,168,58,0) 0%, rgba(139,168,58,.28) 72%, rgba(139,168,58,.85) 100%); mix-blend-mode:multiply}
.qimgwrap.scanning .qscan{animation:qscan .66s cubic-bezier(.4,0,.3,1)}
@keyframes qscan{0%{opacity:0; transform:translateY(-100%)} 14%{opacity:.9} 86%{opacity:.9} 100%{opacity:0; transform:translateY(165%)}}
.qimgwrap.scanning{animation:qpulse .66s ease-out .05s}
@keyframes qpulse{0%,100%{box-shadow:0 0 0 0 rgba(139,168,58,0)} 45%{box-shadow:0 0 0 4px rgba(139,168,58,.55), 0 0 26px 4px rgba(139,168,58,.5)}}
/* QR portal-zoom: a QR clone dilates to fill the screen, then a flash cuts to the phone */
.qrzoom{position:absolute; left:0; top:0; z-index:43; opacity:0; pointer-events:none; overflow:hidden;
  background:#fff; border-radius:6px; will-change:transform}
.qrzoom img{width:100%; height:100%; object-fit:contain; display:block}
#flash{position:absolute; inset:0; z-index:45; opacity:0; pointer-events:none;
  background:radial-gradient(circle at 50% 46%, #ffffff 0%, #eef4df 55%, #dfeac6 100%)}   /* olive-tinted, softer */
#flash.pop{animation:flashpop .45s ease-out}
@keyframes flashpop{0%{opacity:0} 30%{opacity:.9} 100%{opacity:0}}
.qname{font-weight:700; font-size:15px; color:var(--navy); margin-top:12px}
.qbadge{display:inline-block; margin-top:8px; background:var(--olive); color:#fff; font-weight:800; font-size:11.5px; letter-spacing:.04em; padding:5px 12px; border-radius:999px}
.qurl{font-size:10.5px; color:var(--olive-d); margin-top:10px; word-break:break-all}
.qbtns{margin-top:15px; display:flex; flex-direction:column; gap:9px}
.qbtn{display:inline-flex; align-items:center; justify-content:center; gap:8px; background:#F1F5F9; color:var(--navy);
  border-radius:12px; padding:13px; font-weight:700; font-size:13.5px;
  opacity:0; transform:translateY(8px); transition:opacity .4s ease, transform .45s var(--cam-ease)}
.qbtn svg{width:16px; height:16px; flex:0 0 auto}
.qbtn-row{display:flex; gap:9px}
.qbtn-row .qbtn{flex:1; padding:13px 8px}
.qmodal.show .qbtn{opacity:1; transform:none}
.qmodal.show .qbtn[data-f="1"]{transition-delay:.2s}
.qmodal.show .qbtn[data-f="2"]{transition-delay:.32s}
.qmodal.show .qbtn[data-f="3"]{transition-delay:.44s}
.qdone{font-weight:800; font-size:13.5px; letter-spacing:.06em; color:var(--olive-dd); margin-top:16px}

/* ===================================================================
   SCENE: INVOICE (Beat 4b)
   =================================================================== */
.scene--invoice{padding:22px}
.doc{
  position:relative; z-index:1; width:min(86vw, 388px); background:#fff; border-radius:14px;
  box-shadow:var(--shadow-frame); overflow:visible;
  transform:translateY(46px) scale(.9); opacity:0;
  transition:opacity .45s ease, transform .65s cubic-bezier(.2,1.15,.35,1);   /* slides up + springs in */
}
.scene--invoice.is-active .doc{opacity:1; transform:none}
.doc img{width:100%; display:block; border-radius:14px}
/* localized olive glow that pulses exactly on the printed "39,00 €" when the €-chip merges */
.doc__glow{position:absolute; left:86%; top:60%; transform:translate(-50%,-50%); width:30%; aspect-ratio:1;
  border-radius:50%; pointer-events:none; z-index:2; opacity:0;
  background:radial-gradient(circle, rgba(139,168,58,.55) 0%, rgba(139,168,58,0) 62%)}
.doc__glow.pop{animation:docglow .85s ease-out}
@keyframes docglow{0%{opacity:0; transform:translate(-50%,-50%) scale(.35)} 28%{opacity:1} 100%{opacity:0; transform:translate(-50%,-50%) scale(1.5)}}
.plusbadge{
  position:absolute; z-index:6; left:50%; top:63%;   /* down by the Gesamtbetrag / where the €-chip lands */
  display:flex; align-items:center; gap:9px;
  background:var(--pink); color:#fff; font-family:var(--display); font-weight:700; font-size:16px;
  white-space:nowrap; padding:11px 18px; border-radius:999px;
  box-shadow:0 16px 32px -10px rgba(216,27,96,.6);
  opacity:0; transform:translate(-50%,0) scale(.4) rotate(-6deg);
}
.plusbadge.pop{animation:badgepop .75s cubic-bezier(.2,1.3,.4,1) forwards}
.plusbadge .p1{display:grid;place-items:center;width:24px;height:24px;border-radius:999px;background:rgba(255,255,255,.22);font-weight:800}
@keyframes badgepop{
  0%{opacity:0; transform:translate(-50%,0) scale(.3) rotate(-9deg); box-shadow:0 16px 32px -10px rgba(216,27,96,.6)}
  55%{opacity:1; transform:translate(-50%,0) scale(1.16) rotate(3deg); box-shadow:0 0 0 7px rgba(216,27,96,.22), 0 20px 42px -8px rgba(216,27,96,.8)}
  100%{opacity:1; transform:translate(-50%,0) scale(1) rotate(0); box-shadow:0 16px 32px -10px rgba(216,27,96,.6)}
}

/* Transition A: money chip carrying the sale from the patient phone to the Honorarnote total */
.eurochip{
  position:absolute; left:0; top:0; z-index:45; pointer-events:none;
  display:inline-flex; align-items:center; gap:9px; white-space:nowrap;
  font-family:var(--display); font-weight:800; font-size:30px; letter-spacing:-.01em; color:#fff;
  padding:12px 20px 12px 15px; border-radius:999px;
  background:linear-gradient(135deg, var(--olive) 0%, var(--olive-dd) 100%);
  box-shadow:0 22px 46px -14px rgba(105,130,43,.9), inset 0 0 0 1.5px rgba(255,255,255,.22);
  opacity:0; transform:translate(-9999px,-9999px);
  font-variant-numeric:tabular-nums; will-change:transform,opacity;
}
.eurochip .ec-coin{width:30px;height:30px;flex:0 0 auto;filter:drop-shadow(0 2px 3px rgba(0,0,0,.25)); transition:opacity .2s ease, width .28s ease}
.eurochip .ec-val{min-width:132px; text-align:left}
/* dock: pill dissolves to the bare "39,00 €" digits so they land exactly on the printed total */
.eurochip.dock{background:transparent; box-shadow:none; gap:0; padding:0; color:var(--navy)}
.eurochip.dock .ec-coin{opacity:0; width:0}
.eurochip.dock .ec-val{min-width:0}

/* ===================================================================
   SCENE: END (Beat 5)
   =================================================================== */
/* dark brand finale — matches the patient-app spotlight (deep navy field) */
.scene--end{background:radial-gradient(125% 90% at 50% 34%, #1b2739 0%, #0a0e15 72%)}
.end{position:relative; display:flex; flex-direction:column; align-items:center; text-align:center; padding:24px; width:100%}

/* --- "Rise & Focus": the note's logo lifts off, grows to hero, a single glint crosses it --- */
.end__logowrap{position:relative; display:grid; place-items:center; isolation:isolate}
.end__logo{width:min(64vw, 262px); height:auto; opacity:0; transform:scale(.82);
  transform-origin:50% 50%; transform-box:border-box;   /* centre-scale so the rise math lands the logo centred */
  transition:opacity .6s ease, transform .95s cubic-bezier(.16,.84,.3,1)}   /* weighted settle — no bounce */
.end.show .end__logo{opacity:1; transform:none}
.end__logo .lm-word{fill:#ffffff}         /* wordmark knocked out to white on the dark field */
.end__logo .lm-mark{fill:#95b840}         /* mark stays olive, a touch brighter for the dark ground */
/* single specular light-sweep, masked to the logo shape only (the "fancy" beat, no green blob) */
.end__glint{
  position:absolute; inset:0; z-index:3; pointer-events:none; opacity:0; mix-blend-mode:screen;
  -webkit-mask:url(assets/pom-logo.svg) center/contain no-repeat; mask:url(assets/pom-logo.svg) center/contain no-repeat;
  background:linear-gradient(100deg, transparent 42%, rgba(255,255,255,.9) 50%, transparent 58%);
  background-size:280% 100%; background-position:135% 0;
}
.end.show .end__glint{animation:endGlint .95s cubic-bezier(.4,0,.2,1) .82s both}
@keyframes endGlint{
  0%{opacity:0; background-position:135% 0}
  15%{opacity:1}
  85%{opacity:1}
  100%{opacity:0; background-position:-135% 0}
}

.claim{margin-top:30px; display:flex; flex-direction:column; gap:9px}
.claim__line{
  font-family:var(--display); font-weight:800; font-size:clamp(21px, 6.4vw, 31px);
  letter-spacing:-.02em; color:#ffffff; line-height:1.14;   /* "Deine / Dein" in white */
  opacity:0; transform:translateY(16px) scale(.9);
  transition:opacity .5s ease, transform .62s cubic-bezier(.2,1.35,.32,1);   /* pop-in with a touch of overshoot */
}
.claim__line.show{opacity:1; transform:none}
.claim__line .g{color:#a8c65a}   /* highlighted noun — same green as the patient-app headline */

/* ---------- Chrome: progress, replay, muted ---------- */
.progress{position:absolute; left:0; right:0; bottom:0; height:4px; background:rgba(15,23,42,.07); z-index:50}
.progress__bar{height:100%; width:0; background:linear-gradient(90deg, var(--olive), #a3c04f); border-radius:0 3px 3px 0}
.progress.hidden{opacity:0; transition:opacity .6s ease}

.muted{
  position:absolute; top:14px; right:14px; z-index:50;
  display:flex; align-items:center; gap:7px;
  background:rgba(15,23,42,.55); color:#fff; backdrop-filter:blur(6px);
  padding:7px 12px; border-radius:999px; font-size:12.5px; font-weight:600;
  opacity:0; transition:opacity .5s ease; pointer-events:none;
}
.muted.show{opacity:1}
.muted svg{width:15px;height:15px}

.replay{
  position:absolute; left:50%; bottom:7%; transform:translate(-50%, 12px);
  z-index:60; display:inline-flex; align-items:center; gap:10px;
  font-family:var(--display); font-weight:700; font-size:17px; color:#fff;
  background:var(--olive); border:none; cursor:pointer;
  padding:14px 26px; border-radius:16px; box-shadow:var(--shadow-olive);
  opacity:0; visibility:hidden; transition:opacity .5s ease, transform .5s var(--cam-ease), background .15s ease;
}
.replay.show{opacity:1; visibility:visible; transform:translate(-50%, 0)}
.replay:hover{background:var(--olive-d)}
.replay:active{transform:translate(-50%, 0) scale(.98); background:var(--olive-dd)}
.replay svg{width:19px;height:19px}

/* play overlay for browsers that block autoplay */
.tapstart{
  position:absolute; inset:0; z-index:70; display:none; place-items:center;
  background:rgba(15,23,42,.32); backdrop-filter:blur(2px); cursor:pointer;
}
.tapstart.show{display:grid}
.tapstart .btn{
  display:inline-flex; align-items:center; gap:10px;
  font-family:var(--display); font-weight:700; font-size:18px; color:#fff;
  background:var(--olive); padding:16px 30px; border-radius:18px; box-shadow:var(--shadow-olive);
}
.tapstart .btn svg{width:22px;height:22px}

/* no-transition snapshot mode (debug verification) */
.demo.no-trans *{transition-duration:0s !important}

/* (old desktop frame-canvas sizes removed — editor + modals are 1:1 mobile now) */

@media (prefers-reduced-motion:reduce){
  .camera{transition-duration:.01ms !important}
  .qr-wrap{transition-duration:.01ms !important}
}
