:root{
  --bg:#17121f;
  --bg-2:#24182d;
  --panel:rgba(255,244,222,.92);
  --panel-strong:#fff1cf;
  --ink:#251828;
  --muted:#735e79;
  --line:rgba(37,24,40,.17);
  --pink:#ff69a8;
  --pink-2:#ff9ed0;
  --gold:#ffd166;
  --jade:#39d98a;
  --cyan:#68e1fd;
  --violet:#9b6dff;
  --red:#ff5a5f;
  --shadow:0 24px 80px rgba(0,0,0,.42);
  --hard:4px 5px 0 rgba(37,24,40,.32);
}
*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  overflow:hidden;
  color:var(--ink);
  background:radial-gradient(circle at 20% 10%,#3b2454 0,#17121f 34%,#0f0b15 100%);
  font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
}
button{font:inherit}
.grain{position:fixed;inset:0;z-index:40;pointer-events:none;opacity:.14;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 160 160' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.65'/%3E%3C/svg%3E")}
.aurora{position:fixed;inset:-30%;z-index:0;pointer-events:none;background:radial-gradient(circle at 20% 20%,rgba(255,105,168,.38),transparent 27%),radial-gradient(circle at 80% 18%,rgba(104,225,253,.28),transparent 25%),radial-gradient(circle at 65% 85%,rgba(57,217,138,.22),transparent 26%);filter:blur(24px);animation:drift 16s ease-in-out infinite alternate}
@keyframes drift{from{transform:translate3d(-2%,1%,0) rotate(-2deg)}to{transform:translate3d(2%,-1%,0) rotate(2deg)}}
.app-shell{position:relative;height:100dvh;width:100vw;display:grid;grid-template-columns:minmax(0,1fr) 390px;gap:18px;padding:18px;z-index:1}
.map-stage{position:relative;min-width:0;border:1px solid rgba(255,255,255,.18);border-radius:28px;overflow:hidden;box-shadow:var(--shadow);background:#20162b}
#map{position:absolute;inset:0;z-index:1;background:#191120}
.leaflet-tile-pane{filter:saturate(.8) contrast(.92) brightness(.72) hue-rotate(150deg)}
.leaflet-container{font-family:Inter,system-ui,sans-serif;background:#191120}
.leaflet-control-zoom{border:none!important;box-shadow:0 10px 30px rgba(0,0,0,.28)!important}
.leaflet-control-zoom a{background:rgba(255,241,207,.92)!important;color:var(--ink)!important;border-color:rgba(37,24,40,.16)!important}
.map-overlay{position:absolute;inset:0;z-index:2;pointer-events:none;background:radial-gradient(circle at 50% 45%,transparent 0 46%,rgba(15,11,21,.58) 100%),linear-gradient(135deg,rgba(255,105,168,.18),rgba(104,225,253,.08) 40%,rgba(57,217,138,.12));mix-blend-mode:screen}
.fallback-map{position:absolute;inset:20px;z-index:4;display:grid;place-items:center;text-align:center;color:#fff}
.fallback-map[hidden]{display:none!important}
.fallback-map div{background:rgba(23,18,31,.82);border:1px solid rgba(255,255,255,.24);border-radius:20px;padding:20px;display:grid;gap:6px;box-shadow:var(--shadow)}
.hud{height:calc(100dvh - 36px);overflow:auto;display:flex;flex-direction:column;gap:12px;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.25) transparent}
.brand-card,.companion-card,.progress-card,.mood-card,.passport-card,.controls-card{background:var(--panel);border:1px solid rgba(255,255,255,.52);border-radius:24px;padding:18px;box-shadow:var(--hard),0 18px 60px rgba(0,0,0,.23);backdrop-filter:blur(14px)}
.brand-card{position:relative;overflow:hidden;background:linear-gradient(135deg,rgba(255,246,225,.96),rgba(255,225,242,.92) 52%,rgba(222,248,255,.92))}
.brand-card:after{content:"";position:absolute;right:-54px;top:-52px;width:150px;height:150px;border-radius:50%;background:repeating-conic-gradient(from 10deg,var(--pink) 0 12deg,var(--gold) 12deg 24deg,var(--cyan) 24deg 36deg,var(--jade) 36deg 48deg);opacity:.25}
.eyebrow,.mini-label,.section-title,.drawer-rank,.finale-stamp{font-family:"Space Mono",monospace;text-transform:uppercase;letter-spacing:.12em;font-weight:700;font-size:10px;color:#8c3a74}
.brand-card h1{position:relative;margin:8px 0 10px;font-family:"Bricolage Grotesque",Inter,sans-serif;font-size:clamp(2.1rem,3.7vw,3.35rem);line-height:.88;letter-spacing:-.055em;color:#211427}
.brand-card h1 span{font-family:Fraunces,serif;font-style:italic;color:#bb357e;letter-spacing:-.025em}
.brand-card p{position:relative;margin:0;color:#604c68;line-height:1.55;font-size:14px}
.cta-row,.drawer-actions,.finale-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:16px}
.btn{border:0;cursor:pointer;border-radius:999px;padding:11px 15px;font-weight:800;letter-spacing:-.01em;color:var(--ink);background:var(--panel-strong);box-shadow:3px 4px 0 rgba(37,24,40,.28);transition:transform .14s ease,box-shadow .14s ease,filter .14s ease}
.btn:hover{filter:saturate(1.08) brightness(1.03);transform:translateY(-1px)}
.btn:active{transform:translate(3px,4px);box-shadow:0 0 0 rgba(37,24,40,.28)}
.btn.primary{color:#fff;background:linear-gradient(135deg,var(--pink),#9b6dff 58%,#5edfff);text-shadow:0 1px 0 rgba(0,0,0,.18)}
.btn.ghost{background:rgba(255,255,255,.54);border:1px solid rgba(37,24,40,.18)}
.btn.small{padding:9px 12px;font-size:12px}
.companion-card{display:grid;grid-template-columns:62px 1fr;align-items:center;gap:12px;background:linear-gradient(135deg,rgba(255,241,207,.94),rgba(226,255,239,.9))}
.retriever{position:relative;width:58px;height:58px;border-radius:22px;background:linear-gradient(135deg,#ffd166,#f2a23a);color:#211427;display:grid;place-items:center;box-shadow:4px 5px 0 rgba(37,24,40,.24);animation:floaty 2.8s ease-in-out infinite;border:2px solid rgba(37,24,40,.22)}
.retriever .ear{position:absolute;top:11px;width:18px;height:31px;background:#c47a2c;border-radius:999px;z-index:-1}
.retriever .left{left:-7px;transform:rotate(18deg)}.retriever .right{right:-7px;transform:rotate(-18deg)}
.retriever .snout{position:absolute;left:50%;bottom:8px;width:25px;height:17px;transform:translateX(-50%);border-radius:999px;background:rgba(255,246,225,.72);box-shadow:inset 0 -2px 0 rgba(37,24,40,.12)}
.retriever .face{position:relative;z-index:2;font-size:28px;filter:saturate(1.18)}
@keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-5px)}}
.companion-card p{margin:3px 0 0;color:#56405e;font-weight:650;line-height:1.4}
.progress-top,.progress-meta{display:flex;justify-content:space-between;gap:10px;font-size:12px;color:#5f4a66;font-weight:800}
.progress-top strong{color:#a72e78}
.progress-track{height:13px;border-radius:999px;background:rgba(37,24,40,.15);margin:10px 0;overflow:hidden;border:1px solid rgba(37,24,40,.1)}
.progress-track span{display:block;width:0;height:100%;border-radius:inherit;background:linear-gradient(90deg,var(--pink),var(--gold),var(--jade),var(--cyan));transition:width .55s cubic-bezier(.3,.9,.2,1)}
.mood-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;margin-top:12px}
.mood-grid button{border:1px solid rgba(37,24,40,.16);border-radius:16px;padding:10px 9px;background:rgba(255,255,255,.42);font-weight:800;color:#51385a;cursor:pointer}
.mood-grid button.active{background:#211427;color:#fff;border-color:#211427;box-shadow:0 0 0 3px rgba(255,105,168,.16)}
.passport{display:grid;gap:9px;margin-top:12px}
.stamp-row{display:grid;grid-template-columns:44px 1fr auto;align-items:center;gap:10px;padding:10px;border:1px dashed rgba(37,24,40,.22);border-radius:17px;background:rgba(255,255,255,.38);cursor:pointer;transition:transform .15s,background .15s,border-color .15s}
.stamp-row:hover{transform:translateX(-2px);background:rgba(255,255,255,.68)}
.stamp-row.collected{border-style:solid;border-color:rgba(57,217,138,.45);background:rgba(227,255,239,.72)}
.stamp-row.filtered{opacity:.35;filter:grayscale(.6)}
.stamp-icon{width:42px;height:42px;border-radius:15px;background:linear-gradient(135deg,#2a1934,#51306c);display:grid;place-items:center;color:#fff;font-size:19px;box-shadow:3px 3px 0 rgba(37,24,40,.18)}
.stamp-row.collected .stamp-icon{background:linear-gradient(135deg,var(--jade),var(--cyan));color:#102018}
.stamp-title{display:block;font-weight:900;letter-spacing:-.025em;color:#24142b}
.stamp-meta{display:block;font-size:11px;color:#705978;margin-top:2px;font-weight:700;line-height:1.25}
.stamp-status{font-size:18px}
.controls-card{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.sound-toggle{margin-left:auto;border:1px solid rgba(37,24,40,.17);border-radius:999px;padding:8px 11px;background:rgba(255,255,255,.5);font-weight:800;color:#51385a;cursor:pointer;font-size:12px}
.anime-pin{position:relative;width:52px;height:64px;cursor:pointer;filter:drop-shadow(0 12px 8px rgba(0,0,0,.34));transition:transform .18s ease,filter .18s ease}
.anime-pin:hover{transform:translateY(-7px) scale(1.06);filter:drop-shadow(0 18px 12px rgba(0,0,0,.42))}
.anime-pin .orb{position:absolute;left:5px;top:0;width:42px;height:42px;border-radius:15px 15px 17px 4px;background:linear-gradient(135deg,var(--gold),var(--pink));border:2px solid #24142b;transform:rotate(45deg);display:grid;place-items:center;box-shadow:4px 4px 0 rgba(37,24,40,.28)}
.anime-pin .num{transform:rotate(-45deg);font-family:"Bricolage Grotesque",Inter,sans-serif;font-weight:900;font-size:19px;color:#211427}
.anime-pin .spark{position:absolute;left:50%;top:44px;width:10px;height:10px;margin-left:-5px;border-radius:50%;background:var(--cyan);box-shadow:0 0 0 6px rgba(104,225,253,.12),0 0 20px rgba(104,225,253,.85)}
.anime-pin.visited .orb{background:linear-gradient(135deg,var(--jade),var(--cyan))}
.anime-pin.active .orb{animation:pulse 1s ease-in-out infinite}
.anime-pin.filtered{opacity:.42;filter:grayscale(.8) drop-shadow(0 8px 4px rgba(0,0,0,.25))}
.anime-pin.drop{animation:pinDrop .58s cubic-bezier(.25,1.35,.4,1) both}
@keyframes pulse{0%,100%{box-shadow:4px 4px 0 rgba(37,24,40,.28),0 0 0 0 rgba(255,105,168,.46)}50%{box-shadow:4px 4px 0 rgba(37,24,40,.28),0 0 0 18px rgba(255,105,168,0)}}
@keyframes pinDrop{0%{opacity:0;transform:translateY(-70px) scale(.4)}72%{opacity:1;transform:translateY(6px) scale(1.06)}100%{transform:translateY(0) scale(1)}}
.leaflet-popup-content-wrapper{background:var(--panel-strong);border:1px solid rgba(37,24,40,.25);border-radius:20px;box-shadow:6px 7px 0 rgba(37,24,40,.26);padding:0}
.leaflet-popup-content{margin:0!important;width:270px!important}
.leaflet-popup-tip{background:var(--panel-strong)}
.leaflet-popup-close-button{color:#5b4064!important;font-size:22px!important;padding:9px 11px 0 0!important}
.pin-pop{padding:17px 18px;color:#2a1934}
.pin-pop b{font-family:"Bricolage Grotesque",Inter,sans-serif;font-size:20px;letter-spacing:-.035em;display:block;margin-bottom:5px}
.pin-pop p{font-size:12px;line-height:1.55;color:#604c68;margin:0 0 12px}.pin-pop button{width:100%;margin-top:2px}
.quest-drawer{position:absolute;left:34px;bottom:34px;z-index:55;width:min(430px,calc(100vw - 430px - 70px));max-width:430px;min-width:330px;max-height:calc(100dvh - 68px);overflow:auto;background:rgba(255,244,222,.95);border:1px solid rgba(255,255,255,.62);border-radius:28px;padding:22px;box-shadow:var(--hard),var(--shadow);transform:translateY(calc(100% + 60px));opacity:0;transition:transform .42s cubic-bezier(.25,.95,.25,1),opacity .25s;backdrop-filter:blur(16px)}
.quest-drawer.open{transform:translateY(0);opacity:1}
.drawer-close{position:absolute;right:14px;top:12px;width:32px;height:32px;border:1px solid rgba(37,24,40,.16);border-radius:50%;background:rgba(255,255,255,.5);cursor:pointer;font-size:24px;color:#604c68;line-height:24px}
.quest-drawer h2{font-family:"Bricolage Grotesque",Inter,sans-serif;font-size:34px;line-height:.95;letter-spacing:-.055em;margin:8px 34px 8px 0;color:#211427}
.drawer-sub{font-weight:800;color:#a72e78;margin:0 0 12px}.drawer-desc{font-size:14px;line-height:1.58;color:#58425f;margin:0 0 14px}
.mission-box{background:linear-gradient(135deg,rgba(255,105,168,.13),rgba(104,225,253,.16));border:1px solid rgba(37,24,40,.13);border-radius:18px;padding:13px 14px;margin-bottom:14px}
.mission-box span{font-family:"Space Mono",monospace;text-transform:uppercase;font-weight:800;letter-spacing:.1em;color:#8c3a74;font-size:10px}.mission-box p{margin:4px 0 0;color:#37243f;line-height:1.45;font-weight:700}
.challenge{display:grid;gap:9px;margin:12px 0}.challenge-title{font-weight:900;color:#2a1934}.challenge button{border:1px solid rgba(37,24,40,.16);border-radius:15px;background:rgba(255,255,255,.52);padding:10px;text-align:left;cursor:pointer;color:#4d3656;font-weight:750;line-height:1.25}.challenge button.correct{background:rgba(57,217,138,.22);border-color:rgba(57,217,138,.55)}.challenge button.wrong{background:rgba(255,90,95,.15);border-color:rgba(255,90,95,.45)}
.streaming{display:flex;flex-wrap:wrap;gap:7px}.streaming span{border-radius:999px;background:#211427;color:#fff;padding:6px 9px;font-size:11px;font-weight:850}.streaming span:first-child{background:#fff;color:#211427;border:1px solid rgba(37,24,40,.14)}
.finale{position:fixed;inset:0;z-index:60;display:none;place-items:center;background:rgba(15,11,21,.7);backdrop-filter:blur(8px);padding:24px}.finale.show{display:grid}.finale-card{position:relative;z-index:2;width:min(520px,100%);background:linear-gradient(135deg,#fff6df,#ffe3f2 55%,#dcf8ff);border:1px solid rgba(255,255,255,.7);border-radius:30px;padding:30px;text-align:center;box-shadow:8px 10px 0 rgba(0,0,0,.32),var(--shadow);animation:popIn .45s cubic-bezier(.25,1.25,.3,1) both}.finale-card h2{margin:9px 0 10px;font-family:"Bricolage Grotesque",Inter,sans-serif;font-size:38px;line-height:.95;letter-spacing:-.055em;color:#211427}.finale-card p{margin:0 auto 16px;max-width:410px;color:#604c68;line-height:1.55;font-weight:650}.watch-order{text-align:left;display:grid;gap:8px;margin:16px 0 0;padding-left:22px;color:#33223a;font-weight:850}.watch-order li{background:rgba(255,255,255,.5);border:1px solid rgba(37,24,40,.11);border-radius:14px;padding:8px 10px}.finale-actions{justify-content:center}
@keyframes popIn{from{opacity:0;transform:scale(.82) translateY(18px)}to{opacity:1;transform:scale(1) translateY(0)}}
#confetti{position:fixed;inset:0;width:100%;height:100%;pointer-events:none;z-index:1}.toast{position:fixed;left:50%;bottom:28px;z-index:70;transform:translateX(-50%) translateY(140%);background:#211427;color:#fff;border:1px solid rgba(255,255,255,.18);border-radius:999px;padding:12px 18px;font-weight:850;box-shadow:0 18px 50px rgba(0,0,0,.34);transition:transform .36s cubic-bezier(.25,.95,.25,1);max-width:calc(100vw - 24px);text-align:center}.toast.show{transform:translateX(-50%) translateY(0)}
@media (max-width:960px){body{overflow:auto}.app-shell{height:auto;min-height:100dvh;display:flex;flex-direction:column;gap:10px;padding:10px}.map-stage{height:48dvh;min-height:360px;border-radius:24px}.hud{height:auto;overflow:visible;order:2;gap:10px}.quest-drawer{position:fixed;left:10px;right:10px;bottom:10px;width:auto;max-width:none;min-width:0;max-height:min(78dvh,680px);padding:18px;border-radius:24px}.brand-card h1{font-size:44px}.controls-card .sound-toggle{margin-left:0}.toast{bottom:12px}}
@media (max-width:520px){.app-shell{padding:8px;padding-bottom:14px}.map-stage{height:42dvh;min-height:292px;border-radius:20px}.brand-card,.companion-card,.progress-card,.mood-card,.passport-card,.controls-card{border-radius:19px;padding:13px;box-shadow:3px 4px 0 rgba(37,24,40,.22),0 12px 34px rgba(0,0,0,.2)}.brand-card h1{font-size:39px;line-height:.9;margin-bottom:8px}.brand-card p,.drawer-desc{font-size:13px;line-height:1.48}.cta-row{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:12px}.cta-row .btn{width:100%;padding:10px 11px}.companion-card{grid-template-columns:46px 1fr}.retriever{width:44px;height:44px;border-radius:17px}.retriever .ear{width:14px;height:25px;top:9px}.retriever .left{left:-5px}.retriever .right{right:-5px}.retriever .snout{width:20px;height:13px;bottom:7px}.retriever .face{font-size:22px}.companion-card p{font-size:13px}.progress-card{position:sticky;top:8px;z-index:20}.progress-track{height:11px}.mood-grid{display:flex;gap:8px;overflow-x:auto;margin:10px -13px 0;padding:0 13px 2px;scrollbar-width:none}.mood-grid::-webkit-scrollbar{display:none}.mood-grid button{flex:0 0 auto;padding:9px 12px;border-radius:999px;font-size:13px}.stamp-row{grid-template-columns:38px 1fr auto;gap:9px;padding:9px;border-radius:15px}.stamp-icon{width:38px;height:38px;border-radius:13px}.stamp-title{font-size:14px}.stamp-meta{font-size:10.5px}.controls-card{display:grid;grid-template-columns:1fr 1fr;gap:8px}.controls-card .sound-toggle{grid-column:1 / -1;width:100%}.leaflet-control-zoom{display:none}.quest-drawer{left:8px;right:8px;bottom:max(8px,env(safe-area-inset-bottom));max-height:84dvh;padding:17px 15px 15px;border-radius:24px 24px 18px 18px}.drawer-close{right:11px;top:10px}.quest-drawer h2{font-size:30px;line-height:.96;margin-right:36px}.drawer-sub{font-size:13px;line-height:1.35}.mission-box{padding:11px 12px;border-radius:15px}.challenge button{padding:11px 10px}.streaming span{font-size:10.5px}.drawer-actions{display:grid;grid-template-columns:1fr 1fr;gap:8px}.drawer-actions .btn{width:100%;padding:10px 9px}.finale{padding:12px}.finale-card{padding:23px 16px;border-radius:24px}.finale-card h2{font-size:31px}.finale-card p{font-size:13px}.watch-order{padding-left:0;list-style-position:inside}.btn{min-height:42px}.toast{font-size:12px;padding:10px 13px;white-space:normal}}
@media (prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto!important}}
