/* ============================================================================
   THE TRIANGLE KEEPER — fluid Bermudian UI  (premium pass)
   Blend: Triangle deep-ocean · Gombey colour · Longtail elegance
   Type:  Space Grotesk (display) · Inter (UI) · Cormorant Garamond (accent)
   ========================================================================== */

:root{
  --abyss:#05131f; --deep:#082136; --deep-2:#0b2e44;
  --turq:#34e0d0; --teal:#1fb6c4; --peacock:#2aa7e0;
  --magenta:#e84d8a; --marigold:#ffb43d; --coral:#ff7a59;
  --sand:#ffd5c2; --pink:#ff9fb5; --pearl:#f3fbfb;
  --gold:#ffd66e; --gold-deep:#e9a417;
  --foam:#eef9f8; --foam-dim:#c2dde0; --muted:#8fb6bc; --ink:#06202c;

  --glass:rgba(10,34,52,.5); --glass-2:rgba(10,34,52,.74);
  --edge:rgba(120,225,220,.16); --edge-2:rgba(120,225,220,.34);
  --shadow:0 2px 8px rgba(0,0,0,.28),0 26px 64px -28px rgba(0,0,0,.82);
  --ring:0 0 0 3px rgba(52,224,208,.4);
  --ease:cubic-bezier(.2,.8,.2,1);
  --aurora:linear-gradient(105deg,var(--turq),var(--peacock) 45%,var(--magenta));
  --warm:linear-gradient(105deg,var(--marigold),var(--coral) 60%,var(--pink));

  --display:"Space Grotesk",system-ui,sans-serif;
  --ui:"Inter",system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  --serif:"Cormorant Garamond",Georgia,serif;
  --r-lg:22px; --r-md:14px; --r-sm:10px;
}

*{box-sizing:border-box}
html,body{height:100%}
body{margin:0;font-family:var(--ui);color:var(--foam);overflow:hidden;
  background:
    radial-gradient(96% 72% at 50% 30%, rgba(58,210,224,.34), transparent 62%),
    linear-gradient(178deg, #1184a6 0%, #0c668a 24%, #094f70 48%, #073e58 72%, #052e44 100%);
  background-color:#073e58;background-attachment:fixed;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
button{font-family:inherit;cursor:pointer;color:inherit}
:focus-visible{outline:2px solid var(--turq);outline-offset:2px;border-radius:6px}
::selection{background:rgba(52,224,208,.32);color:#fff}
.sprite{position:absolute;width:0;height:0;overflow:hidden}
h1,h2,.level-title,.lede{text-wrap:balance}

/* icons --------------------------------------------------------------------*/
.ico{width:18px;height:18px;flex:none;fill:none;stroke:currentColor;stroke-width:1.8;
  stroke-linecap:round;stroke-linejoin:round}
.ico use{fill:none}

/* ---------------------------- atmosphere ----------------------------------*/
.aurora{position:fixed;inset:-15%;z-index:-6;filter:blur(86px) saturate(116%);opacity:.6}
.aurora span{position:absolute;border-radius:50%;mix-blend-mode:screen;will-change:transform}
.aurora .a1{width:46vw;height:46vw;left:-6vw;top:-6vw;background:radial-gradient(circle,var(--turq),transparent 64%);animation:drift1 28s ease-in-out infinite}
.aurora .a2{width:38vw;height:38vw;right:-8vw;top:6vw;background:radial-gradient(circle,#5fe6da,transparent 64%);opacity:.5;animation:drift2 34s ease-in-out infinite}
.aurora .a3{width:40vw;height:40vw;left:18vw;bottom:-12vw;background:radial-gradient(circle,var(--peacock),transparent 64%);animation:drift3 31s ease-in-out infinite}
.aurora .a4{width:30vw;height:30vw;left:30vw;bottom:-10vw;background:radial-gradient(circle,#2aa7e0,transparent 66%);opacity:.5;animation:drift1 38s ease-in-out infinite reverse}
@keyframes drift1{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(6vw,4vh) scale(1.12)}}
@keyframes drift2{0%,100%{transform:translate(0,0) scale(1.05)}50%{transform:translate(-5vw,5vh) scale(.92)}}
@keyframes drift3{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(4vw,-5vh) scale(1.1)}}

/* ---- animated ocean ---- */
.ocean{position:fixed;inset:0;z-index:-5;overflow:hidden;pointer-events:none}
.sun{position:absolute;top:-12%;left:50%;width:64vw;height:46vh;transform:translateX(-50%);
  background:radial-gradient(circle at 50% 35%,rgba(255,238,196,.16),rgba(255,238,196,0) 60%);animation:sunsway 13s ease-in-out infinite}
@keyframes sunsway{0%,100%{opacity:.65;transform:translateX(-52%) scale(1)}50%{opacity:1;transform:translateX(-48%) scale(1.06)}}
.wave{position:absolute;left:0;right:0;background-repeat:repeat-x;background-size:1200px 100%;will-change:background-position,transform}
.wave-back{bottom:40%;height:150px;opacity:.18;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='1200' height='180'%3E%3Cpath d='M0,90C50,60,150,60,200,90C250,120,350,120,400,90C450,60,550,60,600,90C650,120,750,120,800,90C850,60,950,60,1000,90C1050,120,1150,120,1200,90L1200,180L0,180Z' fill='%235fe6da'/%3E%3C/svg%3E");animation:drift 26s linear infinite,bob 8s ease-in-out infinite}
.wave-mid{bottom:18%;height:190px;opacity:.3;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='1200' height='180'%3E%3Cpath d='M0,90C50,60,150,60,200,90C250,120,350,120,400,90C450,60,550,60,600,90C650,120,750,120,800,90C850,60,950,60,1000,90C1050,120,1150,120,1200,90L1200,180L0,180Z' fill='%231fb6c4'/%3E%3C/svg%3E");animation:driftR 18s linear infinite,bob 6.5s ease-in-out infinite}
.wave-front{bottom:-14px;height:230px;opacity:.5;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='1200' height='180'%3E%3Cpath d='M0,90C50,60,150,60,200,90C250,120,350,120,400,90C450,60,550,60,600,90C650,120,750,120,800,90C850,60,950,60,1000,90C1050,120,1150,120,1200,90L1200,180L0,180Z' fill='%230a4b66'/%3E%3Cpath d='M0,90C50,60,150,60,200,90C250,120,350,120,400,90C450,60,550,60,600,90C650,120,750,120,800,90C850,60,950,60,1000,90C1050,120,1150,120,1200,90' fill='none' stroke='%23eafcff' stroke-width='2.5' opacity='0.5'/%3E%3C/svg%3E");animation:drift 13s linear infinite,bob 5.5s ease-in-out infinite}
@keyframes drift{to{background-position-x:-1200px}}
@keyframes driftR{to{background-position-x:1200px}}
@keyframes bob{0%,100%{transform:translateY(0)}50%{transform:translateY(-7px)}}

.tri{position:fixed;inset:0;z-index:-4;display:grid;place-items:center;opacity:.36}
.tri svg{width:min(64vw,760px);height:auto;transform:translateY(-3%)}
.tri polygon{fill:none;stroke:rgba(120,225,220,.26);stroke-width:1.4;
  filter:drop-shadow(0 0 16px rgba(52,224,208,.4));animation:triPulse 8s ease-in-out infinite}
@keyframes triPulse{0%,100%{opacity:.22}50%{opacity:.5}}

#bg-canvas{position:fixed;inset:0;z-index:-3;pointer-events:none}
.grain{position:fixed;inset:0;z-index:-2;pointer-events:none;opacity:.04;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}
.vignette{position:fixed;inset:0;z-index:-1;pointer-events:none;
  background:radial-gradient(130% 105% at 50% 30%,transparent 66%,rgba(3,28,44,.2) 100%)}

/* user-supplied animated background photo — drop a file at static/bg.jpg.
   No fallback colour, so if the file is absent these stay transparent and the
   built-in ocean + lighthouse scene show through (nothing breaks). */
.photo-bg{position:fixed;inset:0;z-index:-4;background:center/cover no-repeat;
  background-image:url("/static/bg.jpg");animation:kenburns 46s ease-in-out infinite alternate;will-change:transform}
.scrim{position:fixed;left:0;right:0;top:0;height:140px;z-index:-1;pointer-events:none;
  background:linear-gradient(180deg,rgba(2,16,24,.34),transparent)}
.hero-photo{position:absolute;inset:0;z-index:1;background:center 42%/cover no-repeat;
  background-image:url("/static/bg.jpg");animation:kenburns 40s ease-in-out infinite alternate;will-change:transform}
.lighthouse{position:absolute;left:clamp(8px,2.5vw,36px);bottom:0;height:96%;width:auto;z-index:2;
  filter:drop-shadow(0 8px 16px rgba(0,0,0,.5));pointer-events:none}
@keyframes kenburns{from{transform:scale(1.06)}to{transform:scale(1.16) translate(-1.6%,-1.2%)}}

/* coral hazard flash when a defense fires */
body::after{content:"";position:fixed;inset:0;z-index:60;pointer-events:none;opacity:0;
  background:radial-gradient(120% 100% at 50% 50%,transparent 58%,rgba(255,90,70,.5) 100%)}
body.flash::after{animation:hazard .7s ease-out}
@keyframes hazard{0%{opacity:0}16%{opacity:1}100%{opacity:0}}

/* ------------------------------- layout -----------------------------------*/
#app{height:100vh;display:flex;flex-direction:column;padding:14px clamp(12px,2vw,28px) 12px}

.topbar{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:16px;
  padding-bottom:14px;border-bottom:1px solid rgba(120,225,220,.1);animation:rise .5s var(--ease) both}
.brand{display:flex;align-items:center;gap:13px;min-width:0}
.brand-mark{width:46px;height:46px;flex:none;filter:drop-shadow(0 0 12px rgba(52,224,208,.4));animation:floatY 7s ease-in-out infinite}
.brand-text h1{margin:0;font-family:var(--display);font-weight:700;letter-spacing:-.015em;
  font-size:clamp(20px,2.3vw,30px);line-height:1;
  background:linear-gradient(92deg,#fff,var(--turq) 58%,var(--pink));
  -webkit-background-clip:text;background-clip:text;color:transparent}
.brand-text p{margin:4px 0 0;font-family:var(--serif);font-style:italic;font-size:clamp(13px,1.3vw,16px);
  color:var(--foam-dim);letter-spacing:.01em}

.top-actions{display:flex;align-items:center;gap:9px;flex-wrap:wrap;justify-content:flex-end}
.presenter{font-size:11.5px;color:var(--foam-dim);letter-spacing:.04em;padding:6px 13px;border-radius:999px;
  background:rgba(120,225,220,.06);border:1px solid var(--edge)}
.ghost-btn{display:inline-flex;align-items:center;gap:8px;background:var(--glass);border:1px solid var(--edge);
  color:var(--foam);border-radius:999px;padding:9px 15px;font-size:13px;font-weight:500;
  backdrop-filter:blur(10px);transition:transform .18s var(--ease),border-color .18s,background .18s}
.ghost-btn:hover{border-color:var(--edge-2);background:var(--glass-2);transform:translateY(-1px)}
.ghost-btn.accent{border-color:rgba(255,159,181,.45);color:#ffd0db}
.ghost-btn.accent:hover{background:rgba(232,77,138,.14)}
.icon-btn{padding:9px;width:40px;justify-content:center}
.icon-btn .ico{width:20px;height:20px}

.stage{flex:1;min-height:0;display:grid;grid-template-columns:1.55fr .95fr;gap:clamp(14px,1.8vw,24px)}

/* ------------------------------- panels -----------------------------------*/
.panel{position:relative;background:linear-gradient(180deg,rgba(12,38,56,.34),rgba(6,24,38,.46));
  border:1px solid var(--edge);border-radius:var(--r-lg);box-shadow:var(--shadow);
  backdrop-filter:blur(22px);animation:rise .6s var(--ease) both}
.panel::before{content:"";position:absolute;inset:0;border-radius:inherit;padding:1px;pointer-events:none;
  background:linear-gradient(180deg,rgba(255,255,255,.3),rgba(120,225,220,.06) 26%,transparent 60%);
  -webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);-webkit-mask-composite:xor;
  mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);mask-composite:exclude}
.side-col .panel:nth-child(1){animation-delay:.06s}
.side-col .panel:nth-child(2){animation-delay:.13s}
.side-col .panel:nth-child(3){animation-delay:.2s}
@keyframes rise{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:none}}
.panel-title{display:flex;align-items:center;justify-content:space-between;
  font-family:var(--display);font-size:13px;letter-spacing:.03em;font-weight:600;
  color:var(--foam-dim);padding:14px 18px 11px;border-bottom:1px solid var(--edge)}
.panel-title span{display:inline-flex;align-items:center;gap:8px}
.panel-title .ico{color:var(--turq)}
.muted{color:var(--muted);font-family:var(--ui);font-weight:400;font-size:12px;font-variant-numeric:tabular-nums}

/* ----------------------- left: the Keeper + chat --------------------------*/
.keeper-col{display:flex;flex-direction:column;min-height:0;padding:0 0 16px;overflow:hidden}

.keeper-stage{position:relative;height:clamp(172px,21vh,224px);display:grid;place-items:center;flex:none;
  border-bottom:1px solid var(--edge);overflow:hidden}
.keeper-stage::before{content:"";position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(58% 64% at 50% 40%,rgba(52,224,208,.16),transparent 72%)}

/* the Gombey Keeper hero */
.gombey{height:100%;max-height:218px;width:auto;position:relative;z-index:1;filter:drop-shadow(0 16px 34px rgba(0,0,0,.55))}
.gombey .figure{transform-box:fill-box;transform-origin:50% 100%;animation:sway 3.6s ease-in-out infinite}
.gombey .crown{transform-box:fill-box;transform-origin:50% 100%;animation:shimmer 4.4s ease-in-out infinite}
.gombey .eye{animation:eyeFlicker 4s ease-in-out infinite}
.gombey .shadow{animation:shadowPulse 3.6s ease-in-out infinite}
@keyframes sway{0%,100%{transform:rotate(-3deg)}50%{transform:rotate(3deg)}}
@keyframes shimmer{0%,100%{transform:scale(1)}50%{transform:scale(1.045) rotate(.6deg)}}
@keyframes eyeFlicker{0%,100%{opacity:1}48%{opacity:.85}50%{opacity:.5}52%{opacity:.95}}
@keyframes shadowPulse{0%,100%{transform:scaleX(1);opacity:.3}50%{transform:scaleX(1.08);opacity:.2}}
@keyframes floatY{0%,100%{transform:translateY(0)}50%{transform:translateY(-9px)}}

/* gombey plumes — colour glow behind the figure */
.plume{position:absolute;width:220px;height:130px;border-radius:50%;filter:blur(38px);opacity:.42;mix-blend-mode:screen}
.plume.p1{background:var(--turq);animation:plume 13s ease-in-out infinite}
.plume.p2{background:var(--peacock);animation:plume 17s ease-in-out infinite reverse}
.plume.p3{background:#5fe6da;animation:plume 15s ease-in-out infinite}
@keyframes plume{0%{transform:rotate(0) scaleX(1)}50%{transform:rotate(180deg) scaleX(1.2)}100%{transform:rotate(360deg) scaleX(1)}}

/* keeper states (classes on #stage) */
.keeper-stage.thinking .figure{animation-duration:1.7s}
.keeper-stage.thinking .crown{animation-duration:1.7s}
.keeper-stage.thinking .eye{animation-duration:1.1s}
.keeper-stage.thinking .plume{opacity:.74}
.keeper-stage.blocked .eye{fill:#ff5a47}
.keeper-stage.blocked .figure{animation:shudder .5s ease}
.keeper-stage.blocked .plume.p1,.keeper-stage.blocked .plume.p3{background:var(--coral)}
.keeper-stage.win .figure{animation:hop .9s ease}
.keeper-stage.win .crown{animation-duration:1s}
@keyframes shudder{0%,100%{transform:rotate(0)}25%{transform:rotate(-4deg)}75%{transform:rotate(4deg)}}
@keyframes hop{0%,100%{transform:translateY(0)}42%{transform:translateY(-12px)}}

/* ---- AI Sentinel hero (techy) ---- */
.sentinel{height:100%;max-height:210px;width:auto;position:relative;z-index:1;filter:drop-shadow(0 14px 30px rgba(0,0,0,.5))}
.sentinel .sen{animation:floatY 6s ease-in-out infinite}
.sentinel .hud,.sentinel .scan,.sentinel .orbit,.sentinel .snCore,.sentinel .snGlow{transform-box:view-box;transform-origin:120px 120px}
.sentinel .hud{animation:spin 48s linear infinite}
.sentinel .scan{animation:spin 7s linear infinite}
.sentinel .o1{animation:spin 14s linear infinite}
.sentinel .o2{animation:spin 19s linear infinite reverse}
.sentinel .o3{animation:spin 26s linear infinite}
.sentinel .snCore{animation:corePulse 3.2s ease-in-out infinite}
.sentinel .snGlow{animation:glowPulse 3.2s ease-in-out infinite}
.sentinel .nodes circle{animation:blink 2.4s ease-in-out infinite}
.sentinel .nodes circle:nth-child(2){animation-delay:.6s}
.sentinel .nodes circle:nth-child(3){animation-delay:1.2s}
.sentinel .nodes circle:nth-child(4){animation-delay:1.8s}
@keyframes corePulse{0%,100%{transform:scale(.94);opacity:.92}50%{transform:scale(1.06);opacity:1}}
@keyframes glowPulse{0%,100%{opacity:.45;transform:scale(.9)}50%{opacity:.85;transform:scale(1.12)}}
@keyframes blink{0%,100%{opacity:.3}50%{opacity:1}}
.keeper-stage.thinking .o1{animation-duration:5s}
.keeper-stage.thinking .o2{animation-duration:7s}
.keeper-stage.thinking .scan{animation-duration:2.4s}
.keeper-stage.thinking .snCore,.keeper-stage.thinking .snGlow{animation-duration:1.2s}
.keeper-stage.blocked .snCore{fill:#ff5a47}
.keeper-stage.blocked .ringE{stroke:#ff5a47}
.keeper-stage.blocked .sen{animation:shudder .5s ease}
.keeper-stage.win .sen{animation:hop .9s ease}
.keeper-stage.win .snCore{filter:url(#sn_blur) brightness(1.35)}

/* ---- Bermuda coast scene hero: lighthouse + shipwreck + techy HUD ---- */
.scene{position:absolute;inset:0;width:100%;height:100%;display:block}
.scene .beam{transform-box:view-box;transform-origin:120px 50px;animation:beamSweep 7s ease-in-out infinite alternate}
.scene .beam path{mix-blend-mode:screen}
@keyframes beamSweep{from{transform:rotate(-13deg)}to{transform:rotate(33deg)}}
.scene .sun,.scene .sunGlow{transform-box:view-box;transform-origin:470px 124px;animation:glowPulse 5s ease-in-out infinite}
.scene .lightGlow{transform-box:view-box;transform-origin:120px 50px;animation:glowPulse 2.6s ease-in-out infinite}
.scene .ship{transform-box:view-box;transform-origin:578px 150px;animation:shipBob 5.5s ease-in-out infinite}
@keyframes shipBob{0%,100%{transform:rotate(-1.2deg) translateY(0)}50%{transform:rotate(.4deg) translateY(-2px)}}
.scene .wave1{animation:sceneWaveA 11s linear infinite}
.scene .wave2{animation:sceneWaveB 8s linear infinite}
@keyframes sceneWaveA{from{transform:translateX(0)}to{transform:translateX(-110px)}}
@keyframes sceneWaveB{from{transform:translateX(-110px)}to{transform:translateX(0)}}
.scene .stars circle{animation:blink 3.2s ease-in-out infinite}
.scene .stars circle:nth-child(2n){animation-delay:1s}
.scene .stars circle:nth-child(3n){animation-delay:2s}
.scene .grid{animation:gridPulse 4s ease-in-out infinite}
@keyframes gridPulse{0%,100%{opacity:.07}50%{opacity:.14}}
.scene .scanline{animation:scanDown 5.5s linear infinite}
@keyframes scanDown{0%{transform:translateY(-6px);opacity:0}12%{opacity:.5}88%{opacity:.5}100%{transform:translateY(244px);opacity:0}}
.keeper-stage.thinking .scene .beam{animation-duration:3s}
.keeper-stage.thinking .scene .scanline{animation-duration:2.6s}
.keeper-stage.blocked .scene .beam path{fill:#ff3b30}
.keeper-stage.blocked .scene .alert{animation:alertFlash .7s ease}
@keyframes alertFlash{0%{opacity:0}28%{opacity:.5}100%{opacity:0}}
.keeper-stage.win .scene .winflash{animation:winFlash 1.1s ease}
@keyframes winFlash{0%{opacity:0}30%{opacity:.4}100%{opacity:0}}
.scene .clouds{animation:cloudDrift 46s ease-in-out infinite alternate}
@keyframes cloudDrift{from{transform:translateX(-22px)}to{transform:translateX(22px)}}
.scene .sunpath{animation:shimmerP 5s ease-in-out infinite}
@keyframes shimmerP{0%,100%{opacity:.82}50%{opacity:1}}

.level-head{padding:16px 22px 12px;flex:none}
.level-eyebrow{font-family:var(--ui);font-size:10.5px;letter-spacing:.26em;text-transform:uppercase;color:var(--turq);font-weight:700}
.level-title{margin:6px 0 12px;font-family:var(--display);font-weight:600;font-size:clamp(20px,2vw,26px);color:#fff;letter-spacing:-.015em;line-height:1.1}
.badges{display:flex;flex-wrap:wrap;gap:7px}
.badge{font-size:11px;font-weight:600;letter-spacing:.01em;padding:4px 11px;border-radius:999px;
  background:rgba(52,224,208,.13);border:1px solid rgba(52,224,208,.3);color:#7ff0e4}
.badge.none{background:rgba(123,163,170,.1);border-color:rgba(123,163,170,.25);color:var(--muted)}
.badge.heavy{background:rgba(255,180,61,.14);border-color:rgba(255,180,61,.42);color:var(--marigold)}
.badges.small .badge{font-size:10px;padding:3px 9px}

.chat-log{flex:1;min-height:0;overflow-y:auto;padding:16px 20px;display:flex;flex-direction:column;gap:12px}
.msg{max-width:84%;padding:11px 15px;border-radius:18px;line-height:1.55;font-size:14.5px;
  animation:fadeUp .4s var(--ease) both;position:relative}
.msg.keeper{align-self:flex-start;background:linear-gradient(180deg,rgba(21,78,96,.88),rgba(11,46,64,.94));
  border:1px solid var(--edge-2);border-bottom-left-radius:6px;color:var(--foam);
  box-shadow:0 8px 22px -14px rgba(0,0,0,.7),inset 0 1px 0 rgba(255,255,255,.06)}
.msg.sailor{align-self:flex-end;color:#3a1622;border-bottom-right-radius:6px;font-weight:500;
  background:linear-gradient(135deg,var(--sand),var(--pink));box-shadow:0 8px 22px -14px rgba(255,159,181,.5)}
.msg.system{align-self:center;max-width:92%;text-align:center;font-family:var(--serif);font-style:italic;
  font-size:15.5px;color:var(--foam-dim);background:none;padding:2px 8px}
.msg.blocked{align-self:flex-start;background:linear-gradient(180deg,rgba(70,30,26,.86),rgba(46,18,16,.94));
  border:1px solid rgba(255,122,89,.5);border-bottom-left-radius:6px;color:#ffd9d0;
  box-shadow:0 8px 22px -14px rgba(255,90,70,.4)}
.msg .caret{display:inline-block;width:8px;color:var(--turq);animation:caret 1s steps(1) infinite}
.msg.blocked .red{color:var(--coral);font-style:italic;opacity:.85}
@keyframes fadeUp{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
@keyframes caret{50%{opacity:0}}

.typing{align-self:flex-start;display:flex;gap:5px;padding:13px 16px;background:rgba(11,46,64,.7);
  border:1px solid var(--edge);border-radius:18px;border-bottom-left-radius:6px}
.typing i{width:7px;height:7px;border-radius:50%;background:var(--turq);opacity:.5;animation:dot 1.1s ease-in-out infinite}
.typing i:nth-child(2){animation-delay:.18s}.typing i:nth-child(3){animation-delay:.36s}
@keyframes dot{0%,100%{transform:translateY(0);opacity:.4}50%{transform:translateY(-5px);opacity:1}}

.chat-log::-webkit-scrollbar,.side-col::-webkit-scrollbar{width:9px}
.chat-log::-webkit-scrollbar-thumb,.side-col::-webkit-scrollbar-thumb{background:rgba(52,224,208,.22);border-radius:9px}
.chat-log::-webkit-scrollbar-thumb:hover,.side-col::-webkit-scrollbar-thumb:hover{background:rgba(52,224,208,.36)}
.chat-log::-webkit-scrollbar-track,.side-col::-webkit-scrollbar-track{background:transparent}

.composer{display:flex;gap:10px;padding:12px 20px 0;flex:none}
.chat-input{flex:1;background:rgba(5,19,31,.62);border:1px solid var(--edge);border-radius:999px;
  padding:13px 18px;color:var(--foam);font-size:14.5px;outline:none;transition:border-color .18s,box-shadow .18s}
.chat-input::placeholder{color:var(--muted)}
.chat-input:focus{border-color:var(--teal);box-shadow:var(--ring)}
.send-btn{flex:none;width:48px;height:48px;border-radius:50%;border:none;color:#04222b;
  background:var(--aurora);background-size:170% 170%;background-position:0% 50%;display:grid;place-items:center;
  box-shadow:0 10px 24px -10px rgba(42,167,224,.85),inset 0 1px 0 rgba(255,255,255,.3);
  transition:transform .2s var(--ease),box-shadow .2s,background-position .5s}
.send-btn .ico{stroke-width:2;color:#04222b}
.send-btn:hover{transform:translateY(-2px) rotate(6deg);background-position:100% 50%;box-shadow:0 14px 28px -10px rgba(52,224,208,.95)}
.send-btn:active{transform:scale(.94)}
.send-btn:disabled{opacity:.5;cursor:wait;transform:none}

.vault{padding:14px 20px 0;flex:none}
.vault-label{display:flex;align-items:center;gap:8px;font-family:var(--serif);font-style:italic;font-size:14.5px;color:var(--gold);margin-bottom:8px}
.vault-label .ico{color:var(--gold);width:17px;height:17px}
.vault-row{display:flex;gap:10px}
.vault-input{flex:1;background:rgba(40,30,8,.4);border:1px solid rgba(255,214,110,.4);border-radius:var(--r-sm);
  padding:12px 16px;color:var(--gold);font-size:15px;letter-spacing:.1em;text-transform:uppercase;font-weight:600;outline:none;transition:border-color .18s,box-shadow .18s}
.vault-input::placeholder{color:rgba(255,214,110,.45);letter-spacing:.03em;text-transform:none;font-weight:400}
.vault-input:focus{border-color:var(--gold);box-shadow:0 0 0 3px rgba(255,214,110,.22)}
.vault-btn{flex:none;border:none;border-radius:var(--r-sm);padding:0 24px;font-weight:700;font-size:14px;letter-spacing:.02em;color:#3a2606;
  background:linear-gradient(160deg,var(--gold),var(--gold-deep));box-shadow:0 8px 20px -8px rgba(233,164,23,.7),inset 0 1px 0 rgba(255,255,255,.4);
  transition:transform .2s var(--ease);position:relative;overflow:hidden}
.vault-btn:hover{transform:translateY(-2px)}
.vault-btn::after{content:"";position:absolute;top:0;left:-120%;width:55%;height:100%;background:linear-gradient(100deg,transparent,rgba(255,255,255,.6),transparent);transform:skewX(-18deg)}
.vault-btn:hover::after{animation:shine .8s ease}
@keyframes shine{to{left:135%}}
.vault-feedback{min-height:18px;margin-top:8px;font-size:13px;font-weight:600}
.vault-feedback.ok{color:var(--turq)}.vault-feedback.bad{color:var(--coral)}

/* --------------------- right: chart / briefing / board --------------------*/
.side-col{display:flex;flex-direction:column;gap:clamp(12px,1.4vw,18px);min-height:0;overflow-y:auto;padding-right:2px}
.chart-panel #map-svg{width:100%;height:auto;display:block;padding:10px 8px 16px}

.route{fill:none;stroke:rgba(120,225,220,.2);stroke-width:2.5;stroke-dasharray:1 9;stroke-linecap:round}
.route-done{fill:none;stroke-width:3;stroke-linecap:round;stroke-dasharray:1 9;animation:flow 18s linear infinite}
@keyframes flow{to{stroke-dashoffset:-200}}
.map-node{cursor:default}
.map-node.unlocked,.map-node.cleared,.map-node.current{cursor:pointer}
.map-node .halo{fill:none;stroke:transparent;stroke-width:2}
.map-node .dot{fill:#0b2e44;stroke:rgba(120,225,220,.4);stroke-width:2;transition:.2s;filter:drop-shadow(0 2px 4px rgba(0,0,0,.4))}
.map-node .num{font-family:var(--display);font-size:13px;font-weight:600;text-anchor:middle;dominant-baseline:central;fill:var(--foam-dim)}
.map-node .label{font-family:var(--ui);font-size:12px;font-weight:600;fill:var(--foam-dim)}
.map-node .sub{font-family:var(--ui);font-size:9.5px;fill:var(--muted)}
.map-node.locked .dot{fill:#0a2230;stroke:rgba(123,163,170,.22)}
.map-node.locked .num{fill:var(--muted)}
.map-node.locked .label{fill:var(--muted)}
.map-node.unlocked .dot{fill:#0e4a5a;stroke:var(--turq)}
.map-node.unlocked:hover .dot{fill:#127a86}
.map-node.cleared .dot{fill:url(#nodeGold);stroke:var(--gold);filter:drop-shadow(0 0 6px rgba(255,214,110,.65))}
.map-node.cleared .num{fill:#3a2606}
.map-node.cleared .label{fill:var(--gold)}
.map-node.current .dot{fill:#0e4a5a;stroke:#fff;stroke-width:2.4}
.map-node.current .halo{stroke:var(--turq);animation:halo 1.9s ease-out infinite}
.map-node.current .num{fill:#fff}
.map-node.current .label{fill:#fff}
@keyframes halo{0%{stroke-opacity:.85;r:15}100%{stroke-opacity:0;r:27}}

.briefing-panel{padding-bottom:16px}
.briefing-title{margin:14px 18px 6px;font-family:var(--display);font-size:16px;color:var(--turq);font-weight:600;letter-spacing:-.01em}
.briefing-text{margin:0 18px 12px;font-size:13.5px;line-height:1.62;color:var(--foam-dim)}
.briefing-panel .badges{padding:0 18px}
.briefing-idt{margin:12px 18px 0;padding-top:12px;border-top:1px solid var(--edge);
  font-family:var(--serif);font-style:italic;font-size:13.5px;color:var(--gold);line-height:1.5}

.board{list-style:none;margin:0;padding:10px 14px 14px;counter-reset:rank}
.board li{counter-increment:rank;display:flex;align-items:center;gap:10px;padding:8px;border-radius:var(--r-sm)}
.board li:nth-child(odd){background:rgba(255,255,255,.03)}
.board li::before{content:counter(rank);flex:none;width:24px;height:24px;border-radius:50%;display:grid;place-items:center;
  font-size:12px;font-weight:700;color:var(--foam-dim);background:rgba(52,224,208,.12);border:1px solid var(--edge)}
.board li:nth-child(1)::before{background:linear-gradient(160deg,var(--gold),var(--gold-deep));color:#3a2606;border:none;box-shadow:0 2px 10px -2px rgba(255,214,110,.6)}
.board li:nth-child(2)::before{background:linear-gradient(160deg,#e6eef0,#9fb2b6);color:#1a2628;border:none}
.board li:nth-child(3)::before{background:linear-gradient(160deg,#e8a87c,#b9714a);color:#2a1408;border:none}
.board .bd-name{flex:1;font-weight:600;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.board .bd-parish{font-size:11.5px;color:var(--muted)}
.board .bd-time{font-size:12px;color:var(--foam-dim);font-variant-numeric:tabular-nums}
.board .empty{color:var(--muted);font-style:italic;font-size:13px;padding:10px;text-align:center}

/* ------------------------------- modals -----------------------------------*/
.modal{position:fixed;inset:0;z-index:100;display:grid;place-items:center;padding:24px;
  background:rgba(2,10,16,.76);backdrop-filter:blur(10px);animation:fadeUp .3s ease}
.modal[hidden]{display:none}
.modal-card{width:min(540px,100%);max-height:90vh;overflow-y:auto;text-align:center;position:relative;
  background:linear-gradient(180deg,rgba(16,54,72,.97),rgba(7,28,42,.99));
  border:1px solid var(--edge-2);border-radius:26px;padding:36px 32px;
  box-shadow:0 40px 100px -28px rgba(0,0,0,.85),inset 0 1px 0 rgba(255,255,255,.1);
  animation:pop .42s cubic-bezier(.2,.9,.3,1.2) both}
.modal-card::before{content:"";position:absolute;inset:0;border-radius:inherit;padding:1px;pointer-events:none;
  background:linear-gradient(180deg,rgba(255,255,255,.34),transparent 42%);
  -webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);-webkit-mask-composite:xor;
  mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);mask-composite:exclude}
@keyframes pop{from{opacity:0;transform:translateY(20px) scale(.96)}to{opacity:1;transform:none}}
.modal-crest{width:76px;height:76px;border-radius:22px;margin:0 auto 16px;display:grid;place-items:center;
  background:var(--aurora);box-shadow:0 16px 38px -10px rgba(42,167,224,.7),inset 0 1px 0 rgba(255,255,255,.42)}
.modal-crest.gold{background:linear-gradient(150deg,var(--gold),var(--gold-deep));box-shadow:0 16px 38px -10px rgba(233,164,23,.7),inset 0 1px 0 rgba(255,255,255,.5)}
.modal-crest.big{width:90px;height:90px;border-radius:26px}
.crest-ico{width:38px;height:38px;fill:none;stroke:#fff;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.modal-crest.gold .crest-ico{stroke:#3a2606}
.modal-card h2{margin:6px 0 12px;font-family:var(--display);font-weight:700;font-size:clamp(22px,3vw,30px);letter-spacing:-.015em;
  background:linear-gradient(92deg,#fff,var(--turq) 70%,var(--pink));-webkit-background-clip:text;background-clip:text;color:transparent}
.lede{font-family:var(--serif);font-size:18px;line-height:1.55;color:var(--foam-dim);margin:0 0 16px}
.lede em{color:var(--gold);font-style:italic}
.howto{text-align:left;max-width:410px;margin:0 auto 16px;padding-left:22px;line-height:1.6;font-size:14.5px;color:var(--foam)}
.howto li{margin-bottom:8px}.howto b{color:var(--turq)}
.fine{font-size:13px;color:var(--muted);margin:0 0 20px}
.cta{border:none;border-radius:999px;padding:14px 32px;font-size:15px;font-weight:700;letter-spacing:.01em;color:#04222b;
  background:var(--aurora);background-size:180% 180%;background-position:0% 50%;
  box-shadow:0 14px 32px -12px rgba(42,167,224,.85),inset 0 1px 0 rgba(255,255,255,.32);
  transition:transform .2s var(--ease),box-shadow .2s,background-position .5s}
.cta:hover{transform:translateY(-2px);background-position:100% 50%;box-shadow:0 20px 40px -12px rgba(52,224,208,.95)}
.text-close{display:block;margin:14px auto 0;background:none;border:none;color:var(--muted);font-size:13px}
.text-close:hover{color:var(--foam-dim);text-decoration:underline}
.x-close{position:absolute;top:14px;right:14px;background:none;border:none;color:var(--muted);width:34px;height:34px;display:grid;place-items:center;border-radius:50%;transition:.18s}
.x-close:hover{color:var(--foam);background:rgba(255,255,255,.06)}
.x-close .ico{width:20px;height:20px}

.reveal-pass{display:inline-block;font-family:var(--display);font-weight:700;letter-spacing:.12em;color:var(--gold);
  background:rgba(255,214,110,.12);border:1px solid rgba(255,214,110,.4);padding:4px 14px;border-radius:8px;margin-top:6px}
.celebrate .modal-crest{animation:floatY 3s ease-in-out infinite}
.claim{display:flex;gap:10px;margin:8px 0 16px}
.claim input{flex:1;background:rgba(5,19,31,.6);border:1px solid var(--edge);border-radius:999px;padding:13px 18px;color:var(--foam);font-size:14px;outline:none;transition:border-color .18s,box-shadow .18s}
.claim input:focus{border-color:var(--teal);box-shadow:var(--ring)}
.victory .board{max-height:200px;overflow:auto;text-align:left;margin-bottom:8px}

.modal-card.team{width:min(620px,100%)}
.team-body{font-size:14.5px;line-height:1.62;color:var(--foam-dim);text-align:left;margin:0 0 18px}
.team-body b{color:var(--turq)}
.team-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin:0 0 18px}
.team-card{background:rgba(10,34,52,.5);border:1px solid var(--edge);border-radius:var(--r-md);padding:16px 14px;text-align:center;transition:transform .2s var(--ease),border-color .2s}
.team-card:hover{transform:translateY(-2px);border-color:var(--edge-2)}
.team-card .ico{width:26px;height:26px;margin:0 auto;color:var(--turq)}
.team-card b{display:block;margin-top:8px;font-size:14px;color:var(--foam)}
.team-card span{font-size:12px;color:var(--muted)}

/* loading */
#loading{position:fixed;inset:0;z-index:200;display:grid;place-items:center;gap:20px;background:var(--abyss);transition:opacity .5s ease}
#loading.hide{opacity:0;pointer-events:none}
#loading p{font-family:var(--serif);font-style:italic;font-size:18px;color:var(--foam-dim)}
.loader{width:60px;height:60px;border-radius:50%;background:conic-gradient(from 0deg,var(--turq),var(--magenta),var(--marigold),var(--turq));
  -webkit-mask:radial-gradient(farthest-side,transparent calc(100% - 5px),#000 0);mask:radial-gradient(farthest-side,transparent calc(100% - 5px),#000 0);animation:spin 1s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes shake{10%,90%{transform:translateX(-2px)}20%,80%{transform:translateX(4px)}30%,50%,70%{transform:translateX(-7px)}40%,60%{transform:translateX(7px)}}

/* longtail that glides across the screen on a win */
.longtail-fly{position:fixed;top:0;left:0;z-index:90;width:58px;height:24px;pointer-events:none;filter:drop-shadow(0 3px 8px rgba(0,0,0,.45))}
.longtail-fly svg{width:100%;height:100%}

/* ------------------------------ responsive --------------------------------*/
@media (max-width:1024px){
  body{overflow:auto}
  #app{height:auto;min-height:100vh}
  .stage{grid-template-columns:1fr}
  .keeper-col{height:80vh;min-height:580px}
  .side-col{overflow:visible}
}
@media (max-width:560px){
  .top-actions .presenter,.ghost-btn span{display:none}
  .ghost-btn{padding:9px}.ghost-btn.accent,.ghost-btn#btn-howto{width:40px;justify-content:center}
  .brand-text h1{font-size:20px}
  .team-grid{grid-template-columns:1fr}
  .modal-card{padding:26px 20px}
}
@media (prefers-reduced-motion:reduce){
  *{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.05ms!important}
  .aurora,.tri{opacity:.3}
}

/* ============ compact sizing pass — smaller text + boxes ============ */
.topbar{margin-bottom:12px;padding-bottom:10px}
.brand-mark{width:40px;height:40px}
.brand-text h1{font-size:clamp(17px,1.9vw,24px)}
.brand-text p{font-size:clamp(11px,1vw,13px);margin-top:3px}
.ghost-btn{padding:7px 12px;font-size:12px}
.presenter{font-size:11px;padding:5px 11px}

.panel-title{font-size:12px;padding:11px 15px 8px}
.muted{font-size:11px}
.keeper-stage{height:clamp(130px,16vh,176px)}
.level-head{padding:10px 18px 8px}
.level-eyebrow{font-size:10px}
.level-title{font-size:clamp(16px,1.6vw,21px);margin:4px 0 8px}
.badge{font-size:10px;padding:3px 9px}
.badges{gap:6px}

.chat-log{padding:11px 16px;gap:8px}
.msg{font-size:13px;padding:8px 12px;border-radius:15px}
.msg.system{font-size:13px}
.composer{padding:9px 16px 0;gap:8px}
.chat-input{padding:10px 15px;font-size:13px}
.send-btn{width:40px;height:40px}
.send-btn .ico{width:17px;height:17px}

.vault{padding:9px 16px 0}
.vault-label{font-size:12.5px;margin-bottom:6px}
.vault-input{padding:9px 14px;font-size:13.5px}
.vault-btn{padding:0 18px;font-size:13px}
.vault-feedback{font-size:12px}

.side-col{gap:clamp(9px,1.1vw,13px)}
.briefing-title{font-size:14px;margin:11px 16px 5px}
.briefing-text{font-size:12.5px;margin:0 16px 9px;line-height:1.55}
.briefing-idt{font-size:12.5px;margin:10px 16px 0}

.board{padding:7px 12px 11px}
.board li{padding:6px 7px;gap:8px}
.board li::before{width:21px;height:21px;font-size:11px}
.board .bd-name{font-size:12.5px}
.board .bd-parish{font-size:10.5px}
.board .bd-time{font-size:11px}

.map-node .label{font-size:11px}
.map-node .sub{font-size:9px}
.map-node .num{font-size:11.5px}
.map-node .dot{r:13}

.modal-card{padding:28px 26px}
.modal-card h2{font-size:clamp(20px,2.5vw,26px)}
.lede{font-size:16px}
.howto{font-size:13.5px}
.cta{padding:12px 26px;font-size:14px}

/* ---- single centered column + menu pop-ups ---- */
.stage{flex:1;min-height:0;position:relative;display:flex;flex-wrap:wrap;justify-content:center;align-items:stretch;align-content:center;gap:clamp(16px,3vw,56px);overflow:auto;padding:8px 0}
.keeper-col{flex:none;width:min(760px,100%);max-height:100%}
.chat-log{flex:none;height:clamp(150px,26vh,290px)}
.menu-card{width:min(440px,100%);text-align:left}
#modal-board .modal-card{width:min(470px,100%)}
.menu-head{display:flex;align-items:center;justify-content:space-between;gap:10px;
  font-family:var(--display);font-size:14px;font-weight:600;color:var(--foam);
  padding:0 34px 11px 2px;margin-bottom:6px;border-bottom:1px solid var(--edge)}
.menu-head span{display:inline-flex;align-items:center;gap:8px}
.menu-head .ico{color:var(--turq)}
.menu-card #map-svg{display:block;width:100%;height:auto;max-height:62vh}
.menu-card .briefing-title{text-align:left;margin:10px 0 6px}
.menu-card .briefing-text{text-align:left;margin:0 0 12px}
.menu-card .briefing-idt{text-align:left;margin:12px 0 0}
.menu-card .badges{justify-content:flex-start}
.menu-card .board{padding:6px 0 0}

/* ============ layout v2 — map rail beside lighthouse, larger text, compact chat ============ */
.level-title{font-size:clamp(20px,2vw,26px);margin:5px 0 9px}
.msg,.msg.system{font-size:15px}
.chat-input{font-size:15px}
.vault-label{font-size:14px}
.vault-input{font-size:15px}
.vault-btn{font-size:14px}
.level-eyebrow{font-size:11px}
.badge{font-size:11px}
.menu-head{font-size:15px}

.keeper-stage{height:clamp(150px,18vh,204px)}
.lighthouse{left:clamp(6px,2vw,26px);height:96%}
.hero-map{flex:none;align-self:flex-start;width:clamp(210px,19vw,300px);max-height:min(80vh,560px);z-index:5;
  display:flex;flex-direction:column;padding:13px 14px;border-radius:18px;
  background:linear-gradient(180deg,rgba(8,28,42,.52),rgba(6,22,34,.64));border:1px solid var(--edge);
  box-shadow:var(--shadow);backdrop-filter:blur(16px)}
.hero-map-head{display:flex;align-items:center;justify-content:space-between;gap:8px;
  font-family:var(--display);font-size:12px;font-weight:600;color:var(--foam-dim);
  padding-bottom:7px;margin-bottom:5px;border-bottom:1px solid var(--edge)}
.hero-map-head .muted{font-size:11px}
.level-rail{flex:1;min-height:0;overflow-y:auto;display:flex;flex-direction:column;gap:2px;padding-right:2px}
.lvl-chip{display:flex;align-items:center;gap:9px;width:100%;text-align:left;border:none;background:transparent;
  border-radius:8px;padding:4px 7px;color:var(--foam-dim);font-family:var(--ui);cursor:pointer;transition:background .15s}
.lvl-chip:hover{background:rgba(255,255,255,.07)}
.lvl-chip .lvl-num{flex:none;width:22px;height:22px;border-radius:50%;display:grid;place-items:center;
  font-size:11.5px;font-weight:700;background:rgba(52,224,208,.14);border:1px solid var(--edge);color:var(--foam-dim)}
.lvl-chip .lvl-name{font-size:13px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.lvl-chip.locked{opacity:.5;cursor:default}
.lvl-chip.locked .lvl-num{background:rgba(123,163,170,.12)}
.lvl-chip.unlocked .lvl-num{border-color:var(--turq);color:var(--turq)}
.lvl-chip.cleared .lvl-num{background:linear-gradient(160deg,var(--gold),var(--gold-deep));color:#3a2606;border:none}
.lvl-chip.cleared .lvl-name{color:var(--gold)}
.lvl-chip.current{background:rgba(52,224,208,.14)}
.lvl-chip.current .lvl-num{background:var(--turq);color:#04222b;border-color:#fff}
.lvl-chip.current .lvl-name{color:#fff}

.chat-log{height:clamp(108px,15vh,176px)}

/* standalone right map panel — roomier chips with subtitle */
.hero-map-head{font-size:13px}
.level-rail{gap:3px}
.lvl-chip{gap:11px;padding:6px 9px}
.lvl-chip .lvl-num{width:25px;height:25px;font-size:12.5px}
.lvl-text{display:flex;flex-direction:column;min-width:0;line-height:1.2}
.lvl-chip .lvl-name{font-size:14px}
.lvl-sub{font-size:10.5px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.lvl-chip.cleared .lvl-sub,.lvl-chip.current .lvl-sub{color:var(--foam-dim)}

/* pinned riddle / level description (stays put while you chat) */
.level-intro{margin:0 18px 9px;padding:11px 15px;border-radius:12px;
  font-family:var(--serif);font-style:italic;font-size:17px;line-height:1.5;color:var(--foam);
  background:rgba(255,255,255,.05);border:1px solid var(--edge)}
.level-intro:empty{display:none}

/* ============ Gandalf-style interactive input (roomy box, send tucked in corner) ============ */
.composer{position:relative;display:block;gap:0;padding:4px 18px 0;flex:none}
.chat-input{flex:none;width:100%;min-height:66px;max-height:150px;resize:none;display:block;
  border-radius:16px;padding:14px 60px 14px 16px;font-size:15px;font-family:var(--ui);line-height:1.5}
.send-btn{position:absolute;right:28px;bottom:11px;width:40px;height:40px;border-radius:12px}
.send-btn:hover{transform:translateY(-1px);background-position:100% 50%}

/* center the greeting under the image (Gandalf-style plain centered line) */
.level-intro{margin:2px 18px 12px;padding:0 6px;background:none;border:none;border-radius:0;text-align:center}

/* card and map share the same height — balanced side-by-side columns */
.hero-map{align-self:stretch;max-height:100%}
.level-rail{justify-content:space-between}
/* drop the panel entrance-rise on the always-visible card so it doesn't sit 16px low (modals keep it) */
.keeper-col{animation:none;transform:none}

/* ===== Bermuda parish map (right panel) ===== */
.parish-map{width:100%;flex:1;min-height:0;display:block}
.isle-glow{fill:none;stroke:rgba(52,224,208,.10);stroke-width:25;stroke-linecap:round;stroke-linejoin:round}
.isle-coast{fill:none;stroke:rgba(216,242,232,.26);stroke-width:16;stroke-linecap:round;stroke-linejoin:round}
.isle-land{fill:none;stroke-width:13;stroke-linecap:round;stroke-linejoin:round}     /* stroke (isleGrad) set in JS */
.isle-trail{fill:none;stroke:rgba(255,255,255,.16);stroke-width:1.5;stroke-dasharray:1 7;stroke-linecap:round}
.isle-progress{fill:none;stroke-width:2.6;stroke-linecap:round;filter:drop-shadow(0 0 4px rgba(52,224,208,.55))} /* stroke (routeGrad) set in JS */
#parish-map .label{font-size:11px}
#parish-map .sub{font-size:9px}
.compass{opacity:.55}
.compass circle{fill:rgba(6,24,38,.55);stroke:rgba(120,225,220,.3);stroke-width:1}
.compass .n{font-family:var(--ui);font-size:9px;font-weight:700;fill:var(--turq)}
.compass .needle{fill:var(--gold)}

/* per-level hero: real parish photos fill the banner (cover), not a standing cutout */
#level-img{position:absolute;inset:0;left:0;top:0;width:100%;height:100%;object-fit:cover;object-position:center;filter:none}
/* soft scrim so the photo blends into the card below */
.keeper-stage::after{content:"";position:absolute;inset:0;z-index:3;pointer-events:none;
  background:linear-gradient(180deg,rgba(4,18,28,.05) 0%,rgba(4,18,28,0) 38%,rgba(6,22,34,.55) 100%)}

/* ===== realistic parish regions (real public-domain coastline) ===== */
.parish{vector-effect:non-scaling-stroke;stroke:rgba(6,24,38,.6);stroke-width:1.1;transition:fill .2s,filter .2s}
.parish.locked{fill:#15333f;opacity:.55}
.parish.unlocked{fill:#1d6f74;cursor:pointer}
.parish.unlocked:hover{fill:#249099}
.parish.cleared{fill:url(#nodeGold);cursor:pointer}
.parish.current{fill:#2bb6ac;stroke:#fff;stroke-width:1.8;cursor:pointer;filter:drop-shadow(0 0 6px rgba(52,224,208,.55))}
.parish:focus{outline:none}
.parish:focus-visible{stroke:#fff;stroke-width:2.4}
.map-badge{pointer-events:none}
.map-badge .bdot{fill:rgba(6,24,38,.82);stroke:rgba(255,255,255,.5);stroke-width:1}
.map-badge .bdot.current{fill:#0e4a5a;stroke:#fff;stroke-width:1.6}
.map-badge .bdot.cleared{fill:rgba(58,38,6,.85);stroke:var(--gold)}
.map-badge .bnum{font-family:var(--display);font-size:11px;font-weight:700;text-anchor:middle;dominant-baseline:central;fill:#eef9f8}
.compass-note{font-family:var(--ui);font-size:11px;font-weight:700;fill:var(--turq);opacity:.75}

/* widen the map panel ("border") so the whole real island fits without cropping */
.hero-map{width:clamp(340px,33vw,460px)}

/* ============ registration (start) + prize claim (handle + consented email) ============ */
.register{margin:2px auto 16px;max-width:360px;text-align:left}
.reg-label{display:block;font-size:12.5px;font-weight:600;color:var(--foam-dim);margin:0 0 6px;letter-spacing:.01em}
.reg-input{width:100%;background:rgba(5,19,31,.6);border:1px solid var(--edge);border-radius:999px;
  padding:13px 18px;color:var(--foam);font-size:15px;outline:none;transition:border-color .18s,box-shadow .18s}
.reg-input::placeholder{color:var(--muted)}
.reg-input:focus{border-color:var(--teal);box-shadow:var(--ring)}
.reg-hint{margin:7px 4px 0;font-size:12px;color:var(--muted)}
.reg-hint.warn{color:var(--coral)}

.claim-block{display:flex;flex-direction:column;gap:10px;margin:8px 0 14px;text-align:left}
.claim-block input{width:100%;background:rgba(5,19,31,.6);border:1px solid var(--edge);border-radius:999px;
  padding:12px 18px;color:var(--foam);font-size:14px;outline:none;transition:border-color .18s,box-shadow .18s}
.claim-block input::placeholder{color:var(--muted)}
.claim-block input:focus{border-color:var(--teal);box-shadow:var(--ring)}
.consent{display:flex;align-items:flex-start;gap:9px;font-size:13px;color:var(--foam-dim);line-height:1.45;cursor:pointer;padding:0 2px}
.consent input[type=checkbox]{flex:none;width:18px;height:18px;margin-top:1px;accent-color:var(--turq);cursor:pointer}
.consent b{color:var(--foam)}
.fine-note{color:var(--muted);font-size:12px}
.claim-msg{min-height:16px;margin:0 2px;font-size:12.5px;font-weight:600}
.claim-msg.ok{color:var(--turq)}
.claim-msg.bad{color:var(--coral)}
.privacy-fine{margin:2px 2px 0;font-size:11.5px;line-height:1.5;color:var(--muted)}
.privacy-fine a{color:var(--foam-dim)}
