:root{--ink:#182427;--muted:#647276;--paper:#fffaf1;--surface:#fff;--teal:#1f5f68;--teal-soft:#d9f1ee;--coral:#f26d4f;--coral-soft:#ffe2d8;--mint:#ecf8f4;--cream:#fffaf1;--gold:#f4bd45;--green:#5ca87a;--line:#d9e0dc;--shadow:0 18px 45px #1824271f;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*{box-sizing:border-box}body{min-height:100vh;color:var(--ink);background:linear-gradient(120deg, #d9f1eed1, #fffaf1f2 45%, #ffe2d8db), var(--paper);margin:0;overflow-x:hidden}button{font:inherit;color:inherit;cursor:pointer;border:0}button:focus-visible,summary:focus-visible{outline:3px solid var(--gold);outline-offset:3px}.sr-only{clip:rect(0, 0, 0, 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.phone-shell{width:min(100%,760px);padding:max(20px, env(safe-area-inset-top)) max(14px, env(safe-area-inset-right)) max(38px, env(safe-area-inset-bottom)) max(14px, env(safe-area-inset-left));margin:0 auto}.app-card{box-shadow:var(--shadow);background:#ffffff9e;border:1px solid #1f5f682e;border-radius:8px;overflow:hidden}.topbar{justify-content:space-between;align-items:center;gap:16px;padding:18px 20px 0;display:flex}.eyebrow,.moment-label,.move-topline,.level-pill,.feedback p{letter-spacing:0;text-transform:uppercase;margin:0;font-size:.78rem;font-weight:800}.eyebrow{color:var(--coral)}h1,h2,h3,p{margin-top:0}h1{letter-spacing:0;max-width:520px;margin-bottom:0;font-size:2.45rem;line-height:1.02}.back-button,.secondary-button,.surprise-button{border:1px solid var(--line);background:#ffffffc2;border-radius:8px;min-height:44px;padding:0 16px;font-weight:800;box-shadow:0 8px 22px #18242712}.back-button:hover,.secondary-button:hover,.surprise-button:hover{border-color:#1f5f6873;transform:translateY(-1px)}.hero{background:#ffffff75;border-bottom:1px solid #1f5f6824;grid-template-columns:minmax(0,1fr) 184px;align-items:center;gap:18px;min-height:214px;padding:20px;display:grid}.hero-copy h2{letter-spacing:0;max-width:420px;margin-bottom:0;font-size:3.15rem;line-height:1}.escape-button{color:#fff;background:var(--coral);border-radius:8px;align-items:center;gap:10px;min-height:52px;margin-top:22px;padding:0 18px;font-weight:900;display:inline-flex;box-shadow:0 16px 30px #f26d4f38}.escape-button span{background:#fff3;border-radius:999px;place-items:center;width:28px;height:28px;display:grid}.escape-button:hover{background:#df5c43;transform:translateY(-1px)}.moment-label{color:var(--teal);margin-bottom:14px}.companion-wrap{place-items:center;display:grid;position:relative}.companion{aspect-ratio:1;object-fit:contain;filter:drop-shadow(0 18px 18px #18242726);width:min(100%,166px)}.level-pill{color:#fff;background:var(--teal);border-radius:8px;justify-content:space-between;gap:10px;width:min(260px,100%);margin-top:-4px;padding:8px 10px;display:flex;box-shadow:0 10px 24px #1f5f683d}.progress{align-items:center;gap:8px;padding:16px 20px 4px;display:flex}.progress-dot{background:#1f5f6829;border-radius:999px;width:100%;height:9px}.progress-dot.active{background:var(--teal)}.progress-dot[aria-current=step]{background:var(--coral);box-shadow:0 0 0 3px #f26d4f33}.screen{display:none}.screen.active{padding:16px 20px 20px;display:block}.choice-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;display:grid}.choice-grid.compact{grid-template-columns:repeat(3,minmax(0,1fr))}.choice-card{border:1px solid var(--line);text-align:center;background:#ffffffd1;border-radius:8px;align-content:center;justify-items:center;gap:10px;min-height:138px;padding:16px;display:grid;box-shadow:0 10px 28px #18242714}.choice-card:hover,.choice-card.selected{border-color:#f26d4fb3;transform:translateY(-2px);box-shadow:0 18px 34px #18242721}.choice-icon,.move-visual{color:var(--teal);background:var(--teal-soft);place-items:center;display:grid}.choice-icon{border-radius:18px;width:62px;height:62px}.choice-icon svg{width:34px;height:34px}.choice-title{font-size:1.08rem;font-weight:900}.choice-subtitle{color:var(--muted);font-size:.82rem;line-height:1.2}.surprise-button,.back-button{margin-top:16px}.tune-panel{background:#ffffffc2;border:1px solid #1f5f6838;border-radius:8px;margin-bottom:16px;padding:18px;box-shadow:0 10px 28px #18242714}.tune-panel[hidden]{display:none}.tune-panel h3,.tune-panel p{margin-bottom:8px}.tune-panel p{color:var(--muted)}.tune-group{gap:8px;margin-top:14px;display:grid}.tune-group>span{color:var(--teal);text-transform:uppercase;font-size:.78rem;font-weight:900}.chip-row{flex-wrap:wrap;gap:8px;display:flex}.chip{border:1px solid var(--line);min-height:44px;color:var(--muted);background:#ffffffdb;border-radius:999px;padding:0 14px;font-weight:800}.chip.selected{color:#fff;background:var(--teal);border-color:var(--teal)}.compact-actions{margin-top:16px}.move-panel{background:var(--surface);box-shadow:var(--shadow);border:1px solid #1f5f6838;border-radius:8px;padding:24px}.move-visual{color:#fff;background:var(--coral);border-radius:28px;width:88px;height:88px;margin-bottom:18px;box-shadow:0 16px 28px #f26d4f38}.move-visual svg{width:48px;height:48px}.move-topline{color:var(--coral);justify-content:space-between;gap:16px;display:flex}.move-panel h2{letter-spacing:0;margin:16px 0 10px;font-size:3.8rem;line-height:1.02}.move-panel p{color:var(--muted);line-height:1.55}.steps{counter-reset:step;gap:8px;margin:22px 0;padding-left:0;list-style:none;display:grid}.steps li{border:1px solid var(--line);background:#fffaf4;border-radius:8px;grid-template-columns:30px minmax(0,1fr);align-items:center;gap:10px;padding:10px;line-height:1.45;display:grid}.steps li:before{counter-increment:step;content:counter(step);color:#fff;background:var(--teal);border-radius:999px;place-items:center;width:30px;height:30px;font-weight:900;display:grid}.reason{background:var(--teal-soft);color:var(--muted);border-radius:8px;margin-bottom:0;padding:14px 16px}.reason summary{color:var(--teal);cursor:pointer;font-weight:900}.reason p{margin:10px 0 0}.moment-strip{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin-top:16px;display:grid}.moment-strip article{background:#ffffffc7;border:1px solid #1f5f6838;border-radius:8px;grid-template-columns:56px minmax(0,1fr);align-items:center;gap:12px;min-height:96px;padding:14px;display:grid;box-shadow:0 10px 28px #18242714}.strip-icon{color:#fff;background:var(--teal);border-radius:18px;place-items:center;width:56px;height:56px;display:grid}.strip-icon svg{width:31px;height:31px}.moment-strip strong,.moment-strip span{display:block}.moment-strip strong{margin-bottom:4px}.moment-strip span{color:var(--muted);font-size:.9rem;line-height:1.25}.session-panel{background:#ffffffc2;border:1px solid #1f5f6838;border-radius:8px;grid-template-columns:96px minmax(0,1fr);align-items:center;gap:16px;margin-top:16px;padding:18px;display:grid;box-shadow:0 10px 28px #18242714}.session-ring{--progress:0deg;width:96px;height:96px;color:var(--teal);background:radial-gradient(circle at center, #fff 0 58%, transparent 59%), conic-gradient(var(--coral) var(--progress), #1f5f6829 0);border-radius:999px;place-items:center;font-weight:900;display:grid}.session-ring.active{color:#fff;background:radial-gradient(circle at center, var(--teal) 0 58%, transparent 59%), conic-gradient(var(--coral) var(--progress), #1f5f682e 0)}.session-panel h3{margin-bottom:6px;font-size:1.2rem}.session-label{color:var(--coral);text-transform:uppercase;margin-bottom:6px;font-size:.76rem;font-weight:900;display:inline-block}.session-panel p{color:var(--muted);margin:0;line-height:1.4}.action-row{flex-wrap:wrap;gap:10px;margin-top:14px;display:flex}.move-actions .primary-button{flex:2 190px}.move-actions .secondary-button{flex:112px}.primary-button{color:#fff;background:var(--teal);border-radius:8px;min-height:48px;padding:0 22px;font-weight:900;box-shadow:0 14px 30px #1f5f6840}.primary-button:hover{background:#174d55;transform:translateY(-1px)}.primary-button:disabled,.secondary-button:disabled{cursor:default;opacity:.48;transform:none}.feedback{border:1px solid var(--line);background:#ffffffc2;border-radius:8px;margin-top:16px;padding:18px}.mission-reward-panel{background:linear-gradient(135deg,#fffaf1f5,#ffe2d8d1),#fff;border:1px solid #f4bd45b8;border-radius:8px;margin-top:16px;padding:20px;animation:.42s ease-out both reward-pop;position:relative;overflow:hidden;box-shadow:0 18px 36px #f4bd452e}.mission-reward-panel h3{max-width:520px;margin:8px 0 12px;font-size:1.35rem;line-height:1.15}.reward-badge-visual{color:#3b2b06;background:#f4bd4547;border:2px solid #f4bd45c7;border-radius:999px;place-items:center;width:62px;height:62px;margin:10px 0;display:grid;box-shadow:0 12px 22px #f4bd4529}.reward-badge-visual span{font-size:1.8rem;line-height:1}.mission-reward-panel strong{color:#3b2b06;background:#f4bd456b;border-radius:999px;align-items:center;min-height:36px;margin-bottom:10px;padding:0 12px;font-size:.96rem;display:inline-flex}.mission-reward-panel span:not(.reward-burst),.mission-reward-panel p:not(.moment-label){color:var(--muted);margin:0 0 8px;line-height:1.4;display:block}.reward-burst{color:var(--gold);transform-origin:50%;font-size:2.8rem;line-height:1;animation:.9s ease-out both reward-star;position:absolute;top:16px;right:18px}.drawer{align-content:start;gap:16px;padding:0 20px 20px;display:grid}.drawer section{border:1px solid var(--line);background:#ffffffad;border-radius:8px;padding:18px;box-shadow:0 10px 28px #18242714}.drawer h3{margin-bottom:12px;font-size:1rem}.level-meter{background:#1f5f6824;border-radius:999px;height:12px;overflow:hidden}.level-meter span{border-radius:inherit;background:linear-gradient(90deg, var(--coral), var(--gold), var(--green));width:0%;height:100%;display:block}.companion-note{color:var(--muted);margin:12px 0 0;font-size:.9rem;line-height:1.35}.identity-card,.mission-card{color:var(--muted);gap:10px;font-size:.9rem;line-height:1.35;display:grid}.mission-card strong{color:var(--ink)}.mission-reward-summary{color:#3b2b06;background:#f4bd453d;border-radius:8px;padding:10px;font-weight:800}.mini-list{gap:8px;display:grid}.badge-list{gap:10px;display:grid}.badge-empty{color:var(--muted);background:#ffffff80;border:1px dashed #1f5f6847;border-radius:8px;padding:12px;font-size:.9rem}.badge-card{border:1px solid var(--line);background:#ffffffb8;border-radius:8px;grid-template-columns:46px minmax(0,1fr);align-items:center;gap:12px;padding:12px;display:grid}.badge-card>div{min-width:0}.badge-card.earned{background:#fffaf1db;border-color:#f4bd45a3}.badge-card.locked{opacity:.72}.badge-icon{color:#3b2b06;background:#f4bd4552;border-radius:999px;place-items:center;width:46px;height:46px;font-size:1.35rem;font-weight:900;display:grid}.badge-card strong,.badge-card span,.badge-card small{display:block}.badge-card strong{margin-bottom:3px}.badge-card span,.badge-card small{color:var(--muted);overflow-wrap:anywhere;font-size:.82rem;line-height:1.3}.drawer-links{flex-wrap:wrap;gap:.85rem;padding-top:.25rem;font-size:.82rem;display:flex}.drawer-links a,.static-back-link{color:var(--teal);font-weight:800;text-decoration:none}.drawer-links a:hover,.static-back-link:hover{text-decoration:underline}.static-page{background:radial-gradient(circle at 10% 10%, #def7f1d9, transparent 32%), linear-gradient(135deg, var(--mint), var(--cream));min-height:100vh;color:var(--ink);padding:1rem}.static-shell{border:1px solid var(--line);width:min(720px,100%);box-shadow:var(--shadow);background:#ffffffdb;border-radius:8px;margin:0 auto;padding:clamp(1.1rem,4vw,2.25rem)}.static-shell h1{margin:1.25rem 0 1rem;font-size:clamp(2.2rem,8vw,4.5rem);line-height:.95}.static-shell h2{margin:1.5rem 0 .45rem;font-size:1.1rem}.static-shell p,.static-shell li{color:var(--muted);font-size:1rem;line-height:1.55}.static-shell ul{padding-left:1.1rem}.static-updated{margin-top:1.75rem;font-size:.85rem}.mini-item{border-top:1px solid var(--line);color:var(--muted);padding:10px 0;font-size:.9rem;line-height:1.35}.mini-item:first-child{border-top:0;padding-top:0}.toast{color:#fff;background:var(--ink);width:min(360px,100% - 32px);box-shadow:var(--shadow);text-align:center;z-index:10;border-radius:8px;padding:14px 16px;font-weight:800;position:fixed;bottom:24px;left:50%;transform:translate(-50%)}.celebration{pointer-events:none;z-index:9;position:fixed;inset:0}.spark{background:var(--gold);border-radius:4px;width:12px;height:12px;animation:.76s ease-out forwards burst;position:absolute;top:48%;left:50%;transform:translate(-50%,-50%)}.spark:nth-child(2n){background:var(--coral)}.spark:nth-child(3n){background:var(--teal)}@keyframes burst{to{opacity:0;transform:translate(calc(-50% + var(--x)), calc(-50% + var(--y))) rotate(150deg) scale(.65)}}@keyframes reward-pop{0%{opacity:0;transform:translateY(10px)scale(.98)}to{opacity:1;transform:translateY(0)scale(1)}}@keyframes reward-star{0%{opacity:0;transform:rotate(-18deg)scale(.55)}50%{opacity:1;transform:rotate(10deg)scale(1.16)}to{opacity:1;transform:rotate(0)scale(1)}}@media (prefers-reduced-motion:reduce){.mission-reward-panel,.reward-burst{animation:none}}@media (max-width:880px){.hero{grid-template-columns:1fr;min-height:auto}h1{font-size:2.15rem}.hero-copy h2{font-size:2.65rem}.move-panel h2{font-size:3rem}.companion-wrap{grid-row:1}}@media (max-width:540px){.phone-shell{padding:env(safe-area-inset-top) env(safe-area-inset-right) max(18px, env(safe-area-inset-bottom)) env(safe-area-inset-left)}.app-card{box-shadow:none;border-left:0;border-right:0;border-radius:0}.topbar{align-items:flex-start;padding:14px 14px 0}.hero{gap:12px;padding:14px}.hero-copy h2{font-size:2rem}.escape-button{justify-content:center;width:100%}h1{font-size:1.68rem}.move-panel h2{font-size:2.05rem}.screen.active,.drawer,.progress{padding-left:14px;padding-right:14px}.move-panel,.feedback,.mission-reward-panel,.drawer section{padding:14px}.session-panel{grid-template-columns:76px minmax(0,1fr);gap:12px;padding:14px}.session-ring{width:76px;height:76px}.moment-strip{grid-template-columns:1fr}.companion{width:124px}.level-pill{gap:6px;width:min(230px,100%);padding:7px 9px;font-size:.68rem}.choice-grid,.choice-grid.compact{grid-template-columns:1fr}.choice-card{text-align:left;grid-template-columns:52px minmax(0,1fr);justify-items:start;min-height:88px;padding:14px}.choice-icon{border-radius:16px;grid-row:span 2;width:52px;height:52px}.choice-icon svg{width:29px;height:29px}.action-row>button{flex:120px;min-height:44px;padding-left:12px;padding-right:12px}.move-actions .primary-button{flex-basis:100%}.mission-reward-panel h3{font-size:1.16rem}.reward-burst{font-size:2rem;top:12px;right:12px}.reward-badge-visual{width:54px;height:54px}.badge-card{grid-template-columns:40px minmax(0,1fr);gap:10px;padding:10px}.badge-icon{width:40px;height:40px;font-size:1.18rem}.drawer{padding-bottom:max(18px, env(safe-area-inset-bottom));gap:12px}.drawer-links{padding:0 2px}}@media (max-width:340px){.hero-copy h2{font-size:1.82rem}h1{font-size:1.52rem}.move-panel h2{font-size:1.82rem}.session-panel{grid-template-columns:68px minmax(0,1fr)}.session-ring{width:68px;height:68px;font-size:.84rem}.choice-title{font-size:1rem}}
