/* ALTE — Screen Map canvas styling */
.screen-map{min-height:100vh;background:var(--cream);position:relative;
  background-image:radial-gradient(var(--cream-3) 1px,transparent 1px);background-size:26px 26px}
.map-grain{position:fixed;inset:0;pointer-events:none;z-index:0;
  background:radial-gradient(120% 80% at 80% -10%,rgba(255,120,73,.07),transparent 55%),
             radial-gradient(90% 60% at -10% 110%,rgba(74,58,92,.08),transparent 55%)}
.screen-map>*{position:relative;z-index:1}

.map-top{display:flex;align-items:center;justify-content:space-between;max-width:1280px;margin:0 auto;padding:26px var(--gut)}
.map-top-actions{display:flex;align-items:center;gap:18px}
.map-version{font-size:12px;color:var(--ink-mist);letter-spacing:.02em}

.map-intro{max-width:1280px;margin:0 auto;padding:clamp(28px,5vw,64px) var(--gut) 0}
.map-intro .h1{margin-top:14px;max-width:18ch}
.map-legend{display:flex;flex-wrap:wrap;align-items:center;gap:20px;margin-top:30px;padding-top:26px;border-top:1px solid var(--line)}
.leg{display:inline-flex;align-items:center;gap:9px;font-size:13px;font-weight:500;color:var(--ink)}
.leg.total{margin-left:auto;color:var(--ink-mist);font-size:12.5px}
.map-dot{width:9px;height:9px;border-radius:50%;flex:none}

.map-canvas{max-width:1280px;margin:0 auto;padding:clamp(28px,4vw,48px) var(--gut) 0;display:grid;gap:44px}
.map-group-head{display:flex;align-items:center;gap:12px;margin-bottom:20px}
.map-group-head h3{font-size:15px;font-family:var(--inter);font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--ink)}
.map-count{margin-left:6px;font-size:12px;color:var(--ink-mist);font-family:var(--sora)}
.map-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
@media(max-width:980px){.map-cards{grid-template-columns:1fr 1fr}}
@media(max-width:620px){.map-cards{grid-template-columns:1fr}}

.map-card{text-align:left;background:var(--cream);border-radius:16px;box-shadow:inset 0 0 0 1px var(--line);padding:14px;display:flex;flex-direction:column;gap:14px;cursor:pointer;position:relative;overflow:hidden;
  transition:transform .5s var(--ease),box-shadow .5s var(--ease)}
.map-card::after{content:"";position:absolute;left:0;top:0;width:3px;height:100%;background:var(--ac);transform:scaleY(0);transform-origin:top;transition:transform .45s var(--ease)}
.map-card:hover{transform:translateY(-5px);box-shadow:inset 0 0 0 1px var(--line),0 28px 56px -30px rgba(20,33,61,.5)}
.map-card:hover::after{transform:scaleY(1)}

.map-thumb{border-radius:10px;overflow:hidden;background:var(--cream-2);box-shadow:inset 0 0 0 1px var(--line-soft);aspect-ratio:16/10}
.mp-screen{height:100%;display:flex;flex-direction:column;background:var(--cream)}
.mp-bar{height:18px;display:flex;align-items:center;gap:5px;padding:0 9px;background:var(--cream-2);border-bottom:1px solid var(--line-soft)}
.mp-bar span{width:5px;height:5px;border-radius:50%;background:var(--ink-mist);opacity:.4}
.mp-body{flex:1;padding:12px}
.mp-hero{display:flex;flex-direction:column;gap:7px;height:100%;justify-content:center}
.mp-h1{height:9px;width:78%;border-radius:3px;background:var(--ink-deep)}
.mp-h1.short{width:52%;background:var(--coral)}
.mp-cta{margin-top:5px;height:13px;width:38px;border-radius:7px;background:var(--coral)}
.mp-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:6px;height:100%}
.mp-grid span{border-radius:5px;background:var(--cream-2);box-shadow:inset 0 0 0 1px var(--line-soft)}
.mp-grid span:nth-child(1){background:var(--ink-deep)}
.mp-split{display:grid;grid-template-columns:1fr 1fr;gap:8px;height:100%}
.mp-lines{display:flex;flex-direction:column;gap:6px;justify-content:center}
.mp-lines i{height:7px;border-radius:3px;background:var(--cream-3)}
.mp-lines i:nth-child(2){width:80%}.mp-lines i:nth-child(3){width:60%}
.mp-box{border-radius:6px;background:var(--plum);opacity:.85}
.mp-quiz{display:flex;flex-direction:column;gap:6px;height:100%;justify-content:center}
.mp-prog{height:5px;width:60%;border-radius:3px;background:var(--coral)}
.mp-opt{height:13px;border-radius:5px;background:var(--cream-2);box-shadow:inset 0 0 0 1px var(--line-soft)}
.mp-opt.on{background:var(--ink-deep)}

.map-meta{padding:0 6px}
.map-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}
.map-idx{font-size:12px;color:var(--ink-mist)}
.map-route{font-size:11.5px;color:var(--ink-mist);background:var(--cream-2);padding:3px 8px;border-radius:6px;box-shadow:inset 0 0 0 1px var(--line-soft)}
.map-name{font-family:var(--sora);font-weight:600;font-size:18px;letter-spacing:-.02em;color:var(--ink-deep)}
.map-sub{font-size:13px;color:var(--ink-mist);margin-top:4px;line-height:1.45}
.map-open{display:inline-flex;align-items:center;gap:7px;padding:0 6px 4px;font-size:13px;font-weight:600;color:var(--ac);margin-top:auto;transition:gap .35s var(--ease)}
.map-card:hover .map-open{gap:11px}

.map-foot{max-width:1280px;margin:0 auto;padding:54px var(--gut) 48px;display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;font-size:12.5px;color:var(--ink-mist)}
.map-foot .mono{color:var(--ink)}

/* return-to-map floating pill (inside site) */
.map-fab{position:fixed;left:24px;bottom:24px;z-index:70;display:inline-flex;align-items:center;gap:9px;padding:12px 18px;border-radius:100px;background:var(--ink-deep);color:var(--cream);font-size:13px;font-weight:600;box-shadow:0 18px 40px -16px rgba(10,20,38,.6);transition:transform .5s var(--ease),background .3s;cursor:pointer}
.map-fab:hover{transform:translateY(-3px);background:var(--plum)}
.map-fab svg{width:15px;height:15px}
@media(max-width:600px){.map-fab{left:50%;transform:translateX(-50%)}.map-fab:hover{transform:translateX(-50%) translateY(-3px)}}
