[hidden]{display:none!important}:root{--color-brand-agro: #4ade80;--color-neutral-950: #0b1220;--color-neutral-950-panel: rgba(8, 12, 24, .85);--color-neutral-950-panel-strong: rgba(8, 12, 24, .95);--color-neutral-900-glass-light: rgba(30, 41, 59, .55);--color-neutral-900-glass-mid: rgba(15, 23, 42, .7);--color-border-glass: rgba(148, 163, 184, .25);--color-border-glass-strong: rgba(148, 163, 184, .45);--color-text-main: #f8fafc;--color-text-muted: #94a3b8;--color-text: #e8e8ed;--color-text-dim: #94a3b8;--color-text-bright: #ffffff;--color-accent: #38bdf8;--color-accent-strong: #2563eb;--radius-lg: 18px;--shadow-glass: 0 20px 60px rgba(0, 0, 0, .45);--shadow-card: 0 16px 30px rgba(0, 0, 0, .65);--ui-radius-xl: 18px;--ui-radius-lg: 14px;--ui-radius-md: 12px;--ui-radius-sm: 10px;--ui-radius-pill: 999px;--ui-control-height-lg: 52px;--ui-control-height-md: 44px;--ui-control-height-sm: 42px;--ui-control-height-xs: 40px;--ui-focus-ring: 2px solid rgba(125, 211, 252, .95);--ui-focus-ring-strong: 2px solid rgba(216, 248, 241, .88);--ui-focus-offset: 2px;--ui-safe-gap: 8px;--ui-safe-gap-tight: 6px;--ui-safe-gap-loose: 10px;--ui-surface-glass: linear-gradient(180deg, rgba(12, 20, 35, .88), rgba(8, 14, 26, .92));--ui-surface-glass-soft: linear-gradient(180deg, rgba(255, 255, 255, .055), rgba(255, 255, 255, .02));--ui-surface-glass-accent: linear-gradient(140deg, rgba(100, 209, 190, .12), rgba(99, 179, 255, .08)), rgba(8, 18, 32, .74);--ui-border-soft: rgba(173, 189, 214, .12);--ui-border-mid: rgba(173, 189, 214, .18);--ui-border-strong: rgba(180, 220, 255, .28);--ui-shadow-panel: 0 28px 60px rgba(0, 0, 0, .38), inset 0 1px 0 rgba(255, 255, 255, .04);--ui-shadow-card: 0 16px 32px rgba(0, 0, 0, .28), inset 0 1px 0 rgba(255, 255, 255, .03);--ui-pill-bg: rgba(8, 16, 30, .56);--ui-pill-border: rgba(118, 185, 255, .24);--ui-pill-text: #bfe0ff;--ui-pill-accent-bg: rgba(74, 222, 128, .12);--ui-pill-accent-border: rgba(74, 222, 128, .26);--ui-pill-accent-text: #d2ffe4;--surface: rgba(255, 255, 255, .03);--surface-hover: rgba(255, 255, 255, .08);--border: rgba(255, 255, 255, .06);--text: var(--color-text);--text-dim: var(--color-text-dim);--text-bright: var(--color-text-bright);--accent: var(--color-accent);--accent-strong: var(--color-accent-strong);--card-shadow: var(--shadow-card);--agro-green: var(--color-brand-agro);--ui-bg: var(--color-neutral-950);--ui-panel: var(--color-neutral-950-panel);--ui-panel-strong: var(--color-neutral-950-panel-strong);--glass-border: var(--color-border-glass);--glass-border-strong: var(--color-border-glass-strong);--glass-shadow: var(--shadow-glass);--glass-light: var(--color-neutral-900-glass-light);--glass-mid: var(--color-neutral-900-glass-mid);--text-main: var(--color-text-main);--text-muted: var(--color-text-muted);--accent-blue: var(--color-accent);--accent-blue-dark: var(--color-accent-strong);--layer-playfield: 1000;--layer-hud: 2000;--layer-card-hand: 6000;--layer-card-base: 6100;--layer-card: 7000;--layer-card-floating: 7200;--layer-toast: 8000;--layer-tooltip: 8500;--layer-tooltips: var(--layer-tooltip);--layer-modal: 9000;--layer-card-inspect: 9350;--layer-overlay-global: 9500;--layer-profile-select: 9600;--layer-profile-code-modal: 9700;--layer-debug: 11000}.connection-indicator{display:inline-flex;align-items:center;gap:.35em;font-size:.72rem;font-family:Space Grotesk,system-ui,sans-serif;font-weight:500;letter-spacing:.02em;padding:.25em .6em;border-radius:999px;background:#1a1a1a99;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);color:#b3b3b3;pointer-events:none;user-select:none;transition:opacity .3s ease;z-index:calc(var(--layer-hud, 2000) + 1)}.connection-indicator[hidden]{display:none}.connection-indicator__dot{width:.5em;height:.5em;border-radius:50%;flex-shrink:0;transition:background-color .3s ease}.connection-indicator[data-status=connected] .connection-indicator__dot{background-color:#21c45d;box-shadow:0 0 4px #21c45d80}.connection-indicator[data-status=guest] .connection-indicator__dot{background-color:#e7b008;box-shadow:0 0 4px #e7b00880}.connection-indicator[data-status=offline] .connection-indicator__dot{background-color:#db2424;box-shadow:0 0 4px #db242480}.connection-indicator__label{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:10em}.game-topbar .connection-indicator{position:absolute;top:.4em;right:.6em}.home-connection-slot{display:flex;justify-content:center;margin-top:.6em}.ribbon-connection-slot{display:flex;margin-top:.5em}.map-offline-banner{display:flex;align-items:center;gap:.5em;padding:.5em .8em;margin:.4em 0;border-radius:6px;background:#361717a6;color:#f49a9a;font-size:.78rem;font-family:Space Grotesk,system-ui,sans-serif}.map-offline-banner[hidden]{display:none}.map-offline-banner__icon{font-size:1em}.session-end-sync-status{display:inline-flex;align-items:center;gap:.3em;font-size:.72rem;font-family:Space Grotesk,system-ui,sans-serif;font-weight:500;margin-top:.5em;padding:.25em .6em;border-radius:6px;opacity:0;transition:opacity .4s ease}.session-end-sync-status[data-visible=true]{opacity:1}.session-end-sync-status[data-sync=success]{background:#17362299;color:#66e595}.session-end-sync-status[data-sync=pending]{background:#362e1799;color:#f9cf53}.session-end-sync-status[data-sync=none]{display:none}body.page-map{--map-bg-deep: #1a2332;--map-bg-scene: #243447;--map-bg-ground: #2d4a3e;--map-bg-path: #3d5c4a;--map-shell-gap: clamp(12px, 1.45vw, 20px);--map-shell-padding: clamp(12px, 1.45vw, 18px);--map-shell-radius: 28px;--map-shell-card-radius: 20px;--map-shell-panel-bg: linear-gradient(180deg, rgba(19, 31, 46, .94) 0%, rgba(10, 18, 29, .9) 100%);--map-shell-panel-border: var(--ui-border-soft);--map-shell-panel-shadow: var(--ui-shadow-panel);--map-surface: rgba(255, 255, 255, .05);--map-surface-hover: rgba(255, 255, 255, .1);--map-border: rgba(255, 255, 255, .1);--map-text: #e8e8ed;--map-text-dim: #93a7c2;--map-text-bright: #ffffff;--text: var(--map-text);--text-dim: var(--map-text-dim);--text-bright: var(--map-text-bright);--map-motivation: #22c55e;--map-motivation-glow: rgba(34, 197, 94, .4);--map-motivation-bg: rgba(34, 197, 94, .15);--map-energy: #fbbf24;--map-stress: #ef4444;--map-confidence: #c084fc;--map-appui: #22d3ee;--map-artefact: #93c5fd;--node-standard: #3b82f6;--node-activity: #8b5cf6;--node-eval: #f59e0b;--node-remediation: #06b6d4;--node-cantine: #22c55e;--node-profs: #f97316;--node-vie: #ec4899;--node-admin: #6b7280;--node-tim: #14b8a6;--node-boss: #dc2626;--node-completed: #22c55e;--node-current: #fbbf24;--node-accessible: #e8e8ed;--node-locked: #4b5563;--node-completed-path: #d9a45f;--node-completed-surface: #7a5a34;--node-locked-text: #c5d0de;--node-refused: #f87171}.map-sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip-path:inset(50%);white-space:nowrap;border:0}*{box-sizing:border-box}html,body.page-map{height:100%;margin:0}body.page-map{background:radial-gradient(circle at 18% 14%,rgba(125,211,252,.14),transparent 24%),radial-gradient(circle at 82% 82%,rgba(34,197,94,.08),transparent 22%),var(--map-bg-deep);color:var(--map-text);font-family:Space Grotesk,system-ui,sans-serif;overflow:hidden}.map-page{display:flex;height:100vh;overflow:hidden;gap:var(--map-shell-gap);padding:var(--map-shell-padding);background:radial-gradient(circle at top left,rgba(148,163,184,.08),transparent 28%),linear-gradient(180deg,#060a12cc,#080c16f5)}@media(max-width:980px){html,body.page-map{height:auto;min-height:100%;overflow:auto}.map-page{min-height:100dvh;height:auto;flex-direction:column;gap:0;padding:0;overflow:visible;background:var(--map-bg-deep)}}.map-container{flex:1;min-width:0;position:relative;isolation:isolate;z-index:var(--layer-playfield);overflow:hidden;border-radius:var(--map-shell-radius);border:1px solid var(--map-shell-panel-border);box-shadow:var(--map-shell-panel-shadow);--map-fog-frontier: 55%;--map-fog-opacity: .82;--map-fog-blur: 3.4px;background:radial-gradient(ellipse 100% 80% at 50% 100%,rgba(45,74,62,.6) 0%,transparent 60%),linear-gradient(180deg,var(--map-bg-deep) 0%,var(--map-bg-scene) 50%,var(--map-bg-ground) 100%)}.map-scroll-surface{position:relative;width:100%;height:100%;min-width:100%;min-height:100%}.map-container.map-container--desktop-scroll{overflow:auto;overscroll-behavior:contain;scrollbar-width:thin;cursor:grab}.map-container.map-container--desktop-scroll.map-container--dragging{cursor:grabbing}.map-container.map-container--desktop-scroll .map-scroll-surface{width:205%;height:175%;min-width:205%;min-height:175%}.map-container .map-bg{position:absolute;inset:0;background-image:repeating-linear-gradient(0deg,transparent,transparent 40px,rgba(255,255,255,.02) 40px,rgba(255,255,255,.02) 41px),repeating-linear-gradient(90deg,transparent,transparent 40px,rgba(255,255,255,.015) 40px,rgba(255,255,255,.015) 41px);opacity:.5;pointer-events:none}.map-fog-layer{position:absolute;inset:0;z-index:calc(var(--layer-playfield) - 980);pointer-events:none;opacity:var(--map-fog-opacity);background:linear-gradient(90deg,#090e1800 0% calc(var(--map-fog-frontier) - 18%),#090e1833 calc(var(--map-fog-frontier) - 8%),#080d178f calc(var(--map-fog-frontier) + 3.5%),#060a12e6),radial-gradient(circle at 88% 42%,rgba(182,211,241,.16),transparent 42%);mask-image:linear-gradient(90deg,transparent 0%,transparent calc(var(--map-fog-frontier) - 20%),rgba(0,0,0,.32) calc(var(--map-fog-frontier) - 8%),#000 calc(var(--map-fog-frontier) + 6%),#000 100%);-webkit-mask-image:linear-gradient(90deg,transparent 0%,transparent calc(var(--map-fog-frontier) - 20%),rgba(0,0,0,.32) calc(var(--map-fog-frontier) - 8%),#000 calc(var(--map-fog-frontier) + 6%),#000 100%);backdrop-filter:blur(var(--map-fog-blur));-webkit-backdrop-filter:blur(var(--map-fog-blur));transition:opacity .42s ease,backdrop-filter .42s ease,-webkit-backdrop-filter .42s ease,background .42s ease}.map-svg,.map-connections-canvas{position:absolute;inset:0;width:100%;height:100%;pointer-events:none;z-index:calc(var(--layer-playfield) - 1)}.connection-line{fill:none;stroke:#eff6ff6b;stroke-width:1.2;opacity:.62;stroke-linecap:round;stroke-linejoin:round;transition:stroke .22s ease,stroke-width .22s ease,opacity .22s ease,filter .22s ease}.connection-line.completed{stroke:color-mix(in srgb,var(--node-completed-path, #d9a45f) 84%,#fff2c8);stroke-width:4;stroke-dasharray:none;opacity:.92}.connection-line.active{stroke:color-mix(in srgb,#ffd56a 84%,#fff7d4);stroke-width:3;stroke-dasharray:10 7;stroke-dashoffset:0;opacity:1;animation:map-active-path-flow 1.1s linear infinite}.connection-line.future{stroke:#eef5ffa3;stroke-width:1.45;stroke-dasharray:none;opacity:.52}.connection-line.locked{stroke:#b3c0d642;stroke-width:1;stroke-dasharray:1.4 6;opacity:.2}@keyframes map-active-path-flow{to{stroke-dashoffset:-34}}@media(prefers-reduced-motion:reduce){.connection-line.active{animation:none}}.connection-line.is-highlighted-route{stroke:color-mix(in srgb,#ffe186 76%,#fff9dd);stroke-width:3.5;opacity:1}.connection-line.is-dimmed{opacity:.16;filter:none}.connection-line.animating{stroke:color-mix(in srgb,#ffe9ad 64%,#fffef2);stroke-width:3.6;stroke-dasharray:var(--path-length);stroke-dashoffset:var(--path-length);opacity:1;animation:draw-connection var(--path-draw-duration, .68s) cubic-bezier(.22,.82,.31,1) forwards}@keyframes draw-connection{to{stroke-dashoffset:0}}.map-nodes,.map-nodes-container{position:absolute;inset:0;z-index:calc(var(--layer-playfield) + 100)}.node,.map-node{position:absolute;transform:translate(-50%,-50%);cursor:pointer;transition:transform .3s cubic-bezier(.34,1.56,.64,1);z-index:calc(var(--layer-playfield) + 1)}.node.locked,.node.completed{z-index:calc(var(--layer-playfield) + 1)}.node.accessible{z-index:calc(var(--layer-playfield) + 4)}.node.current,.node.map-node--spotlight,.node:focus-visible{z-index:calc(var(--layer-playfield) + 5)}.node-inner{position:relative;z-index:calc(var(--layer-playfield) + 2);display:flex;flex-direction:column;align-items:center;gap:.4rem;transition:transform .26s cubic-bezier(.22,.85,.29,1)}.node-icon{width:50px;height:50px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.3rem;border:3px solid var(--map-border);background:linear-gradient(135deg,var(--node-color, #3b82f6),color-mix(in srgb,var(--node-color, #3b82f6) 70%,black));box-shadow:0 4px 12px #0006,inset 0 2px 4px #ffffff1a;transition:all .3s ease;position:relative;z-index:calc(var(--layer-playfield) + 2)}.node-icon.has-image{background:var(--map-surface);background-image:var(--node-image);background-size:cover;background-position:center;background-repeat:no-repeat;border:2px solid rgba(255,255,255,.2);overflow:hidden;padding:0}.node[data-type=standard] .node-icon{--node-color: var(--node-standard)}.node[data-type=activity] .node-icon{--node-color: var(--node-activity)}.node[data-type=eval] .node-icon{--node-color: var(--node-eval)}.node[data-type=remediation] .node-icon{--node-color: var(--node-remediation)}.node[data-type=cantine] .node-icon{--node-color: var(--node-cantine)}.node[data-type=profs] .node-icon{--node-color: var(--node-profs)}.node[data-type=vie] .node-icon{--node-color: var(--node-vie)}.node[data-type=admin] .node-icon{--node-color: var(--node-admin)}.node[data-type=tim] .node-icon{--node-color: var(--node-tim)}.node[data-type=start] .node-icon{--node-color: #475569;width:40px;height:40px;font-size:1rem}.node[data-type=boss] .node-icon{--node-color: var(--node-boss);width:65px;height:65px;font-size:1.8rem}.node.current .node-icon{border-color:var(--node-current);box-shadow:0 0 20px #fbbf2480,0 4px 12px #0006,inset 0 2px 4px #ffffff1a;animation:pulse-current 1.55s ease-in-out infinite}.node.current .node-icon:before{content:"";position:absolute;inset:-9px;border-radius:50%;border:2px solid rgba(251,191,36,.72);box-shadow:0 0 20px #fbbf2461;opacity:.7;transform:scale(.9);pointer-events:none;animation:current-node-ring 1.75s cubic-bezier(.12,.79,.26,1) infinite}.node.map-node--opportunity-pulse:not(.current) .node-icon{animation:opportunity-reveal-pulse 1.45s ease-out both}.node.map-node--opportunity-pulse:not(.current) .node-icon:after{content:"";position:absolute;inset:-10px;border:2px solid rgba(161,226,186,.82);border-radius:50%;box-shadow:0 0 24px #50cd8b85;pointer-events:none;animation:opportunity-reveal-ring 1.45s ease-out both}@keyframes pulse-current{0%,to{box-shadow:0 0 20px #fbbf2480,0 4px 12px #0006}50%{box-shadow:0 0 35px #fbbf24b3,0 4px 12px #0006}}@keyframes current-node-ring{0%{opacity:.76;transform:scale(.86)}70%{opacity:.18;transform:scale(1.16)}to{opacity:0;transform:scale(1.24)}}@keyframes opportunity-reveal-pulse{0%{transform:scale(.92);box-shadow:0 0 #50cd8b00,0 4px 12px #0006}35%{transform:scale(1.14);box-shadow:0 0 30px #50cd8bb3,0 8px 18px #0000006b}to{transform:scale(1);box-shadow:0 4px 12px #0006,inset 0 2px 4px #ffffff1a}}@keyframes opportunity-reveal-ring{0%{opacity:.85;transform:scale(.72)}to{opacity:0;transform:scale(1.35)}}.node.completed .node-icon{border-color:color-mix(in srgb,var(--node-completed-path, #d9a45f) 78%,#fff2c8);opacity:.78;filter:sepia(.38) saturate(.74);background:linear-gradient(135deg,#7a5a34f5,#4c3822f5)}.node.completed .node-icon:after{content:"\2713";position:absolute;top:-5px;right:-5px;width:18px;height:18px;background:var(--node-completed-path, #d9a45f);border-radius:50%;font-size:.65rem;display:flex;align-items:center;justify-content:center;color:#000;font-weight:700}.node.accessible .node-icon{border-color:var(--node-accessible);animation:map-accessible-node-hover-float 2.2s ease-in-out infinite}.node.accessible:hover,.node.current:hover{transform:translate(-50%,calc(-50% - 4px)) scale(1.04)}.map-node:focus-visible{outline:none}.map-node:focus-visible .node-icon{outline:3px solid #fbbf24;outline-offset:3px}.node.accessible:hover .node-inner,.node.current:hover .node-inner{transform:translate(1px)}.node.accessible:hover .node-icon{border-color:var(--map-motivation);box-shadow:0 16px 24px #0000006b,0 6px 14px #0000004d,0 0 22px var(--map-motivation-glow),inset 0 2px 4px #ffffff1f}.node.current:hover .node-icon{box-shadow:0 18px 26px #00000070,0 0 26px #fbbf249e,inset 0 2px 4px #ffffff24}.node.locked{opacity:.66;cursor:not-allowed;filter:grayscale(.86) saturate(.56)}.node.locked:hover{transform:translate(-50%,-50%) scale(1)}.node.requires-capacity-missing .node-icon{border-color:#f59e0b;box-shadow:0 0 0 1px #f59e0b8c,0 0 14px #f59e0b52,inset 0 2px 4px #ffffff1a}.node.requires-capacity-missing .node-cost{border-color:#f59e0b;color:#fbbf24;background:#181104eb}.node.locked .node-label{color:var(--node-locked-text, #c5d0de);background:#09101cfa;border-color:#aebed33d}.node.completed .node-label{color:#f8e3bf;background:#302315f5;border-color:#d9a45f61}.node.map-node--refused .node-icon{border-color:var(--node-refused, #f87171);box-shadow:0 0 0 2px #f87171ad,0 0 20px #f8717175,0 4px 12px #00000061;animation:map-node-refused-shake .26s ease both}.node.map-node--spotlight .node-icon{box-shadow:0 0 0 2px #ffe186cc,0 0 24px #ffe18694,0 6px 16px #0006}.node.map-node--spotlight .node-icon:after{content:"";position:absolute;inset:-12px;border:2px solid rgba(255,225,134,.72);border-radius:50%;pointer-events:none;animation:current-node-ring 1.1s ease-out both}.node.is-highlighted-route .node-icon{border-color:#ffe186;box-shadow:0 0 0 1px #ffe1869e,0 0 15px #ffe18685,0 4px 12px #0000005c}.node.is-dimmed{opacity:1;filter:saturate(.65) grayscale(.3) brightness(.78)}.node-label{position:relative;z-index:calc(var(--layer-playfield) + 3);pointer-events:none;background:#030812f2;border:1px solid rgba(148,163,184,.18);padding:.25rem .5rem;border-radius:4px;font-size:.75rem;font-weight:500;white-space:normal;max-width:130px;overflow:visible;overflow-wrap:anywhere;text-align:center;display:flex;flex-direction:column;align-items:center;gap:.1rem}.node.is-dimmed .node-label{background:#030812f7;border-color:#94a3b824;opacity:.98}.node-name{line-height:1.1}.node[data-type=boss] .node-label{background:#dc2626cc;font-family:Bebas Neue,sans-serif;font-size:.8rem;letter-spacing:.05em}.node-requirement-badge{position:absolute;z-index:calc(var(--layer-playfield) + 4);top:34px;left:50%;transform:translate(-50%);max-width:110px;padding:.12rem .36rem;border-radius:9px;border:1px solid rgba(245,158,11,.62);background:#181104eb;color:#fbbf24;font-family:JetBrains Mono,monospace;font-size:.65rem;font-weight:700;line-height:1.1;white-space:nowrap;pointer-events:none}.node-cost{position:absolute;z-index:calc(var(--layer-playfield) + 4);top:-25px;left:50%;transform:translate(-50%) translateY(5px);background:var(--map-motivation-bg);border:1px solid var(--map-motivation);padding:.15rem .4rem;border-radius:10px;font-family:JetBrains Mono,monospace;font-size:.7rem;font-weight:700;color:var(--map-motivation);opacity:0;transition:all .2s ease;white-space:nowrap;pointer-events:none}.node.accessible:hover .node-cost{opacity:1;transform:translate(-50%) translateY(0)}@keyframes node-appear{0%{opacity:0;transform:translate(-50%,-50%) scale(.5)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}.node{animation:node-appear .4s cubic-bezier(.34,1.56,.64,1) backwards}.node.moving-from .node-icon{animation:shrink-out .2s ease forwards}.node.moving-to .node-icon{animation:pop-in .3s cubic-bezier(.34,1.56,.64,1)}@keyframes shrink-out{to{transform:scale(.8);opacity:.5}}@keyframes pop-in{0%{transform:scale(1.3)}to{transform:scale(1)}}@keyframes map-accessible-node-hover-float{0%,to{transform:translateY(0)}50%{transform:translateY(-2px)}}@keyframes map-node-refused-shake{0%,to{transform:translate(0)}28%{transform:translate(-3px)}58%{transform:translate(3px)}}@media(max-width:980px){.map-container{flex:none;min-height:52vh}.node-icon{width:44px;height:44px;font-size:1.1rem;border-width:2px}.node[data-type=start] .node-icon{width:36px;height:36px;font-size:.9rem}.node[data-type=boss] .node-icon{width:56px;height:56px;font-size:1.55rem}.node-label{max-width:84px;font-size:.68rem}}@media(max-width:640px){.map-container{min-height:46vh}.connection-line{stroke-width:1.1}.node-cost{font-size:.65rem}}@media(prefers-reduced-motion:reduce){.connection-line,.map-fog-layer,.node,.node-inner,.node-icon,.node.map-node--opportunity-pulse:not(.current) .node-icon,.node.map-node--opportunity-pulse:not(.current) .node-icon:after,.node.map-node--refused .node-icon,.node.map-node--spotlight .node-icon:after,.node.current .node-icon:before,.node-cost{animation:none;transition:none}.node.map-node--refused .node-icon{box-shadow:0 0 0 2px #f87171c7,0 0 0 5px #f871712e}}.map-page .icon{position:relative;width:22px;height:22px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.map-page .icon-themed{width:100%;height:100%;object-fit:contain}.map-page .icon-fallback{display:none;font-size:1rem;line-height:1}.motivation-header .icon{width:18px;height:18px}.run-item .icon{width:48px;height:48px;margin-bottom:.25rem}.run-item[data-carnet-badge] .icon{width:52px;height:52px;filter:drop-shadow(0 0 6px rgba(251,191,36,.5))}#btnArtefacts .icon{width:56px;height:56px}.map-sidebar-group{display:grid;gap:.78rem}.map-sidebar-group__title{margin:0;font-size:.68rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:color-mix(in srgb,var(--map-text-dim) 82%,#ffffff 18%)}.sidebar-left{position:relative;z-index:var(--layer-hud);width:288px;background:var(--map-shell-panel-bg);border:1px solid var(--map-shell-panel-border);border-radius:var(--map-shell-radius);box-shadow:var(--map-shell-panel-shadow);display:flex;flex-direction:column;padding:1.08rem;gap:1rem;flex-shrink:0;overflow-y:auto;backdrop-filter:blur(18px)}.map-sidebar-group--hero{padding:1rem;border-radius:calc(var(--map-shell-card-radius) + 2px);border:1px solid var(--ui-border-mid);background:var(--ui-surface-glass-accent);box-shadow:var(--ui-shadow-card)}.sequence-header{display:grid;gap:.38rem;text-align:left}.sequence-label{display:inline-flex;align-items:center;width:fit-content;padding:.32rem .62rem;border-radius:999px;border:1px solid var(--ui-pill-border);background:var(--ui-pill-bg);font-size:.6rem;text-transform:uppercase;letter-spacing:.17em;color:var(--ui-pill-text)}.sequence-title{font-family:Bebas Neue,sans-serif;font-size:clamp(1.6rem,1rem + 1.2vw,2.25rem);letter-spacing:.04em;color:var(--map-text-bright);line-height:.96;text-wrap:balance}.sequence-work{font-size:.88rem;color:color-mix(in srgb,var(--map-energy) 76%,#fff3c0 24%)}.work-cover{position:relative;width:100%;aspect-ratio:3/4;background:linear-gradient(145deg,#2a3a4a,#1a2530);margin-top:.1rem;border-radius:18px;border:1px solid rgba(173,189,214,.2);display:flex;flex-direction:column;align-items:center;justify-content:center;overflow:hidden;background-size:cover;background-position:center;box-shadow:0 20px 42px #040a125c}.work-cover:before{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 60%,rgba(0,0,0,.6) 100%)}.work-cover-icon{font-size:3.5rem;z-index:calc(var(--layer-hud) + 1)}.work-cover-title{position:absolute;bottom:.6rem;left:.6rem;right:.6rem;font-family:Bebas Neue,sans-serif;font-size:.95rem;text-align:center;color:var(--map-text-bright);z-index:calc(var(--layer-hud) + 1);line-height:1.2}.work-cover.has-image{border-color:#fff3;box-shadow:0 4px 20px #0006;cursor:pointer}.work-cover.has-image:before{background:linear-gradient(180deg,transparent 50%,rgba(0,0,0,.7) 100%)}.work-cover.has-image .work-cover-icon{display:none}.work-cover.has-image:after{content:"\1f50d";position:absolute;top:8px;right:8px;width:26px;height:26px;background:#000000b3;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.75rem;opacity:0;transition:opacity .2s ease;z-index:calc(var(--layer-hud) + 2)}.work-cover.has-image:hover:after{opacity:1}.work-cover-tooltip{position:fixed;z-index:var(--layer-hud);pointer-events:none;opacity:0;transform:translateY(-50%) scale(.9);transition:opacity .2s ease,transform .2s ease}.work-cover-tooltip.visible{opacity:1;transform:translateY(-50%) scale(1)}.work-cover-tooltip-inner{background:#0d1117;border:2px solid rgba(255,255,255,.2);border-radius:16px;padding:10px;box-shadow:0 30px 100px #000000f2,0 0 0 1px #ffffff0d}.work-cover-tooltip-image{width:450px;aspect-ratio:3/4;border-radius:10px;display:block;object-fit:cover}.work-cover-title.image-overlay{text-shadow:0 4px 16px rgba(0,0,0,.8)}.sequence-objective{background:linear-gradient(180deg,#162232e0,#0d1421b8);border:1px solid rgba(173,189,214,.16);border-radius:var(--map-shell-card-radius);padding:.95rem 1rem;box-shadow:inset 0 1px #ffffff08}.objective-label{font-size:.58rem;text-transform:uppercase;letter-spacing:.16em;color:var(--map-text-dim);margin-bottom:.5rem}.objective-text{font-size:.8rem;color:var(--map-text);line-height:1.5}.objective-capacity{margin-top:.55rem;padding-top:.55rem;border-top:1px solid var(--map-border);font-size:.72rem;color:var(--map-confidence)}.btn-capacities{display:flex;align-items:center;justify-content:center;gap:.5rem;min-height:50px;padding:.72rem 1rem;background:linear-gradient(135deg,#22d3ee2e,#60a5fa1f);border:1px solid rgba(125,211,252,.34);border-radius:999px;color:var(--map-text);font-family:inherit;font-size:.78rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;cursor:pointer;box-shadow:0 14px 28px #02061733;transition:transform .2s ease,border-color .2s ease,background .2s ease}.btn-capacities:hover{transform:translateY(-1px);background:linear-gradient(135deg,#22d3ee42,#7dd3fc29);border-color:color-mix(in srgb,var(--map-confidence) 52%,#7dd3fc);color:color-mix(in srgb,var(--map-confidence) 84%,#f8fafc)}.btn-capacities:focus-visible{outline:2px solid var(--map-energy);outline-offset:2px}.sidebar-left #capacities-panel{margin-bottom:0;border-width:1px;border-color:#7d93b24d;border-radius:var(--map-shell-card-radius);background:linear-gradient(180deg,#0e1623f5,#0a101ce6);box-shadow:inset 0 1px #ffffff0a}.sidebar-left .capacity-header h3{font-size:1rem}.sidebar-left .capacity-stats{font-size:.82rem}.sidebar-right{position:relative;z-index:var(--layer-hud);width:328px;background:var(--map-shell-panel-bg);border:1px solid var(--map-shell-panel-border);border-radius:var(--map-shell-radius);box-shadow:var(--map-shell-panel-shadow);flex-shrink:0;min-height:0;overflow:visible;backdrop-filter:blur(18px)}.sidebar-right .icon{width:32px;height:32px}.sidebar-right .motivation-header .icon{width:30px;height:30px}.sidebar-right .capacities-header .icon{width:28px;height:28px}.sidebar-right .run-item .icon{width:48px;height:48px}.sidebar-right .run-item[data-carnet-badge] .icon{width:54px;height:54px}.sidebar-right-scroll{position:relative;z-index:calc(var(--layer-hud) + 2);display:flex;flex-direction:column;gap:1.04rem;width:100%;height:100%;min-height:0;padding:1.08rem;overflow-y:auto}.motivation-display{background:linear-gradient(180deg,#22c55e2e,#0d131ed1);border:1px solid color-mix(in srgb,var(--map-motivation) 70%,rgba(255,255,255,.14));border-radius:18px;padding:.92rem;text-align:center;box-shadow:inset 0 1px #ffffff0d;transition:all .3s ease}.motivation-header{display:flex;align-items:center;justify-content:center;gap:.4rem;margin-bottom:.3rem}.motivation-label{font-size:.6rem;text-transform:uppercase;letter-spacing:.15em;color:var(--map-motivation)}.motivation-value{font-family:Bebas Neue,sans-serif;font-size:2.5rem;color:var(--map-motivation);line-height:1;text-shadow:0 0 20px var(--map-motivation-glow)}.motivation-value span{font-size:1.2rem;color:var(--map-text-dim)}.motivation-bar{height:6px;background:#0000004d;border-radius:3px;margin-top:.6rem;overflow:hidden}.motivation-bar-fill{height:100%;background:linear-gradient(90deg,var(--map-stress),var(--map-energy),var(--map-motivation));border-radius:3px;transition:width .5s ease}.motivation-warning{font-size:.65rem;color:#fca5a5;margin-top:.4rem;opacity:0;transition:opacity .3s ease}.motivation-display.low .motivation-warning{opacity:1}.motivation-display.low{border-color:var(--map-stress);background:#ef444426}.motivation-floater{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-family:Bebas Neue,sans-serif;font-size:1.5rem;color:var(--map-stress);animation:float-up .6s ease-out forwards;pointer-events:none}.motivation-floater.gain{color:var(--map-motivation)}@keyframes float-up{0%{opacity:1;transform:translate(-50%,-50%)}to{opacity:0;transform:translate(-50%,-150%)}}.motivation-display.shake{animation:shake .5s ease-in-out}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-5px)}75%{transform:translate(5px)}}.motivation-display.pulse{animation:pulse .4s ease}@keyframes pulse{0%{transform:scale(1)}50%{transform:scale(1.05)}to{transform:scale(1)}}.teacher-stats{display:flex;flex-direction:column;gap:.48rem}.stat-row{display:flex;align-items:center;gap:.62rem;width:100%;padding:.7rem .78rem;background:linear-gradient(180deg,#ffffff0f,#ffffff08);border:1px solid rgba(173,189,214,.12);border-radius:14px;transition:transform .2s ease,border-color .2s ease,background .2s ease}button.stat-row{appearance:none;font:inherit;color:inherit;text-align:left;cursor:pointer}.stat-row:hover{background:linear-gradient(180deg,#ffffff14,#ffffff0a);transform:translateY(-1px)}.stat-row.is-clickable{cursor:pointer}.stat-row.is-clickable:hover{border-color:var(--map-artefact)}.stat-label{flex:1;font-size:.82rem;color:var(--map-text-dim)}.stat-value{font-family:JetBrains Mono,monospace;font-size:.92rem;font-weight:700}.stat-value.energy{color:var(--map-energy)}.stat-value.stress{color:var(--map-stress)}.stat-value.confidence{color:var(--map-confidence)}.stat-value.appui{color:var(--map-appui)}.stat-value.artefacts{color:var(--map-artefact)}.stat-value.second-chance{color:var(--map-energy)}.stat-value.second-chance.depleted{color:var(--map-stress);opacity:.88}.capacities-summary{background:linear-gradient(180deg,#151f2ee0,#0d1421bd);border:1px solid rgba(173,189,214,.14);border-radius:18px;padding:.8rem .86rem;box-shadow:inset 0 1px #ffffff0a}.capacities-header{display:flex;align-items:center;gap:.4rem;margin-bottom:.5rem}.capacities-header .icon{width:18px;height:18px}.capacities-label{flex:1;font-size:.68rem;text-transform:uppercase;letter-spacing:.1em;color:var(--map-text-dim)}.capacities-count{font-family:JetBrains Mono,monospace;font-size:.88rem;color:var(--map-confidence)}.capacities-summary.is-impact{border-color:color-mix(in srgb,var(--map-appui) 60%,#ffffff 40%);box-shadow:0 0 0 1px color-mix(in srgb,var(--map-appui) 65%,transparent),0 12px 28px #00000057,0 0 22px color-mix(in srgb,var(--map-appui) 40%,transparent);animation:map-capacity-summary-impact .42s cubic-bezier(.2,.82,.24,1)}.capacities-count.is-impact{color:color-mix(in srgb,var(--map-appui) 70%,#ffffff 30%);text-shadow:0 0 16px color-mix(in srgb,var(--map-appui) 66%,transparent);animation:map-capacity-count-impact .52s cubic-bezier(.2,.82,.24,1)}.capacities-dots{display:flex;gap:3px;flex-wrap:wrap}.capacity-dot{width:10px;height:10px;border-radius:2px;background:var(--map-surface);border:1px solid var(--map-border);transition:all .3s ease}.capacity-dot.acquired{background:var(--map-confidence);border-color:var(--map-confidence)}.map-capacity-fx-layer{position:fixed;inset:0;z-index:calc(var(--layer-modal) - 1);pointer-events:none;overflow:visible}.map-capacity-particle{position:absolute;left:0;top:0;width:24px;height:24px;overflow:visible;opacity:0;transform:translate(-9999px,-9999px);transform-origin:center;will-change:transform,opacity;filter:drop-shadow(0 0 4px rgba(255,255,255,.75)) drop-shadow(0 0 11px color-mix(in srgb,var(--map-appui) 62%,transparent))}.map-capacity-particle__glyph{fill:currentColor;opacity:.88}.map-capacity-particle__core{fill:#f8fdff;opacity:.96}@keyframes map-capacity-summary-impact{0%{transform:translate(0) scale(1)}20%{transform:translate(1px) scale(1.015)}50%{transform:translate(-2px) scale(1.01)}to{transform:translate(0) scale(1)}}@keyframes map-capacity-count-impact{0%{transform:translateY(0) scale(1)}35%{transform:translateY(-2px) scale(1.12)}62%{transform:translateY(1px) scale(.96)}to{transform:translateY(0) scale(1)}}.run-items{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:.72rem}.run-item{appearance:none;display:flex;flex-direction:column;align-items:center;position:relative;min-height:118px;background:linear-gradient(180deg,#ffffff0f,#ffffff08);border:1px solid rgba(173,189,214,.14);border-radius:18px;padding:.82rem .56rem;text-align:center;font:inherit;color:inherit;cursor:pointer;box-shadow:inset 0 1px #ffffff08;transition:transform .2s ease,border-color .2s ease,background .2s ease}.run-item:hover{background:linear-gradient(180deg,#ffffff17,#ffffff0a);border-color:var(--map-energy);transform:translateY(-2px)}.run-item:focus-visible{outline:2px solid var(--map-energy);outline-offset:2px}.notif-badge{position:absolute;top:-6px;right:-6px;min-width:20px;height:20px;padding:0 6px;border-radius:999px;background:#f97316;color:#0f172a;border:2px solid var(--map-surface);font-family:JetBrains Mono,monospace;font-size:.75rem;font-weight:700;display:none;align-items:center;justify-content:center;box-shadow:0 0 0 2px #00000040}.run-item-count{font-family:JetBrains Mono,monospace;font-size:1.12rem;font-weight:700;color:var(--map-text-bright)}.run-item-label{font-size:.62rem;text-transform:uppercase;letter-spacing:.1em;color:var(--map-text-dim);margin-top:.1rem}.run-item.is-open{border-color:var(--map-artefact);box-shadow:0 0 0 1px color-mix(in srgb,var(--map-artefact) 45%,transparent)}.artefacts-panel{margin-top:.08rem;display:grid;gap:.6rem;padding:.85rem;border-radius:16px;border:1px solid var(--map-border);background:color-mix(in srgb,var(--map-surface) 86%,#0b1220 14%)}.artefacts-panel[hidden]{display:none}.artefacts-panel__item{display:grid;grid-template-columns:44px 1fr;gap:.75rem;align-items:start}.artefacts-panel__icon{width:40px;height:40px;border-radius:10px;border:1px solid color-mix(in srgb,var(--map-border) 75%,#ffffff 25%);background:#060a1385;object-fit:contain}.artefacts-panel__name{font-size:.86rem;font-weight:700;color:var(--map-text-bright);margin:0}.artefacts-panel__effect{margin:.1rem 0 0;font-size:.78rem;line-height:1.42;color:var(--map-text-dim)}.artefacts-panel__empty{font-size:.72rem;color:var(--map-text-dim)}.map-legend{margin-top:auto;padding-top:.8rem;border-top:1px solid var(--map-border)}.map-legend .legend-title{font-size:.55rem;text-transform:uppercase;letter-spacing:.1em;color:var(--map-text-dim);margin-bottom:.4rem}.map-legend .legend-items{display:grid;grid-template-columns:1fr 1fr;gap:.3rem}.map-legend .legend-item{display:flex;align-items:center;gap:.3rem;font-size:.6rem;color:var(--map-text-dim)}.map-legend .legend-dot{width:8px;height:8px;border-radius:50%}.map-legend .legend-dot.standard{background:var(--node-standard)}.map-legend .legend-dot.activity{background:var(--node-activity)}.map-legend .legend-dot.eval{background:var(--node-eval)}.map-legend .legend-dot.cantine{background:var(--node-cantine)}.map-legend .legend-dot.profs{background:var(--node-profs)}.map-legend .legend-dot.vie{background:var(--node-vie)}@media(max-width:1200px){.sidebar-left{width:252px;padding:1rem}.sidebar-right{width:292px}.sidebar-right-scroll{padding:1rem}.work-cover-tooltip-image{width:360px}}@media(max-width:980px){.sidebar-left,.sidebar-right{width:100%;max-height:none;overflow:visible}.sidebar-right-scroll{padding:.95rem 1rem;overflow:visible}.sidebar-left{padding:.95rem 1rem;border-bottom-left-radius:0;border-bottom-right-radius:0}.sidebar-right{border-top-left-radius:0;border-top-right-radius:0}.sequence-header{text-align:left}.sequence-title{font-size:1.3rem}.run-items{display:grid;grid-template-columns:repeat(3,minmax(0,1fr))}.work-cover{max-width:220px;align-self:center}.work-cover-tooltip{display:none}.map-legend{margin-top:0}.map-legend .legend-items{grid-template-columns:repeat(3,minmax(0,1fr))}}@media(max-width:640px){.map-sidebar-group--hero{padding:.82rem}.map-sidebar-group__title{font-size:.56rem;letter-spacing:.14em}.map-legend .legend-items{grid-template-columns:1fr 1fr}.sidebar-right .run-item .icon{width:38px;height:38px}#btnArtefacts .icon{width:42px;height:42px}.sidebar-right .run-item[data-carnet-badge] .icon{width:44px;height:44px}.artefacts-panel__item{grid-template-columns:36px 1fr;gap:.6rem}.artefacts-panel__icon{width:32px;height:32px;border-radius:8px}.artefacts-panel__name{font-size:.81rem}.artefacts-panel__effect{font-size:.74rem}}@media(prefers-reduced-motion:reduce){.motivation-display,.motivation-floater,.run-item,.stat-row,.btn-capacities,.work-cover-tooltip,.capacities-summary.is-impact,.capacities-count.is-impact,.map-capacity-particle{animation:none;transition:none}}body.page-map{--map-tooltip-bg: linear-gradient(135deg, #1e2d3d, #162029);--map-tooltip-shadow: 0 10px 40px rgba(0, 0, 0, .5);--map-tooltip-radius: 10px;--map-tooltip-padding: .8rem;--map-tooltip-max-width: 220px;--map-overlay-bg: rgba(0, 0, 0, .8);--map-modal-bg: linear-gradient(135deg, #1e2d3d, #162029);--map-modal-border-width: 2px;--map-modal-radius: 16px;--map-modal-padding: 1.5rem;--map-modal-max-width: 380px}body.page-map .mobile-map-recenter{position:fixed;top:calc(var(--map-shell-padding, 16px) + .5rem);right:calc(288px + var(--map-shell-gap, 16px) + var(--map-shell-padding, 16px) + .5rem);z-index:calc(var(--layer-hud, 1200) + 4);min-height:36px;padding:0 .78rem;border-radius:8px;border:1px solid rgba(190,205,225,.28);background:#0b121ee6;color:#f8fafc;font-size:.76rem;font-weight:700;cursor:pointer;backdrop-filter:blur(12px)}body.page-map .mobile-map-recenter[hidden]{display:none}.map-opportunity-toast-layer{position:fixed;right:clamp(1rem,3vw,2rem);bottom:calc(1rem + env(safe-area-inset-bottom));z-index:var(--layer-toast, 8000);display:grid;gap:.5rem;width:min(320px,calc(100vw - 2rem));pointer-events:none}.map-legend{position:absolute;left:.85rem;bottom:.85rem;z-index:calc(var(--layer-hud, 1200) + 1);width:min(260px,calc(100% - 1.7rem));color:var(--map-text);pointer-events:auto}.map-legend__toggle{min-height:36px;padding:0 .72rem;border-radius:8px;border:1px solid rgba(190,205,225,.28);background:#0b121ee6;color:#f8fafc;font-size:.76rem;font-weight:700;cursor:pointer;backdrop-filter:blur(12px)}.map-legend__panel{display:grid;gap:.65rem;margin-top:.45rem;padding:.75rem;border:1px solid rgba(190,205,225,.24);border-radius:8px;background:#09101ceb;box-shadow:0 14px 32px #0000005c;backdrop-filter:blur(14px)}.map-legend__title{margin:0 0 .35rem;color:color-mix(in srgb,var(--map-text-dim) 80%,#fff 20%);font-size:.66rem;font-weight:700;text-transform:uppercase}.map-legend__list{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.36rem .48rem;margin:0;padding:0;list-style:none}.map-legend__item{display:flex;align-items:center;min-width:0;gap:.34rem;color:#e5edf7;font-size:.72rem;line-height:1.2}.map-legend__swatch{flex:0 0 auto;display:inline-block;width:14px;height:14px;border-radius:50%;border:2px solid rgba(255,255,255,.36);background:#64748b}.map-legend__swatch.current{border-color:var(--node-current);background:#fbbf24}.map-legend__swatch.accessible{border-color:var(--node-accessible);background:#dbeafe}.map-legend__swatch.completed{border-color:var(--node-completed-path, #d9a45f);background:var(--node-completed-surface, #7a5a34)}.map-legend__swatch.locked{border-color:#94a3b8;background:#475569;opacity:.75}.map-legend__swatch.requires-capacity-missing{border-color:#f59e0b;background:#451a03}.map-legend__swatch.node-type-standard{background:var(--node-standard)}.map-legend__swatch.node-type-activity{background:var(--node-activity)}.map-legend__swatch.node-type-eval{background:var(--node-eval)}.map-legend__swatch.node-type-remediation{background:var(--node-remediation)}.map-legend__swatch.node-type-boss{background:var(--node-boss)}.map-legend__swatch.node-type-cantine{background:var(--node-cantine)}.map-legend__swatch.node-type-profs{background:var(--node-profs)}.map-legend__swatch.node-type-vie{background:var(--node-vie)}.map-legend__swatch.node-type-admin{background:var(--node-admin)}.map-legend__swatch.node-type-tim{background:var(--node-tim)}.map-legend__swatch.node-type-start{background:#475569}.map-opportunity-toast{display:grid;gap:.2rem;padding:.7rem .85rem;border:1px solid rgba(161,226,186,.48);border-radius:8px;color:#eef8ef;background:linear-gradient(135deg,#16231ff5,#18212ef0);box-shadow:0 12px 26px #00000057;opacity:0;transform:translateY(8px);animation:map-opportunity-toast-in 4.2s ease forwards}.map-opportunity-toast__title{font-size:.82rem;line-height:1.15}.map-opportunity-toast__detail{color:#eef8efc7;font-size:.74rem;line-height:1.25}@keyframes map-opportunity-toast-in{0%{opacity:0;transform:translateY(8px)}10%,82%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(4px)}}@media(prefers-reduced-motion:reduce){.map-opportunity-toast{animation:none;opacity:1;transform:none}}.map-node-tooltip,#tooltip{position:fixed;z-index:var(--layer-tooltip);background:var(--map-tooltip-bg);border:1px solid var(--map-border);border-radius:var(--map-tooltip-radius);padding:var(--map-tooltip-padding);max-width:var(--map-tooltip-max-width);box-shadow:var(--map-tooltip-shadow);pointer-events:none;opacity:0;transform:translateY(10px);transition:opacity .2s ease,transform .2s ease}.map-node-tooltip.visible,#tooltip.visible{opacity:1;transform:translateY(0)}.map-node-tooltip .tooltip-header,#tooltip .tooltip-header{display:flex;align-items:center;gap:.4rem;margin-bottom:.4rem}.map-node-tooltip .tooltip-icon,#tooltip .tooltip-icon{font-size:1.1rem}.map-node-tooltip .tooltip-title,#tooltip .tooltip-title{font-weight:700;font-size:.85rem;color:var(--map-text-bright)}.map-node-tooltip .tooltip-type,#tooltip .tooltip-type{font-size:.6rem;text-transform:uppercase;letter-spacing:.1em;color:var(--map-text-dim);margin-bottom:.4rem}.map-node-tooltip .tooltip-type:empty,#tooltip .tooltip-type:empty{display:none;margin-bottom:0}.map-node-tooltip .tooltip-desc,#tooltip .tooltip-desc{font-size:.75rem;color:var(--map-text);line-height:1.4;margin-bottom:.6rem}.map-node-tooltip .tooltip-effects,#tooltip .tooltip-effects{display:flex;flex-direction:column;gap:.25rem;padding-top:.4rem;border-top:1px solid var(--map-border)}.map-node-tooltip .tooltip-effects:empty,#tooltip .tooltip-effects:empty{display:none;padding-top:0;border-top:0}.map-node-tooltip .tooltip-effect,#tooltip .tooltip-effect{font-size:.7rem;padding-left:.5rem}.map-node-tooltip .tooltip-effect.positive,#tooltip .tooltip-effect.positive{color:var(--map-motivation)}.map-node-tooltip .tooltip-effect.negative,#tooltip .tooltip-effect.negative{color:var(--map-stress)}.map-node-tooltip .tooltip-effect.neutral,#tooltip .tooltip-effect.neutral{color:var(--map-text-dim)}@media(prefers-reduced-motion:reduce){.map-node-tooltip,#tooltip{animation:none;transition:none}}.modal-overlay{position:fixed;inset:0;background:var(--map-overlay-bg);display:flex;align-items:center;justify-content:center;z-index:var(--layer-modal);opacity:0;pointer-events:none;transition:opacity .3s ease}.modal-overlay.visible{opacity:1;pointer-events:auto}.modal-overlay .modal{background:var(--map-modal-bg);border:var(--map-modal-border-width) solid var(--map-border);border-radius:var(--map-modal-radius);padding:var(--map-modal-padding);max-width:var(--map-modal-max-width);width:90%;transform:scale(.9);transition:transform .3s ease}.modal-overlay .modal:focus-visible{outline:2px solid var(--map-energy);outline-offset:2px}.modal-overlay.visible .modal{transform:scale(1)}.modal-overlay .modal-header{display:flex;align-items:center;gap:.8rem;margin-bottom:.8rem}.modal-overlay .modal-icon{font-size:2rem}.modal-overlay .modal-title{font-family:Bebas Neue,sans-serif;font-size:1.3rem;color:var(--map-text-bright)}.modal-overlay .modal-desc{color:var(--map-text);line-height:1.5;margin-bottom:1rem;font-size:.9rem}.modal-overlay .modal-effects{display:flex;flex-direction:column;gap:.3rem;margin-bottom:1rem;padding:.6rem;background:var(--map-surface);border-radius:8px}.modal-overlay .modal-effects.modal-effects--event-result{border:1px solid color-mix(in srgb,var(--map-border) 80%,#ffffff 20%);background:color-mix(in srgb,var(--map-surface) 78%,#0f172a 22%)}.modal-overlay .modal-effect{font-size:.8rem}.modal-overlay .modal-effect.positive{color:var(--map-motivation)}.modal-overlay .modal-effect.negative{color:var(--map-stress)}.modal-overlay .modal-effect.neutral{color:var(--map-text-dim)}.modal-overlay .modal-buttons{display:flex;gap:.8rem}.modal-overlay .modal-btn{flex:1;padding:.7rem 1rem;border:none;border-radius:8px;font-family:inherit;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .2s ease}.modal-overlay .modal-btn.primary{background:var(--map-motivation);color:#000}.modal-overlay .modal-btn.primary:hover{transform:scale(1.03);box-shadow:0 4px 20px var(--map-motivation-glow)}.modal-overlay .modal-btn.secondary{background:var(--map-surface);border:1px solid var(--map-border);color:var(--map-text)}.modal-overlay .modal-btn.secondary:hover{background:var(--map-surface-hover)}.modal-overlay .reward-choices{display:flex;flex-direction:column;gap:.6rem;margin-top:1rem}.modal-overlay .reward-choice{display:flex;align-items:center;gap:.8rem;padding:.8rem;background:var(--map-surface);border:2px solid var(--map-border);border-radius:10px;cursor:pointer;transition:all .2s ease;text-align:left}.modal-overlay .reward-choice:hover{border-color:var(--map-energy);background:var(--map-surface-hover);transform:translate(5px)}.modal-overlay .reward-icon{font-size:1.5rem}.modal-overlay .reward-name{font-weight:600;color:var(--map-text-bright);display:block}.modal-overlay .reward-desc{font-size:.75rem;color:var(--map-text-dim);display:block;margin-top:.2rem}.modal-overlay .modal-rewards-title{font-size:.7rem;text-transform:uppercase;letter-spacing:.1em;color:var(--map-text-dim);margin-bottom:.3rem}.modal-overlay .stop-offers-budget{margin-bottom:.9rem;padding:.65rem .75rem;border:1px solid var(--map-border);border-radius:10px;background:color-mix(in srgb,var(--map-surface) 82%,#0f172a 18%);color:var(--map-text-bright);font-size:.82rem}.modal-overlay .stop-offers-budget strong{color:var(--map-energy);font-weight:700}.modal-overlay .stop-offers-columns{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:.75rem;margin-bottom:.95rem}.modal-overlay .stop-offers-section{display:flex;flex-direction:column;gap:.55rem}.modal-overlay .stop-offers-section h3{margin:0;font-size:.74rem;letter-spacing:.08em;text-transform:uppercase;color:var(--map-text-dim)}.modal-overlay .stop-offers-empty{border:1px dashed var(--map-border);border-radius:8px;padding:.75rem;font-size:.76rem;color:var(--map-text-dim);background:var(--map-surface)}.modal-overlay .stop-offer-card{border:1px solid var(--map-border);border-radius:10px;background:var(--map-surface);padding:.75rem;display:flex;flex-direction:column;gap:.5rem}.modal-overlay .stop-offer-card.is-selected{border-color:var(--map-energy);box-shadow:0 0 0 1px color-mix(in srgb,var(--map-energy) 60%,transparent)}.modal-overlay .stop-offer-body{display:flex;align-items:flex-start;gap:.65rem;min-width:0}.modal-overlay .stop-offer-visual{width:52px;height:52px;flex:0 0 auto;display:flex;align-items:center;justify-content:center;border-radius:12px;background:#0f172ad9;border:1px solid color-mix(in srgb,var(--map-border) 72%,#ffffff 28%);padding:6px}.modal-overlay .stop-offer-image{width:100%;height:100%;object-fit:contain}.modal-overlay .stop-offer-text{min-width:0;flex:1}.modal-overlay .stop-offer-head{display:flex;align-items:baseline;justify-content:space-between;gap:.45rem}.modal-overlay .stop-offer-name{margin:0;font-size:.84rem;color:var(--map-text-bright)}.modal-overlay .stop-offer-cost{font-size:.73rem;color:var(--map-energy)}.modal-overlay .stop-offer-desc{margin:0;font-size:.75rem;line-height:1.35;color:var(--map-text)}.modal-overlay .stop-offer-btn{width:100%;border:1px solid var(--map-border);border-radius:8px;background:color-mix(in srgb,var(--map-surface) 80%,#111827 20%);color:var(--map-text-bright);padding:.5rem .6rem;font-size:.74rem;font-weight:700;cursor:pointer;transition:background .18s ease,transform .18s ease,opacity .18s ease}@media(max-width:820px){.modal-overlay .stop-offer-visual{width:44px;height:44px;padding:5px;border-radius:10px}.modal-overlay .stop-offer-head{gap:.35rem}.modal-overlay .stop-offer-name{font-size:.78rem}.modal-overlay .stop-offer-body{gap:.55rem}}.modal-overlay .stop-offer-btn:hover:not(:disabled){transform:translateY(-1px);background:color-mix(in srgb,var(--map-surface-hover) 75%,#0f172a 25%)}.modal-overlay .stop-offer-btn:disabled{cursor:not-allowed;opacity:.55}.modal-overlay .modal.modal--start-draft{width:min(96vw,980px);max-width:980px;max-height:min(92vh,820px);overflow-y:auto}.modal-overlay .start-draft-header{margin-bottom:.55rem}.modal-overlay .start-draft-icon{display:inline-flex;align-items:center;justify-content:center;width:2rem;height:2rem;border-radius:999px;background:color-mix(in srgb,var(--map-energy) 22%,transparent);color:var(--map-energy);font-family:JetBrains Mono,monospace;font-size:1rem;font-weight:700}.modal-overlay .start-draft-card-options{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:.8rem;margin:1rem 0}.modal-overlay .start-draft-card-option{min-width:0;border:1px solid var(--map-border);border-radius:10px;background:color-mix(in srgb,var(--map-surface) 82%,#0f172a 18%);color:var(--map-text);padding:.7rem;text-align:left;cursor:pointer;transition:border-color .18s ease,box-shadow .18s ease,transform .18s ease,background .18s ease}.modal-overlay .start-draft-card-option:hover,.modal-overlay .start-draft-card-option.is-selected{border-color:var(--map-energy);background:color-mix(in srgb,var(--map-surface-hover) 86%,#111827 14%)}.modal-overlay .start-draft-card-option:hover{transform:translateY(-1px)}.modal-overlay .start-draft-card-option.is-selected{box-shadow:0 0 0 1px color-mix(in srgb,var(--map-energy) 60%,transparent)}.modal-overlay .start-draft-card-option__frame{display:grid;grid-template-columns:104px minmax(0,1fr);gap:.75rem;align-items:stretch}.modal-overlay .start-draft-card-option__art{min-width:0}.modal-overlay .start-draft-card-shell.card{position:relative;left:auto;bottom:auto;width:104px;height:158px;transform:none;animation:none;cursor:default;pointer-events:none}.modal-overlay .start-draft-card-shell .cardInner{border-radius:10px}.modal-overlay .start-draft-card-shell .card-art{min-height:42px}.modal-overlay .start-draft-card-shell .card__header{gap:.22rem;padding:.38rem}.modal-overlay .start-draft-card-shell .badge,.modal-overlay .start-draft-card-shell .card-icons,.modal-overlay .start-draft-card-shell .card-tags,.modal-overlay .start-draft-card-shell .effect__note{display:none}.modal-overlay .start-draft-card-shell .card__title{font-size:.58rem;line-height:1.05}.modal-overlay .start-draft-card-shell .card__body{padding:.32rem;min-height:0}.modal-overlay .start-draft-card-shell .effect,.modal-overlay .start-draft-card-shell .effect__text{font-size:.5rem;line-height:1.15}.modal-overlay .start-draft-card-option__body{display:flex;min-width:0;flex-direction:column;gap:.45rem}.modal-overlay .start-draft-card-option__title{color:var(--map-text-bright);font-size:.9rem;font-weight:700;line-height:1.15}.modal-overlay .start-draft-card-option__chips{display:flex;flex-wrap:wrap;gap:.3rem}.modal-overlay .start-draft-card-chip{display:inline-flex;align-items:center;min-height:1.35rem;border:1px solid color-mix(in srgb,var(--map-border) 82%,#ffffff 18%);border-radius:999px;padding:0 .45rem;color:var(--map-text);background:#0f172a94;font-size:.66rem;font-weight:700}.modal-overlay .start-draft-card-chip--rare{border-color:color-mix(in srgb,var(--map-energy) 70%,#ffffff 30%);color:var(--map-energy)}.modal-overlay .start-draft-card-option__summary{color:var(--map-text);font-size:.76rem;line-height:1.35}.modal-overlay .start-draft-actions{align-items:center}.modal-overlay .start-draft-status{flex:1 1 auto;min-height:1.2rem;margin:0;color:var(--map-text-dim);font-size:.78rem;line-height:1.3}.modal-overlay .start-draft-confirm{flex:0 0 min(260px,100%)}.modal-overlay .start-draft-confirm:disabled{cursor:not-allowed;opacity:.55}.modal-overlay .modal-btn:focus-visible,.modal-overlay .reward-choice:focus-visible,.modal-overlay .stop-offer-btn:focus-visible,.modal-overlay .start-draft-card-option:focus-visible{outline:2px solid var(--map-energy);outline-offset:2px}@media(max-width:960px){.modal-overlay .start-draft-card-options{grid-template-columns:1fr}}@media(max-width:700px){.modal-overlay .modal{width:calc(100% - 1.5rem);max-width:none;padding:1rem;border-radius:12px}.modal-overlay .modal-buttons{flex-direction:column}.modal-overlay .reward-choice{padding:.7rem}.modal-overlay .stop-offers-columns{grid-template-columns:1fr}.modal-overlay .start-draft-card-option__frame{grid-template-columns:88px minmax(0,1fr);gap:.65rem}.modal-overlay .start-draft-card-shell.card{width:88px;height:136px}.modal-overlay .start-draft-actions{align-items:stretch}}@media(prefers-reduced-motion:reduce){.modal-overlay,.modal-overlay .modal,.modal-overlay .modal-btn,.modal-overlay .reward-choice,.modal-overlay .start-draft-card-option{animation:none;transition:none}}.sidebar-right{--account-panel-min-height: 13rem;--portrait-width: 8.5rem;--portrait-height: 15rem;--portrait-left: -4.1rem;--portrait-top: 1.08rem;--account-main-shift: 3.5rem}.account-actions{position:relative;width:100%;min-height:var(--account-panel-min-height);margin-bottom:0;padding:0;z-index:calc(var(--layer-hud) + 2)}.account-visual{position:absolute;top:var(--portrait-top);left:var(--portrait-left);width:var(--portrait-width);height:var(--portrait-height);pointer-events:none;z-index:calc(var(--layer-hud) + 2);border-radius:24px;overflow:hidden;background:linear-gradient(180deg,#121d2c4d,#080e180d);box-shadow:0 22px 34px #03081057,inset 0 0 0 1px #ffffff0f}.account-profile-portrait{display:block;width:100%;height:100%;max-width:100%;border:0;border-radius:inherit;object-fit:cover;object-position:center top;background:transparent;box-shadow:none;filter:saturate(1.02);opacity:.98}.account-main{position:relative;z-index:calc(var(--layer-hud) + 2);margin-left:var(--account-main-shift);min-height:var(--account-panel-min-height);padding:1rem 1rem .98rem;border-radius:24px;border:1px solid rgba(160,194,226,.24);background:linear-gradient(180deg,#172739db,#0a121fbd);box-shadow:0 20px 38px #03081047,inset 0 0 0 1px #ffffff08;display:flex;flex-direction:column;justify-content:space-between;gap:.74rem}.account-status-wrap{display:flex;flex-direction:column;gap:.2rem;min-width:0;width:100%}.account-status-label{font-size:.62rem;letter-spacing:.14em;text-transform:uppercase;color:var(--map-text-dim);font-weight:700}.account-status{font-size:clamp(1.34rem,1.9vw,2.2rem);color:var(--map-text);font-weight:700;letter-spacing:.01em;line-height:.98;width:100%;max-width:100%;white-space:normal;overflow-wrap:anywhere;text-wrap:balance}.account-status[data-state=guest]{color:#cfdcec;font-weight:700}.account-meta{font-size:.72rem;line-height:1.2;color:var(--map-text-dim);min-width:0;white-space:normal;text-wrap:balance}.account-meta-row{display:flex;align-items:center;justify-content:space-between;gap:.5rem;width:100%;min-width:0}.account-connection-slot{display:flex;justify-content:flex-start;align-items:center;min-height:1.65rem;flex-shrink:0}.account-connection-slot .connection-indicator{position:static;max-width:100%;padding:.22rem .56rem;border:1px solid rgba(160,194,226,.14);background:#070e187a;color:color-mix(in srgb,var(--map-text-dim) 82%,#f8fbff 18%);font-size:.64rem;box-shadow:none}.account-link{align-self:flex-start;display:inline-flex;align-items:center;justify-content:center;width:auto;max-width:100%;min-height:42px;padding:.34rem 1rem;border-radius:999px;border:2px solid rgba(255,255,255,.24);background:#09152257;color:var(--map-text);font-size:clamp(.84rem,1vw,1rem);line-height:1.02;font-weight:700;text-decoration:none;cursor:pointer;transition:background .2s ease,border-color .2s ease,color .2s ease;text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.account-link:hover{background:#0f203085;border-color:#ffffff4d}.account-logout{color:#dbffe9;background:#22c55e2e;border-color:#4ade803d}.account-logout:hover{background:#22c55e42;border-color:#4ade8057}.motivation-display,.teacher-stats,.capacities-summary,.run-items{position:relative;z-index:calc(var(--layer-hud) + 3)}.map-page+#btn-fullscreen{position:fixed;right:16px;bottom:16px;width:46px;height:46px;border-radius:12px;border:1px solid var(--map-border, rgba(255, 255, 255, .08));background:#000000a6;color:#fff;font-size:1.2rem;cursor:pointer;box-shadow:0 10px 30px #00000059;z-index:var(--layer-hud)}.map-page+#btn-fullscreen:hover{background:#ffffff1a}.account-link:focus-visible,.map-page+#btn-fullscreen:focus-visible{outline:2px solid var(--map-energy);outline-offset:2px}@media(max-width:1200px){.sidebar-right{--account-panel-min-height: 12.2rem;--portrait-width: 7.6rem;--portrait-height: 13.6rem;--portrait-left: -3.4rem;--portrait-top: 1rem;--account-main-shift: 3rem}.account-main{padding:.86rem .84rem .82rem}.account-status{font-size:clamp(1.2rem,2.1vw,1.8rem)}.account-link{min-height:44px;font-size:.92rem}.account-meta{font-size:.68rem}}@media(max-width:980px){.sidebar-right{--account-panel-min-height: 11.6rem;--portrait-width: 6rem;--portrait-height: 11.6rem;--portrait-left: -.2rem;--portrait-top: .95rem;--account-main-shift: 4.7rem}.account-actions{margin-bottom:.68rem}.account-main{border-radius:20px;padding:.8rem .8rem .76rem}.account-status{font-size:clamp(1.08rem,3vw,1.58rem);max-width:none}.account-link{min-height:40px;font-size:.88rem}.account-meta{font-size:.64rem}.account-meta-row{align-items:flex-start;flex-direction:column}}@media(max-width:640px){.sidebar-right{--account-panel-min-height: 9.8rem;--portrait-width: 5rem;--portrait-height: 9.6rem;--portrait-left: .18rem;--portrait-top: .72rem;--account-main-shift: 4.2rem}.account-main{border-radius:16px;padding:.62rem .62rem .6rem;gap:.54rem}.account-status-label{font-size:.54rem}.account-status{font-size:.98rem}.account-link{min-height:36px;font-size:.76rem;border-width:1px}.account-meta{font-size:.58rem}}@media(max-width:980px){.map-page+#btn-fullscreen{width:40px;height:40px;right:10px;bottom:10px;border-radius:10px}}@media(prefers-reduced-motion:reduce){.account-link,.map-page+#btn-fullscreen{animation:none;transition:none}}body.page-map.map-theme-donjuan .map-page{background:#0b1220}body.page-map.map-theme-donjuan .map-container{background:linear-gradient(180deg,#0b1220d1,#121d2ed1 60%,#192c41e6),url(../../assets/map/donjuan/donjuan-bg.webp) center center / cover no-repeat}body.page-map.map-theme-donjuan .map-bg{opacity:.35}body.page-map.map-theme-donjuan{--map-bg-deep: #0b1220;--map-bg-scene: #111b2b;--map-bg-ground: #162438;--map-bg-path: #2f4966}.carnet-modal{--carnet-overlay: rgba(0, 0, 0, .75);--carnet-surface: linear-gradient(180deg, rgba(30, 35, 50, .98), rgba(15, 20, 30, .98));--carnet-border: rgba(148, 163, 184, .25);--carnet-shadow: 0 25px 80px rgba(0, 0, 0, .6);--carnet-text: #e5e7eb;--carnet-title: #fff;--carnet-muted: #9ca3af;--carnet-panel: rgba(0, 0, 0, .25);--carnet-panel-border: rgba(148, 163, 184, .15);--carnet-warning: #fbbf24;--carnet-success: #22c55e;--carnet-close-bg: rgba(255, 255, 255, .1);--carnet-close-hover: rgba(255, 255, 255, .2);--carnet-section-border: rgba(148, 163, 184, .2);--carnet-effet-bg: rgba(0, 0, 0, .2);--carnet-effet-impact-bg: rgba(0, 0, 0, .25);--carnet-effet-badge-bg: rgba(34, 197, 94, .25);--carnet-effet-decouvert-border: rgba(251, 191, 36, .3);--carnet-effet-maitrise-border: rgba(34, 197, 94, .4);--carnet-effet-maitrise-bg: rgba(34, 197, 94, .08);--carnet-impact-muted: #6b7280;position:fixed;inset:0;z-index:calc(var(--layer-modal) + 150);display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transition:opacity .3s ease,visibility .3s ease}.carnet-modal.is-visible{opacity:1;visibility:visible}.carnet-modal__backdrop{position:absolute;inset:0;background:var(--carnet-overlay);backdrop-filter:blur(4px)}.carnet-modal__content{position:relative;width:min(600px,90vw);max-height:85vh;background:var(--carnet-surface);border:1px solid var(--carnet-border);border-radius:16px;box-shadow:var(--carnet-shadow);overflow:hidden;transform:translateY(20px);transition:transform .3s ease}.carnet-modal.is-visible .carnet-modal__content{transform:translateY(0)}.carnet-modal__close{position:absolute;top:12px;right:12px;width:36px;height:36px;border:none;background:var(--carnet-close-bg);color:var(--carnet-title);font-size:1.2rem;border-radius:50%;cursor:pointer;transition:background .2s ease;z-index:calc(var(--layer-modal) + 10)}.carnet-modal__close:hover{background:var(--carnet-close-hover)}.carnet-modal__body{max-height:85vh;overflow-y:auto;padding:24px}.carnet{color:var(--carnet-text)}.carnet__header{text-align:center;margin-bottom:24px}.carnet__title{margin:0;font-size:1.6rem;font-weight:700;color:var(--carnet-title)}.carnet__subtitle{margin:8px 0 0;font-size:.9rem;color:var(--carnet-muted)}.carnet__stats{display:flex;justify-content:center;gap:24px;margin-bottom:28px;padding:16px;background:var(--carnet-panel);border-radius:12px;border:1px solid var(--carnet-panel-border)}.carnet__stat{display:flex;flex-direction:column;align-items:center;gap:4px}.carnet__stat-value{font-size:1.8rem;font-weight:800;color:var(--carnet-warning)}.carnet__stat-label{font-size:.75rem;color:var(--carnet-muted);text-transform:uppercase;letter-spacing:.05em}.carnet__section{margin-bottom:20px}.carnet__section-title{margin:0 0 16px;font-size:1rem;font-weight:600;color:var(--carnet-muted);text-transform:uppercase;letter-spacing:.08em;border-bottom:1px solid var(--carnet-section-border);padding-bottom:8px}.carnet__effets{display:flex;flex-direction:column;gap:12px}.carnet__effet{padding:14px 16px;background:var(--carnet-effet-bg);border:1px solid var(--carnet-panel-border);border-radius:10px;transition:all .2s ease}.carnet__effet--inconnu{opacity:.5;filter:grayscale(.5)}.carnet__effet--decouvert{border-color:var(--carnet-effet-decouvert-border)}.carnet__effet--maitrise{border-color:var(--carnet-effet-maitrise-border);background:var(--carnet-effet-maitrise-bg)}.carnet__effet-header{display:flex;align-items:center;gap:10px;margin-bottom:8px}.carnet__effet-icone{font-size:1.4rem}.carnet__effet-nom{font-size:1.1rem;font-weight:700;color:var(--carnet-title)}.carnet__effet-badge{margin-left:auto;padding:4px 10px;background:var(--carnet-effet-badge-bg);color:var(--carnet-success);font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;border-radius:999px}.carnet__effet-description{font-size:.85rem;color:var(--carnet-muted);margin-bottom:8px}.carnet__effet-impact{font-size:.85rem;padding:8px 12px;background:var(--carnet-effet-impact-bg);border-radius:6px}.carnet__effet-locked{color:var(--carnet-muted);font-style:italic}.carnet__effet-progression{margin-top:8px;font-size:.75rem;color:var(--carnet-impact-muted)}.impact-bad{color:#ef4444}.impact-block{color:#f59e0b;font-weight:600}.btn-carnet{--carnet-button-bg: rgba(251, 191, 36, .15);--carnet-button-border: rgba(251, 191, 36, .35);--carnet-button-hover-bg: rgba(251, 191, 36, .25);--carnet-button-hover-border: rgba(251, 191, 36, .5);display:flex;align-items:center;gap:8px;padding:8px 14px;background:var(--carnet-button-bg);border:1px solid var(--carnet-button-border);border-radius:10px;color:var(--carnet-warning);font-size:.85rem;font-weight:600;cursor:pointer;transition:all .2s ease}.btn-carnet:hover{background:var(--carnet-button-hover-bg);border-color:var(--carnet-button-hover-border);transform:translateY(-1px)}.btn-carnet__icon{width:20px;height:20px;object-fit:contain}@media(max-width:500px){.carnet-modal__body{padding:16px}.carnet__stats{gap:16px}.carnet__stat-value{font-size:1.4rem}}.deck-modal-open{overflow:hidden}.deck-modal-overlay{--deck-modal-overlay: rgba(15, 23, 42, .75);--deck-modal-surface: #0b1220;--deck-modal-border: rgba(255, 255, 255, .08);--deck-modal-divider: rgba(255, 255, 255, .06);--deck-modal-title: #e2e8f0;--deck-modal-muted: #94a3b8;--deck-modal-chip: rgba(255, 255, 255, .08);--deck-modal-chip-hover: rgba(255, 255, 255, .12);--deck-modal-shadow: 0 20px 70px rgba(0, 0, 0, .6);--deck-card-shadow: 0 12px 36px rgba(0, 0, 0, .35);--deck-card-surface: linear-gradient(180deg, rgba(148, 163, 184, .1), rgba(15, 23, 42, .8));--deck-card-visual-bg: #0f172a;--deck-card-empty-bg: rgba(255, 255, 255, .04);--deck-card-malus-bg: linear-gradient(180deg, rgba(239, 68, 68, .08), rgba(15, 23, 42, .85));--deck-card-malus-border: rgba(239, 68, 68, .25);--deck-card-malus-chip: rgba(239, 68, 68, .16);--deck-card-malus-text: #fecaca;position:fixed;inset:0;background:var(--deck-modal-overlay);backdrop-filter:blur(4px);display:none;align-items:center;justify-content:center;padding:2rem 1.25rem;z-index:calc(var(--layer-modal) + 200)}.deck-modal-overlay.visible{display:flex}.deck-modal{background:var(--deck-modal-surface);border:1px solid var(--deck-modal-border);border-radius:16px;box-shadow:var(--deck-modal-shadow);max-width:1100px;width:100%;max-height:90vh;display:flex;flex-direction:column;overflow:hidden}.deck-modal__header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-bottom:1px solid var(--deck-modal-divider);gap:1rem}.deck-modal__title{font-size:1.1rem;font-weight:700;color:var(--deck-modal-title)}.deck-modal__subtitle{font-size:.9rem;color:var(--deck-modal-muted);margin-top:.1rem}.deck-modal__close{border:none;background:var(--deck-modal-chip);color:var(--deck-modal-title);border-radius:999px;width:34px;height:34px;cursor:pointer;font-size:1rem;transition:background .2s ease,transform .1s ease}.deck-modal__close:hover{background:var(--deck-modal-chip-hover);transform:translateY(-1px)}.deck-modal__body{padding:1rem 1.25rem 1.25rem;overflow:auto;max-height:calc(90vh - 80px)}.deck-modal__grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(208px,208px));justify-content:center;gap:1rem}.deck-modal__empty{padding:2rem;text-align:center;color:color-mix(in srgb,var(--deck-modal-title) 80%,#000);background:var(--deck-card-empty-bg);border:1px dashed var(--deck-modal-border);border-radius:12px}.deck-card{position:relative;width:200px;height:360px}.deck-modal .deck-card.card{--layer-card-floating: 1;--card-z-hover: 1;--card-z-selected: 1;--card-z-dragging: 1;--card-z-blocked-hover: 1;position:relative;left:auto;bottom:auto;width:200px;height:360px;transform:none;animation:none;z-index:calc(var(--layer-modal) + 1);cursor:zoom-in;pointer-events:auto}.deck-modal .deck-card.card:before{display:none}.deck-modal .deck-card.card:hover .cardInner,.deck-modal .deck-card.card.is-selected .cardInner,.deck-modal .deck-card.card.dragging .cardInner{transform:translateY(0) scale(1);filter:none;box-shadow:var(--deck-card-shadow)}.deck-modal .deck-card .cardInner{box-shadow:var(--deck-card-shadow);border-color:color-mix(in srgb,var(--typeColor, rgba(148, 163, 184, .55)) 60%,rgba(255,255,255,.18))}.deck-modal .deck-card:focus-visible{outline:3px solid rgba(56,189,248,.85);outline-offset:4px}.deck-modal .deck-card .card-art{height:190px}.deck-modal .deck-card .card__body{padding-bottom:18px}.deck-modal .deck-card .card-cost img{width:15px;height:15px;object-fit:contain;image-rendering:pixelated}.deck-modal .deck-card .card-cost{gap:3px}.deck-modal .deck-card .card-tag{font-size:.68rem}.deck-modal .deck-card .effect{font-size:.72rem}.deck-modal .deck-card .effect__text{white-space:pre-line}.deck-modal .deck-card .card-effect-badge{bottom:10px;right:10px}.deck-card__top-badge{position:absolute;top:-9px;right:10px;z-index:calc(var(--layer-modal) + 12);display:inline-flex;align-items:center;justify-content:center;padding:3px 8px;border-radius:999px;font-size:.66rem;font-weight:800;letter-spacing:.06em;text-transform:uppercase;color:#0c0d18;background:linear-gradient(135deg,#fcd34d,#fbbf24);box-shadow:0 6px 18px #00000059}.deck-card--top .cardInner{box-shadow:0 12px 34px #0000007a,0 0 0 1px #fcd34d52}@media(max-width:720px){.deck-modal__grid{grid-template-columns:repeat(auto-fit,minmax(172px,172px));gap:.85rem}.deck-card,.deck-modal .deck-card.card{width:172px;height:312px}.deck-modal .deck-card .card-art{height:155px}.deck-modal .deck-card .card__title{font-size:.9rem}}.card{position:absolute;bottom:0;left:50%;z-index:var(--layer-card-base);transform-origin:50% 120%;width:178px;height:232px;--typeColor: rgba(148, 163, 184, .45);--card-z-base: var(--layer-card-base);--card-z-content: calc(var(--layer-card-base) + 1);--card-z-badge: calc(var(--layer-card-base) + 10);transition:transform .25s cubic-bezier(.22,1,.36,1);transform:translate(calc(-50% + var(--tx, 0px))) translateY(var(--ty, 0px)) rotate(var(--rot, 0deg));animation:card-entry .35s ease-out both;animation-delay:var(--card-delay, 0ms)}.cardInner{position:relative;width:100%;height:100%;border-radius:18px;overflow:hidden;display:flex;flex-direction:column;justify-content:space-between;background:linear-gradient(180deg,#ffffff0f,#00000085),radial-gradient(circle at 20% 0%,rgba(255,255,255,.12),transparent 45%),#0c0e18eb;border:1px solid color-mix(in srgb,var(--typeColor) 65%,rgba(255,255,255,.08));box-shadow:0 10px 28px #0000008c,var(--card-shadow);transition:transform .25s cubic-bezier(.22,1,.36,1),box-shadow .2s ease,border-color .2s ease,filter .25s ease;padding:12px;transform:translateY(0) scale(1);transform-origin:50% 120%}.card:hover{z-index:var(--layer-card-floating)}.card:hover .cardInner{transform:translateY(-180px) rotate(calc(-1 * var(--rot, 0deg))) scale(1.32);box-shadow:0 50px 150px #000000eb,0 0 36px #ffb84f73;filter:saturate(1.05) brightness(1.04)}.card.dragging{z-index:var(--layer-card-floating)}.card.dragging .cardInner{transform:translateY(-150px) rotate(calc(-1 * var(--rot, 0deg))) scale(1.18);box-shadow:0 40px 120px #000000e6,0 0 0 2px color-mix(in srgb,var(--typeColor) 60%,rgba(255,255,255,.2))}.card.is-selected{z-index:var(--layer-card-floating)}.card.is-selected .cardInner{transform:translateY(-180px) rotate(calc(-1 * var(--rot, 0deg))) scale(1.32);box-shadow:0 50px 150px #000000eb,0 0 36px #ffb84f73;filter:saturate(1.05) brightness(1.04)}.card .card__shadeTop,.card .card__shadeBottom{position:absolute;inset:0;pointer-events:none;z-index:var(--card-z-base)}.card__header{position:relative;z-index:var(--card-z-content);display:flex;justify-content:space-between;align-items:center;gap:6px;margin-bottom:8px;pointer-events:none}.badge{padding:5px 10px;border-radius:8px;font-size:.75rem;letter-spacing:.1em;color:#0c0d18;font-weight:800;text-transform:uppercase;background:color-mix(in srgb,var(--typeColor) 75%,rgba(255,255,255,.7));box-shadow:0 6px 16px #00000059}.card__title{font-size:1.05rem;font-weight:800;color:var(--text);text-shadow:0 1px 6px rgba(0,0,0,.4)}.card__body{position:relative;z-index:var(--card-z-content);background:#00000047;border-radius:12px;padding:10px;display:flex;flex-direction:column;gap:8px;border:1px solid rgba(255,255,255,.04);pointer-events:none;margin-top:auto}.card .pill{display:inline-flex;align-items:center;gap:4px;padding:4px 8px;border-radius:10px;font-size:.78rem;background:#ffffff0f;border:1px solid rgba(255,255,255,.08);color:var(--text);font-weight:700}.effect{padding:10px 12px;border-radius:12px;background:#00000047;border:1px solid rgba(255,255,255,.08);color:var(--text);line-height:1.3;font-size:.9rem}.card__img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center;display:block;image-rendering:crisp-edges;transform:scale(1.01);filter:saturate(.95) contrast(1.05);opacity:.22;z-index:var(--card-z-content)}.card__img--blur{filter:blur(8px) brightness(.7);transform:scale(1.04);opacity:.6;z-index:var(--card-z-base)}.card__imgPlaceholder{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;text-align:center;padding:10px;font-weight:800;line-height:1.1;color:#e2e8f0eb;background:radial-gradient(120% 120% at 20% 10%,#38bdf82e,#0f172af2)}.card__shadeTop{inset:0 0 auto;height:30%;background:linear-gradient(180deg,#000000c7,#0000)}.card__shadeBottom{inset:auto 0 0;height:46%;background:linear-gradient(0deg,#000000e0,#0000)}.costBadge{position:absolute;top:8px;right:8px;display:inline-flex;align-items:center;justify-content:center;font-weight:900;font-size:1rem;color:#fef3c7;text-shadow:0 2px 6px rgba(0,0,0,.6);z-index:var(--card-z-badge);pointer-events:none}.card-cost{display:inline-flex;align-items:center;gap:4px;letter-spacing:.04em}.hand--ribbon{display:flex;flex-wrap:nowrap;gap:10px;overflow-x:auto;overflow-y:visible;padding:8px 2px 12px;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch}.hand--ribbon::-webkit-scrollbar{height:10px}.hand--ribbon::-webkit-scrollbar-thumb{background:#94a3b840;border-radius:999px}.card.card--type-consigne{--typeColor: var(--color-type-consigne)}.card.card--type-support{--typeColor: var(--color-type-support)}.card.card--type-analyse{--typeColor: var(--color-type-analyse)}.card.card--type-lecture{--typeColor: var(--color-type-lecture)}.card.card--type-malus{--typeColor: var(--color-type-malus)}.card.card--type-autre{--typeColor: var(--color-type-default)}.hand--ribbon .card{position:relative;width:178px;min-width:178px;height:210px;scroll-snap-align:start}.hand--ribbon .card .cardInner{padding:12px;overflow:hidden;transition:transform .16s ease,height .16s ease,box-shadow .16s ease,border-color .16s ease,opacity .16s ease}.hand:hover .card:not(:hover):not(.is-selected):not(.dragging) .cardInner{transform:translateY(0) scale(1)}.hand--ribbon .card .card-art{height:135px;padding-top:0;margin-bottom:10px;transition:height .3s ease}.hand--ribbon .card .card-cost,.hand--ribbon .card .card-effects{display:none}@media(max-width:780px){.hand{height:320px}.card{width:158px;height:206px}}@keyframes card-entry{0%{opacity:0;transform:translate(calc(-50% + var(--tx, 0px))) translateY(calc(var(--ty, 0px) + 30px)) rotate(var(--rot, 0deg)) scale(.9)}to{opacity:1;transform:translate(calc(-50% + var(--tx, 0px))) translateY(var(--ty, 0px)) rotate(var(--rot, 0deg)) scale(1)}}.panel--combat,.combat,.handWrap,.hand{overflow:visible}.card-art{position:relative;width:100%;padding-top:100%;border-radius:12px;overflow:hidden;background:linear-gradient(135deg,#0f172a,#020617);border:1px solid rgba(148,163,184,.18);margin-bottom:8px}.card-art img{position:absolute;inset:0;width:100%;height:100%;object-fit:contain;object-position:center top;display:block;opacity:.9;filter:saturate(1.08) contrast(1.08) brightness(1.05)}.hand--ribbon .card .card-art{height:160px;padding-top:0;margin-bottom:10px}.hand--ribbon .card.is-selected .card-art,.hand--ribbon .card:hover:not(.no-hover-open) .card-art{height:220px}@media(max-width:780px){.hand--ribbon .card .card-art{height:140px}.hand--ribbon .card.is-selected .card-art,.hand--ribbon .card:hover:not(.no-hover-open) .card-art{height:200px}}.card{position:absolute;bottom:0;left:50%;--card-radius: 14px;--card-border-width: 2px;--card-band-height: 30px;--hover-lift: 200px;--select-lift: 230px;--drag-lift: 190px;--hover-scale: 1.16;--ty-base: 140px;--card-z-hover: var(--layer-card-floating);--card-z-selected: var(--layer-card-floating);--card-z-dragging: calc(var(--layer-card) + 2);--card-z-blocked-hover: calc(var(--layer-card-base) + 5);--card-z-base: var(--layer-card-base);--card-z-content: calc(var(--layer-card-base) + 1);--card-z-content-top: calc(var(--layer-card-base) + 2);--card-z-badge: calc(var(--layer-card-base) + 10);--card-z-overlay: calc(var(--layer-card-base) + 100);width:200px;height:360px;transform-origin:center bottom;transform:translate(calc(-50% + var(--tx, 0px))) translateY(calc(var(--ty-base, 0px) + var(--ty, 0px))) rotate(var(--rot, 0deg));--typeColor: rgba(148, 163, 184, .6);transition:transform .16s cubic-bezier(.34,1.56,.64,1);animation:card-enter .4s cubic-bezier(.34,1.56,.64,1) backwards;animation-delay:var(--card-delay, 0ms);cursor:pointer;z-index:var(--layer-card-base);pointer-events:auto}.cardInner{position:relative;width:100%;height:100%;border-radius:var(--card-radius);overflow:hidden;display:flex;flex-direction:column;justify-content:flex-start;background:linear-gradient(180deg,#141923f2,#0a0c14fa);border:var(--card-border-width) solid color-mix(in srgb,var(--typeColor) 70%,rgba(255,255,255,.15));box-shadow:0 8px 24px #00000080;transition:transform .16s cubic-bezier(.34,1.56,.64,1),box-shadow .16s ease,border-color .16s ease;transform:translateY(0) scale(1);transform-origin:center bottom}.card:before{content:"";position:absolute;left:0;right:0;bottom:-14px;height:14px;pointer-events:auto}.card.dragging:before{display:none}.card:hover{z-index:var(--card-z-hover);pointer-events:auto}.card:hover:not(.card--blocked) .cardInner{transform:translateY(calc(-1 * var(--hover-lift))) rotate(calc(-1 * var(--rot, 0deg))) scale(var(--hover-scale));box-shadow:0 30px 60px #000000b3,0 0 40px #fbbf244d}.card:hover .card-art,.card:hover .card__shadeTop,.card:hover .card__shadeBottom,.card:hover .card__header,.card:hover .card__body{pointer-events:none}.hand:hover .card:not(:hover):not(.is-selected):not(.dragging) .cardInner{transform:scale(.96)}.hand:has(.card:hover) .card:not(:hover):not(.dragging){pointer-events:auto}.card.is-selected{z-index:var(--card-z-selected)}.card.is-selected .cardInner{transform:translateY(calc(-1 * var(--select-lift))) rotate(calc(-1 * var(--rot, 0deg))) scale(1.18);box-shadow:0 35px 70px #000c,0 0 50px #fbbf2466;border-color:#fbbf24}.hand:has(.card.is-selected) .card:not(.is-selected):not(.dragging) .cardInner{transform:scale(.94)}.card.dragging{z-index:var(--card-z-dragging);opacity:.85;cursor:grabbing;pointer-events:none;transition:none}.card.card--blocked{cursor:not-allowed;opacity:.7;filter:grayscale(70%) brightness(.7);pointer-events:auto}.card.card--blocked:hover{z-index:var(--card-z-blocked-hover)}.card.card--blocked:hover .cardInner{transform:translateY(0) scale(1.02);box-shadow:0 8px 24px #00000080,0 0 20px #ef444466}@keyframes card-blocked-shake{0%,to{transform:translate(calc(-50% + var(--tx, 0px))) translateY(calc(var(--ty-base, 0px) + var(--ty, 0px))) rotate(var(--rot, 0deg))}25%{transform:translate(calc(-50% + var(--tx, 0px) - 8px)) translateY(calc(var(--ty-base, 0px) + var(--ty, 0px))) rotate(var(--rot, 0deg))}75%{transform:translate(calc(-50% + var(--tx, 0px) + 8px)) translateY(calc(var(--ty-base, 0px) + var(--ty, 0px))) rotate(var(--rot, 0deg))}}.card.card--blocked.card--shake{animation:card-blocked-shake .4s ease}.card-art{position:relative;width:100%;height:190px;flex-shrink:0;overflow:hidden;background:linear-gradient(135deg,#1a2030,#0d1018);pointer-events:none}.card-art img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 20%;opacity:.85;filter:saturate(1.1) contrast(1.05);pointer-events:none}.card__imgPlaceholder{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:2rem;background:radial-gradient(circle at 30% 30%,rgba(56,189,248,.15),transparent);pointer-events:none}.card__shadeTop{position:absolute;top:0;left:0;right:0;height:40px;background:linear-gradient(180deg,rgba(0,0,0,.6) 0%,transparent 100%);pointer-events:none;z-index:var(--card-z-content)}.card__shadeBottom{position:absolute;bottom:0;left:0;right:0;height:60%;background:linear-gradient(0deg,rgba(0,0,0,.9) 0%,transparent 100%);pointer-events:none;z-index:var(--card-z-content)}.card__header{position:absolute;top:0;left:0;right:0;height:190px;z-index:var(--card-z-content-top);pointer-events:none}.card__headerTop{position:absolute;top:0;left:0;right:0;display:grid;grid-template-columns:1fr auto;grid-template-rows:var(--card-band-height) auto;grid-template-areas:"badge cost" "tags cost";align-items:center;gap:4px 8px;padding:0 12px;border-top-left-radius:calc(var(--card-radius) - var(--card-border-width));border-top-right-radius:calc(var(--card-radius) - var(--card-border-width));overflow:hidden;pointer-events:none;z-index:var(--card-z-content-top)}.card__headerTop .badge{grid-area:badge;background:transparent;box-shadow:none;padding:0;border-radius:0}.card__headerTop .costBadge{grid-area:cost;justify-self:end;position:static;align-self:center}.card__headerTop .card__pedago{grid-area:tags}.card__headerTop:before{content:"";position:absolute;top:0;left:0;right:0;height:var(--card-band-height);background:var(--typeColor);border-radius:inherit;z-index:var(--card-z-base)}.card__headerTop>*{position:relative;z-index:var(--card-z-content)}.badge{display:inline-block;padding:5px 10px;border-radius:8px;font-size:.65rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:#0c0d18;background:var(--typeColor);box-shadow:0 2px 8px #0000004d;pointer-events:none}.card__title{position:absolute;left:12px;right:12px;bottom:-10px;font-size:1.05rem;font-weight:800;color:#fff;line-height:1.25;text-shadow:0 1px 4px rgba(0,0,0,.5);text-align:center;padding:7px 10px;background:linear-gradient(180deg,#000000a6,#0000008c);border-radius:12px;border:1px solid rgba(255,255,255,.08);pointer-events:none}.card__body{position:relative;z-index:var(--card-z-content-top);flex:1;display:flex;flex-direction:column;gap:8px;padding:2px 12px 18px;margin-top:0;min-height:0;pointer-events:none}.card .stats{display:flex;flex-wrap:wrap;gap:6px}.card .pill{display:inline-flex;align-items:center;gap:4px;padding:4px 9px;border-radius:6px;font-size:.72rem;font-weight:700;background:#ffffff1a;border:1px solid rgba(255,255,255,.1);color:#e8e8ed}.effect{display:flex;flex-direction:column;gap:6px;font-size:.74rem;line-height:1.4;color:#c8c8d0;padding:10px 12px;background:linear-gradient(180deg,#ffffff0a,#00000061);border-radius:10px;border:1px solid rgba(255,255,255,.08)}.effect__text{font-size:.7rem;color:#eef2ff;line-height:1.45}.effect em,.effect__note{font-size:.78rem;color:#cbd5e1}.costBadge{position:absolute;top:6px;right:6px;display:inline-flex;align-items:center;justify-content:center;font-weight:900;font-size:.95rem;color:#fef3c7;text-shadow:0 2px 6px rgba(0,0,0,.6);z-index:var(--card-z-badge);pointer-events:none}.card.card--type-consigne{--typeColor: #3b82f6}.card.card--type-support{--typeColor: #22c55e}.card.card--type-analyse{--typeColor: #f59e0b}.card.card--type-lecture{--typeColor: #ec4899}.card.card--type-malus{--typeColor: #ef4444}.card.card--type-autre{--typeColor: rgba(148, 163, 184, .7)}@keyframes card-enter{0%{opacity:0;transform:translate(calc(-50% + var(--tx, 0px))) translateY(calc(var(--ty-base, 0px) + 60px)) rotate(var(--rot, 0deg)) scale(.8)}to{opacity:1;transform:translate(calc(-50% + var(--tx, 0px))) translateY(calc(var(--ty-base, 0px) + var(--ty, 0px))) rotate(var(--rot, 0deg)) scale(1)}}.hand{position:relative;grid-row:3;width:min(1200px,98%);height:min(320px,32vh);min-height:180px;margin:0 auto;padding-bottom:12px;display:flex;align-items:flex-end;justify-content:center;pointer-events:auto;z-index:var(--layer-card-hand);overflow-x:auto;overflow-y:visible;overscroll-behavior-x:contain;overscroll-behavior-y:none;touch-action:pan-x}.hand::-webkit-scrollbar{height:10px}.hand::-webkit-scrollbar:vertical{width:0}.hand::-webkit-scrollbar-thumb:vertical{background:transparent}.hand::-webkit-scrollbar-corner{background:transparent}.hand:before{display:none}@media(max-width:900px){.card{width:170px;height:235px}.card-art{height:120px}.card__title{font-size:.9rem}.effect{font-size:.72rem}.costBadge{font-size:.85rem}}@media(max-width:600px){.card{width:140px;height:200px}.card-art{height:95px}.card:hover:not(.card--blocked) .cardInner{transform:translateY(-110px) rotate(calc(-1 * var(--rot, 0deg))) scale(1.1)}}.card__blocked-overlay{position:absolute;inset:0;background:#00000080;display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:var(--card-z-overlay);border-radius:inherit;backdrop-filter:blur(2px)}.card__blocked-icon{font-size:2.5rem;margin-bottom:.25rem;filter:drop-shadow(0 2px 8px rgba(0,0,0,.6));text-shadow:0 2px 8px rgba(0,0,0,.5);animation:pulse-blocked 1.5s ease-in-out infinite}.card__blocked-text{font-size:.75rem;font-weight:600;color:#ff6b6b;text-transform:uppercase;letter-spacing:.05em;text-shadow:0 1px 4px rgba(0,0,0,.8);background:#0009;padding:.2rem .5rem;border-radius:4px}@keyframes pulse-blocked{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.1);opacity:.8}}.card--shake{animation:shake-card .4s ease-in-out}@keyframes shake-card{0%,to{transform:translate(0) rotate(var(--rot, 0deg))}10%,30%,50%,70%,90%{transform:translate(-5px) rotate(var(--rot, 0deg))}20%,40%,60%,80%{transform:translate(5px) rotate(var(--rot, 0deg))}}.effect-badge--inconnu{background:#64646499;color:#888;font-style:italic}.effect-badge--maitrise{background:#22c55e33;border-color:var(--motivation)}.blocked-card-notif{position:fixed;top:20%;left:50%;transform:translate(-50%) translateY(-20px);background:linear-gradient(135deg,#2d1f1f,#1a1212);border:2px solid #ff6b6b;border-radius:12px;padding:1rem 1.5rem;display:flex;align-items:center;gap:1rem;z-index:calc(var(--layer-toast) + 200);opacity:0;transition:all .3s ease;box-shadow:0 8px 32px #ff6b6b4d}.blocked-card-notif--visible{opacity:1;transform:translate(-50%) translateY(0)}.blocked-card-notif__icon{font-size:2rem}.blocked-card-notif__text{display:flex;flex-direction:column;gap:.25rem}.blocked-card-notif__text strong{color:#ff6b6b;font-size:1rem}.blocked-card-notif__text span{color:#aaa;font-size:.85rem}.card__pedago,.card .card-tags{display:flex;flex-wrap:wrap;gap:6px;align-items:center;margin:0;padding:0;overflow:hidden;min-width:0;pointer-events:none;max-width:100%}.card__body .card-tags{margin:-10px 0 6px;padding:0;width:100%;max-width:100%;max-height:64px;flex-shrink:0;align-content:flex-start;justify-content:flex-start}.card__body .card-lifecycle{display:flex;align-items:center;margin:-2px 0 4px}.card-lifecycle-chip{display:inline-flex;align-items:center;justify-content:center;min-height:18px;padding:1px 8px;border-radius:999px;border:1px solid rgba(255,255,255,.35);background:#0f172ab3;color:#f8fafc;font-size:.58rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;pointer-events:none;max-width:100%}.card-lifecycle-chip--consume{background:#7f1d1db8;border-color:#fca5a5b8;color:#fee2e2}.card-lifecycle-chip--recycle{background:#1e40afb8;border-color:#93c5fdb8;color:#dbeafe}.card__body .card-tags.card-tags--single{margin-top:-8px}.card__body .card-tags.card-tags--triple{gap:4px}.card__body .card-tags.card-tags--triple.card-tags--packed .card-tag{max-width:calc((100% - 4px)/2);padding:3px 6px;font-size:.64rem}.card__body .card-tags.card-tags--triple.card-tags--packed.card-tags--packed-strong .card-tag{max-width:100%;font-size:.62rem;padding:2px 5px}.card__body .card-tags.card-tags--triple.card-tags--packed-strong{display:grid;grid-template-columns:1fr;gap:3px}.card__body .card-tags.card-tags--triple.card-tags--packed-strong .card-tag{width:fit-content;justify-self:start}.card__pedago--missing,.card .card-tags--missing{color:#dce7f5;font-size:.85rem;opacity:.9}.card .card-tag,.pedago-badge,.pedago-chip{display:inline-flex;align-items:center;flex:0 1 auto;width:fit-content;max-width:100%;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;background:#38bdf824;color:#c8f0ff;border:1px solid rgba(56,189,248,.35);border-radius:999px;padding:4px 8px;font-size:.75rem;text-transform:lowercase;letter-spacing:.01em}.pedago-chip{padding:2px 8px;font-size:12px;line-height:1.1}.pedago-chip--more{opacity:.9;font-weight:600;cursor:help;pointer-events:auto}.card-tag--more{opacity:.85;font-weight:600}.card--refused{animation:card-refused .4s ease;box-shadow:0 0 0 2px #ef444499,var(--card-shadow, 0 16px 30px rgba(0, 0, 0, .65))}@keyframes card-refused{0%{transform:translateY(0) scale(1)}30%{transform:translateY(-6px) scale(1.03)}60%{transform:translateY(2px) scale(.98)}to{transform:translateY(0) scale(1)}}.card{pointer-events:auto;cursor:grab;user-select:none;-webkit-user-select:none;-moz-user-select:none}body.is-dragging,body.is-dragging *{cursor:grabbing}.card__header,.card__body,.card__shadeTop,.card__shadeBottom,.card__blocked-overlay,.card-art,.card__img,.card__img--blur,.card__imgPlaceholder{pointer-events:none}.card.dragging .cardInner{transform:translateY(-150px) rotate(calc(-1 * var(--rot, 0deg))) scale(1.18);box-shadow:0 40px 120px #000000e6,0 0 0 2px color-mix(in srgb,var(--typeColor) 60%,rgba(255,255,255,.2));transition:none}.hand:has(.card.dragging) .card:not(.dragging){opacity:.6;filter:brightness(.7);transition:opacity .2s ease,filter .2s ease}.target-zone.drag-over,.dropzone.drag-over{background:#94a3b81f;border-color:#94a3b88c;box-shadow:0 0 18px #94a3b847;transform:scale(1.02);transition:all .16s ease}.dropzone--valid.drag-over{background:#22c55e29;border-color:#22c55ed9;box-shadow:0 0 22px #22c55e59}.dropzone--invalid.drag-over{background:#94a3b81a;border-color:#94a3b88c;box-shadow:0 0 16px #94a3b833}.card *{user-select:none;-webkit-user-select:none;-moz-user-select:none}.card__header:after{content:"";position:absolute;left:14px;right:14px;bottom:-6px;height:1px;background:linear-gradient(90deg,transparent,rgba(226,232,240,.45),transparent)}.card__title{font-size:1.12rem;letter-spacing:.01em}.card__body{background:linear-gradient(180deg,#080c14a6,#020617e6);border:1px solid rgba(148,163,184,.14);border-radius:12px}.card-level-badge{position:absolute;top:8px;left:8px;z-index:var(--card-z-badge, 10);display:inline-flex;align-items:center;justify-content:center;width:58px;height:24px;border-radius:999px;border:1px solid rgba(255,255,255,.36);font-size:.66rem;font-weight:900;line-height:1;letter-spacing:0;white-space:nowrap;pointer-events:none;box-shadow:0 6px 16px #00000061}.card-level-badge--level-2{color:#2a1308;background:linear-gradient(135deg,#d39b63,#b86b38);border-color:#f6bc82eb}.card-level-badge--level-3{color:#2d2100;background:linear-gradient(135deg,#ffe89a,#f5c542 48%,#c8901c);border-color:#fff1aaf2;box-shadow:0 6px 18px #0006,0 0 18px #f5c54259}.card--level-2 .cardInner{border-color:color-mix(in srgb,#c27a41 74%,rgba(255,255,255,.2))}.card--level-3 .cardInner{border-color:color-mix(in srgb,#f5c542 80%,rgba(255,255,255,.24));box-shadow:0 8px 24px #00000080,0 0 18px #f5c54247}.card--level-3 .cardInner:after{content:"";position:absolute;inset:0;z-index:calc(var(--card-z-content-top, 2) + 1);pointer-events:none;background:linear-gradient(115deg,transparent 0 34%,rgba(255,255,255,.18) 44%,transparent 54% 100%);mix-blend-mode:screen;opacity:.32}.card-level-badge--pulse,.card--evolved-now .card-level-badge{animation:card-level-pulse .68s cubic-bezier(.18,.82,.22,1) both}@keyframes card-level-pulse{0%{transform:scale(.82);filter:brightness(1)}45%{transform:scale(1.15);filter:brightness(1.24)}to{transform:scale(1);filter:brightness(1)}}.effect{font-size:.8rem;color:#f1f5f9eb}.effect__text{font-size:.78rem;color:#f1f5f9f2}.effect__note{color:#cbd5e1e6}.card.card--hover:not(.card--blocked):not(.card--disabled),.card.card--hover.is-selected:not(.card--blocked):not(.card--disabled){z-index:var(--layer-card-floating)}.card.card--hover:not(.card--blocked):not(.card--disabled) .cardInner,.card.card--hover.is-selected:not(.card--blocked):not(.card--disabled) .cardInner{transform:translateY(calc(-1 * var(--hover-lift, 160px))) rotate(calc(-1 * var(--rot, 0deg))) scale(var(--hover-scale, 1.1));box-shadow:0 30px 60px #000000bf,0 0 45px #fbbf2459}.card.is-selected,.card.card--selected{outline:2px solid rgba(251,191,36,.7);outline-offset:2px}.card--disabled,.card--disabled.card--blocked{filter:grayscale(65%) brightness(.85);opacity:.8}.card--disabled:hover .cardInner{box-shadow:0 8px 24px #00000080,0 0 18px #ef444459}@media(max-width:780px){.card{--hover-lift: 160px;--select-lift: 180px;--drag-lift: 150px;--hover-scale: 1.1}.hand{min-height:240px}}@media(max-height:900px){.card{--hover-lift: 145px;--select-lift: 165px;--drag-lift: 140px;--hover-scale: 1.1}}@media(max-height:760px){.card{--hover-lift: 120px;--select-lift: 138px;--drag-lift: 118px;--hover-scale: 1.08}}@media(max-width:420px){.card{width:132px;height:190px}.card__title{font-size:.95rem}}.card-inspect-modal{--inspect-backdrop: rgba(0, 0, 0, .85);--inspect-panel-bg: rgba(16, 24, 32, .96);--inspect-panel-border: rgba(245, 230, 211, .2);--inspect-panel-shadow: 0 24px 60px rgba(0, 0, 0, .6);--inspect-left-bg: rgba(12, 18, 24, .95);--inspect-left-separator: rgba(245, 230, 211, .1);--inspect-image-bg: rgba(15, 23, 42, .7);--inspect-image-border: rgba(245, 230, 211, .2);--inspect-text: #f5e6d3;--inspect-close-bg: rgba(245, 230, 211, .1);--inspect-close-bg-hover: rgba(245, 230, 211, .2);--inspect-close-border: rgba(245, 230, 211, .3);--inspect-close-text: #f5e6d3;--inspect-cost-text: rgba(245, 230, 211, .85);--inspect-cost-icon: #fef3c7;--inspect-section-title: rgba(251, 191, 36, .9);--inspect-copy: rgba(245, 230, 211, .9);--inspect-statline: rgba(168, 214, 255, .9);--inspect-tag-bg: rgba(139, 115, 85, .35);--inspect-tag-border: rgba(139, 115, 85, .6);--inspect-footer-bg: rgba(0, 0, 0, .6);--inspect-footer-text: rgba(245, 230, 211, .85);--inspect-footer-meta: rgba(245, 230, 211, .78);--inspect-footer-meta-label: rgba(245, 230, 211, .9);position:fixed;inset:0;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .2s ease-in-out;z-index:var(--layer-card-inspect)}.card-inspect-modal.card-inspect-modal--malus{--inspect-backdrop: rgba(16, 0, 4, .93);--inspect-panel-bg: linear-gradient(180deg, rgba(66, 8, 14, .98), rgba(30, 0, 8, .98));--inspect-panel-border: rgba(255, 86, 126, .9);--inspect-panel-shadow: 0 28px 66px rgba(0, 0, 0, .78), 0 0 0 2px rgba(255, 70, 110, .26), 0 0 42px rgba(255, 60, 105, .34);--inspect-left-bg: rgba(42, 4, 10, .98);--inspect-left-separator: rgba(255, 118, 153, .48);--inspect-image-bg: rgba(56, 6, 12, .9);--inspect-image-border: rgba(255, 122, 158, .62);--inspect-text: #fee2e2;--inspect-close-bg: rgba(255, 94, 130, .28);--inspect-close-bg-hover: rgba(255, 118, 151, .44);--inspect-close-border: rgba(255, 131, 163, .78);--inspect-close-text: #ffe4e6;--inspect-cost-text: #ffd4db;--inspect-cost-icon: #ff96ad;--inspect-section-title: #ff9bb0;--inspect-copy: #ffe4e6;--inspect-statline: #ffd2d9;--inspect-tag-bg: rgba(255, 55, 95, .28);--inspect-tag-border: rgba(255, 130, 160, .72);--inspect-footer-bg: rgba(34, 0, 8, .78);--inspect-footer-text: rgba(254, 226, 226, .92);--inspect-footer-meta: rgba(255, 213, 221, .88);--inspect-footer-meta-label: rgba(255, 233, 237, .98)}.card-inspect-modal.card-inspect-modal--malus.malus-tone-brutal{--inspect-panel-bg: linear-gradient(180deg, rgba(92, 8, 18, .99), rgba(34, 0, 8, .99));--inspect-panel-border: rgba(255, 74, 114, .95);--inspect-panel-shadow: 0 28px 66px rgba(0, 0, 0, .8), 0 0 0 2px rgba(255, 74, 114, .34), 0 0 34px rgba(255, 60, 102, .32);--inspect-left-bg: rgba(54, 4, 12, .98);--inspect-left-separator: rgba(255, 118, 153, .56);--inspect-image-border: rgba(255, 138, 170, .74);--inspect-cost-icon: #ff8ea8;--inspect-tag-bg: rgba(255, 62, 108, .32);--inspect-tag-border: rgba(255, 134, 164, .78)}.card-inspect-modal.card-inspect-modal--malus.malus-tone-neon{--inspect-panel-bg: linear-gradient(180deg, rgba(82, 8, 66, .99), rgba(28, 0, 22, .99));--inspect-panel-border: rgba(255, 110, 214, .95);--inspect-panel-shadow: 0 28px 66px rgba(0, 0, 0, .8), 0 0 0 2px rgba(255, 103, 208, .34), 0 0 42px rgba(255, 82, 204, .44);--inspect-left-bg: rgba(52, 4, 40, .98);--inspect-left-separator: rgba(255, 152, 224, .58);--inspect-image-border: rgba(255, 170, 232, .74);--inspect-section-title: #ffb6e6;--inspect-cost-icon: #ffb0e0;--inspect-tag-bg: rgba(255, 86, 200, .3);--inspect-tag-border: rgba(255, 164, 230, .76)}.card-inspect-modal.card-inspect-modal--malus.malus-tone-brutal.malus-tone-neon{--inspect-panel-bg: linear-gradient(180deg, rgba(102, 6, 54, .995), rgba(34, 0, 20, .995));--inspect-panel-border: rgba(255, 102, 196, .98);--inspect-panel-shadow: 0 30px 72px rgba(0, 0, 0, .82), 0 0 0 2px rgba(255, 95, 182, .36), 0 0 50px rgba(255, 76, 178, .56);--inspect-left-bg: rgba(62, 2, 32, .985);--inspect-left-separator: rgba(255, 154, 220, .64);--inspect-image-border: rgba(255, 182, 236, .8);--inspect-section-title: #ffc5ea;--inspect-cost-icon: #ffb8e4;--inspect-tag-bg: linear-gradient(90deg, rgba(255, 63, 118, .34), rgba(255, 96, 210, .34));--inspect-tag-border: rgba(255, 184, 232, .84)}.card-inspect-modal.card-inspect-modal--malus .card-inspect-modal__title{color:#fff1f2;text-shadow:0 0 14px rgba(255,118,151,.4)}.card-inspect-modal.card-inspect-modal--malus .card-inspect-modal__cost{font-weight:700;text-shadow:0 0 8px rgba(255,120,150,.32)}.card-inspect-modal.is-visible{opacity:1;pointer-events:auto}.card-inspect-modal__backdrop{position:absolute;inset:0;background:var(--inspect-backdrop)}.card-inspect-modal__panel{position:relative;display:grid;grid-template-columns:40% 60%;max-width:900px;width:min(900px,92vw);background:var(--inspect-panel-bg);border:2px solid var(--inspect-panel-border);border-radius:16px;overflow:hidden;box-shadow:var(--inspect-panel-shadow);z-index:calc(var(--layer-card-inspect) + 1)}.card-inspect-modal__left{display:flex;flex-direction:column;align-items:center;padding:24px;gap:16px;background:var(--inspect-left-bg);border-right:2px solid var(--inspect-left-separator)}.card-inspect-modal__image{width:100%;aspect-ratio:3 / 4;border-radius:12px;overflow:hidden;background:var(--inspect-image-bg);border:1px solid var(--inspect-image-border);display:flex;align-items:center;justify-content:center}.card-inspect-modal__image img{width:100%;height:100%;object-fit:contain;object-position:center top}.card-inspect-modal__right{padding:24px 28px;display:flex;flex-direction:column;gap:16px;color:var(--inspect-text)}.card-inspect-modal__header{display:flex;align-items:center;justify-content:space-between;gap:12px}.card-inspect-modal__title{font-size:22px;margin:0;flex:1 1 auto;min-width:0}.card-inspect-modal__level-badge{flex:0 0 auto;display:inline-flex;align-items:center;justify-content:center;width:64px;height:26px;border-radius:999px;border:1px solid rgba(255,255,255,.36);font-size:.72rem;font-weight:900;letter-spacing:0;color:#2a1308;background:linear-gradient(135deg,#d39b63,#b86b38);box-shadow:0 8px 18px #00000047}.card-inspect-modal__level-badge--level-3{color:#2d2100;background:linear-gradient(135deg,#ffe89a,#f5c542 48%,#c8901c);border-color:#fff1aaf0;box-shadow:0 8px 18px #0000004d,0 0 18px #f5c54252}.card-inspect-modal__close{width:32px;height:32px;border-radius:8px;border:1px solid var(--inspect-close-border);background:var(--inspect-close-bg);color:var(--inspect-close-text);font-size:18px;cursor:pointer}.card-inspect-modal__close:hover{background:var(--inspect-close-bg-hover)}.card-inspect-modal__cost{display:flex;align-items:center;gap:8px;font-size:14px;color:var(--inspect-cost-text)}.card-inspect-modal__cost-icon{display:inline-flex;align-items:center;justify-content:center;font-weight:800;color:var(--inspect-cost-icon);text-shadow:0 2px 6px rgba(0,0,0,.6);letter-spacing:.04em}.card-inspect-modal__section h3{margin:0 0 6px;font-size:13px;letter-spacing:.08em;text-transform:uppercase;color:var(--inspect-section-title)}.card-inspect-modal__section p,.card-inspect-modal__section li{margin:0 0 6px;font-size:14px;line-height:1.5;color:var(--inspect-copy)}.card-inspect-modal__statline{font-weight:600;color:var(--inspect-statline)}.card-inspect-modal__rules ul{margin:0;padding-left:18px}.card-inspect-modal__tags{display:flex;flex-wrap:wrap;gap:6px;max-height:2.6em;overflow:hidden}.card-inspect-modal__tag{padding:4px 8px;border-radius:999px;background:var(--inspect-tag-bg);border:1px solid var(--inspect-tag-border);font-size:12px;max-width:100%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.card-inspect-modal__tag-empty{font-size:12px;opacity:.7}.card-inspect-modal__tag--more{opacity:.8;font-weight:600}.card-inspect-modal__footer{width:100%;background:var(--inspect-footer-bg);border-radius:12px;padding:12px 14px;color:var(--inspect-footer-text);font-size:12px;line-height:1.4}.card-inspect-modal__footer-title{font-weight:700;letter-spacing:.08em;text-transform:uppercase;margin-bottom:4px}.card-inspect-modal__footer-text{margin:0 0 6px}.card-inspect-modal__footer-meta{margin-top:3px;font-size:11px;line-height:1.35;color:var(--inspect-footer-meta)}.card-inspect-modal__footer-meta-label{font-weight:700;color:var(--inspect-footer-meta-label)}@media(max-width:900px){.card-inspect-modal__panel{grid-template-columns:1fr}.card-inspect-modal__left{border-right:none;border-bottom:2px solid var(--inspect-left-separator)}}.card__effects{display:flex;flex-wrap:wrap;gap:6px;align-items:center;margin-top:6px}.effect-badge{display:inline-flex;align-items:center;gap:4px;padding:4px 8px;border-radius:8px;font-size:.85rem;font-weight:700;background:#0006;border:1.5px solid rgba(255,255,255,.15);transition:all .2s ease;white-space:nowrap}.effect-badge__icon{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;flex-shrink:0;object-fit:contain;image-rendering:-webkit-optimize-contrast;image-rendering:crisp-edges}.effect-badge__value{font-family:JetBrains Mono,Courier New,monospace;font-size:.9rem;font-weight:800;letter-spacing:-.02em}.effect-badge--difficulte{background:linear-gradient(135deg,#fbbf2433,#f59e0b26);border-color:#fbbf2466;color:#fbbf24;box-shadow:0 0 12px #fbbf2426}.effect-badge--confiance{background:linear-gradient(135deg,#38bdf833,#0ea5e926);border-color:#38bdf866;color:#38bdf8;box-shadow:0 0 12px #38bdf826}.effect-badge--confiance .effect-badge__icon{color:#38bdf8;filter:drop-shadow(0 0 3px rgba(56,189,248,.4))}.effect-badge--motivation{background:linear-gradient(135deg,#22c55e33,#16a34a26);border-color:#22c55e66;color:#22c55e;box-shadow:0 0 12px #22c55e26}.effect-badge--motivation .effect-badge__icon{color:#22c55e;filter:drop-shadow(0 0 3px rgba(34,197,94,.4))}.effect-badge--stress{background:linear-gradient(135deg,#ef444433,#dc262626);border-color:#ef444466;color:#ef4444;box-shadow:0 0 12px #ef444426}.effect-badge--stress .effect-badge__icon{color:#ef4444;filter:drop-shadow(0 0 3px rgba(239,68,68,.4))}.effect-badge--temps{background:linear-gradient(135deg,#a855f733,#9333ea26);border-color:#a855f766;color:#a855f7;box-shadow:0 0 12px #a855f726}.effect-badge--temps .effect-badge__icon{color:#a855f7;filter:drop-shadow(0 0 3px rgba(168,85,247,.4))}.effect-badge--energie{background:linear-gradient(135deg,#ffd70033,#ffc10726);border-color:#ffd70066;color:gold;box-shadow:0 0 12px #ffd70026}.effect-badge--energie .effect-badge__icon{color:gold;filter:drop-shadow(0 0 3px rgba(255,215,0,.4))}.effect-badge__value--positive{color:inherit;text-shadow:0 0 6px currentColor}.effect-badge__value--negative{color:inherit;opacity:.9}.effect-badge:hover{transform:scale(1.05);border-color:#ffffff4d;box-shadow:0 0 16px currentColor}@keyframes badge-appear{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}.effect-badge{animation:badge-appear .25s ease-out backwards;animation-delay:calc(var(--badge-index, 0) * .05s)}@media(max-width:780px){.effect-badge{padding:3px 6px;font-size:.75rem;gap:3px}.effect-badge__icon{width:16px;height:16px;font-size:.8rem}.effect-badge__value{font-size:.8rem}}.card .stats{display:none}.card__body .card__effects{padding:0;margin:0;background:transparent;border:none}.card__body--has-effect-badge{padding-bottom:34px}.card-effect-badge{position:absolute;right:12px;bottom:12px;z-index:calc(var(--layer-card-base) + 2);width:22px;height:22px;border-radius:8px;background:#00000059;backdrop-filter:blur(2px);display:inline-flex;align-items:center;justify-content:center;pointer-events:none}.card-effect-badge img{width:18px;height:18px;image-rendering:pixelated}.card-effect-text{display:none}.tooltip-inline-icon{display:inline-block;vertical-align:middle;width:24px;height:24px;margin:0 4px;object-fit:contain}.tooltip-desc{line-height:1.6}:root{--teacher-profile-select-layer-base: var(--layer-profile-select, 9600);--teacher-profile-code-modal-layer-base: var(--layer-profile-code-modal, 9700)}.teacher-profile-select-overlay{position:fixed;inset:0;background:#02040aeb;display:flex;align-items:center;justify-content:center;z-index:var(--teacher-profile-select-layer-base);padding:12px;opacity:0;transition:opacity .35s ease;backdrop-filter:blur(6px)}.teacher-profile-select-overlay.is-visible{opacity:1}.teacher-profile-select{width:100%;max-width:1100px;height:100%;max-height:100%;background:radial-gradient(ellipse 80% 40% at 50% 0%,rgba(60,80,120,.12),transparent),linear-gradient(180deg,#0a0e18,#0f131c 40%,#0b0f17);color:#f4f5f8;border-radius:18px;padding:16px 20px 14px;border:1px solid rgba(255,255,255,.06);box-shadow:0 0 80px #0009,0 0 0 1px #ffffff08 inset;display:flex;flex-direction:column;gap:10px;position:relative;isolation:isolate;overflow:hidden}.teacher-profile-select:before{content:"";position:absolute;top:0;left:10%;right:10%;height:1px;background:linear-gradient(90deg,transparent,rgba(127,179,255,.5),transparent)}.teacher-profile-select__header{text-align:center;position:relative;padding:2px 0;flex-shrink:0}.teacher-profile-select__header-deco{position:absolute;top:50%;left:50%;transform:translate(-50%,-60%);width:280px;height:60px;background:radial-gradient(ellipse,rgba(127,179,255,.08),transparent 70%);pointer-events:none}.teacher-profile-select__title{font-size:clamp(1.1rem,2.5vw,1.5rem);font-weight:800;margin:0;letter-spacing:.05em;text-transform:uppercase;background:linear-gradient(180deg,#fff 20%,#94b8e0);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;filter:drop-shadow(0 2px 8px rgba(127,179,255,.2));position:relative}.teacher-profile-select__guide-card{position:absolute;left:50%;bottom:62px;transform:translate(-50%);width:min(620px,calc(100% - 36px));max-width:min(620px,calc(100% - 36px));padding:14px 16px;border-radius:18px;border:2px solid rgba(196,214,235,.9);background:radial-gradient(rgba(69,94,132,.35) 1px,transparent 1px),linear-gradient(180deg,#09152afa,#071022fa);background-size:10px 10px,auto;box-shadow:0 20px 40px #00000075;pointer-events:auto;z-index:calc(var(--teacher-profile-select-layer-base) + 5);transition:top .18s ease,right .18s ease,left .18s ease,bottom .18s ease,width .18s ease,transform .18s ease}.teacher-profile-select[data-tutorial-coach-pos=top-right] .teacher-profile-select__guide-card{inset:60px 16px auto auto;transform:none;width:min(390px,36vw);max-width:min(390px,36vw)}.teacher-profile-select[data-tutorial-coach-pos=bottom-center] .teacher-profile-select__guide-card{inset:auto auto 62px 50%;transform:translate(-50%);width:min(620px,calc(100% - 36px));max-width:min(620px,calc(100% - 36px))}.teacher-profile-select[data-tutorial-coach-viewport=desktop-wide][data-tutorial-coach-pos=top-right] .teacher-profile-select__guide-card{top:52px;right:20px;width:min(410px,32vw);max-width:min(410px,32vw)}.teacher-profile-select[data-tutorial-coach-viewport=desktop][data-tutorial-coach-pos=top-right] .teacher-profile-select__guide-card{top:58px;right:16px;width:min(390px,35vw);max-width:min(390px,35vw)}.teacher-profile-select[data-tutorial-coach-viewport=laptop][data-tutorial-coach-pos=top-right] .teacher-profile-select__guide-card{top:64px;right:12px;width:min(360px,40vw);max-width:min(360px,40vw)}.teacher-profile-select[data-tutorial-coach-viewport=desktop-wide][data-tutorial-coach-pos=bottom-center] .teacher-profile-select__guide-card{bottom:66px;width:min(660px,calc(100% - 48px));max-width:min(660px,calc(100% - 48px))}.teacher-profile-select[data-tutorial-coach-viewport=desktop][data-tutorial-coach-pos=bottom-center] .teacher-profile-select__guide-card{bottom:62px;width:min(620px,calc(100% - 36px));max-width:min(620px,calc(100% - 36px))}.teacher-profile-select[data-tutorial-coach-viewport=laptop][data-tutorial-coach-pos=bottom-center] .teacher-profile-select__guide-card{bottom:58px;width:min(560px,calc(100% - 28px));max-width:min(560px,calc(100% - 28px))}.teacher-profile-select[data-tutorial-coach-viewport=mobile][data-tutorial-coach-pos=bottom-center] .teacher-profile-select__guide-card{right:10px;left:10px;bottom:56px;transform:none;width:auto;max-width:none}.teacher-profile-select__focus{position:absolute;z-index:calc(var(--teacher-profile-select-layer-base) + 3);pointer-events:none;border-radius:16px;border:2px solid rgba(250,204,21,.95);box-shadow:0 0 0 9999px #02060f85,0 0 0 7px #fbbf242e,0 18px 40px #00000075;transition:top .18s ease,left .18s ease,width .18s ease,height .18s ease}.teacher-profile-select__focus[hidden]{display:none}.teacher-profile-select .is-teacher-tutorial-focus-target{position:relative;z-index:calc(var(--teacher-profile-select-layer-base) + 2);outline:2px dashed rgba(250,204,21,.9);outline-offset:4px}.teacher-profile-select__grid.is-teacher-tutorial-focus-target{border-radius:14px}.teacher-profile-select__guide-step{margin:0 0 8px;display:inline-flex;padding:3px 10px;border-radius:999px;font-size:.74rem;letter-spacing:.08em;text-transform:uppercase;font-weight:700;color:#e0f2fe;border:1px solid rgba(125,211,252,.46);background:#0e2d48a6}.teacher-profile-select__guide-title{margin:0 0 8px;font-size:clamp(1.45rem,2.4vw,1.95rem);line-height:1.12;color:#e2e8f0}.teacher-profile-select__guide-description{margin:0 0 10px;color:#e2e8f0f0;font-size:clamp(1.05rem,1.7vw,1.18rem);line-height:1.38}.teacher-profile-select__guide-hint{margin:0 0 12px;padding:8px 10px;border-radius:12px;border:1px solid rgba(56,189,248,.58);background:#0369a133;color:#dbeafe;font-size:1.02rem;line-height:1.3}.teacher-profile-select__guide-actions{display:grid;grid-template-columns:1fr auto;align-items:center;gap:8px 10px}.teacher-profile-select__guide-btn{border-radius:999px;min-height:44px;padding:0 22px;font-size:.95rem;font-weight:700;letter-spacing:.01em;cursor:pointer}.teacher-profile-select__guide-btn--secondary{justify-self:start;border:1px solid rgba(148,163,184,.5);background:#0f172a75;color:#e2e8f0e6}.teacher-profile-select__guide-btn--primary{justify-self:end;border:1px solid rgba(252,211,77,.76);background:linear-gradient(180deg,#fde047f0,#f59e0bf5);color:#1f2937;box-shadow:0 6px 14px #f59e0b3d}.teacher-profile-select__guide-btn--secondary:disabled,.teacher-profile-select__guide-btn--primary:disabled{opacity:.55;cursor:not-allowed}.teacher-profile-select[data-tutorial-overlay=locked] .teacher-profile-select__guide-card{border-color:#fbbf24a6}.teacher-profile-select[data-tutorial-overlay=profileInfo] .teacher-profile-select__guide-card{border-color:#c084fcb8}.teacher-profile-select[data-tutorial-overlay=profileInfo] .teacher-profile-select__guide-hint{border-color:#c084fc80;background:#581c873d;color:#f3e8fff5}.teacher-profile-select[data-tutorial-overlay=locked] .teacher-profile-select__guide-hint{border-color:#fbbf2473;background:#78350f42;color:#fef3c7f2}.teacher-profile-select[data-tutorial-overlay=ready] .teacher-profile-select__guide-card{border-color:#4ade80a6}.teacher-profile-select[data-tutorial-overlay=ready] .teacher-profile-select__guide-hint{border-color:#4ade806b;background:#15803d38;color:#dcfce7f5}.teacher-profile-select__message{min-height:18px;color:#ffb347;font-size:.8rem;text-align:center;flex-shrink:0}.teacher-profile-select__grid{display:grid;grid-template-columns:repeat(5,1fr);gap:10px;flex:1;min-height:0}@media(min-width:769px){.teacher-profile-select[data-profile-count="6"]{max-width:min(1500px,calc(100vw - 24px));padding-left:14px;padding-right:14px}.teacher-profile-select__grid[data-profile-count="6"]{grid-template-columns:repeat(6,minmax(0,1fr));grid-template-rows:minmax(0,1fr);gap:10px;align-items:stretch}.teacher-profile-select__grid[data-profile-count="6"] .teacher-profile-card{height:100%;min-height:0}}.teacher-profile-card{--card-accent: #7fb3ff;position:relative;border-radius:14px;border:2px solid rgba(255,255,255,.06);background:linear-gradient(180deg,#ffffff08,#00000026);color:inherit;padding:0;text-align:center;display:flex;flex-direction:column;cursor:pointer;transition:border-color .3s ease,box-shadow .3s ease,transform .3s ease;overflow:hidden;animation:cardEntrance .45s ease both;animation-delay:calc(var(--card-index, 0) * .07s)}@keyframes cardEntrance{0%{opacity:0;transform:translateY(16px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}.teacher-profile-card:focus{outline:2px solid var(--card-accent);outline-offset:2px}.teacher-profile-card:hover{transform:translateY(-3px)}.teacher-profile-card:not(.is-locked):hover{border-color:color-mix(in srgb,var(--card-accent) 50%,transparent);box-shadow:0 6px 24px #0006,0 0 16px color-mix(in srgb,var(--card-accent) 12%,transparent)}.teacher-profile-card.is-selected{border-color:var(--card-accent);box-shadow:0 0 0 1px color-mix(in srgb,var(--card-accent) 30%,transparent),0 0 20px color-mix(in srgb,var(--card-accent) 18%,transparent),0 4px 16px #0000004d}.teacher-profile-card.is-selected:after{content:"";position:absolute;inset:0;border-radius:12px;background:linear-gradient(180deg,color-mix(in srgb,var(--card-accent) 6%,transparent),transparent 40%);pointer-events:none}.teacher-profile-card--tutorial-recommended:not(.is-selected){border-color:color-mix(in srgb,var(--card-accent) 72%,transparent);box-shadow:0 0 0 1px color-mix(in srgb,var(--card-accent) 40%,transparent),0 0 18px color-mix(in srgb,var(--card-accent) 22%,transparent);animation:tutorialRecommendedPulse 1.8s ease-in-out infinite}@keyframes tutorialRecommendedPulse{0%,to{transform:translateY(-1px);box-shadow:0 0 0 1px color-mix(in srgb,var(--card-accent) 40%,transparent),0 0 18px color-mix(in srgb,var(--card-accent) 20%,transparent)}50%{transform:translateY(-3px);box-shadow:0 0 0 1px color-mix(in srgb,var(--card-accent) 60%,transparent),0 0 24px color-mix(in srgb,var(--card-accent) 30%,transparent)}}.teacher-profile-card.is-locked{cursor:not-allowed}.teacher-profile-card.is-locked:before{content:"";position:absolute;inset:0;z-index:calc(var(--teacher-profile-select-layer-base) + 5);pointer-events:none;border-radius:12px;opacity:0;transition:opacity .3s ease;background:repeating-linear-gradient(0deg,transparent,transparent 2px,rgba(255,50,50,.04) 2px,rgba(255,50,50,.04) 4px);mix-blend-mode:screen}.teacher-profile-card.is-locked:hover:before{opacity:1}.teacher-profile-card.is-locked .teacher-profile-card__portrait-container{filter:saturate(.25) brightness(.7);transition:filter .35s ease}.teacher-profile-card.is-locked:hover .teacher-profile-card__portrait-container{filter:saturate(.4) brightness(.85)}.teacher-profile-card__portrait-container{position:relative;width:100%;flex:1;min-height:0;overflow:hidden;background:linear-gradient(180deg,#0000000d,#00000040)}.teacher-profile-card__aura{position:absolute;bottom:0;left:50%;transform:translate(-50%);width:130%;height:50%;background:radial-gradient(ellipse at 50% 100%,color-mix(in srgb,var(--card-accent) 14%,transparent),transparent 70%);opacity:0;transition:opacity .4s ease;pointer-events:none}.teacher-profile-card:not(.is-locked):hover .teacher-profile-card__aura,.teacher-profile-card.is-selected .teacher-profile-card__aura{opacity:1}.teacher-profile-card.is-locked:hover .teacher-profile-card__aura{opacity:.6;background:radial-gradient(ellipse at 50% 100%,rgba(255,40,40,.12),transparent 70%)}.teacher-profile-card__portrait{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center top;transition:opacity .35s ease,transform .4s ease}.teacher-profile-card__portrait--inactive{opacity:1}.teacher-profile-card__portrait--active{opacity:0;transform:scale(1.02)}.teacher-profile-card:hover .teacher-profile-card__portrait--inactive{opacity:0}.teacher-profile-card:hover .teacher-profile-card__portrait--active,.teacher-profile-card.is-selected .teacher-profile-card__portrait--active{opacity:1;transform:scale(1)}.teacher-profile-card.is-selected .teacher-profile-card__portrait--inactive{opacity:0}.teacher-profile-card__portrait-container:after{content:"";position:absolute;bottom:0;left:0;right:0;height:18%;background:linear-gradient(to top,#0a0e18,transparent);pointer-events:none;z-index:calc(var(--teacher-profile-select-layer-base) + 1)}.teacher-profile-card__lock{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;pointer-events:none;z-index:calc(var(--teacher-profile-select-layer-base) + 3)}.teacher-profile-card__lock-icon{width:32px;height:32px;fill:#ffffff80;filter:drop-shadow(0 2px 10px rgba(0,0,0,.8));transition:opacity .3s ease}.teacher-profile-card.is-locked:hover .teacher-profile-card__lock-icon{opacity:.3}.teacher-profile-card__info{padding:8px 8px 10px;display:flex;flex-direction:column;align-items:center;gap:4px;flex-shrink:0;position:relative;z-index:calc(var(--teacher-profile-select-layer-base) + 2)}.teacher-profile-card__label{font-weight:800;font-size:clamp(.75rem,1.2vw,.95rem);line-height:1.2;color:#f4f5f8}.teacher-profile-card.is-locked .teacher-profile-card__label{color:#f4f5f866;font-style:italic}.teacher-profile-card__info-slot{width:70%;height:4px;border-radius:2px;background:#ffffff0f;transition:background .3s ease}.teacher-profile-card__info-slot.is-revealed{width:100%;height:auto;min-height:1.35em;border-radius:6px;padding:3px 6px;background:#ffffff14;color:#f4f5f8e0;font-size:.64rem;line-height:1.25;letter-spacing:.01em;text-align:left;display:-webkit-box;-webkit-box-orient:vertical;text-overflow:ellipsis;overflow:hidden}.teacher-profile-card__info-slot[data-slot=description]{width:85%}.teacher-profile-card__info-slot[data-slot=special]{width:55%}.teacher-profile-card__info-slot.is-revealed[data-slot=description],.teacher-profile-card__info-slot.is-revealed[data-slot=special]{width:100%}.teacher-profile-card__info-slot[data-slot=tagline].is-revealed{-webkit-line-clamp:1;text-align:center;font-weight:700}.teacher-profile-card__info-slot[data-slot=description].is-revealed{display:block;-webkit-line-clamp:unset;position:relative;max-height:5.2em;padding-bottom:.7em;overflow:hidden;text-overflow:clip}.teacher-profile-card__info-slot[data-slot=description].is-revealed:after{content:"";position:absolute;left:0;right:0;bottom:0;height:1.45em;pointer-events:none;background:linear-gradient(180deg,#0a0e1800,#0a0e18f5)}.teacher-profile-card__info-slot[data-slot=special].is-revealed{-webkit-line-clamp:1;text-align:center;color:color-mix(in srgb,var(--card-accent) 65%,#f4f5f8);font-style:italic}.teacher-profile-card:not(.is-locked):hover .teacher-profile-card__info-slot{background:color-mix(in srgb,var(--card-accent) 15%,transparent)}.teacher-profile-card.is-selected .teacher-profile-card__info-slot{background:color-mix(in srgb,var(--card-accent) 20%,transparent)}.teacher-profile-card.is-locked .teacher-profile-card__info-slot{background:#ffffff08}.teacher-profile-card.is-locked .teacher-profile-card__info-slot.is-revealed{background:#ffffff0d;color:#f4f5f894}.teacher-profile-card__intel{font-size:.6rem;text-transform:uppercase;letter-spacing:.08em;color:#f4f5f861}.teacher-profile-card:not(.is-locked):hover .teacher-profile-card__intel,.teacher-profile-card.is-selected .teacher-profile-card__intel{color:color-mix(in srgb,var(--card-accent) 75%,#f4f5f8)}.teacher-profile-card__selected{font-size:.65rem;text-transform:uppercase;letter-spacing:.08em;font-weight:700;color:var(--card-accent);margin-top:2px;opacity:0;transform:translateY(3px);transition:opacity .25s ease,transform .25s ease}.teacher-profile-card.is-selected .teacher-profile-card__selected{opacity:1;transform:translateY(0)}.teacher-profile-select__bottom{display:flex;align-items:center;justify-content:space-between;flex-shrink:0;padding-top:6px}.teacher-profile-select__bottom--single-action{justify-content:flex-start}.teacher-profile-select__code-link{background:transparent;border:none;color:#f4f5f859;font-size:.78rem;cursor:pointer;padding:6px 12px;border-radius:6px;transition:color .2s ease,background .2s ease;letter-spacing:.02em}.teacher-profile-select__code-link:hover{color:#f4f5f8b3;background:#ffffff0a}.teacher-profile-select__code-link:focus{outline:1px solid rgba(127,179,255,.4);outline-offset:2px}.teacher-profile-select__confirm{background:linear-gradient(135deg,#5a9cff,#7fb3ff);border:none;color:#0a0e18;font-weight:800;font-size:.95rem;padding:12px 36px;border-radius:10px;cursor:pointer;text-transform:uppercase;letter-spacing:.06em;transition:transform .2s ease,box-shadow .2s ease;box-shadow:0 4px 16px #5a9cff40}.teacher-profile-select__confirm:hover{transform:translateY(-2px);box-shadow:0 6px 24px #5a9cff59}.teacher-profile-select__confirm:active{transform:translateY(0)}.teacher-profile-select__confirm:focus{outline:2px solid #f4f5f8;outline-offset:3px}.code-modal-overlay{position:fixed;inset:0;background:#000000bf;display:flex;align-items:center;justify-content:center;z-index:var(--teacher-profile-code-modal-layer-base);opacity:0;transition:opacity .25s ease;backdrop-filter:blur(4px)}.code-modal-overlay.is-visible{opacity:1}.code-modal{background:#12161f;border:1px solid rgba(127,179,255,.2);border-radius:14px;padding:28px 32px;width:min(400px,90vw);display:flex;flex-direction:column;gap:16px;box-shadow:0 20px 60px #00000080}.code-modal__title{margin:0;font-size:1.1rem;font-weight:700;color:#f4f5f8;text-align:center;letter-spacing:.03em}.code-modal__input{width:100%;padding:12px 14px;border-radius:10px;border:1px solid rgba(255,255,255,.12);background:#ffffff0a;color:#f4f5f8;font-size:1rem;font-family:monospace;text-transform:uppercase;letter-spacing:.06em;text-align:center;box-sizing:border-box;transition:border-color .2s ease,background .2s ease}.code-modal__input:focus{outline:none;border-color:#7fb3ff;background:#7fb3ff14}.code-modal__input::placeholder{color:#f4f5f84d;text-transform:none}.code-modal__result{min-height:20px;font-size:.85rem;text-align:center}.code-modal__result--success{color:#6dd56d}.code-modal__result--error{color:#ff7b7b}.code-modal__actions{display:flex;gap:10px;justify-content:center}.code-modal__cancel{padding:10px 20px;border-radius:8px;border:1px solid rgba(255,255,255,.12);background:transparent;color:#f4f5f899;cursor:pointer;font-size:.9rem;transition:background .2s ease,color .2s ease}.code-modal__cancel:hover{background:#ffffff0d;color:#f4f5f8}.code-modal__submit{padding:10px 24px;border-radius:8px;border:none;background:linear-gradient(135deg,#5a9cff,#7fb3ff);color:#0a0e18;font-weight:700;cursor:pointer;font-size:.9rem;transition:transform .15s ease,box-shadow .15s ease}.code-modal__submit:hover{transform:translateY(-1px);box-shadow:0 4px 12px #5a9cff4d}.code-modal__cancel:focus,.code-modal__submit:focus{outline:2px solid #f4f5f8;outline-offset:2px}@media(max-width:768px){.teacher-profile-select__grid{grid-template-columns:repeat(3,1fr);gap:8px}.teacher-profile-select{padding:12px 10px 10px;gap:8px}.teacher-profile-select__guide-card{right:10px;left:10px;transform:none;width:auto;max-width:none;padding:12px}.teacher-profile-select__guide-title{font-size:clamp(1.25rem,4.2vw,1.6rem)}.teacher-profile-select__guide-description,.teacher-profile-select__guide-hint{font-size:.95rem}.teacher-profile-select__guide-actions{grid-template-columns:1fr}.teacher-profile-select__guide-btn--secondary,.teacher-profile-select__guide-btn--primary{justify-self:stretch}.teacher-profile-card__info-slot[data-slot=description].is-revealed{display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:3;position:static;max-height:none;padding-bottom:3px;overflow:hidden;text-overflow:ellipsis}.teacher-profile-card__info-slot[data-slot=description].is-revealed:after{display:none}}@media(max-width:480px){.teacher-profile-select__grid{grid-template-columns:repeat(2,1fr);gap:6px}.teacher-profile-select__confirm{padding:10px 20px;font-size:.85rem}.teacher-profile-card__info{padding:6px 6px 8px}.teacher-profile-card__info-slot[data-slot=description].is-revealed{-webkit-line-clamp:2}}#capacities-panel{background:#14141ef2;border:2px solid #4a5568;border-radius:12px;padding:16px;margin-bottom:16px;max-height:60vh;overflow-y:auto}.capacity-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid #4a5568}.capacity-header h3{margin:0;font-size:18px;color:#f7fafc}.capacity-stats{font-size:14px;color:#cbd5e0}.capacity-stats .percentage{color:#9ae6b4;font-weight:700}.capacity-level-group{margin-bottom:16px}.capacity-level-group h4{margin:8px 0;font-size:14px;color:#a0aec0;text-transform:uppercase;letter-spacing:.5px}.capacity-list{display:flex;flex-direction:column;gap:6px}.capacity-badge{background:linear-gradient(135deg,#2d3748,#1a202c);border:1px solid #4a5568;border-radius:8px;padding:8px 12px;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:space-between}.capacity-badge:hover{background:linear-gradient(135deg,#3d4758,#2a303c);border-color:#63b3ed;transform:translate(4px)}.capacity-label{font-size:13px;color:#e2e8f0;flex:1}.capacity-level-badge{background:#4a5568;color:#f7fafc;font-size:10px;padding:2px 6px;border-radius:4px;text-transform:uppercase;letter-spacing:.5px}.capacity-level-badge[data-level=global],.capacity-badge[data-level=global] .capacity-level-badge{background:linear-gradient(135deg,#9f7aea,#805ad5)}.capacity-level-badge[data-level=intermediate],.capacity-badge[data-level=intermediate] .capacity-level-badge{background:linear-gradient(135deg,#4299e1,#3182ce)}.capacity-level-badge[data-level=intermediate_fine],.capacity-badge[data-level=intermediate_fine] .capacity-level-badge{background:linear-gradient(135deg,#48bb78,#38a169)}.capacity-level-badge[data-level=specific_generic],.capacity-badge[data-level=specific_generic] .capacity-level-badge{background:linear-gradient(135deg,#ed8936,#dd6b20)}.optimal-path-bonuses{margin-top:16px;padding-top:12px;border-top:1px solid #4a5568}.optimal-path-bonuses h4{margin:0 0 8px;font-size:14px;color:#fbbf24}.optimal-path-bonuses ul{list-style:none;padding:0;margin:0}.optimal-path-bonuses li{background:#fbbf241a;border-left:3px solid #fbbf24;padding:6px 10px;margin-bottom:4px;font-size:12px;color:#fef3c7;border-radius:4px}.capacity-tooltip{position:fixed;background:#1a202cfa;border:2px solid #63b3ed;border-radius:8px;padding:12px;max-width:300px;z-index:var(--layer-tooltip);display:none;box-shadow:0 10px 30px #00000080}.tooltip-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;padding-bottom:8px;border-bottom:1px solid #4a5568}.tooltip-header strong{font-size:14px;color:#f7fafc}.tooltip-description{font-size:12px;color:#cbd5e0;line-height:1.5;margin-bottom:8px}.tooltip-section{margin-top:8px;font-size:11px}.tooltip-section strong{color:#a0aec0;display:block;margin-bottom:4px}.tooltip-section ul{list-style:none;padding:0;margin:0}.tooltip-section li{color:#e2e8f0;padding:2px 0}.tooltip-section span{color:#cbd5e0;font-style:italic}.capacity-modal{position:fixed;top:0;left:0;width:100%;height:100%;background:#000c;display:none;justify-content:center;align-items:center;z-index:var(--layer-overlay-global);animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background:linear-gradient(180deg,#2d3748,#1a202c);border:3px solid #63b3ed;border-radius:16px;padding:24px;max-width:500px;width:90%;box-shadow:0 20px 60px #000000b3;animation:slideIn .3s ease}@keyframes slideIn{0%{transform:translateY(-50px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-content.capacity-acquired .modal-header h2{color:#9ae6b4}.modal-content.capacity-auto-unlocked .modal-header h2{color:#90cdf4}.modal-content.optimal-path-bonus .modal-header h2{color:#fbbf24}.modal-header{text-align:center;margin-bottom:20px}.modal-header h2{margin:0;font-size:24px}.modal-body{text-align:center}.capacity-icon-large{width:80px;height:80px;margin:0 auto 16px;background:linear-gradient(135deg,#4a5568,#2d3748);border-radius:50%;display:flex;align-items:center;justify-content:center;position:relative}.capacity-icon-large .capacity-level-badge{font-size:12px;padding:4px 8px}.modal-body h3{margin:16px 0 8px;font-size:20px;color:#f7fafc}.capacity-description{font-size:14px;color:#cbd5e0;line-height:1.6;margin:12px 0}.priority-note{font-size:12px;color:#9ae6b4;font-style:italic;margin-top:8px}.auto-unlock-note{font-size:13px;color:#90cdf4;background:#90cdf41a;border-left:3px solid #90cdf4;padding:8px 12px;border-radius:4px;margin-top:12px;text-align:left}.bonus-details{background:#fbbf241a;border:2px solid #fbbf24;border-radius:8px;padding:16px;margin-top:16px}.bonus-details h4{margin:0 0 8px;color:#fbbf24;font-size:14px}.bonus-description{font-size:16px;color:#fef3c7;font-weight:700;margin:0}.modal-footer{margin-top:24px;text-align:center}.btn-continue{background:linear-gradient(135deg,#4299e1,#3182ce);color:#fff;border:none;border-radius:8px;padding:12px 32px;font-size:16px;font-weight:700;cursor:pointer;transition:all .2s ease}.btn-continue:hover{background:linear-gradient(135deg,#5aace1,#4199de);transform:translateY(-2px);box-shadow:0 6px 20px #4299e166}.btn-continue:active{transform:translateY(0)}.card-locked-capacity{opacity:.5;position:relative}.card-locked-capacity:after{content:"\1f512";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:48px;opacity:.8}.card-locked-reason{font-size:11px;color:#fc8181;text-align:center;margin-top:4px}@media(max-width:768px){#capacities-panel{max-height:40vh}.modal-content{padding:16px;max-width:90%}.capacity-icon-large{width:60px;height:60px}.modal-header h2{font-size:20px}.modal-body h3{font-size:18px}}#capacities-panel::-webkit-scrollbar{width:8px}#capacities-panel::-webkit-scrollbar-track{background:#2d374880;border-radius:4px}#capacities-panel::-webkit-scrollbar-thumb{background:#4a5568;border-radius:4px}#capacities-panel::-webkit-scrollbar-thumb:hover{background:#63b3ed}.capacity-tree-overlay{position:fixed;inset:0;background:radial-gradient(circle at 20% 20%,rgba(99,179,237,.05),transparent 35%),radial-gradient(circle at 80% 0%,rgba(237,137,54,.06),transparent 40%),#050a14eb;display:none;align-items:center;justify-content:center;padding:32px;z-index:var(--layer-overlay-global);backdrop-filter:blur(2px)}.capacity-tree-overlay.open{display:flex}.capacity-tree-panel{background:linear-gradient(180deg,#1a202c,#0f172a);border:1px solid #2d3748;box-shadow:0 25px 80px #0000008c;border-radius:18px;width:min(1200px,96vw);height:min(880px,90vh);display:flex;flex-direction:column;overflow:hidden}.capacity-tree-header{padding:18px 20px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid #2d3748;gap:16px}.capacity-tree-title h2{margin:4px 0;color:#f7fafc;font-size:26px}.capacity-tree-title .eyebrow{margin:0;color:#a0aec0;text-transform:uppercase;letter-spacing:.08em;font-size:11px}.capacity-tree-subtitle{margin:2px 0 0;color:#cbd5e0;font-size:13px}.capacity-tree-actions{display:flex;align-items:center;gap:10px}.capacity-tree-counter{background:#63b3ed26;color:#bee3f8;padding:8px 12px;border-radius:10px;font-weight:700;font-size:13px;border:1px solid rgba(99,179,237,.35)}.capacity-tree-close{background:#1f2937;border:1px solid #4a5568;color:#e2e8f0;width:36px;height:36px;border-radius:10px;cursor:pointer;transition:background-color .2s ease,border-color .2s ease,color .2s ease,transform .2s ease,box-shadow .2s ease;font-size:18px;line-height:1}.capacity-tree-close:hover{background:#2d3748;border-color:#63b3ed;color:#fff}.capacity-tree-body{position:relative;flex:1;background:radial-gradient(circle at 50% 20%,rgba(99,179,237,.08),transparent 40%),linear-gradient(180deg,#2d374866,#1a202c80);overflow:auto;padding:20px 16px}.capacity-tree-columns{position:relative;display:grid;grid-template-columns:repeat(4,minmax(200px,1fr));gap:12px;z-index:calc(var(--layer-overlay-global) + 1)}.capacity-tree-column{background:#0f172abf;border:1px solid rgba(74,85,104,.5);border-radius:12px;padding:12px;backdrop-filter:blur(2px)}.capacity-tree-column h3{margin:0 0 8px;font-size:14px;text-transform:uppercase;letter-spacing:.08em;color:#a0aec0;display:flex;align-items:center;gap:6px}.capacity-tree-column h3 .badge{background:#2d3748;color:#e2e8f0;padding:2px 8px;border-radius:999px;font-size:11px}.capacity-tree-list{display:flex;flex-direction:column;gap:8px}.capacity-tree-node{position:relative;padding:10px 12px;border-radius:10px;border:1px solid #4a5568;background:linear-gradient(145deg,#2d3748cc,#1a202ce6);box-shadow:0 6px 16px #00000059;transition:transform .16s ease,border-color .16s ease,box-shadow .16s ease}.capacity-tree-node.is-clickable{cursor:pointer}.capacity-tree-node:hover{transform:translateY(-2px);border-color:#63b3ed;box-shadow:0 12px 24px #63b3ed26}.capacity-tree-node[data-status=acquired]{border-color:#48bb78;box-shadow:0 0 0 1px #48bb7840;background:linear-gradient(135deg,#38a1692e,#1a202cd9)}.capacity-tree-node[data-status=available]{border-color:#63b3ed;box-shadow:0 0 0 1px #63b3ed40}.capacity-tree-node[data-status=locked]{opacity:.8}.capacity-tree-node.is-selected{border-color:#7dd3fc;box-shadow:0 0 0 2px #7dd3fc80,0 14px 30px #7dd3fc38;transform:translateY(-2px)}.capacity-tree-node.is-related:not(.is-selected){border-color:#63b3ed;box-shadow:0 0 0 1px #63b3ed59,0 10px 20px #63b3ed1f}.capacity-tree-node.is-dimmed{opacity:.38}.capacity-tree-node-header{display:flex;align-items:center;gap:8px;margin-bottom:6px}.capacity-tree-code{background:#2d3748;border-radius:6px;padding:4px 8px;font-weight:700;color:#e2e8f0;font-size:11px}.capacity-tree-node-label{color:#f7fafc;font-size:14px;line-height:1.35;margin:0 0 4px}.capacity-tree-node-meta{color:#cbd5e0;font-size:12px}.capacity-tree-node-meta .pill{display:inline-flex;align-items:center;gap:4px;padding:4px 8px;background:#ffffff0d;border-radius:999px}.capacity-tree-node-meta .pill strong{color:#e2e8f0}.capacity-tree-links{position:absolute;inset:0;width:100%;height:100%;z-index:var(--layer-overlay-global);pointer-events:none;overflow:visible}.capacity-tree-link{fill:none;stroke:#4a5568;stroke-width:2;opacity:.78;stroke-linecap:round;stroke-linejoin:round}.capacity-tree-link.status-acquired{stroke:#48bb78;opacity:.95}.capacity-tree-link.status-available{stroke:#63b3ed;stroke-dasharray:6 4}.capacity-tree-link.status-locked{stroke:#4a5568}.capacity-tree-link.is-highlighted{stroke:#7dd3fc;stroke-width:3;opacity:1;filter:drop-shadow(0 0 6px rgba(125,211,252,.6))}.capacity-tree-link.is-highlighted.is-direct{stroke:#f59e0b;filter:drop-shadow(0 0 8px rgba(245,158,11,.65))}.capacity-tree-link.is-highlighted.is-indirect{stroke:#38bdf8;filter:drop-shadow(0 0 6px rgba(56,189,248,.5))}.capacity-tree-link.is-dimmed{opacity:.1}.capacity-tree-link-endpoint{fill:#4a5568;opacity:.85;transition:opacity .16s ease,r .16s ease,fill .16s ease}.capacity-tree-link-endpoint.status-acquired{fill:#48bb78}.capacity-tree-link-endpoint.status-available{fill:#63b3ed}.capacity-tree-link-endpoint.status-locked{fill:#4a5568}.capacity-tree-link-endpoint.is-highlighted{fill:#7dd3fc;opacity:1}.capacity-tree-link-endpoint.is-highlighted.is-direct{fill:#f59e0b}.capacity-tree-link-endpoint.is-highlighted.is-indirect{fill:#38bdf8}.capacity-tree-link-endpoint.is-dimmed{opacity:.12}.capacity-tree-legend{padding:12px 20px;border-top:1px solid #2d3748;display:flex;gap:16px;flex-wrap:wrap;color:#cbd5e0;font-size:13px}.capacity-tree-legend .legend-item{display:inline-flex;align-items:center;gap:8px;padding:6px 10px;background:#2d3748a6;border-radius:999px;border:1px solid rgba(74,85,104,.6)}.legend-dot{width:12px;height:12px;border-radius:50%;display:inline-block}.legend-dot.acquired{background:#48bb78}.legend-dot.available{background:#63b3ed}.legend-dot.locked{background:#4a5568}.legend-line{width:36px;height:0;border-top:2px solid #63b3ed;display:inline-block}.capacity-tree-tabs{display:flex;gap:10px;padding:8px 20px 0;border-top:1px solid #111827;border-bottom:1px solid #2d3748;background:#0f172a73}.capacity-tree-tab{background:#111827;color:#cbd5e0;border:1px solid #1f2937;border-bottom:2px solid transparent;padding:10px 14px;border-radius:10px 10px 0 0;cursor:pointer;font-weight:700;letter-spacing:.02em}.capacity-tree-tab.active{background:linear-gradient(180deg,#1f2937,#111827);color:#f7fafc;border-color:#2d3748;border-bottom-color:#0f172a;box-shadow:0 10px 24px #00000059}.capacity-tree-body[data-active=false]{display:none}.capacity-tree-dendrogram{display:flex;flex-direction:column;gap:14px;--path-focus: #f8fafc;--path-ancestor-1: #f59e0b;--path-ancestor-2: #fbbf24;--path-ancestor-3: #fcd34d;--path-ancestor-4: #fde68a;--path-descendant-1: #22d3ee;--path-descendant-2: #38bdf8;--path-descendant-3: #60a5fa;--path-descendant-4: #93c5fd;--path-mixed: #c084fc}.capacity-dendrogram-toolbar{display:flex;justify-content:space-between;gap:12px;padding:12px 16px 0}.dendrogram-toggles{display:inline-flex;background:#0f172a;border:1px solid #2d3748;border-radius:999px;padding:4px;gap:6px}.dendro-toggle{background:transparent;color:#cbd5e0;border:1px solid transparent;border-radius:999px;padding:8px 12px;cursor:pointer;transition:background-color .2s ease,border-color .2s ease,color .2s ease,transform .2s ease,box-shadow .2s ease;font-weight:700}.dendro-toggle.active{background:linear-gradient(135deg,#1f2937,#111827);border-color:#63b3ed;color:#e0f2fe;box-shadow:0 8px 20px #63b3ed33}.dendrogram-search{display:flex;align-items:center;gap:8px;flex:1;justify-content:flex-end}.dendrogram-search input{background:#0b1220;color:#e2e8f0;border:1px solid #2d3748;border-radius:10px;padding:10px 12px;width:100%;max-width:320px}.dendrogram-search button{background:#1f2937;color:#cbd5e0;border:1px solid #2d3748;border-radius:10px;padding:10px 12px;cursor:pointer}.capacity-dendrogram-layout{display:grid;grid-template-columns:3fr 1fr;gap:12px;padding:0 12px 12px;flex:1;min-height:520px}.capacity-dendrogram-canvas{background:radial-gradient(circle at 50% 40%,rgba(99,179,237,.06),transparent 50%),linear-gradient(180deg,#2d374866,#1a202ca6);border:1px solid rgba(45,55,72,.65);border-radius:12px;position:relative;overflow:hidden;min-height:520px}.capacity-dendrogram-canvas svg{width:100%;height:100%;cursor:grab}.capacity-dendrogram-sidebar{background:#0f172abf;border:1px solid rgba(74,85,104,.6);border-radius:12px;padding:12px;display:flex;flex-direction:column;gap:8px;max-height:100%;overflow:auto}.capacity-dendrogram-sidebar .eyebrow{margin:0;color:#a0aec0;text-transform:uppercase;font-size:11px;letter-spacing:.08em}.capacity-dendrogram-sidebar h3{margin:0;color:#f7fafc}.capacity-dendrogram-sidebar .code{margin:0;font-family:JetBrains Mono,Fira Code,monospace;color:#a0aec0}.capacity-dendrogram-sidebar .level-chip{background:#1f2937;border:1px solid #2d3748;color:#e2e8f0;padding:6px 10px;border-radius:999px;align-self:flex-start;text-transform:uppercase;letter-spacing:.08em}.capacity-dendrogram-sidebar .focus-meta{display:inline-flex;align-items:center;gap:8px;background:#ffffff0a;border:1px solid rgba(74,85,104,.4);border-radius:999px;padding:6px 10px;align-self:flex-start;color:#cbd5e0;font-size:12px}.capacity-dendrogram-sidebar .focus-status{border-radius:999px;padding:3px 8px;font-weight:700;font-size:11px;border:1px solid transparent}.capacity-dendrogram-sidebar .focus-status.acquired{background:#48bb782e;border-color:#48bb788c;color:#9ae6b4}.capacity-dendrogram-sidebar .focus-status.available{background:#63b3ed33;border-color:#63b3ed8c;color:#90cdf4}.capacity-dendrogram-sidebar .focus-status.locked{background:#f6ad5533;border-color:#f6ad5580;color:#fbd38d}.capacity-dendrogram-sidebar .focus-level-dot{width:10px;height:10px;border-radius:50%;display:inline-block;background:var(--level-color, #63b3ed);box-shadow:0 0 0 2px #ffffff0f}.capacity-dendrogram-sidebar .description{color:#cbd5e0;margin:0;line-height:1.5}.capacity-dendrogram-sidebar .description.muted{color:#718096;font-style:italic}.capacity-dendrogram-sidebar .path-summary{background:linear-gradient(145deg,#111827bf,#1e293bad);border:1px solid rgba(74,85,104,.46);border-radius:10px;padding:10px}.capacity-dendrogram-sidebar .path-summary h4,.capacity-dendrogram-sidebar .requirements h4,.capacity-dendrogram-sidebar .dependents h4{margin:0 0 8px;font-size:13px;color:#e2e8f0}.capacity-dendrogram-sidebar .summary-grid{display:grid;gap:6px}.capacity-dendrogram-sidebar .summary-chip{border-radius:999px;border:1px solid transparent;padding:4px 10px;font-size:11px;font-weight:700;color:#e2e8f0;background:#ffffff0a}.capacity-dendrogram-sidebar .summary-chip.ancestor{border-color:#f59e0ba6;color:#fcd34d}.capacity-dendrogram-sidebar .summary-chip.ancestor-soft{border-color:#fbbf2480;color:#fde68a}.capacity-dendrogram-sidebar .summary-chip.descendant{border-color:#22d3ee9e;color:#67e8f9}.capacity-dendrogram-sidebar .summary-chip.descendant-soft{border-color:#60a5fa85;color:#bfdbfe}.capacity-dendrogram-sidebar .path-caption{margin:0;color:#cbd5e0;font-size:12px;line-height:1.45}.capacity-dendrogram-sidebar .requirements ul{list-style:none;padding:0;margin:8px 0 0;display:grid;gap:6px}.capacity-dendrogram-sidebar .requirements li{background:#ffffff08;border:1px solid rgba(74,85,104,.35);padding:7px 8px;border-radius:8px;color:#e2e8f0;display:grid;grid-template-columns:auto 1fr;gap:6px;align-items:center}.capacity-dendrogram-sidebar .requirements .req-code{font-size:11px;font-family:JetBrains Mono,Fira Code,monospace;color:#cbd5e0;background:#ffffff0d;border-radius:6px;padding:2px 6px}.capacity-dendrogram-sidebar .requirements li.ok{border-color:#48bb7873}.capacity-dendrogram-sidebar .requirements li.missing{border-color:#ed893680}.capacity-dendrogram-sidebar .dependents ul{list-style:none;margin:8px 0 0;padding:0;display:grid;gap:6px}.capacity-dendrogram-sidebar .dependents li{display:grid;grid-template-columns:auto 1fr auto;gap:6px;align-items:center;background:#ffffff08;border:1px solid rgba(74,85,104,.35);border-radius:8px;padding:7px 8px;color:#e2e8f0}.capacity-dendrogram-sidebar .dependents .dependent-id{font-size:11px;font-family:JetBrains Mono,Fira Code,monospace;color:#cbd5e0;background:#ffffff0d;border-radius:6px;padding:2px 6px}.capacity-dendrogram-sidebar .dependents .dependent-status{border-radius:999px;padding:3px 8px;font-size:11px;border:1px solid rgba(74,85,104,.45);color:#cbd5e0}.capacity-dendrogram-sidebar .dependents li.ok{border-color:#48bb7873}.capacity-dendrogram-sidebar .dependents li.ok .dependent-status{color:#9ae6b4;border-color:#48bb788c}.capacity-dendrogram-sidebar .dependents li.ready{border-color:#63b3ed7a}.capacity-dendrogram-sidebar .dependents li.ready .dependent-status{color:#90cdf4;border-color:#63b3ed99}.capacity-dendrogram-sidebar .dependents li.missing{border-color:#f6ad5573}.capacity-dendrogram-sidebar .dependents li.missing .dependent-status{color:#fbd38d;border-color:#f6ad5599}.capacity-dendrogram-sidebar .placeholder{margin:0;color:#a0aec0;line-height:1.5}.capacity-dendrogram-legend{padding:0 12px 14px;display:flex;gap:12px;flex-wrap:wrap}.capacity-dendrogram-legend .legend-section{background:#0f172ad9;border:1px solid rgba(74,85,104,.6);border-radius:12px;padding:10px 12px}.capacity-dendrogram-legend .legend-title{margin:0 0 6px;color:#e2e8f0;font-weight:700;font-size:13px}.capacity-dendrogram-legend .legend-items{display:flex;gap:8px;flex-wrap:wrap}.legend-pill{display:inline-flex;align-items:center;gap:6px;background:#ffffff0a;padding:6px 10px;border-radius:999px;color:#e2e8f0;border:1px solid rgba(74,85,104,.6);text-transform:capitalize}.legend-pill .dot{width:12px;height:12px;border-radius:50%;display:inline-block}.legend-pill.state .dot{border:2px solid currentColor;background:transparent}.legend-pill.state.acquired .dot{color:#48bb78}.legend-pill.state.pending .dot{color:#63b3ed}.legend-pill.state.prereq-ok .dot{color:#81e6d9}.legend-pill.state.prereq-missing .dot{color:#f6ad55}.legend-pill.path.focus .dot{background:var(--path-focus)}.legend-pill.path.ancestor .dot{background:var(--path-ancestor-1)}.legend-pill.path.ancestor-soft .dot{background:var(--path-ancestor-2)}.legend-pill.path.descendant .dot{background:var(--path-descendant-1)}.legend-pill.path.descendant-soft .dot{background:var(--path-descendant-2)}.capacity-dendro-tooltip{position:absolute;background:#0a1020f5;border:1px solid rgba(74,85,104,.75);border-radius:12px;padding:10px 12px 11px;color:#e2e8f0;min-width:280px;max-width:360px;box-shadow:0 16px 36px #0000007a;pointer-events:none;opacity:0;transform:translateY(-4px);transition:opacity .1s ease,transform .1s ease;z-index:calc(var(--layer-overlay-global) + 10)}.capacity-dendro-tooltip.visible{opacity:1;transform:translateY(0)}.capacity-dendro-tooltip .tooltip-title-row{display:flex;align-items:center;gap:6px;flex-wrap:wrap;margin-bottom:6px}.capacity-dendro-tooltip .code{font-family:JetBrains Mono,Fira Code,monospace;background:#111827;padding:4px 6px;border-radius:6px;font-size:12px;border:1px solid rgba(74,85,104,.6)}.capacity-dendro-tooltip .badge{padding:3px 8px;border-radius:6px;background:#2d3748f2;text-transform:none;font-size:11px;letter-spacing:.02em;border:1px solid rgba(74,85,104,.55)}.capacity-dendro-tooltip .badge.status.acquired{color:#9ae6b4;border-color:#48bb78a8}.capacity-dendro-tooltip .badge.status.available{color:#90cdf4;border-color:#63b3eda8}.capacity-dendro-tooltip .badge.status.locked{color:#fbd38d;border-color:#f6ad55a8}.capacity-dendro-tooltip .badge.path.path-focus{color:#f8fafc;border-color:#f8fafcb8}.capacity-dendro-tooltip .badge.path.path-ancestor{color:var(--path-ancestor-2);border-color:#fbbf24b8}.capacity-dendro-tooltip .badge.path.path-descendant{color:var(--path-descendant-2);border-color:#38bdf8b3}.capacity-dendro-tooltip .badge.path.path-mixed{color:var(--path-mixed);border-color:#c084fcb3}.capacity-dendro-tooltip .tooltip-label{font-weight:800;margin-bottom:5px;color:#f8fafc}.capacity-dendro-tooltip .tooltip-path{margin:0 0 7px;color:#cbd5e0;font-size:12px;line-height:1.42}.capacity-dendro-tooltip .tooltip-desc{margin:0 0 8px;color:#d1d5db;line-height:1.45}.capacity-dendro-tooltip .tooltip-reqs strong{font-size:12px;color:#e2e8f0}.capacity-dendro-tooltip .tooltip-reqs ul{list-style:none;margin:6px 0 0;padding:0;display:grid;gap:4px}.capacity-dendro-tooltip .tooltip-reqs li{display:grid;grid-template-columns:auto auto 1fr;gap:6px;align-items:center;border:1px solid rgba(74,85,104,.45);border-radius:8px;padding:5px 7px;color:#d1d5db}.capacity-dendro-tooltip .tooltip-reqs li .state-dot{width:8px;height:8px;border-radius:50%;display:inline-block;background:#94a3b8}.capacity-dendro-tooltip .tooltip-reqs li .req-code{font-size:11px;font-family:JetBrains Mono,Fira Code,monospace;color:#cbd5e0}.capacity-dendro-tooltip .tooltip-reqs li.empty{grid-template-columns:1fr;color:#cbd5e0}.capacity-dendro-tooltip .tooltip-reqs li.ok{color:#9ae6b4;border-color:#48bb7894}.capacity-dendro-tooltip .tooltip-reqs li.ok .state-dot{background:#48bb78}.capacity-dendro-tooltip .tooltip-reqs li.missing{color:#fbd38d;border-color:#f6ad5594}.capacity-dendro-tooltip .tooltip-reqs li.missing .state-dot{background:#f6ad55}.dendro-guides{pointer-events:none}.dendro-depth-band{fill:none;stroke:#7dd3fc24;stroke-width:1;stroke-dasharray:3 6}.dendro-depth-guide{stroke:#7dd3fc29;stroke-width:1;stroke-dasharray:3 6}.dendro-depth-guide[data-depth="0"]{stroke:#f8fafc47}.dendro-links path{fill:none;stroke-width:1.8;opacity:.88;transition:d .35s ease,stroke .3s ease,opacity .3s ease,stroke-width .3s ease}.dendro-link.open{stroke:#63b3ed}.dendro-link.locked{stroke:#f6ad55;stroke-dasharray:4 3}.dendro-link.secondary{stroke-dasharray:2 3;opacity:.72}.dendro-link.search-dimmed,.dendro-link.path-dimmed{opacity:.1}.dendro-link.path-highlight{opacity:1;stroke-width:2.8;stroke-linecap:round}.dendro-link.path-kind-focus{stroke:var(--path-focus)}.dendro-link.path-kind-ancestor.path-depth-1{stroke:var(--path-ancestor-1)}.dendro-link.path-kind-ancestor.path-depth-2{stroke:var(--path-ancestor-2)}.dendro-link.path-kind-ancestor.path-depth-3{stroke:var(--path-ancestor-3)}.dendro-link.path-kind-ancestor.path-depth-4{stroke:var(--path-ancestor-4)}.dendro-link.path-kind-descendant.path-depth-1{stroke:var(--path-descendant-1)}.dendro-link.path-kind-descendant.path-depth-2{stroke:var(--path-descendant-2)}.dendro-link.path-kind-descendant.path-depth-3{stroke:var(--path-descendant-3)}.dendro-link.path-kind-descendant.path-depth-4{stroke:var(--path-descendant-4)}.dendro-link.path-kind-mixed{stroke:var(--path-mixed)}.dendro-node{transition:transform .25s ease,opacity .25s ease}.dendro-node circle{transition:fill .25s ease,stroke .25s ease,stroke-width .25s ease,filter .25s ease}.dendro-node text{font-size:11px;fill:#cbd5e0;transition:opacity .25s ease,font-weight .25s ease,fill .25s ease;paint-order:stroke;stroke:#050a1473;stroke-width:1.2px}.dendro-node .code{font-size:10px;fill:#dbeafe}.dendro-node .label{opacity:.72}.dendro-node.search-dimmed,.dendro-node.path-dimmed{opacity:.35}.dendro-node.search-dimmed .label,.dendro-node.path-dimmed .label{opacity:.24}.dendro-node:hover .label,.dendro-node.is-match .label{opacity:1;font-weight:700;fill:#fff}.dendro-node.path-linked .label{opacity:.95}.dendro-node.path-linked .code{opacity:1}.dendro-node.path-kind-focus circle{stroke:var(--path-focus);filter:drop-shadow(0 0 8px rgba(248,250,252,.5))}.dendro-node.path-kind-ancestor.path-depth-1 circle{stroke:var(--path-ancestor-1)}.dendro-node.path-kind-ancestor.path-depth-2 circle{stroke:var(--path-ancestor-2)}.dendro-node.path-kind-ancestor.path-depth-3 circle{stroke:var(--path-ancestor-3)}.dendro-node.path-kind-ancestor.path-depth-4 circle{stroke:var(--path-ancestor-4)}.dendro-node.path-kind-descendant.path-depth-1 circle{stroke:var(--path-descendant-1)}.dendro-node.path-kind-descendant.path-depth-2 circle{stroke:var(--path-descendant-2)}.dendro-node.path-kind-descendant.path-depth-3 circle{stroke:var(--path-descendant-3)}.dendro-node.path-kind-descendant.path-depth-4 circle{stroke:var(--path-descendant-4)}.dendro-node.path-kind-mixed circle{stroke:var(--path-mixed)}.dendro-node.is-match circle{stroke-width:3;stroke:#fff;filter:drop-shadow(0 0 5px rgba(255,255,255,.5))}.dendro-node.focused circle{stroke-width:3.1;filter:drop-shadow(0 0 12px rgba(248,250,252,.4))}.dendro-node.acquired circle{fill-opacity:.42;stroke-width:2.4}.dendro-node.pending circle{fill:#ffffff0f}.dendro-node.prereq-missing circle{stroke:#f6ad55}.capacity-dendrogram-canvas:focus-within .dendro-node .label{opacity:1}.capacity-tree-panel{--capacity-bg-surface: #0f172a;--capacity-bg-surface-soft: #111d35;--capacity-bg-panel: #111827;--capacity-border: rgba(96, 165, 250, .26);--capacity-text-main: #f8fafc;--capacity-text-soft: #cbd5e1}.capacity-tree-filters{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 20px 10px;border-bottom:1px solid rgba(71,85,105,.45);background:linear-gradient(180deg,#0a1222cc,#0f172a73)}.capacity-filter-search{display:flex;flex-direction:column;gap:4px;width:min(460px,100%)}.capacity-filter-search span{font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:#94a3b8;font-weight:700}.capacity-filter-search input{background:#071021;color:var(--capacity-text-main);border:1px solid rgba(100,116,139,.55);border-radius:12px;padding:10px 12px;font-size:14px}.capacity-filter-search input:focus-visible{outline:2px solid rgba(56,189,248,.55);outline-offset:1px;border-color:#38bdf8}.capacity-filter-chips{display:flex;align-items:center;flex-wrap:wrap;gap:8px;justify-content:flex-end}.capacity-filter-chip{border-radius:999px;border:1px solid rgba(71,85,105,.75);background:#0f172acc;color:#dbeafe;padding:7px 12px;font-weight:700;cursor:pointer;transition:border-color .16s ease,background-color .16s ease,transform .16s ease}.capacity-filter-chip:hover{border-color:#38bdf8d9;transform:translateY(-1px)}.capacity-filter-chip.active{background:linear-gradient(125deg,#1d4ed880,#0e749059);border-color:#7dd3fcf2;color:#f0f9ff;box-shadow:0 8px 20px #0e74904d}.capacity-filter-chip:focus-visible{outline:2px solid rgba(186,230,253,.85);outline-offset:1px}.capacity-tree-summary{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 20px 14px;border-bottom:1px solid rgba(71,85,105,.45);background:linear-gradient(180deg,#0b1220a6,#0b122047)}.capacity-summary-cards{display:flex;align-items:center;gap:10px}.capacity-summary-card{min-width:118px;border-radius:12px;border:1px solid rgba(71,85,105,.7);background:#0f172ad1;padding:8px 10px;display:flex;flex-direction:column;gap:4px}.capacity-summary-card .label{font-size:11px;text-transform:uppercase;letter-spacing:.07em;color:#94a3b8}.capacity-summary-card strong{color:#f8fafc;font-size:19px}.capacity-summary-card.acquired strong{color:#86efac}.capacity-summary-card.available strong{color:#7dd3fc}.capacity-summary-card.locked strong{color:#fbbf24}.capacity-progress{width:min(360px,45%);min-width:180px;display:flex;flex-direction:column;gap:5px;align-items:flex-end}.capacity-progress-track{width:100%;height:10px;border-radius:999px;background:#0f172ae6;border:1px solid rgba(71,85,105,.72);overflow:hidden}.capacity-progress-fill{display:block;height:100%;width:0%;border-radius:inherit;background:linear-gradient(90deg,#38bdf8,#22c55e 60%,#16a34a);transition:width .28s ease}.capacity-progress-label{color:#bfdbfe;font-size:12px;font-weight:700}.capacity-tree-node-header{align-items:flex-start}.capacity-level-badge{display:inline-flex;align-items:center;border:1px solid rgba(100,116,139,.62);border-radius:999px;padding:3px 8px;font-size:10px;text-transform:uppercase;letter-spacing:.08em;color:#bfdbfe}.capacity-tree-status{margin-left:auto;border-radius:999px;border:1px solid rgba(100,116,139,.72);padding:3px 7px;font-size:10px;text-transform:uppercase;letter-spacing:.08em;font-weight:700}.capacity-tree-status.status-acquired{color:#86efac;border-color:#16a34ab8}.capacity-tree-status.status-available{color:#7dd3fc;border-color:#38bdf8b8}.capacity-tree-status.status-locked{color:#fbbf24;border-color:#f59e0bb8}.capacity-grid-layout{display:grid;grid-template-columns:minmax(0,3fr) minmax(280px,1fr);gap:12px;min-height:0}.capacity-grid-canvas{position:relative;min-height:560px}.capacity-grid-detail{border-radius:12px;border:1px solid rgba(71,85,105,.68);background:linear-gradient(160deg,#090f1ceb,#0f172ae0);padding:12px;color:var(--capacity-text-main);display:flex;flex-direction:column;gap:10px;max-height:100%;overflow:auto}.capacity-grid-detail .placeholder{margin:0;color:#94a3b8;line-height:1.45}.capacity-grid-detail-head h3{margin:2px 0 0}.capacity-grid-detail-head .eyebrow{margin:0;font-size:10px;text-transform:uppercase;letter-spacing:.08em;color:#94a3b8}.capacity-grid-detail-meta{display:inline-flex;align-items:center;gap:8px}.capacity-grid-detail-code{font-family:JetBrains Mono,Fira Code,monospace;font-size:11px;color:#bfdbfe;border-radius:8px;padding:3px 7px;border:1px solid rgba(100,116,139,.65);background:#0f172abf}.capacity-grid-detail-status{border-radius:999px;border:1px solid rgba(71,85,105,.75);padding:3px 8px;font-size:11px;color:#e2e8f0}.capacity-grid-detail-warning{margin:0;color:#fbbf24;font-size:12px}.capacity-grid-detail-description{margin:0;color:#cbd5e1;line-height:1.5}.capacity-grid-detail-description.muted{color:#94a3b8}.capacity-grid-detail-section h4{margin:0 0 7px;color:#e2e8f0;font-size:13px}.capacity-grid-detail-section ul{list-style:none;margin:0;padding:0;display:grid;gap:6px}.capacity-grid-detail-section li{border:1px solid rgba(71,85,105,.52);border-radius:8px;padding:6px 8px;background:#0f172a8c;display:grid;grid-template-columns:auto 1fr auto;gap:6px;align-items:center}.capacity-grid-detail-section li.ok{border-color:#22c55ea6}.capacity-grid-detail-section li.missing{border-color:#f59e0ba6}.capacity-grid-detail-label{color:#e2e8f0;font-size:13px}.capacity-tree-link.link-direct{stroke-width:2.1}.capacity-tree-link.link-indirect{stroke-dasharray:4 4;opacity:.6}.capacity-tree-link-endpoint.link-indirect{opacity:.68}.dendrogram-controls{display:inline-flex;align-items:center;gap:8px;flex-wrap:wrap;justify-content:flex-end}.dendrogram-controls button{background:#0f172ae0;color:#e2e8f0;border:1px solid rgba(100,116,139,.72);border-radius:10px;padding:9px 11px;font-weight:700;cursor:pointer}.dendrogram-controls button:hover{border-color:#7dd3fce6;color:#f8fafc}.dendrogram-controls button:focus-visible{outline:2px solid rgba(186,230,253,.85);outline-offset:1px}.dendro-node[data-depth] .label{max-width:240px}.capacity-tree-node:focus-visible{outline:2px solid rgba(186,230,253,.85);outline-offset:1px}.capacity-tree-panel{background:radial-gradient(circle at top left,rgba(56,189,248,.08),transparent 28%),radial-gradient(circle at top right,rgba(249,115,22,.06),transparent 26%),linear-gradient(180deg,#182130,#0b1220);border:1px solid rgba(96,165,250,.16);box-shadow:0 36px 100px #0000008f;border-radius:24px;width:min(1280px,96vw);height:min(900px,92vh)}.capacity-tree-header{padding:26px 30px 18px;align-items:flex-start;background:linear-gradient(180deg,#0b122038,#0b122000)}.capacity-tree-title h2{font-size:clamp(2rem,2.5vw,3rem);line-height:1;letter-spacing:-.04em;text-wrap:balance}.capacity-tree-title .eyebrow{font-size:.72rem;font-weight:800;color:#94a3b8}.capacity-tree-subtitle{margin-top:10px;max-width:64ch;color:#dbe4f0;font-size:.98rem;line-height:1.45;text-wrap:pretty}.capacity-tree-actions{gap:12px;align-self:flex-start}.capacity-tree-counter{padding:10px 15px;border-radius:999px;background:#2563eb29;border-color:#7dd3fc47;color:#dbeafe;font-size:.92rem;font-weight:800;box-shadow:inset 0 1px #ffffff0d;font-variant-numeric:tabular-nums}.capacity-tree-close{width:42px;height:42px;border-radius:14px;background:#0f172ad6;border-color:#64748b8f}.capacity-tree-close:hover{transform:translateY(-1px);box-shadow:0 14px 24px #38bdf81f}.capacity-tree-tabs{padding:14px 30px 0;gap:8px;border-top:none;background:linear-gradient(180deg,#0b12202e,#0f172a00)}.capacity-tree-tab{background:#0f172ac2;border:1px solid rgba(71,85,105,.58);border-bottom:1px solid rgba(71,85,105,.58);border-radius:999px;padding:10px 16px;transition:background-color .16s ease,border-color .16s ease,color .16s ease,transform .16s ease,box-shadow .16s ease}.capacity-tree-tab:hover{transform:translateY(-1px);border-color:#7dd3fcb8;color:#f8fafc}.capacity-tree-tab.active{background:linear-gradient(135deg,#1e40af94,#082f49c2);border-color:#7dd3fce0;color:#f8fafc;box-shadow:0 16px 28px #0e749029}.capacity-tree-filters{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:14px 18px;align-items:end;padding:16px 30px 14px;background:linear-gradient(180deg,#080e1ccc,#090f1c61)}.capacity-filter-search{max-width:580px}.capacity-filter-search input{min-height:48px;border-radius:14px;padding:12px 14px;font-size:.96rem;background:#030a18c7;box-shadow:inset 0 1px #ffffff05}.capacity-filter-chips{align-self:center;gap:10px}.capacity-filter-chip{padding:8px 14px;transition:border-color .16s ease,background-color .16s ease,color .16s ease,transform .16s ease,box-shadow .16s ease}.capacity-tree-summary{display:grid;grid-template-columns:minmax(0,1fr) minmax(360px,520px);gap:20px;align-items:start;padding:16px 30px 18px}.capacity-summary-overview{display:grid;gap:6px;align-content:start;max-width:56ch}.capacity-summary-kicker{margin:0;font-size:.72rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:#94a3b8}.capacity-summary-hint{margin:0;color:#dbe4f0;font-size:.95rem;line-height:1.55;text-wrap:pretty}.capacity-summary-metrics{display:grid;gap:12px}.capacity-summary-cards{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}.capacity-summary-card{min-width:0;border-radius:16px;padding:11px 12px;background:#090f1cd1;border-color:#64748b80;box-shadow:inset 0 1px #ffffff08}.capacity-summary-card strong{font-size:1.35rem;font-variant-numeric:tabular-nums}.capacity-summary-card.locked strong{color:#e2e8f0}.capacity-progress{width:100%;min-width:0;gap:8px;align-items:stretch}.capacity-progress-header{display:flex;align-items:center;justify-content:space-between;gap:12px}.capacity-progress-kicker{color:#94a3b8;font-size:.72rem;font-weight:800;text-transform:uppercase;letter-spacing:.08em}.capacity-progress-track{height:12px;background:#060b17e6}.capacity-progress-label{font-variant-numeric:tabular-nums}.capacity-tree-body{padding:22px 18px 18px}.capacity-dendrogram-toolbar{padding:0 10px 12px;align-items:center}.dendrogram-toggles{padding:5px;border-color:#64748b7a;background:#080e1cb8}.dendrogram-controls{gap:10px}.dendrogram-controls button{border-radius:12px;padding:9px 12px;transition:border-color .16s ease,color .16s ease,transform .16s ease,background-color .16s ease,box-shadow .16s ease}.dendrogram-controls button:hover{transform:translateY(-1px);box-shadow:0 14px 22px #0f172a33}.capacity-dendrogram-layout{grid-template-columns:minmax(0,1fr) 340px;gap:16px;padding:0 10px 10px;min-height:560px}.capacity-dendrogram-canvas{min-height:560px;border-radius:20px;background:radial-gradient(circle at 50% 12%,rgba(59,130,246,.14),transparent 32%),radial-gradient(circle at 0% 100%,rgba(15,118,110,.1),transparent 28%),linear-gradient(180deg,#131c2cf0,#080e1cfa);border-color:#47556980;box-shadow:inset 0 1px #ffffff0a,0 24px 50px #0206175c}.capacity-dendrogram-canvas:before{content:"";position:absolute;inset:0;background:linear-gradient(to bottom,rgba(15,23,42,.18) 1px,transparent 1px),linear-gradient(to right,rgba(15,23,42,.12) 1px,transparent 1px);background-size:100% 98px,168px 100%;opacity:.32;pointer-events:none}.capacity-dendrogram-canvas svg{position:relative;z-index:calc(var(--layer-overlay-global) + 1)}.capacity-dendrogram-sidebar{border-radius:20px;padding:18px 16px;gap:12px;background:linear-gradient(180deg,#080e1ceb,#0c1424e0);box-shadow:inset 0 1px #ffffff0a}.focus-empty-state{display:grid;gap:8px}.capacity-dendrogram-sidebar .focus-header{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:12px;align-items:start}.capacity-dendrogram-sidebar h3{text-wrap:balance}.capacity-dendrogram-sidebar .focus-meta{width:fit-content}.capacity-dendrogram-sidebar .focus-status.locked{background:#64748b2e;border-color:#94a3b870;color:#e2e8f0}.capacity-dendrogram-sidebar .focus-callout,.capacity-grid-detail-callout{display:grid;gap:4px;border-radius:14px;padding:12px 13px;border:1px solid rgba(100,116,139,.36);background:linear-gradient(160deg,#0f172ae0,#0f172aa3)}.capacity-dendrogram-sidebar .focus-callout-label,.capacity-grid-detail-callout-label{margin:0;font-size:.68rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:#94a3b8}.capacity-dendrogram-sidebar .focus-callout strong,.capacity-grid-detail-callout strong{color:#f8fafc;font-size:.98rem}.capacity-dendrogram-sidebar .focus-callout span,.capacity-grid-detail-callout span{color:#cbd5e1;line-height:1.5}.capacity-dendrogram-sidebar .focus-callout.tone-acquired,.capacity-grid-detail-callout.tone-acquired{border-color:#22c55e61;background:linear-gradient(160deg,#071912eb,#0f172ac2)}.capacity-dendrogram-sidebar .focus-callout.tone-available,.capacity-grid-detail-callout.tone-available{border-color:#38bdf866;background:linear-gradient(160deg,#051827eb,#0f172ac2)}.capacity-dendrogram-sidebar .focus-callout.tone-locked,.capacity-grid-detail-callout.tone-locked{border-color:#f59e0b52;background:linear-gradient(160deg,#271908d6,#0f172ac7)}.capacity-dendrogram-sidebar .focus-metrics,.capacity-grid-detail-metrics{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.capacity-dendrogram-sidebar .focus-metric,.capacity-grid-detail-metric{display:grid;gap:4px;padding:10px 11px;border-radius:12px;border:1px solid rgba(71,85,105,.38);background:#ffffff08}.capacity-dendrogram-sidebar .focus-metric .label,.capacity-grid-detail-metric .label{font-size:.72rem;font-weight:700;color:#94a3b8}.capacity-dendrogram-sidebar .focus-metric strong,.capacity-grid-detail-metric strong{color:#f8fafc;font-size:1.05rem;font-variant-numeric:tabular-nums}.capacity-dendrogram-sidebar .requirements li,.capacity-dendrogram-sidebar .dependents li{border-radius:10px}.capacity-dendrogram-sidebar .placeholder{color:#cbd5e1}.capacity-dendrogram-legend{padding:0 10px 14px}.capacity-dendrogram-legend .legend-section{background:#080e1cb8;border-radius:14px}.dendro-depth-label{font-size:10px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;fill:#94a3b8;paint-order:stroke;stroke:#050a14e6;stroke-width:3.8px}.dendro-depth-label[data-depth="0"]{fill:#e2e8f0}.dendro-depth-guide{stroke:#7dd3fc1f}.dendro-link.locked{stroke:#94a3b88a}.dendro-node text{font-size:12px;stroke-width:2.2px}.dendro-node .code{font-size:10.5px;fill:#e0f2fe}.dendro-node .label{opacity:.78}.dendro-node.prereq-missing circle{stroke:#94a3b8c7}.capacity-tree-columns{gap:14px}.capacity-tree-column{border-radius:18px;padding:16px;background:linear-gradient(180deg,#0b1220eb,#0f172abd);border-color:#47556975;box-shadow:inset 0 1px #ffffff08}.capacity-tree-column-head{display:grid;gap:6px;margin-bottom:12px}.capacity-tree-column h3{margin:0;display:grid;grid-template-columns:auto 1fr auto;gap:8px;align-items:center;font-size:.95rem;text-transform:none;letter-spacing:0}.capacity-tree-column-stage{font-size:.65rem;font-weight:800;text-transform:uppercase;letter-spacing:.08em;color:#94a3b8}.capacity-tree-column-name{color:#f8fafc;font-weight:700}.capacity-tree-column h3 .badge{min-width:30px;justify-content:center;font-variant-numeric:tabular-nums}.capacity-tree-column-caption{margin:0;color:#94a3b8;font-size:.8rem;line-height:1.45}.capacity-tree-node{border-radius:14px;padding:12px 12px 13px;background:linear-gradient(155deg,#141e30e0,#0a101cf0);border-color:#4755698f}.capacity-tree-node[data-status=locked]{opacity:.96;border-color:#64748b70}.capacity-tree-node-label{font-size:.94rem;line-height:1.5}.capacity-tree-status.status-locked{color:#cbd5e1;border-color:#64748bb8}.capacity-tree-link.status-locked{stroke:#64748b9e}.capacity-grid-detail{border-radius:18px;padding:16px;gap:12px;background:linear-gradient(180deg,#080e1cf5,#0f172ae0)}.capacity-detail-placeholder{display:grid;gap:8px}.capacity-grid-detail .placeholder-title{margin:0;color:#f8fafc;font-size:1.02rem;font-weight:800}.capacity-grid-detail-meta{flex-wrap:wrap}.capacity-grid-detail-section li{border-radius:10px}@media(prefers-reduced-motion:reduce){.capacity-tree-node,.capacity-tree-link,.capacity-tree-link-endpoint,.dendro-node,.dendro-links path,.capacity-progress-fill,.capacity-filter-chip{transition:none}}@media(max-width:1100px){.capacity-tree-columns{grid-template-columns:repeat(2,minmax(220px,1fr))}.capacity-dendrogram-layout,.capacity-grid-layout,.capacity-tree-filters,.capacity-tree-summary{grid-template-columns:1fr}.capacity-progress{width:100%;align-items:flex-start}.capacity-filter-chips{justify-content:flex-start}}@media(max-width:720px){.capacity-tree-overlay{padding:12px}.capacity-tree-columns{grid-template-columns:repeat(1,minmax(240px,1fr))}.capacity-tree-panel{height:92vh}.capacity-tree-header,.capacity-tree-tabs,.capacity-tree-filters,.capacity-tree-summary{padding-left:20px;padding-right:20px}.capacity-dendrogram-toolbar{flex-direction:column;align-items:flex-start}.capacity-summary-cards{grid-template-columns:repeat(3,minmax(0,1fr))}.capacity-dendrogram-sidebar .focus-metrics,.capacity-grid-detail-metrics{grid-template-columns:1fr}.capacity-grid-canvas{min-height:480px}.capacity-tree-header{flex-direction:column;align-items:flex-start}.capacity-tree-column h3{grid-template-columns:1fr auto}.capacity-tree-column-stage{grid-column:1 / -1}}.runtime-error-dialog[hidden]{display:none}.runtime-error-dialog{position:fixed;inset:0;z-index:calc(var(--layer-overlay-global, 5000) + 30);display:grid;place-items:center;padding:20px;background:#040810cc;backdrop-filter:blur(6px)}.runtime-error-dialog__panel{width:min(560px,100%);display:grid;gap:12px;padding:18px;border-radius:16px;border:1px solid rgba(248,113,113,.34);background:linear-gradient(165deg,#141825fa,#0b0f19fa);box-shadow:0 24px 58px #0000006b;color:#f8fafc}.runtime-error-dialog__eyebrow{margin:0;font-size:.74rem;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:#fca5a5f0}.runtime-error-dialog__title{margin:0;font-size:clamp(1.2rem,2vw,1.5rem)}.runtime-error-dialog__message{margin:0;color:#e2e8f0eb;line-height:1.5;white-space:pre-wrap}.runtime-error-dialog__actions{display:flex;justify-content:flex-end}.runtime-error-dialog__btn{min-height:44px;min-width:120px;padding:0 16px;border-radius:11px;border:1px solid rgba(248,113,113,.46);background:linear-gradient(135deg,#ef44442e,#b91c1c57);color:#fff5f5;font:inherit;font-weight:700;cursor:pointer}.runtime-error-dialog__btn:focus-visible{outline:2px solid rgba(252,165,165,.95);outline-offset:2px}:root{--mobile-screen-gap: var(--ui-safe-gap, 8px);--mobile-screen-padding-top: var(--mobile-screen-gap);--mobile-screen-padding-right: var(--mobile-screen-gap);--mobile-screen-padding-bottom: var(--mobile-screen-gap);--mobile-screen-padding-left: var(--mobile-screen-gap);--mobile-screen-safe-inline: calc(var(--mobile-screen-padding-left) + var(--mobile-screen-padding-right));--mobile-screen-safe-block: calc(var(--mobile-screen-padding-top) + var(--mobile-screen-padding-bottom));--mobile-floating-top: var(--ui-safe-gap, 8px);--mobile-floating-right: var(--ui-safe-gap, 8px);--mobile-floating-bottom: var(--ui-safe-gap, 8px);--mobile-floating-left: var(--ui-safe-gap, 8px);--mobile-floating-safe-inline: calc(var(--mobile-floating-left) + var(--mobile-floating-right));--mobile-panel-radius: var(--ui-radius-md, 12px);--mobile-panel-radius-lg: var(--ui-radius-lg, 14px);--mobile-card-radius: var(--ui-radius-xl, 18px);--mobile-pill-radius: var(--ui-radius-pill, 999px);--mobile-touch-target-lg: var(--ui-control-height-lg, 52px);--mobile-touch-target: var(--ui-control-height-md, 44px);--mobile-touch-target-compact: var(--ui-control-height-sm, 42px);--mobile-touch-target-tight: var(--ui-control-height-xs, 40px);--mobile-focus-ring: var(--ui-focus-ring, 2px solid rgba(125, 211, 252, .95));--mobile-focus-offset: var(--ui-focus-offset, 2px);--mobile-glass-surface: rgba(8, 14, 26, .94);--mobile-glass-surface-soft: rgba(4, 8, 16, .62);--mobile-glass-surface-strong: rgba(6, 12, 24, .92);--mobile-glass-border: rgba(148, 163, 184, .34);--mobile-glass-border-strong: rgba(148, 163, 184, .42);--mobile-glass-border-soft: rgba(148, 163, 184, .24);--mobile-glass-shadow: 0 20px 44px rgba(0, 0, 0, .42);--mobile-glass-backdrop: blur(8px);--mobile-panel-top-offset: 52px;--mobile-panel-top-offset-lg: 58px}body.mobile-ui{--mobile-screen-gap: var(--ui-safe-gap, 8px);--mobile-screen-padding-top: max(var(--mobile-screen-gap), env(safe-area-inset-top));--mobile-screen-padding-right: max(var(--mobile-screen-gap), env(safe-area-inset-right));--mobile-screen-padding-bottom: calc(var(--mobile-screen-gap) + env(safe-area-inset-bottom));--mobile-screen-padding-left: max(var(--mobile-screen-gap), env(safe-area-inset-left));--mobile-screen-safe-inline: calc(var(--mobile-screen-padding-left) + var(--mobile-screen-padding-right));--mobile-screen-safe-block: calc(var(--mobile-screen-padding-top) + var(--mobile-screen-padding-bottom));--mobile-floating-top: max(var(--ui-safe-gap, 8px), env(safe-area-inset-top));--mobile-floating-right: max(var(--ui-safe-gap, 8px), env(safe-area-inset-right));--mobile-floating-bottom: max(var(--ui-safe-gap, 8px), env(safe-area-inset-bottom));--mobile-floating-left: max(var(--ui-safe-gap, 8px), env(safe-area-inset-left));--mobile-floating-safe-inline: calc(var(--mobile-floating-left) + var(--mobile-floating-right));--mobile-panel-radius: var(--ui-radius-md, 12px);--mobile-panel-radius-lg: var(--ui-radius-lg, 14px);--mobile-card-radius: var(--ui-radius-xl, 18px);--mobile-pill-radius: var(--ui-radius-pill, 999px);--mobile-touch-target-lg: var(--ui-control-height-lg, 52px);--mobile-touch-target: var(--ui-control-height-md, 44px);--mobile-touch-target-compact: var(--ui-control-height-sm, 42px);--mobile-touch-target-tight: var(--ui-control-height-xs, 40px);--mobile-focus-ring: var(--ui-focus-ring, 2px solid rgba(125, 211, 252, .95));--mobile-focus-offset: var(--ui-focus-offset, 2px);--mobile-glass-surface: rgba(8, 14, 26, .94);--mobile-glass-surface-soft: rgba(4, 8, 16, .62);--mobile-glass-surface-strong: rgba(6, 12, 24, .92);--mobile-glass-border: rgba(148, 163, 184, .34);--mobile-glass-border-strong: rgba(148, 163, 184, .42);--mobile-glass-border-soft: rgba(148, 163, 184, .24);--mobile-glass-shadow: 0 20px 44px rgba(0, 0, 0, .42);--mobile-glass-backdrop: blur(8px);--mobile-panel-top-offset: 52px;--mobile-panel-top-offset-lg: 58px}body.mobile-ui :where(button,[role=button],a,input,select,textarea){-webkit-tap-highlight-color:transparent}body.mobile-ui :where(button,[role=button],[type=button],[type=submit],a,input,select,textarea):focus-visible{outline:var(--mobile-focus-ring);outline-offset:var(--mobile-focus-offset)}body.mobile-ui :where(.auth-btn,.entry-auth__btn,.menu-btn,.pwa-install-banner__btn,.mobile-map-toolbar__btn,.mobile-map-recenter,.mobile-map-next-choices__choice,.ribbon-launch-btn,.yearly-composer__btn,.end-turn-btn.end-turn-btn--hud,.toast-center-toggle,#btn-game-hud-details){min-height:var(--mobile-touch-target)}body.page-title.mobile-ui :where(.entry-auth__btn,.menu-btn){min-height:var(--mobile-touch-target-lg)}body.page-profile.mobile-ui :where(.auth-tab,.form-field input,.form-field select,.auth-btn){min-height:var(--mobile-touch-target-compact)}body.page-profile.mobile-ui .shell-link{min-height:max(36px,calc(var(--mobile-touch-target-tight) - 4px))}.mobile-orientation-overlay[hidden]{display:none}.mobile-orientation-overlay{position:fixed;inset:0;display:grid;place-items:center;padding:18px;background:#050810e6;backdrop-filter:var(--mobile-glass-backdrop);z-index:var(--layer-overlay-global, 5000)}.mobile-orientation-overlay__card{width:min(360px,92vw);padding:18px 16px;border-radius:var(--mobile-panel-radius-lg);border:1px solid rgba(125,211,252,.35);background:linear-gradient(145deg,#10172af5,#070b17f5);text-align:center;box-shadow:0 20px 44px #0006}.mobile-orientation-overlay__eyebrow{margin:0 0 6px;font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;color:#bae6fdf2}.mobile-orientation-overlay__title{margin:0;font-size:1.25rem;color:#f8fafc}.mobile-orientation-overlay__text{margin:8px 0 0;font-size:.9rem;color:#e2e8f0eb}.mobile-beta-warning{position:relative;isolation:isolate;display:grid;gap:4px;width:100%;margin:0;padding:10px 12px;border:1px solid rgba(52,211,153,.48);background:linear-gradient(150deg,#08221ddb,#061814cc);color:#defcf4f2;box-shadow:0 10px 20px #00000038,inset 0 0 0 1px #ffffff12}.mobile-beta-warning[hidden]{display:none}.mobile-beta-warning__title,.mobile-beta-warning__text{margin:0}.mobile-beta-warning__title{font-size:.76rem;font-weight:800;letter-spacing:.06em;text-transform:uppercase}.mobile-beta-warning__text{font-size:.83rem;line-height:1.35}.mobile-panel-scrim[hidden]{display:none}.mobile-panel-scrim{position:fixed;inset:0;border:0;margin:0;padding:0;background:#03070f8f;backdrop-filter:blur(2px);z-index:calc(var(--layer-hud, 1200) + 1);touch-action:none}body.mobile-ui .mobile-panel-surface{border-radius:var(--mobile-panel-radius-lg);border:1px solid var(--mobile-glass-border);background:#0d1422e6;box-shadow:var(--mobile-glass-shadow)}.mobile-panel-header{display:none}body.mobile-ui .mobile-panel-header,body.mobile-ui .mobile-panel-surface__header{display:flex;align-items:center;justify-content:space-between;gap:8px;min-height:calc(var(--mobile-touch-target) + 2px);padding:.55rem .72rem;border-bottom:1px solid var(--mobile-glass-border-soft);background:#080e1ad1}body.mobile-ui .mobile-panel-title,body.mobile-ui .mobile-panel-surface__title{font-size:.76rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:#e2e8f0f2}body.mobile-ui .mobile-panel-close,body.mobile-ui .mobile-panel-surface__close{width:var(--mobile-touch-target);height:var(--mobile-touch-target);min-width:var(--mobile-touch-target);min-height:var(--mobile-touch-target);border-radius:var(--ui-radius-sm);border:1px solid rgba(148,163,184,.32);background:#1e293b8c;color:#f8fafc;font:inherit;font-size:1rem;display:inline-flex;align-items:center;justify-content:center;cursor:pointer}body.mobile-ui.mobile-panel-open{overscroll-behavior:none}.pwa-install-banner-host[hidden]{display:none}.pwa-install-banner-host{position:fixed;top:var(--mobile-floating-top);left:var(--mobile-floating-left);right:var(--mobile-floating-right);display:flex;justify-content:center;pointer-events:none;z-index:calc(var(--layer-hud, 1200) + 18)}.pwa-install-banner{width:min(560px,100%);display:grid;grid-template-columns:minmax(0,1fr) auto;gap:10px;align-items:center;pointer-events:auto;padding:12px 14px;border-radius:var(--mobile-card-radius);border:1px solid rgba(125,211,252,.28);background:linear-gradient(155deg,var(--mobile-glass-surface),rgba(6,18,24,.9));box-shadow:0 18px 36px #00000052;backdrop-filter:blur(10px)}.pwa-install-banner[data-context=internal]{width:min(360px,100%);padding:10px 12px;border-radius:var(--mobile-panel-radius-lg)}.pwa-install-banner__copy{min-width:0;display:grid;gap:4px}.pwa-install-banner__title,.pwa-install-banner__text{margin:0}.pwa-install-banner__title{font-size:.78rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:#bae6fdf5}.pwa-install-banner__text{font-size:.84rem;line-height:1.38;color:#e2e8f0f0}.pwa-install-banner[data-context=internal] .pwa-install-banner__text{font-size:.76rem}.pwa-install-banner__actions{display:inline-flex;align-items:center;flex-wrap:wrap;justify-content:flex-end;gap:8px}.pwa-install-banner__btn{min-height:var(--mobile-touch-target-compact);padding:0 14px;border-radius:var(--mobile-pill-radius);border:1px solid transparent;cursor:pointer;font:inherit;font-size:.76rem;font-weight:700;letter-spacing:.03em;transition:transform .16s ease,border-color .16s ease,background-color .16s ease}.pwa-install-banner__btn:hover,.pwa-install-banner__btn:focus-visible{transform:translateY(-1px)}.pwa-install-banner__btn--primary{color:#061019;background:linear-gradient(135deg,#4ade80,#7dd3fc)}.pwa-install-banner__btn--ghost{color:#f8fafc;border-color:#94a3b857;background:#ffffff0f}.app-standalone #btn-fullscreen{display:none}body.page-title .pwa-install-banner-host{top:calc(var(--mobile-floating-top) + 4px)}@media(max-width:640px){.pwa-install-banner{grid-template-columns:1fr;justify-items:stretch}.pwa-install-banner__actions{justify-content:stretch}.pwa-install-banner__btn{width:100%}}body.page-map.mobile-ui{overflow:hidden}body.page-map.mobile-ui.mobile-landscape.mobile-layout-map-first .map-page{position:relative;display:block;height:100dvh;min-height:100dvh;padding-top:var(--mobile-screen-padding-top);padding-right:var(--mobile-screen-padding-right);padding-bottom:var(--mobile-screen-padding-bottom);padding-left:var(--mobile-screen-padding-left);overflow:hidden}body.page-map.mobile-ui.mobile-landscape.mobile-layout-map-first .map-container{min-height:0;height:100%;border-radius:var(--mobile-panel-radius-lg);--map-fog-opacity: .58;--map-fog-frontier: 66%;box-shadow:inset 0 0 0 1px #94a3b842}body.page-map.mobile-ui.mobile-landscape.mobile-layout-map-first .map-container.map-container--mobile-scroll{overflow:auto;overscroll-behavior:contain;-webkit-overflow-scrolling:touch;touch-action:pan-x pan-y;scrollbar-width:thin}body.page-map.mobile-ui.mobile-landscape.mobile-layout-map-first .map-container.map-container--mobile-scroll .map-scroll-surface{width:205%;height:175%;min-width:205%;min-height:175%}body.page-map.mobile-ui.mobile-landscape.mobile-layout-map-first .map-legend{left:var(--mobile-floating-left);bottom:var(--mobile-floating-bottom);width:min(190px,calc(100vw - var(--mobile-floating-safe-inline)))}body.page-map.mobile-ui.mobile-landscape.mobile-layout-map-first .map-legend__panel{max-height:42vh;overflow:auto}body.page-map.mobile-ui.mobile-landscape.mobile-layout-map-first .map-legend__list{grid-template-columns:1fr}body.page-map.mobile-ui.mobile-landscape.mobile-layout-map-first .mobile-map-toolbar{position:fixed;top:var(--mobile-floating-top);left:var(--mobile-floating-left);display:flex;align-items:center;gap:4px;padding:4px;border-radius:var(--mobile-panel-radius);border:1px solid var(--mobile-glass-border-soft);background:var(--mobile-glass-surface-soft);backdrop-filter:var(--mobile-glass-backdrop);z-index:calc(var(--layer-hud, 1200) + 4);max-width:220px}body.page-map.mobile-ui.mobile-landscape.mobile-layout-map-first .mobile-map-toolbar[hidden],body.page-map.mobile-ui.mobile-landscape.mobile-layout-map-first .mobile-map-next-choices[hidden],body.page-map.mobile-ui.mobile-landscape.mobile-layout-map-first .mobile-map-recenter[hidden]{display:none}body.page-map.mobile-ui.mobile-landscape.mobile-layout-map-first .mobile-map-toolbar__btn{min-height:var(--mobile-touch-target);min-width:64px;padding:0 8px;border-radius:var(--ui-radius-sm);border:1px solid var(--mobile-glass-border-strong);background:var(--mobile-glass-surface-strong);color:#f8fafc;font-size:.68rem;font-weight:700;letter-spacing:.02em;text-transform:uppercase}body.page-map.mobile-ui.mobile-landscape.mobile-layout-map-first .mobile-map-recenter{position:fixed;top:var(--mobile-floating-top);right:var(--mobile-floating-right);min-height:var(--mobile-touch-target);min-width:44px;padding:0 10px;border-radius:var(--ui-radius-sm);border:1px solid var(--mobile-glass-border);background:var(--mobile-glass-surface-strong);color:#f8fafc;font-size:.68rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;z-index:calc(var(--layer-hud, 1200) + 4)}body.page-map.mobile-ui.mobile-landscape.mobile-layout-map-first .mobile-map-next-choices{position:fixed;top:calc(var(--mobile-floating-top) + var(--mobile-panel-top-offset-lg));left:var(--mobile-floating-left);width:min(220px,calc(100vw - var(--mobile-floating-safe-inline)));display:grid;gap:4px;padding:5px 6px;border-radius:var(--mobile-panel-radius);border:1px solid var(--mobile-glass-border-soft);background:var(--mobile-glass-surface-soft);backdrop-filter:var(--mobile-glass-backdrop);box-shadow:0 10px 24px #02061759;z-index:calc(var(--layer-hud, 1200) + 4)}body.page-map.mobile-ui.mobile-landscape.mobile-layout-map-first .mobile-map-next-choices__head{display:flex;align-items:center;justify-content:space-between;gap:8px}body.page-map.mobile-ui.mobile-landscape.mobile-layout-map-first .mobile-map-next-choices__title{font-size:.58rem;letter-spacing:.08em;text-transform:uppercase;font-weight:700;color:#e2e8f0f2}body.page-map.mobile-ui.mobile-landscape.mobile-layout-map-first .mobile-map-next-choices__current{min-width:0;font-size:.62rem;font-weight:600;color:#bae6fdf2;text-overflow:ellipsis;white-space:nowrap;overflow:hidden}body.page-map.mobile-ui.mobile-landscape.mobile-layout-map-first .mobile-map-next-choices__list{display:flex;align-items:stretch;gap:6px;overflow-x:auto;overflow-y:hidden;scrollbar-width:thin;-webkit-overflow-scrolling:touch;padding-bottom:2px}body.page-map.mobile-ui.mobile-landscape.mobile-layout-map-first .mobile-map-next-choices__list::-webkit-scrollbar{height:6px}body.page-map.mobile-ui.mobile-landscape.mobile-layout-map-first .mobile-map-next-choices__choice{flex:0 0 auto;min-width:96px;min-height:var(--mobile-touch-target);padding:0 8px;border-radius:var(--ui-radius-sm);border:1px solid var(--mobile-glass-border);background:var(--mobile-glass-surface-strong);color:#f8fafc;font-size:.68rem;font-weight:700;line-height:1.1;text-align:center;touch-action:manipulation}body.page-map.mobile-ui.mobile-landscape.mobile-layout-map-first .mobile-map-next-choices__choice--focus{border-color:#7dd3fceb;box-shadow:0 0 0 1px #7dd3fc59 inset}body.page-map.mobile-ui.mobile-landscape.mobile-layout-map-first.mobile-panel-left-open .mobile-map-next-choices,body.page-map.mobile-ui.mobile-landscape.mobile-layout-map-first.mobile-panel-right-open .mobile-map-next-choices{opacity:0;pointer-events:none}body.page-map.mobile-ui.mobile-landscape.mobile-layout-map-first .mobile-map-toolbar__btn[aria-expanded=true]{border-color:#4ade80cc;box-shadow:0 0 0 1px #4ade8059 inset}body.page-map.mobile-ui.mobile-landscape.mobile-layout-map-first .mobile-map-toolbar__btn:disabled{opacity:.56;cursor:default}body.page-map.mobile-ui.mobile-landscape.mobile-layout-map-first .mobile-map-scrim{z-index:calc(var(--layer-hud, 1200) + 2)}body.page-map.mobile-ui.mobile-landscape.mobile-layout-map-first .sidebar-left,body.page-map.mobile-ui.mobile-landscape.mobile-layout-map-first .sidebar-right{position:fixed;top:calc(var(--mobile-floating-top) + var(--mobile-panel-top-offset));bottom:var(--mobile-floating-bottom);width:min(92vw,360px);max-width:360px;border-radius:var(--mobile-panel-radius-lg);border:1px solid var(--map-border);backdrop-filter:blur(12px);box-shadow:var(--mobile-glass-shadow);background:#0d1422e6;overflow:hidden;z-index:calc(var(--layer-hud, 1200) + 3);transition:transform .18s ease;pointer-events:none}body.page-map.mobile-ui.mobile-landscape.mobile-layout-map-first .sidebar-left{left:var(--mobile-floating-left);border-right:1px solid var(--map-border);border-bottom:1px solid var(--map-border);transform:translate(-112%);overflow-y:auto;overflow-x:hidden;overscroll-behavior:contain;-webkit-overflow-scrolling:touch;touch-action:pan-y}body.page-map.mobile-ui.mobile-landscape.mobile-layout-map-first .sidebar-right{right:var(--mobile-floating-right);border-left:1px solid var(--map-border);border-top:1px solid var(--map-border);transform:translate(112%)}body.page-map.mobile-ui.mobile-landscape.mobile-layout-map-first.mobile-panel-left-open .sidebar-left,body.page-map.mobile-ui.mobile-landscape.mobile-layout-map-first.mobile-panel-right-open .sidebar-right{transform:translate(0);pointer-events:auto}body.page-map.mobile-ui.mobile-landscape.mobile-layout-map-first .sidebar-left,body.page-map.mobile-ui.mobile-landscape.mobile-layout-map-first .sidebar-right-scroll{padding:.72rem}body.page-map.mobile-ui.mobile-landscape.mobile-layout-map-first .map-sidebar-group{gap:.62rem}body.page-map.mobile-ui.mobile-landscape.mobile-layout-map-first .map-sidebar-group__title{font-size:.56rem;letter-spacing:.12em}body.page-map.mobile-ui.mobile-landscape.mobile-layout-map-first .map-sidebar-group--hero{padding:.78rem;border-radius:var(--mobile-panel-radius)}body.page-map.mobile-ui.mobile-landscape.mobile-layout-map-first .mobile-map-stats-stack{display:grid;gap:12px;margin-top:12px;padding-top:12px;border-top:1px solid rgba(148,163,184,.22)}body.page-map.mobile-ui.mobile-landscape.mobile-layout-map-first .mobile-map-stats-stack:empty{display:none}body.page-map.mobile-ui.mobile-landscape.mobile-layout-map-first .mobile-map-stats-stack .account-visual-global{margin:0}body.page-map.mobile-ui.mobile-landscape.mobile-layout-map-first .mobile-map-stats-stack .sidebar-right-scroll{padding:0}body.page-map.mobile-ui.mobile-landscape.mobile-layout-map-first .sidebar-right-scroll,body.page-map.mobile-ui.mobile-landscape.mobile-layout-map-first #capacities-panel{overflow:auto}body.page-map.mobile-ui.mobile-landscape.mobile-layout-map-first .sequence-objective,body.page-map.mobile-ui.mobile-landscape.mobile-layout-map-first #capacities-panel,body.page-map.mobile-ui.mobile-landscape.mobile-layout-map-first .motivation-display,body.page-map.mobile-ui.mobile-landscape.mobile-layout-map-first .capacities-summary,body.page-map.mobile-ui.mobile-landscape.mobile-layout-map-first .artefacts-panel{border-radius:var(--mobile-panel-radius)}body.page-map.mobile-ui.mobile-landscape.mobile-layout-map-first .teacher-stats{gap:.44rem}body.page-map.mobile-ui.mobile-landscape.mobile-layout-map-first .sidebar-right .account-visual-global{padding:.6rem .72rem 0}body.page-map.mobile-ui.mobile-landscape.mobile-layout-map-first .map-node{min-width:var(--mobile-touch-target);min-height:var(--mobile-touch-target);display:flex;align-items:center;justify-content:center;touch-action:manipulation;transition:transform .16s ease,opacity .16s ease,filter .16s ease}body.page-map.mobile-ui.mobile-landscape.mobile-layout-map-first .map-node:before{content:"";position:absolute;inset:-8px}body.page-map.mobile-ui.mobile-landscape.mobile-layout-map-first .map-node:not(.current):not(.accessible):not(:focus-visible){opacity:.42;filter:saturate(.5) brightness(.72)}body.page-map.mobile-ui.mobile-landscape.mobile-layout-map-first .map-node.accessible,body.page-map.mobile-ui.mobile-landscape.mobile-layout-map-first .map-node.current{opacity:1;filter:none;z-index:calc(var(--layer-playfield) + 5)}body.page-map.mobile-ui.mobile-landscape.mobile-layout-map-first .map-node.map-node--spotlight{z-index:calc(var(--layer-playfield) + 7)}body.page-map.mobile-ui.mobile-landscape.mobile-layout-map-first .map-node.map-node--spotlight .node-icon{animation:map-node-mobile-spotlight .9s cubic-bezier(.2,.9,.22,1);border-color:#7dd3fcf5}body.page-map.mobile-ui.mobile-landscape.mobile-layout-map-first .node-icon{width:50px;height:50px}body.page-map.mobile-ui.mobile-landscape.mobile-layout-map-first .node[data-type=start] .node-icon{width:var(--mobile-touch-target);height:var(--mobile-touch-target)}body.page-map.mobile-ui.mobile-landscape.mobile-layout-map-first .node[data-type=boss] .node-icon{width:60px;height:60px}body.page-map.mobile-ui.mobile-landscape.mobile-layout-map-first .node-label{display:none;max-width:92px;font-size:.56rem;padding:.18rem .4rem;line-height:1.08}body.page-map.mobile-ui.mobile-landscape.mobile-layout-map-first .map-node.current .node-label,body.page-map.mobile-ui.mobile-landscape.mobile-layout-map-first .map-node.map-node--spotlight .node-label,body.page-map.mobile-ui.mobile-landscape.mobile-layout-map-first .map-node:focus-visible .node-label{display:block}body.page-map.mobile-ui.mobile-landscape.mobile-layout-map-first .node-cost{display:none}body.page-map.mobile-ui.mobile-landscape.mobile-layout-map-first .map-node.current .node-cost,body.page-map.mobile-ui.mobile-landscape.mobile-layout-map-first .map-node.map-node--spotlight .node-cost{display:block}body.page-map.mobile-ui.mobile-landscape.mobile-layout-map-first .map-node.accessible .node-icon{border-color:#fbbf24f5;box-shadow:0 0 0 1px #fbbf2499,0 0 16px #fbbf245c}body.page-map.mobile-ui.mobile-landscape.mobile-layout-map-first .connection-line.future,body.page-map.mobile-ui.mobile-landscape.mobile-layout-map-first .connection-line.locked{opacity:.18}body.page-map.mobile-ui.mobile-landscape.mobile-layout-map-first .connection-line.active{opacity:1;stroke-width:3.5}body.page-map.mobile-ui.mobile-landscape.mobile-layout-map-first .run-item,body.page-map.mobile-ui.mobile-landscape.mobile-layout-map-first .btn-capacities,body.page-map.mobile-ui.mobile-landscape.mobile-layout-map-first .account-link,body.page-map.mobile-ui.mobile-landscape.mobile-layout-map-first .capacity-filter-chip,body.page-map.mobile-ui.mobile-landscape.mobile-layout-map-first .capacity-tree-close,body.page-map.mobile-ui.mobile-landscape.mobile-layout-map-first .capacity-tree-tab,body.page-map.mobile-ui.mobile-landscape.mobile-layout-map-first .modal-btn,body.page-map.mobile-ui.mobile-landscape.mobile-layout-map-first .reward-choice,body.page-map.mobile-ui.mobile-landscape.mobile-layout-map-first #btn-fullscreen{min-height:var(--mobile-touch-target)}body.page-map.mobile-ui.mobile-landscape.mobile-layout-map-first .run-items{gap:.54rem}body.page-map.mobile-ui.mobile-landscape.mobile-layout-map-first .run-item{min-height:96px;padding:.68rem .4rem;border-radius:var(--mobile-panel-radius)}body.page-map.mobile-ui.mobile-landscape.mobile-layout-map-first .run-item .icon{margin-bottom:.12rem}body.page-map.mobile-ui.mobile-landscape.mobile-layout-map-first .run-item-count{font-size:.94rem}body.page-map.mobile-ui.mobile-landscape.mobile-layout-map-first .run-item-label{font-size:.56rem}body.page-map.mobile-ui.mobile-landscape.mobile-layout-map-first #btn-fullscreen{width:var(--mobile-touch-target);height:var(--mobile-touch-target);right:var(--mobile-floating-right);bottom:var(--mobile-floating-bottom)}@keyframes map-node-mobile-spotlight{0%{transform:scale(1);box-shadow:0 0 #7dd3fc14}42%{transform:scale(1.12);box-shadow:0 0 0 10px #7dd3fc38}to{transform:scale(1);box-shadow:0 0 #7dd3fc00}}@media(prefers-reduced-motion:reduce){body.page-map.mobile-ui.mobile-landscape.mobile-layout-map-first .sidebar-left,body.page-map.mobile-ui.mobile-landscape.mobile-layout-map-first .sidebar-right,body.page-game.mobile-ui.mobile-landscape.mobile-hud-compact #game-mobile-hud-panel,body.page-map.mobile-ui.mobile-landscape.mobile-layout-map-first .mobile-map-next-choices,body.page-map.mobile-ui.mobile-landscape.mobile-layout-map-first .map-node.map-node--spotlight .node-icon{transition:none;animation:none}}
