@font-face{font-family:Inter;src:url(/assets/Inter-VariableFont_opsz_wght-c8O0ljhh.ttf) format("truetype");font-weight:100 900;font-style:normal;font-display:swap}@font-face{font-family:DM Sans;src:url(/assets/DMSans-Regular-BYFsQjAW.ttf) format("truetype");font-weight:400;font-style:normal;font-display:swap}@font-face{font-family:DM Sans;src:url(/assets/DMSans-Bold-Cdsr5R1z.ttf) format("truetype");font-weight:700;font-style:normal;font-display:swap}@font-face{font-family:Noto Sans JP;src:url(/fonts/NotoSansJP-kereta.woff2) format("woff2");font-weight:100 900;font-style:normal;font-display:swap}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body{background:var(--bg);color:var(--fg);font-family:var(--font-body);font-size:var(--font-size-md);font-weight:var(--font-weight-normal);line-height:1.6;-webkit-font-smoothing:auto}h1,h2{font-family:var(--font-display)}h3,h4,h5,h6,label,caption{font-family:var(--font-label)}p{font-family:var(--font-body)}code,kbd,pre,pre code{font-family:var(--font-mono)}button,input,select,textarea{font-weight:var(--font-weight-medium)}:lang(ja){font-family:var(--font-ja)}h1:lang(ja),h2:lang(ja),h3:lang(ja),h4:lang(ja),:lang(ja) h1,:lang(ja) h2,:lang(ja) h3,:lang(ja) h4{font-family:var(--font-ja-display)}.grad,.grad-primary{background:var(--grad-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.grad-alt{background:var(--grad-alt);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.grad-rainbow{background:var(--grad-rainbow);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.grad-ocean{background:var(--grad-ocean);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.grad-aurora{background:var(--grad-aurora);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.grad-forest{background:var(--grad-forest);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.grad-fire{background:var(--grad-fire);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.grad-sunset{background:var(--grad-sunset);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.grad-neon{background:var(--grad-neon);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.grad-cold{background:var(--grad-cold);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.grad-warm{background:var(--grad-warm);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}h1,h2,h3,h4,h5,h6{font-weight:var(--font-weight-black);line-height:1.1;letter-spacing:0em}h1{letter-spacing:.02em}h2{letter-spacing:.01em}h1{font-size:var(--font-size-3xl)}h2{font-size:var(--font-size-2xl)}h3{font-size:var(--font-size-xl)}.container{width:100%;max-width:1200px;margin:0 auto;padding:0 var(--sp-4)}.grid{display:grid;gap:var(--sp-4)}.grid-2{grid-template-columns:repeat(2,1fr)}.grid-3{grid-template-columns:repeat(3,1fr)}.grid-4{grid-template-columns:repeat(4,1fr)}.flex-center{display:flex;align-items:center;justify-content:center}.flex-between{display:flex;align-items:center;justify-content:space-between}@media(max-width:639px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}h1{font-size:var(--font-size-2xl)}h2{font-size:var(--font-size-xl)}.container{padding:0 var(--sp-3)}.sm-hidden{display:none!important}.sm-block{display:block!important}.sm-flex-col{flex-direction:column!important}.sm-w-full{width:100%!important}.sm-text-center{text-align:center!important}.sm-p-3{padding:var(--sp-3)!important}}@media(min-width:640px)and (max-width:767px){.grid-3,.grid-4{grid-template-columns:repeat(2,1fr)}}@media(min-width:768px){.md-hidden{display:none!important}.md-flex{display:flex!important}.md-grid-2{grid-template-columns:repeat(2,1fr)!important}.md-grid-3{grid-template-columns:repeat(3,1fr)!important}}@media(min-width:1024px){.lg-hidden{display:none!important}.lg-flex{display:flex!important}.lg-grid-3{grid-template-columns:repeat(3,1fr)!important}.lg-grid-4{grid-template-columns:repeat(4,1fr)!important}}.bar-v{width:3px;align-self:stretch;background:var(--grad-primary)}.bar-h{height:3px;width:100%;background:var(--grad-primary)}.btn{display:inline-flex;align-items:center;gap:var(--sp-2);padding:var(--sp-2) var(--sp-6);font-family:var(--font-ui);font-size:var(--font-size-sm);font-weight:var(--font-weight-bold);letter-spacing:.05em;text-transform:uppercase;border:var(--border-accent);background:var(--surface-interactive);color:var(--cyan);cursor:pointer;border-radius:var(--radius);position:relative;overflow:hidden;transition:background .15s,box-shadow .15s,color .15s}.btn:hover:not(:disabled):not([aria-disabled=true]){background:var(--surface-interactive-hover);color:var(--fg);box-shadow:0 0 14px #38bdf840}.btn-primary{background:#38bdf8e6;color:var(--on-accent);border-color:var(--cyan);box-shadow:0 2px 12px #38bdf840}.btn-primary:hover:not(:disabled):not([aria-disabled=true]){background:#38bdf8;color:var(--on-accent);box-shadow:0 2px 20px #38bdf866}.btn-ghost{border-color:var(--fg-subtle);color:var(--fg-muted);background:transparent}.btn-ghost:after{display:none}.btn-ghost:hover:not(:disabled):not([aria-disabled=true]){background:var(--surface-neutral-hover);border-color:var(--fg-muted);color:var(--fg);box-shadow:none}.btn-sm{padding:var(--sp-1) var(--sp-3);font-size:var(--font-size-xs);letter-spacing:.04em}.btn-lg{padding:var(--sp-3) var(--sp-8);font-size:var(--font-size-md)}.card{background:var(--bg-2);border:var(--border);border-radius:var(--radius);padding:var(--sp-6);position:relative;overflow:hidden;box-shadow:var(--shadow-sm)}.card:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--surface-highlight),transparent);pointer-events:none}.card:after{content:"";position:absolute;inset:0;opacity:.018;filter:url(#noise);background:var(--surface-noise);pointer-events:none;border-radius:var(--radius)}.card-accent{border-left:3px solid var(--cyan)}.input{width:100%;padding:var(--sp-2) var(--sp-4);background:var(--bg-2);border:var(--border);border-radius:var(--radius);color:var(--fg);font-family:var(--font-ui);font-size:var(--font-size-md);outline:none;transition:border-color .15s}.input:focus{border-color:var(--cyan)}.input::placeholder{color:var(--fg-subtle);font-family:var(--font-ui)}.input.sm{padding:var(--sp-1) var(--sp-3);font-size:var(--font-size-sm)}.input.lg{padding:var(--sp-3) var(--sp-5);font-size:var(--font-size-lg)}.textarea{width:100%;padding:var(--sp-2) var(--sp-4);background:var(--bg-2);border:var(--border);border-radius:var(--radius);color:var(--fg);font-family:var(--font-ui);font-size:var(--font-size-md);line-height:1.6;outline:none;resize:vertical;min-height:5rem;transition:border-color .15s}.textarea:focus{border-color:var(--cyan)}.textarea::placeholder{color:var(--fg-subtle);font-family:var(--font-ui)}.badge{display:inline-block;padding:var(--sp-1) var(--sp-3);font-family:var(--font-tag);font-size:var(--font-size-xs);font-weight:var(--font-weight-bold);letter-spacing:.08em;text-transform:uppercase;border:1px solid currentColor;border-radius:var(--radius)}.badge-cyan{color:var(--cyan)}.badge-magenta{color:var(--magenta)}.badge-green{color:var(--green)}.badge-blue{color:var(--blue)}.badge-red{color:var(--red)}.badge-orange{color:var(--orange)}.badge-yellow{color:var(--yellow)}.badge-teal{color:var(--teal)}.badge-purple{color:var(--purple)}.badge-amber{color:var(--amber)}.badge-lime{color:var(--lime)}.badge-emerald{color:var(--emerald)}.badge-pink{color:var(--pink)}.badge-filled{background:currentColor;color:var(--bg);border-color:transparent;opacity:.88}.badge-soft{background:var(--surface-cyan);border-color:transparent}.badge-soft.badge-cyan{background:var(--surface-cyan)}.badge-soft.badge-magenta{background:var(--surface-magenta)}.badge-soft.badge-green{background:var(--surface-green)}.badge-soft.badge-blue{background:var(--surface-blue)}.badge-soft.badge-red{background:var(--surface-red)}.badge-soft.badge-orange{background:var(--surface-orange)}.badge-soft.badge-yellow{background:var(--surface-yellow)}.badge-soft.badge-teal{background:var(--surface-teal)}.badge-soft.badge-purple{background:var(--surface-purple)}.badge-soft.badge-amber{background:var(--surface-amber)}.badge-soft.badge-lime{background:var(--surface-lime)}.badge-soft.badge-emerald{background:var(--surface-emerald)}.badge-soft.badge-pink{background:var(--surface-pink)}.badge-circle{width:1.25rem;height:1.25rem;border-radius:50%;padding:0;display:inline-flex;align-items:center;justify-content:center;font-size:.6rem;letter-spacing:0;text-transform:none}.badge-circle.lg{width:1.75rem;height:1.75rem;font-size:.75rem}.notif-dot{position:absolute;top:-3px;right:-3px;width:8px;height:8px;border-radius:50%;background:var(--red);border:2px solid var(--bg);flex-shrink:0}.avatar{width:2rem;height:2rem;border-radius:var(--radius);background:var(--bg-3);border:var(--border);display:inline-flex;align-items:center;justify-content:center;font-family:var(--font-ui);font-size:var(--font-size-xs);font-weight:var(--font-weight-bold);color:var(--fg-muted);flex-shrink:0;overflow:hidden;position:relative}.avatar img{width:100%;height:100%;object-fit:cover;border-radius:inherit}.avatar.circle{border-radius:50%}.avatar.sm{width:1.5rem;height:1.5rem;font-size:.55rem}.avatar.lg{width:3rem;height:3rem;font-size:1rem}.avatar.xl{width:4rem;height:4rem;font-size:1.25rem}.avatar.cyan{background:var(--surface-cyan);color:var(--cyan)}.avatar.magenta{background:var(--surface-magenta);color:var(--magenta)}.avatar.green{background:var(--surface-green);color:var(--green)}.avatar.purple{background:var(--surface-purple);color:var(--purple)}.avatar.orange{background:var(--surface-orange);color:var(--orange)}.avatar-group{display:inline-flex;align-items:center}.avatar-group .avatar{margin-left:-.5rem;border:2px solid var(--bg);transition:margin .15s}.avatar-group .avatar:first-child{margin-left:0}.avatar-group:hover .avatar{margin-left:-.2rem}.avatar-overflow{width:2rem;height:2rem;border-radius:var(--radius);background:var(--bg-3);border:2px solid var(--bg);display:inline-flex;align-items:center;justify-content:center;font-size:.6rem;color:var(--fg-muted);font-family:var(--font-ui);margin-left:-.5rem}.chip{display:inline-flex;align-items:center;gap:var(--sp-1);padding:.2em .55em .2em .65em;background:var(--bg-3);border:var(--border);border-radius:999px;font-family:var(--font-tag);font-size:var(--font-size-xs);color:var(--fg-muted);line-height:1.4}.chip-remove{cursor:pointer;opacity:.45;font-size:.85em;line-height:1;transition:opacity .1s;border:none;background:transparent;color:inherit;padding:0}.chip-remove:hover{opacity:1}.chip.cyan{border-color:var(--cyan);color:var(--cyan)}.chip.magenta{border-color:var(--magenta);color:var(--magenta)}.chip.green{border-color:var(--green);color:var(--green)}.divider{height:1px;background:var(--fg-subtle);border:none}.muted{color:var(--fg-muted);font-size:var(--font-size-sm)}.flex{display:flex}.flex-col{display:flex;flex-direction:column}.flex-row{display:flex;flex-direction:row}.flex-wrap{flex-wrap:wrap}.flex-1{flex:1}.flex-none{flex:none}.flex-shrink-0{flex-shrink:0}.items-start{align-items:flex-start}.items-center{align-items:center}.items-end{align-items:flex-end}.items-stretch{align-items:stretch}.justify-start{justify-content:flex-start}.justify-center{justify-content:center}.justify-end{justify-content:flex-end}.justify-between{justify-content:space-between}.gap-1{gap:var(--sp-1)}.gap-2{gap:var(--sp-2)}.gap-3{gap:var(--sp-3)}.gap-4{gap:var(--sp-4)}.gap-6{gap:var(--sp-6)}.gap-8{gap:var(--sp-8)}.gap-y-1{row-gap:var(--sp-1)}.gap-y-2{row-gap:var(--sp-2)}.gap-y-3{row-gap:var(--sp-3)}.gap-y-4{row-gap:var(--sp-4)}.gap-y-6{row-gap:var(--sp-6)}.w-full{width:100%}.h-full{height:100%}.min-h-screen{min-height:100vh}.overflow-hidden{overflow:hidden}.overflow-auto{overflow:auto}.overflow-y-auto{overflow-y:auto}.relative{position:relative}.absolute{position:absolute}.fixed{position:fixed}.sticky{position:sticky}.inset-0{inset:0}.z-10{z-index:10}.z-50{z-index:50}.z-100{z-index:100}.text-left{text-align:left}.text-center{text-align:center}.text-right{text-align:right}.cursor-pointer{cursor:pointer}.cursor-default{cursor:default}.pointer-none{pointer-events:none}.hidden{display:none}.block{display:block}.inline{display:inline}.inline-flex{display:inline-flex}.rounded-full{border-radius:9999px}@keyframes anim-fade-in{0%{opacity:0}to{opacity:1}}@keyframes anim-slide-up{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}@keyframes anim-slide-in-right{0%{opacity:0;transform:translate(12px)}to{opacity:1;transform:translate(0)}}@keyframes anim-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes anim-pulse{0%,to{opacity:1}50%{opacity:.4}}@keyframes anim-bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-4px)}}@keyframes anim-shake{0%,to{transform:translate(0)}20%{transform:translate(-4px)}40%{transform:translate(4px)}60%{transform:translate(-3px)}80%{transform:translate(3px)}}@keyframes anim-pop{0%{transform:scale(1)}40%{transform:scale(1.12)}to{transform:scale(1)}}@keyframes anim-ping{0%{transform:scale(1);opacity:.8}to{transform:scale(2);opacity:0}}@keyframes anim-wiggle{0%,to{transform:rotate(0)}25%{transform:rotate(-6deg)}75%{transform:rotate(6deg)}}@keyframes anim-slide-in-left{0%{opacity:0;transform:translate(-12px)}to{opacity:1;transform:translate(0)}}@keyframes anim-slide-down{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.animate-in{animation:anim-slide-up .18s ease both}.fade-in{animation:anim-fade-in .2s ease both}.slide-in{animation:anim-slide-in-right .2s ease both}.slide-in-left{animation:anim-slide-in-left .2s ease both}.slide-down{animation:anim-slide-down .18s ease both}.animate-spin{animation:anim-spin .8s linear infinite;display:inline-flex;align-items:center;justify-content:center;transform-origin:center center;line-height:1}.animate-pulse{animation:anim-pulse 1.6s ease-in-out infinite}.animate-bounce{animation:anim-bounce .8s ease-in-out infinite}.animate-shake{animation:anim-shake .4s ease both}.animate-pop{animation:anim-pop .3s ease both}.animate-wiggle{animation:anim-wiggle .5s ease-in-out infinite}.animate-ping{position:relative}.animate-ping:before{content:"";position:absolute;inset:0;border-radius:inherit;background:currentColor;opacity:.6;animation:anim-ping 1.2s ease-out infinite}.transition{transition:all .15s ease}.transition-colors{transition:color .15s ease,background .15s ease,border-color .15s ease}.transition-transform{transition:transform .15s ease}.duration-100{transition-duration:.1s}.duration-200{transition-duration:.2s}.duration-300{transition-duration:.3s}.ease-out{transition-timing-function:ease-out}.ease-in-out{transition-timing-function:ease-in-out}@keyframes anim-morph{0%{border-radius:40% 60% 60% 40%/40% 40% 60% 60%}25%{border-radius:60% 40% 50% 50%/55% 45%}50%{border-radius:50% 50% 40% 60%/60% 40%}75%{border-radius:45% 55% 60% 40%/40% 60%}to{border-radius:40% 60% 60% 40%/40% 40% 60% 60%}}@keyframes anim-wave{0%{transform:translate(0)}to{transform:translate(-50%)}}@keyframes anim-ripple{0%{transform:scale(0);opacity:.6}to{transform:scale(3);opacity:0}}@keyframes anim-float{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}@keyframes anim-spring{0%{transform:scale(1)}30%{transform:scale(.88)}60%{transform:scale(1.1)}80%{transform:scale(.97)}to{transform:scale(1)}}@keyframes anim-reveal-up{0%{opacity:0;transform:translateY(24px);clip-path:inset(0 0 100% 0)}to{opacity:1;transform:translateY(0);clip-path:inset(0 0 0% 0)}}@keyframes anim-reveal-left{0%{opacity:0;transform:translate(-24px);clip-path:inset(0 100% 0 0)}to{opacity:1;transform:translate(0);clip-path:inset(0 0% 0 0)}}@keyframes anim-gradient-shift{0%{background-position:0% 50%}50%{background-position:100% 50%}to{background-position:0% 50%}}.animate-morph{animation:anim-morph 6s ease-in-out infinite}.animate-float{animation:anim-float 3s ease-in-out infinite}.animate-spring{animation:anim-spring .5s cubic-bezier(.34,1.56,.64,1) both}.reveal-up{animation:anim-reveal-up .5s cubic-bezier(.16,1,.3,1) both}.reveal-left{animation:anim-reveal-left .5s cubic-bezier(.16,1,.3,1) both}.animate-gradient{background-size:200% 200%;animation:anim-gradient-shift 4s ease infinite}.stagger>*{animation:anim-slide-up .3s cubic-bezier(.16,1,.3,1) both}.stagger>*:nth-child(1){animation-delay:0s}.stagger>*:nth-child(2){animation-delay:.06s}.stagger>*:nth-child(3){animation-delay:.12s}.stagger>*:nth-child(4){animation-delay:.18s}.stagger>*:nth-child(5){animation-delay:.24s}.stagger>*:nth-child(6){animation-delay:.3s}.stagger>*:nth-child(7){animation-delay:.36s}.stagger>*:nth-child(8){animation-delay:.42s}.ripple{position:relative;overflow:hidden}.ripple-dot{position:absolute;border-radius:50%;background:#ffffff40;width:80px;height:80px;margin-left:-40px;margin-top:-40px;pointer-events:none;animation:anim-ripple .5s ease-out forwards}.wave-bg{position:relative;overflow:hidden}.wave-bg:before{content:"";position:absolute;bottom:0;left:0;width:200%;height:60%;background:repeating-linear-gradient(90deg,transparent 0%,rgba(107,209,224,.06) 25%,transparent 50%);animation:anim-wave 8s linear infinite;pointer-events:none}.text-cyan{color:var(--cyan)}.text-magenta{color:var(--magenta)}.text-green{color:var(--green)}.text-blue{color:var(--blue)}.text-red{color:var(--red)}.text-orange{color:var(--orange)}.text-yellow{color:var(--yellow)}.text-teal{color:var(--teal)}.text-purple{color:var(--purple)}.text-amber{color:var(--amber)}.text-lime{color:var(--lime)}.text-emerald{color:var(--emerald)}.text-pink{color:var(--pink)}.text-muted{color:var(--fg-muted)}.text-subtle{color:var(--fg-subtle)}.text-cyan-dim{color:var(--cyan-dim)}.text-magenta-dim{color:var(--magenta-dim)}.text-green-dim{color:var(--green-dim)}.text-blue-dim{color:var(--blue-dim)}.text-red-dim{color:var(--red-dim)}.text-orange-dim{color:var(--orange-dim)}.bg-surface-cyan{background:var(--surface-cyan)}.bg-surface-magenta{background:var(--surface-magenta)}.bg-surface-green{background:var(--surface-green)}.bg-surface-blue{background:var(--surface-blue)}.bg-surface-red{background:var(--surface-red)}.bg-surface-orange{background:var(--surface-orange)}.bg-surface-yellow{background:var(--surface-yellow)}.bg-surface-teal{background:var(--surface-teal)}.bg-surface-purple{background:var(--surface-purple)}.bg-surface-amber{background:var(--surface-amber)}.bg-surface-lime{background:var(--surface-lime)}.bg-surface-emerald{background:var(--surface-emerald)}.bg-surface-pink{background:var(--surface-pink)}.p-1{padding:var(--sp-1)}.p-2{padding:var(--sp-2)}.p-3{padding:var(--sp-3)}.p-4{padding:var(--sp-4)}.p-6{padding:var(--sp-6)}.p-8{padding:var(--sp-8)}.px-2{padding-left:var(--sp-2);padding-right:var(--sp-2)}.px-3{padding-left:var(--sp-3);padding-right:var(--sp-3)}.px-4{padding-left:var(--sp-4);padding-right:var(--sp-4)}.px-6{padding-left:var(--sp-6);padding-right:var(--sp-6)}.py-1{padding-top:var(--sp-1);padding-bottom:var(--sp-1)}.py-2{padding-top:var(--sp-2);padding-bottom:var(--sp-2)}.py-3{padding-top:var(--sp-3);padding-bottom:var(--sp-3)}.py-4{padding-top:var(--sp-4);padding-bottom:var(--sp-4)}.mt-1{margin-top:var(--sp-1)}.mt-2{margin-top:var(--sp-2)}.mt-4{margin-top:var(--sp-4)}.mt-6{margin-top:var(--sp-6)}.mb-1{margin-bottom:var(--sp-1)}.mb-2{margin-bottom:var(--sp-2)}.mb-4{margin-bottom:var(--sp-4)}.mb-6{margin-bottom:var(--sp-6)}.mx-auto{margin-left:auto;margin-right:auto}.surface-paper{--paper-bg: #0d0c0b;--paper-noise: #c8b89a;--paper-noise-opacity: .055;background:var(--paper-bg);color:var(--paper-fg, var(--fg));position:relative}.surface-paper:before{content:"";position:fixed;inset:0;pointer-events:none;z-index:9998;opacity:var(--paper-noise-opacity);filter:url(#noise);background:var(--paper-noise)}.surface-glass{background:linear-gradient(160deg,#ffffff16,#ffffff08 42%,#0000001f);border:1px solid var(--border-strong);box-shadow:var(--shadow-md);position:relative;overflow:hidden}.surface-glass:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.35) 30%,rgba(255,255,255,.55) 50%,rgba(255,255,255,.35) 70%,transparent 100%);pointer-events:none}.surface-glass:after{content:"";position:absolute;inset:0;opacity:.022;filter:url(#noise);background:#fff;pointer-events:none;border-radius:inherit}.surface-dark{background:var(--bg)}.noise-overlay{position:relative;isolation:isolate}.noise-overlay:after{content:"";position:absolute;inset:0;opacity:.04;filter:url(#noise);background:#fff;pointer-events:none;z-index:1;border-radius:inherit}.glass{background:linear-gradient(160deg,#ffffff16,#ffffff08 42%,#0000001f);border:1px solid var(--border-strong);box-shadow:var(--shadow-md);position:relative;overflow:hidden}.glass:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.35) 30%,rgba(255,255,255,.55) 50%,rgba(255,255,255,.35) 70%,transparent 100%);pointer-events:none}.glass:after{content:"";position:absolute;inset:0;opacity:.022;filter:url(#noise);background:#fff;pointer-events:none;border-radius:inherit}.glass-overlay{position:absolute;inset:0;background:linear-gradient(160deg,#ffffff2e,#ffffff14,#00000040);border-top:1px solid rgba(255,255,255,.35);display:flex;flex-direction:column;overflow:hidden;isolation:isolate;color:#fff;text-shadow:0 1px 8px rgba(0,0,0,.45)}.glass-overlay .muted{color:#ffffffb3}.glass-overlay:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.5) 40%,rgba(255,255,255,.7) 50%,rgba(255,255,255,.5) 60%,transparent);pointer-events:none}.glass-overlay:after{content:"";position:absolute;inset:0;opacity:.025;filter:url(#noise);background:#fff;pointer-events:none;z-index:-1}.glass-blur{position:absolute;inset:0;backdrop-filter:blur(var(--glass-blur, 16px)) saturate(1.4);-webkit-backdrop-filter:blur(var(--glass-blur, 16px)) saturate(1.4);background:#ffffff14;border-top:1px solid rgba(255,255,255,.3);border-left:1px solid rgba(255,255,255,.15);display:flex;flex-direction:column;overflow:hidden;isolation:isolate;color:#fff;text-shadow:0 1px 6px rgba(0,0,0,.3)}.glass-blur .muted{color:#ffffffa6}.glass-blur:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.6) 40%,rgba(255,255,255,.8) 50%,rgba(255,255,255,.6) 60%,transparent);pointer-events:none}.glass-blur:after{content:"";position:absolute;inset:0;opacity:.03;filter:url(#noise);background:#fff;pointer-events:none;z-index:-1}.glass-blur.sm{--glass-blur: 8px}.glass-blur.lg{--glass-blur: 28px}.glass-blur.xl{--glass-blur: 48px}.glass-blur.dark{background:#00000040}.glass-blur.cyan{background:#6bd1e01f;border-color:#6bd1e04d}.glass-blur.warm{background:#ffa25c1f;border-color:#ffa25c4d}:root{--bg: #080a0d;--bg-1: #0d1014;--bg-2: #13171c;--bg-3: #1b2128;--fg: #ffffff;--fg-muted: #b5bdc7;--fg-subtle: #737d89;--cyan: #6bd1e0;--magenta: #e040b8;--green: #3fc763;--blue: #5964d3;--white: #ffffff;--red: #ff6060;--orange: #ffa25c;--yellow: #f8ff5c;--teal: #2ecbb4;--purple: #d74bec;--amber: #ffcc00;--lime: #a8e040;--emerald: #28c878;--pink: #ff64b5;--cyan-dim: #3d8c9a;--magenta-dim: #a82888;--green-dim: #2d8a42;--blue-dim: #3e479e;--red-dim: #cc3a3a;--orange-dim: #cc6a28;--yellow-dim: #9c9e00;--teal-dim: #1e8a78;--purple-dim: #9e2cb8;--amber-dim: #b89000;--lime-dim: #609800;--emerald-dim: #1a9055;--pink-dim: #cc3d88;--surface-cyan: rgba(107, 209, 224, .12);--surface-magenta: rgba(224, 64, 184, .12);--surface-green: rgba(63, 199, 99, .12);--surface-blue: rgba(89, 100, 211, .12);--surface-red: rgba(255, 96, 96, .12);--surface-orange: rgba(255, 162, 92, .12);--surface-yellow: rgba(248, 255, 92, .1);--surface-teal: rgba( 46, 203, 180, .12);--surface-purple: rgba(215, 75, 236, .12);--surface-amber: rgba(255, 204, 0, .12);--surface-lime: rgba(168, 224, 64, .1);--surface-emerald: rgba(40, 200, 120, .12);--surface-pink: rgba(255, 100, 181, .12);--color-primary: var(--cyan);--color-secondary: var(--magenta);--color-success: var(--green);--color-info: var(--blue);--color-danger: var(--red);--color-warning: var(--orange);--color-caution: var(--yellow);--grad-primary: linear-gradient(135deg, var(--cyan), var(--purple));--grad-alt: linear-gradient(135deg, var(--magenta), var(--orange));--grad-rainbow: linear-gradient(90deg, var(--cyan), var(--blue), var(--purple), var(--magenta));--grad-ocean: linear-gradient(135deg, var(--blue), var(--cyan), var(--emerald));--grad-aurora: linear-gradient(135deg, var(--green), var(--teal), var(--blue));--grad-forest: linear-gradient(135deg, var(--lime), var(--green), var(--emerald));--grad-fire: linear-gradient(135deg, var(--red), var(--orange), var(--yellow));--grad-sunset: linear-gradient(135deg, var(--orange), var(--magenta), var(--purple));--grad-neon: linear-gradient(135deg, var(--cyan), var(--magenta));--grad-cold: linear-gradient(135deg, var(--blue), var(--purple), var(--cyan));--grad-warm: linear-gradient(135deg, var(--amber), var(--orange), var(--red));--font-display: "Inter", sans-serif;--font-ui: "Inter", sans-serif;--font-body: "SF Pro", sans-serif;--font-label: "Helvetica Neue", sans-serif;--font-accent: "DM Sans", sans-serif;--font-tag: "Switzer", sans-serif;--font-ja: "Hiragino Sans", sans-serif;--font-ja-display: "Noto Sans JP", sans-serif;--font-mono: "Fira Code", monospace;--font-math: "CM Unicode", serif;--font-prose: "CM Unicode", serif;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-md: 1rem;--font-size-lg: 1.25rem;--font-size-xl: 1.75rem;--font-size-2xl: 2.5rem;--font-size-3xl: 4rem;--font-weight-normal: 400;--font-weight-medium: 500;--font-weight-bold: 700;--font-weight-black: 900;--sp-1: .25rem;--sp-2: .5rem;--sp-3: .75rem;--sp-4: 1rem;--sp-5: 1.25rem;--sp-6: 1.5rem;--sp-8: 2rem;--sp-12: 3rem;--sp-16: 4rem;--shadow-sm: 0 1px 2px rgba(0,0,0,.5), 0 4px 12px rgba(0,0,0,.18);--shadow-md: 0 8px 24px rgba(0,0,0,.32);--shadow-lg: 0 18px 48px rgba(0,0,0,.42);--radius: 8px;--border-color: #303944;--border-strong: #465363;--border: 1px solid var(--border-color);--border-accent: 1px solid var(--cyan);--surface-interactive: rgba(107, 209, 224, .18);--surface-interactive-hover: rgba(107, 209, 224, .32);--surface-neutral-hover: rgba(255, 255, 255, .05);--surface-highlight: rgba(255, 255, 255, .12);--surface-noise: #ffffff;--scrim: rgba(0, 0, 0, .7);--on-accent: #000000;--focus-ring: 0 0 0 3px rgba(107, 209, 224, .35)}.navbar{display:flex;align-items:center;justify-content:space-between;padding:0 var(--sp-6);height:56px;background:var(--bg-1);border-bottom:var(--border);position:sticky;top:0;z-index:100}.navbar-brand{font-family:var(--font-display);font-size:var(--font-size-lg);font-weight:var(--font-weight-black);letter-spacing:.02em;color:var(--fg);text-decoration:none}.navbar-nav{display:flex;align-items:center;gap:var(--sp-6);list-style:none}.navbar-link{font-family:var(--font-accent);font-size:var(--font-size-sm);font-weight:var(--font-weight-bold);letter-spacing:.06em;text-transform:uppercase;color:var(--fg-muted);text-decoration:none;transition:color .15s}.navbar-link:hover,.navbar-link.active{color:var(--fg)}.navbar-link.active{color:var(--cyan)}.navbar-actions{display:flex;align-items:center;gap:var(--sp-3)}.navbar-toggle{display:none;flex-direction:column;justify-content:center;gap:5px;width:2rem;height:2rem;background:none;border:none;cursor:pointer;padding:0}.navbar-toggle span{display:block;height:2px;width:100%;background:var(--fg-muted);border-radius:1px;transition:background .15s}.navbar-toggle:hover span{background:var(--fg)}@media(max-width:639px){.navbar{padding:0 var(--sp-4)}.navbar-toggle{display:flex}.navbar-nav{display:none;position:absolute;top:56px;left:0;right:0;flex-direction:column;align-items:flex-start;gap:0;background:var(--bg-1);border-bottom:var(--border);padding:var(--sp-2) 0;z-index:99}.navbar-nav .navbar-link{display:block;width:100%;padding:var(--sp-3) var(--sp-4)}.navbar.open .navbar-nav{display:flex}.navbar-actions{gap:var(--sp-2)}.navbar-actions .btn{padding:var(--sp-1) var(--sp-3);font-size:var(--font-size-xs)}}.sidebar{width:240px;height:100vh;background:var(--bg-1);border-right:var(--border);display:flex;flex-direction:column;padding:var(--sp-4) 0;position:sticky;top:0;overflow-y:auto}.sidebar-section{padding:var(--sp-4) var(--sp-4) var(--sp-2)}.sidebar-label{font-family:var(--font-accent);font-size:var(--font-size-xs);font-weight:var(--font-weight-bold);letter-spacing:.1em;text-transform:uppercase;color:var(--fg-subtle);padding:0 var(--sp-3);margin-bottom:var(--sp-1)}.sidebar-item{display:flex;align-items:center;gap:var(--sp-3);padding:var(--sp-2) var(--sp-3);font-family:var(--font-ui);font-size:var(--font-size-sm);color:var(--fg-muted);text-decoration:none;border-radius:var(--radius);transition:background .1s,color .1s;cursor:pointer}.sidebar-item:hover{background:var(--bg-2);color:var(--fg)}.sidebar-item.active{background:var(--bg-2);color:var(--cyan);border-left:2px solid var(--cyan);padding-left:calc(var(--sp-3) - 2px)}.sidebar-divider{height:1px;background:var(--fg-subtle);margin:var(--sp-2) var(--sp-3)}.app-shell{display:grid;grid-template-columns:240px 1fr;min-height:100vh}.app-main{padding:var(--sp-8);overflow-y:auto}@media(max-width:767px){.app-shell{grid-template-columns:1fr}.sidebar{position:fixed;top:0;left:0;height:100vh;width:280px;transform:translate(-100%);transition:transform .25s ease;z-index:200;box-shadow:var(--shadow-lg, 4px 0 24px rgba(0,0,0,.5))}.sidebar.open{transform:translate(0)}.sidebar-backdrop{display:none;position:fixed;inset:0;background:#00000080;z-index:199}.sidebar.open~.sidebar-backdrop,.sidebar-backdrop.open{display:block}.app-main{padding:var(--sp-4)}}.toolbar{display:flex;align-items:center;gap:var(--sp-1);padding:var(--sp-2) var(--sp-3);background:var(--bg-2);border-bottom:var(--border)}.toolbar.top{border-bottom:var(--border);border-top:none}.toolbar.bottom{border-top:var(--border);border-bottom:none}.toolbar.side{flex-direction:column;border-bottom:none;border-right:var(--border);padding:var(--sp-3) var(--sp-2)}.toolbar-sep{flex:1}.toolbar-divider{width:1px;height:1.25rem;background:var(--fg-subtle);margin:0 var(--sp-1);flex-shrink:0}.toolbar.side .toolbar-divider{width:1.25rem;height:1px;margin:var(--sp-1) 0}.tool-btn{display:flex;align-items:center;justify-content:center;width:2rem;height:2rem;border:none;border-radius:var(--radius);background:transparent;color:var(--fg-muted);cursor:pointer;font-size:var(--font-size-md);transition:background .1s,color .1s;flex-shrink:0;padding:0}.tool-btn:hover{background:var(--bg-3);color:var(--fg)}.tool-btn.active{background:#38bdf826;color:var(--cyan)}.tool-btn.danger:hover{color:var(--red)}.tool-btn-label{height:2rem;padding:0 var(--sp-3);width:auto;gap:var(--sp-2);font-family:var(--font-ui);font-size:var(--font-size-xs);letter-spacing:.04em}.app-shell-3{display:grid;grid-template-columns:auto 1fr auto;grid-template-rows:1fr;height:100%;overflow:hidden}.app-panel{background:var(--bg-2);border-right:var(--border);overflow-y:auto;overflow-x:hidden;display:flex;flex-direction:column}.app-panel:last-child{border-right:none;border-left:var(--border)}.app-panel-header{display:flex;align-items:center;justify-content:space-between;padding:var(--sp-3) var(--sp-4);border-bottom:var(--border);font-family:var(--font-accent);font-size:var(--font-size-xs);letter-spacing:.08em;text-transform:uppercase;color:var(--fg-subtle);flex-shrink:0}.tile-grid{display:grid;gap:2px;padding:var(--sp-2)}.tile-grid.cols-4{grid-template-columns:repeat(4,1fr)}.tile-grid.cols-6{grid-template-columns:repeat(6,1fr)}.tile-grid.cols-8{grid-template-columns:repeat(8,1fr)}.tile-grid.cols-auto{grid-template-columns:repeat(auto-fill,minmax(2rem,1fr))}.tile{aspect-ratio:1;border:1px solid transparent;border-radius:4px;cursor:pointer;background:var(--bg-3);display:flex;align-items:center;justify-content:center;font-size:var(--font-size-sm);color:var(--fg-muted);transition:border-color .1s,background .1s;-webkit-user-select:none;user-select:none}.tile:hover{border-color:var(--fg-muted);background:var(--bg-2);color:var(--fg)}.tile.active{border-color:var(--cyan);background:#38bdf81f;color:var(--cyan)}.tile.selected{border-color:var(--magenta);box-shadow:0 0 0 1px var(--magenta)}.slides{position:relative;width:100%;overflow:hidden;background:var(--bg);border:var(--border);border-radius:var(--radius);aspect-ratio:16 / 9}.slide{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:center;padding:10%;opacity:0;pointer-events:none;transition:opacity .4s ease}.slide.active{opacity:1;pointer-events:auto}.slide-center{align-items:center;text-align:center}.slide-split{flex-direction:row;align-items:center;gap:8%}.slide-split>*{flex:1}.slide-eyebrow{font-family:var(--font-accent);font-size:.75rem;letter-spacing:.12em;text-transform:uppercase;color:var(--cyan);margin-bottom:.75rem}.slide-title{font-family:var(--font-display);font-size:clamp(1.75rem,4vw,3.5rem);font-weight:900;line-height:1.1;margin-bottom:1rem}.slide-body{font-family:var(--font-body);font-size:clamp(.9rem,1.5vw,1.15rem);color:var(--fg-muted);line-height:1.65;max-width:56ch}.slides-nav{position:absolute;bottom:1.25rem;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:.5rem;z-index:10}.slides-dot{width:6px;height:6px;border-radius:50%;background:var(--fg-subtle);border:none;cursor:pointer;transition:background .2s,transform .2s;padding:0}.slides-dot.active{background:var(--cyan);transform:scale(1.4)}.slides-prev,.slides-next{position:absolute;top:50%;transform:translateY(-50%);z-index:10;background:#ffffff0d;border:var(--border);color:var(--fg-muted);width:2.5rem;height:2.5rem;border-radius:var(--radius);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1.1rem;transition:background .15s,color .15s}.slides-prev{left:1rem}.slides-next{right:1rem}.slides-prev:hover,.slides-next:hover{background:#ffffff1a;color:var(--fg)}.slides-counter{position:absolute;top:1rem;right:1.25rem;font-family:var(--font-accent);font-size:.7rem;letter-spacing:.1em;color:var(--fg-subtle)}.slide:after{content:"";position:absolute;bottom:0;left:0;right:0;height:2px;background:var(--grad-primary);opacity:0;transition:opacity .4s}.slide.active:after{opacity:1}.slides-fade .slide{transition:opacity .45s ease}.slides-slide .slide{transition:opacity .35s ease,transform .35s cubic-bezier(.4,0,.2,1);transform:translate(100%);opacity:0}.slides-slide .slide.active{transform:translate(0);opacity:1}.slides-slide .slide.prev{transform:translate(-100%);opacity:0}.slides-zoom .slide{transition:opacity .4s ease,transform .4s cubic-bezier(.16,1,.3,1);transform:scale(.94);opacity:0}.slides-zoom .slide.active{transform:scale(1);opacity:1}.slides-flip{perspective:1200px}.slides-flip .slide{transition:opacity .5s ease,transform .5s ease;transform:rotateY(-15deg) scale(.95);opacity:0}.slides-flip .slide.active{transform:rotateY(0) scale(1);opacity:1}.slides-fullscreen{position:fixed;inset:0;z-index:9000;border-radius:0;border:none;aspect-ratio:unset;background:var(--bg)}.slides-fullscreen .slides-prev{left:2rem}.slides-fullscreen .slides-next{right:2rem}.slides-exit{position:absolute;top:1.25rem;left:1.25rem;z-index:10;background:#ffffff0f;border:var(--border);color:var(--fg-muted);padding:.3rem .7rem;border-radius:var(--radius);font-size:var(--font-size-xs);cursor:pointer;transition:background .15s;display:none}.slides-fullscreen .slides-exit{display:block}.slide-notes{display:none;position:absolute;bottom:3.5rem;left:10%;right:10%;font-size:.7rem;color:var(--fg-subtle);font-family:var(--font-body);text-align:left;border-top:1px solid var(--fg-subtle);padding-top:var(--sp-2)}.slides-fullscreen .slide-notes{display:block}.table-wrap{width:100%;overflow-x:auto;border:var(--border);border-radius:var(--radius)}table,.table{width:100%;border-collapse:collapse;font-family:var(--font-ui);font-size:var(--font-size-sm)}thead th{font-family:var(--font-accent);font-size:var(--font-size-xs);font-weight:var(--font-weight-bold);letter-spacing:.08em;text-transform:uppercase;color:var(--fg-muted);text-align:left;padding:var(--sp-3) var(--sp-4);border-bottom:var(--border);background:var(--bg-1)}tbody td{padding:var(--sp-3) var(--sp-4);color:var(--fg);border-bottom:1px solid var(--bg-3)}tbody tr:last-child td{border-bottom:none}tbody tr:hover td{background:var(--bg-2)}td.num,th.num{text-align:right;font-family:var(--font-mono);letter-spacing:0}td.status{white-space:nowrap}.stat{display:flex;flex-direction:column;gap:var(--sp-1);padding:var(--sp-6);background:var(--bg-2);border:var(--border);border-radius:var(--radius);position:relative;overflow:hidden}.stat:after{content:"";position:absolute;inset:0;opacity:.018;filter:url(#noise);background:#fff;pointer-events:none;border-radius:var(--radius)}.stat-label{font-family:var(--font-accent);font-size:var(--font-size-xs);font-weight:var(--font-weight-bold);letter-spacing:.08em;text-transform:uppercase;color:var(--fg-muted)}.stat-value{font-family:var(--font-display);font-size:var(--font-size-3xl);font-weight:var(--font-weight-black);letter-spacing:.01em;line-height:1;color:var(--fg)}.stat-value.grad{background:var(--grad-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.stat-sub{font-family:var(--font-body);font-size:var(--font-size-sm);color:var(--fg-muted)}.stat-accent{border-left:3px solid var(--cyan)}.tabs{display:flex;flex-direction:column}.tabs-list{display:flex;border-bottom:var(--border);gap:0}.tab{font-family:var(--font-ui);font-size:var(--font-size-sm);font-weight:var(--font-weight-bold);letter-spacing:.04em;color:var(--fg-muted);padding:var(--sp-2) var(--sp-4);background:none;border:none;border-bottom:2px solid transparent;cursor:pointer;transition:color .15s,border-color .15s;margin-bottom:-1px}.tab:hover{color:var(--fg)}.tab.active,.tab[aria-selected=true]{color:var(--cyan);border-bottom-color:var(--cyan)}.tab-panel{padding:var(--sp-6) 0;display:none}.tab-panel.active{display:block}.tab-panel:not(.active){visibility:hidden}.accordion{display:flex;flex-direction:column;border:var(--border);border-radius:var(--radius);overflow:hidden}.accordion-item{border-bottom:var(--border)}.accordion-item:last-child{border-bottom:none}.accordion-trigger{width:100%;display:flex;align-items:center;justify-content:space-between;padding:var(--sp-4) var(--sp-4);background:var(--bg-2);border:none;color:var(--fg);font-family:var(--font-label);font-size:var(--font-size-md);font-weight:var(--font-weight-bold);cursor:pointer;transition:background .1s;text-align:left}.accordion-trigger:hover{background:var(--bg-3)}.accordion-trigger:after{content:"+";font-size:var(--font-size-lg);color:var(--fg-muted);transition:transform .2s}.accordion-item.open .accordion-trigger:after{transform:rotate(45deg)}.accordion-content{display:grid;grid-template-rows:0fr;transition:grid-template-rows .28s cubic-bezier(.16,1,.3,1);background:var(--bg-1)}.accordion-content-inner{overflow:hidden;padding:0 var(--sp-4);font-family:var(--font-body);font-size:var(--font-size-md);color:var(--fg-muted);line-height:1.6;transition:padding .28s cubic-bezier(.16,1,.3,1)}.accordion-item.open .accordion-content{grid-template-rows:1fr}.accordion-item.open .accordion-content-inner{padding:var(--sp-4)}.progress{width:100%;height:6px;background:var(--bg-3);border-radius:3px;overflow:hidden}.progress-fill{height:100%;border-radius:3px;background:var(--cyan);transition:width .4s ease}.progress-fill.magenta{background:var(--magenta)}.progress-fill.green{background:var(--green)}.progress-fill.blue{background:var(--blue)}.progress-fill.red{background:var(--red)}.progress-fill.orange{background:var(--orange)}.progress-fill.yellow{background:var(--yellow)}.progress-fill.grad{background:var(--grad-primary)}.progress.sm{height:3px}.progress.md{height:6px}.progress.lg{height:10px}.progress.xl{height:16px;border-radius:var(--radius)}.progress-labeled{display:flex;flex-direction:column;gap:var(--sp-1)}.progress-header{display:flex;justify-content:space-between;align-items:baseline}.progress-title{font-family:var(--font-ui);font-size:var(--font-size-xs);letter-spacing:.06em;text-transform:uppercase;color:var(--fg-muted)}.progress-value{font-family:var(--font-mono);font-size:var(--font-size-xs);color:var(--fg-muted)}@keyframes progress-stripe{0%{background-position:0 0}to{background-position:24px 0}}.progress-fill.striped{background-image:repeating-linear-gradient(-45deg,transparent,transparent 6px,rgba(255,255,255,.08) 6px,rgba(255,255,255,.08) 12px);background-size:24px 100%;animation:progress-stripe .6s linear infinite}.bar-chart{display:flex;align-items:flex-end;gap:var(--sp-2);height:10rem;padding-bottom:1.75rem;position:relative}.bar-chart-grid{background-image:repeating-linear-gradient(to top,var(--fg-subtle) 0px,var(--fg-subtle) 1px,transparent 1px,transparent 25%)}.bar-col{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;height:100%;position:relative}.bar-fill{width:100%;height:var(--val, 50%);background:var(--bar-color, var(--cyan));border-radius:var(--radius) var(--radius) 0 0;transition:height .4s cubic-bezier(.4,0,.2,1);position:relative}.bar-fill:after{content:attr(data-val);position:absolute;top:-1.4rem;left:50%;transform:translate(-50%);font-size:var(--font-size-xs);color:var(--fg-muted);white-space:nowrap;opacity:0;transition:opacity .15s}.bar-fill:hover:after{opacity:1}.bar-label{position:absolute;bottom:-1.5rem;font-size:var(--font-size-xs);color:var(--fg-muted);white-space:nowrap}.bar-col.cyan{--bar-color: var(--cyan)}.bar-col.magenta{--bar-color: var(--magenta)}.bar-col.green{--bar-color: var(--green)}.bar-col.blue{--bar-color: var(--blue)}.bar-col.orange{--bar-color: var(--orange)}.bar-col.red{--bar-color: var(--red)}.bar-col.purple{--bar-color: var(--purple)}.bar-col.amber{--bar-color: var(--amber)}.bar-chart-h{display:flex;flex-direction:column;gap:var(--sp-3)}.bar-row{display:flex;align-items:center;gap:var(--sp-3)}.bar-row .bar-label{position:static;width:5rem;flex-shrink:0;text-align:right;font-size:var(--font-size-sm);color:var(--fg-muted)}.bar-track{flex:1;height:.5rem;background:var(--bg-3);border-radius:99px;overflow:hidden}.bar-row .bar-fill{width:var(--val, 50%);height:100%;border-radius:99px;transition:width .4s cubic-bezier(.4,0,.2,1)}.bar-row .bar-fill:after{display:none}.bar-val{width:2.5rem;flex-shrink:0;font-size:var(--font-size-xs);color:var(--fg-muted);font-family:var(--font-mono)}.line-chart-wrap{position:relative;width:100%;background:var(--bg-2);border:var(--border);border-radius:var(--radius);overflow:hidden}.line-chart{display:block;width:100%;height:auto}.chart-line{fill:none;stroke:var(--chart-color, var(--cyan));stroke-width:2;stroke-linecap:round;stroke-linejoin:round}.chart-area{fill:var(--chart-color, var(--cyan));opacity:.12}.chart-grid-line{stroke:var(--fg-subtle);stroke-width:.5}.chart-cursor{stroke:var(--green);stroke-width:1.5;stroke-dasharray:3 2}.chart-dot{fill:var(--chart-color, var(--cyan))}.chart-dot-outline{fill:var(--bg);stroke:var(--chart-color, var(--cyan));stroke-width:2}.chart-axis-label{fill:var(--fg-muted);font-size:8px;font-family:var(--font-mono)}.line-chart-wrap.cyan{--chart-color: var(--cyan)}.line-chart-wrap.magenta{--chart-color: var(--magenta)}.line-chart-wrap.green{--chart-color: var(--green)}.line-chart-wrap.blue{--chart-color: var(--blue)}.line-chart-wrap.purple{--chart-color: var(--purple)}.line-chart-wrap.orange{--chart-color: var(--orange)}.line-chart-wrap.amber{--chart-color: var(--amber)}.radial-progress{width:5rem;height:5rem;transform:rotate(-90deg)}.radial-track{fill:none;stroke:var(--bg-3);stroke-width:3}.radial-fill{fill:none;stroke:var(--radial-color, var(--cyan));stroke-width:3;stroke-linecap:round;stroke-dasharray:calc(var(--val, 0) * 100) 100;transition:stroke-dasharray .5s cubic-bezier(.4,0,.2,1)}.radial-text{fill:var(--fg);font-size:7px;font-family:var(--font-ui);font-weight:var(--font-weight-bold);text-anchor:middle;transform:rotate(90deg);transform-origin:center}.radial-progress.sm{width:3rem;height:3rem}.radial-progress.lg{width:7rem;height:7rem}.radial-progress.xl{width:9rem;height:9rem}.radial-progress.cyan{--radial-color: var(--cyan)}.radial-progress.magenta{--radial-color: var(--magenta)}.radial-progress.green{--radial-color: var(--green)}.radial-progress.blue{--radial-color: var(--blue)}.radial-progress.orange{--radial-color: var(--orange)}.radial-progress.red{--radial-color: var(--red)}.radial-progress.amber{--radial-color: var(--amber)}.eval-bar{height:.375rem;border-radius:99px;background:var(--bg-3);overflow:hidden;flex-shrink:0}.eval-fill{height:100%;width:var(--white-pct, 50%);background:#eeeed2;transition:width .3s ease}.eval-bar.vertical{width:.375rem;height:100%;display:flex;flex-direction:column;border-radius:99px}.eval-bar.vertical .eval-fill{width:100%;height:var(--white-pct, 50%);order:1}.sparkline-wrap{display:inline-flex;align-items:center;gap:var(--sp-2)}.sparkline{display:inline-block;vertical-align:middle;width:3.75rem;height:1.25rem;overflow:visible}.sparkline-line{fill:none;stroke:var(--sparkline-color, var(--cyan));stroke-width:1.5;stroke-linecap:round;stroke-linejoin:round}.sparkline-dot{fill:var(--sparkline-color, var(--cyan))}.sparkline-val{font-size:var(--font-size-xs);font-family:var(--font-mono);color:var(--fg-muted)}.sparkline-wrap.up{--sparkline-color: var(--green)}.sparkline-wrap.up .sparkline-val{color:var(--green)}.sparkline-wrap.down{--sparkline-color: var(--red)}.sparkline-wrap.down .sparkline-val{color:var(--red)}.annotated{position:relative;display:inline-block;vertical-align:top;line-height:1.4;cursor:default}.annotated[data-note]:after{content:attr(data-note);display:block;font-family:var(--font-ui);font-size:.58em;line-height:1.2;color:var(--cyan);text-align:center;white-space:nowrap;margin-top:.15em;pointer-events:none;-webkit-user-select:none;user-select:none;letter-spacing:0}ruby{ruby-position:over}rt{font-family:var(--font-ui);font-size:.55em;color:var(--fg-muted);text-align:center;line-height:1.2}.word-token{display:inline-block;vertical-align:top;cursor:pointer;border-radius:3px;transition:background .1s;padding:0 1px}.word-token.known{color:var(--fg)}.word-token.known:hover{background:#ffffff0d;color:var(--fg-muted)}.word-token.unknown{color:var(--cyan);font-weight:var(--font-weight-bold)}.word-token.unknown:hover{background:#38bdf81a}.word-token.active{background:#38bdf826}.word-token[data-trans]:after{content:attr(data-trans);display:block;font-size:.58em;line-height:1.2;color:#38bdf8bf;text-align:center;white-space:nowrap;margin-top:.1em;font-weight:400;pointer-events:none;-webkit-user-select:none;user-select:none}.reading-text{font-family:var(--font-body);font-size:var(--font-size-lg);line-height:2.2;color:var(--fg);text-align:justify;word-break:break-word}mark,.mark{background:#cdb30040;color:var(--fg);border-radius:2px;padding:0 2px}.mark-cyan{background:#38bdf833;color:var(--cyan)}.mark-magenta{background:#e879f933;color:var(--magenta)}.mark-green{background:#4ade8033;color:var(--green)}.mark-red{background:#ff606033;color:var(--red)}.prose{font-family:var(--font-prose);font-size:1.05rem;line-height:1.8;color:var(--fg);max-width:68ch}.prose h1,.prose h2,.prose h3,.prose h4{font-family:var(--font-display);margin-top:2em;margin-bottom:.5em;line-height:1.25}.prose h1{font-size:2rem}.prose h2{font-size:1.5rem;color:var(--fg-muted)}.prose h3{font-size:1.15rem}.prose h4{font-size:1rem;text-transform:uppercase;letter-spacing:.06em}.prose p{margin-bottom:1.25em}.prose a{color:var(--cyan);text-decoration:none;border-bottom:1px solid rgba(56,189,248,.35);transition:border-color .15s}.prose a:hover{border-bottom-color:var(--cyan)}.prose strong{color:var(--fg);font-weight:700}.prose em{color:var(--fg-muted)}.prose code{font-family:var(--font-mono);font-size:.88em;background:var(--bg-3);padding:.15em .45em;border-radius:4px;color:var(--cyan)}.prose pre{background:var(--bg-2);border:var(--border);border-radius:var(--radius);padding:1.25rem 1.5rem;overflow-x:auto;margin:1.5em 0}.prose pre code{background:none;padding:0;font-size:.9rem;color:var(--fg)}.prose blockquote{border-left:3px solid var(--cyan);padding:.5em 1.25em;margin:1.5em 0;color:var(--fg-muted);font-style:italic}.prose ul,.prose ol{padding-left:1.75em;margin-bottom:1.25em}.prose li{margin-bottom:.4em}.prose ul li::marker{color:var(--cyan)}.prose ol li::marker{color:var(--fg-muted)}.prose hr{border:none;height:1px;background:var(--fg-subtle);margin:2.5em 0}.prose table{width:100%;border-collapse:collapse;margin:1.5em 0;font-size:.9em}.prose th{text-align:left;font-family:var(--font-ui);font-size:.75rem;letter-spacing:.06em;text-transform:uppercase;color:var(--fg-muted);border-bottom:var(--border);padding:.5em .75em}.prose td{padding:.6em .75em;border-bottom:1px solid rgba(68,68,68,.4)}.hud{position:absolute;inset:0;pointer-events:none;font-family:var(--font-ui)}.hud-tl{position:absolute;top:1rem;left:1rem}.hud-tr{position:absolute;top:1rem;right:1rem}.hud-bl{position:absolute;bottom:1rem;left:1rem}.hud-br{position:absolute;bottom:1rem;right:1rem}.hud-tc{position:absolute;top:1rem;left:50%;transform:translate(-50%)}.hud-bc{position:absolute;bottom:1rem;left:50%;transform:translate(-50%)}.score{display:flex;flex-direction:column;align-items:flex-start}.score-label{font-size:.6rem;letter-spacing:.14em;text-transform:uppercase;color:var(--fg-subtle)}.score-value{font-size:2rem;font-weight:900;line-height:1;color:var(--fg);letter-spacing:.04em}.score-value.flash{color:var(--cyan);text-shadow:0 0 12px rgba(56,189,248,.6)}.health-bar{width:160px;height:6px;background:var(--bg-3);border-radius:3px;overflow:hidden}.health-bar-fill{height:100%;background:var(--green);border-radius:3px;transition:width .3s,background .3s}.health-bar-fill.warn{background:#facc15}.health-bar-fill.crit{background:var(--magenta)}.minimap{width:140px;aspect-ratio:1;background:#0009;border:1px solid var(--fg-subtle);border-radius:4px;position:relative;overflow:hidden}.minimap-dot{position:absolute;width:6px;height:6px;border-radius:50%;transform:translate(-50%,-50%);background:var(--fg-muted)}.minimap-dot.player{background:var(--cyan);box-shadow:0 0 6px #38bdf8cc;z-index:2}.minimap-dot.enemy{background:var(--magenta)}.minimap-dot.item{background:var(--green)}.game-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;position:absolute;inset:0;background:#000000d1;-webkit-backdrop-filter:none;backdrop-filter:none;z-index:100}.game-title{font-family:var(--font-display);font-size:3.5rem;font-weight:900;letter-spacing:.06em;line-height:1;margin-bottom:.5rem}.game-subtitle{font-family:var(--font-accent);font-size:.8rem;letter-spacing:.18em;text-transform:uppercase;color:var(--fg-muted);margin-bottom:2.5rem}.item-slot{width:3rem;height:3rem;background:var(--bg-2);border:var(--border);border-radius:var(--radius);display:flex;align-items:center;justify-content:center;font-size:1.5rem;position:relative;cursor:pointer;transition:border-color .1s}.item-slot:hover{border-color:var(--fg-muted)}.item-slot.active{border-color:var(--cyan);box-shadow:0 0 8px #38bdf84d}.item-slot .item-count{position:absolute;bottom:2px;right:4px;font-size:.6rem;font-family:var(--font-mono);color:var(--fg-muted)}.hotbar{display:flex;gap:.5rem;padding:.5rem;background:#00000080;border:var(--border);border-radius:var(--radius)}.event-log{display:flex;flex-direction:column-reverse;gap:.25rem;max-width:260px}.event-entry{font-size:.75rem;font-family:var(--font-ui);color:var(--fg-muted);opacity:.8;line-height:1.4}.event-entry.good{color:var(--green)}.event-entry.bad{color:var(--magenta)}.event-entry.info{color:var(--cyan)}.toast-container{position:fixed;bottom:var(--sp-6);right:var(--sp-6);display:flex;flex-direction:column;gap:var(--sp-3);z-index:9999}.toast{display:flex;align-items:center;gap:var(--sp-3);padding:var(--sp-3) var(--sp-4);background:var(--bg-2);border:var(--border);border-radius:var(--radius);font-family:var(--font-ui);font-size:var(--font-size-sm);color:var(--fg);min-width:260px;max-width:400px;box-shadow:var(--shadow-md, 0 4px 24px rgba(0,0,0,.4));animation:toast-in .2s ease}.toast-info{border-left:3px solid var(--cyan)}.toast-success{border-left:3px solid var(--green)}.toast-error{border-left:3px solid var(--magenta)}.toast-warn{border-left:3px solid var(--blue)}.toast-msg{flex:1;line-height:1.4}.toast-close{background:none;border:none;color:var(--fg-muted);cursor:pointer;font-size:var(--font-size-lg);line-height:1;padding:0;transition:color .1s}.toast-close:hover{color:var(--fg)}@keyframes toast-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.modal-backdrop{position:fixed;inset:0;background:var(--scrim);display:flex;align-items:center;justify-content:center;z-index:1000;animation:backdrop-in .15s ease}.modal{background:var(--bg-2);border:var(--border);border-radius:var(--radius);padding:var(--sp-8);width:100%;max-width:480px;position:relative;overflow:hidden;animation:modal-in .2s ease}.modal:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--surface-highlight),transparent);pointer-events:none}.modal-title{font-family:var(--font-display);font-size:var(--font-size-xl);font-weight:var(--font-weight-black);letter-spacing:.01em;margin-bottom:var(--sp-3)}.modal-body{font-family:var(--font-body);font-size:var(--font-size-md);color:var(--fg-muted);line-height:1.6;margin-bottom:var(--sp-6)}.modal-actions{display:flex;justify-content:flex-end;gap:var(--sp-3)}.modal-close{position:absolute;top:var(--sp-4);right:var(--sp-4);background:none;border:none;color:var(--fg-muted);cursor:pointer;font-size:var(--font-size-xl);line-height:1;padding:0;transition:color .1s}.modal-close:hover{color:var(--fg)}@keyframes backdrop-in{0%{opacity:0}to{opacity:1}}@keyframes modal-in{0%{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}@keyframes skeleton-shimmer{0%{background-position:-400px 0}to{background-position:400px 0}}.skeleton{background:linear-gradient(90deg,var(--bg-2) 25%,var(--bg-3) 50%,var(--bg-2) 75%);background-size:800px 100%;animation:skeleton-shimmer 1.4s infinite linear;border-radius:var(--radius)}.skeleton-text{height:1em;margin-bottom:.5em}.skeleton-text.w-full{width:100%}.skeleton-text.w-3-4{width:75%}.skeleton-text.w-1-2{width:50%}.skeleton-text.w-1-3{width:33%}.skeleton-title{height:1.5em;width:60%;margin-bottom:.75em}.skeleton-avatar{width:2.5rem;height:2.5rem;border-radius:50%;flex-shrink:0}.skeleton-thumb{width:100%;aspect-ratio:16 / 9;border-radius:var(--radius)}.skeleton-btn{height:2rem;width:6rem;border-radius:var(--radius)}.popover-anchor{position:relative;display:inline-block}.popover{position:absolute;z-index:300;min-width:180px;background:var(--bg-2);border:var(--border);border-radius:var(--radius);box-shadow:var(--shadow-lg, 0 8px 24px rgba(0,0,0,.5));padding:var(--sp-3);font-family:var(--font-ui);font-size:var(--font-size-sm);color:var(--fg);opacity:0;pointer-events:none;transform:translateY(-4px);transition:opacity .12s ease,transform .12s ease}.popover-anchor.open .popover,.popover-anchor:focus-within .popover{opacity:1;pointer-events:auto;transform:translateY(0)}.popover{top:calc(100% + var(--sp-2));left:0}.popover.popover-top{top:auto;bottom:calc(100% + var(--sp-2));transform:translateY(4px)}.popover-anchor.open .popover.popover-top{transform:translateY(0)}.popover.popover-right{top:0;left:calc(100% + var(--sp-2));transform:translate(-4px) translateY(0)}.popover-anchor.open .popover.popover-right{transform:translate(0)}.popover.popover-left{top:0;right:calc(100% + var(--sp-2));left:auto;transform:translate(4px) translateY(0)}.popover-anchor.open .popover.popover-left{transform:translate(0)}.popover:before{content:"";position:absolute;width:8px;height:8px;background:var(--bg-2);border-left:var(--border);border-top:var(--border);top:-5px;left:var(--sp-4);transform:rotate(45deg)}.popover.popover-top:before{top:auto;bottom:-5px;transform:rotate(225deg)}.popover.popover-right:before{top:var(--sp-3);left:-5px;transform:rotate(-45deg)}.popover.popover-left:before{top:var(--sp-3);left:auto;right:-5px;transform:rotate(135deg)}.popover-title{font-weight:var(--font-weight-bold);color:var(--fg);margin-bottom:var(--sp-2);padding-bottom:var(--sp-2);border-bottom:var(--border)}.popover-body{color:var(--fg-muted);line-height:1.5}.popover-actions{display:flex;gap:var(--sp-2);margin-top:var(--sp-3);padding-top:var(--sp-2);border-top:var(--border)}.popover-menu{padding:var(--sp-1) 0;min-width:200px}.popover-menu-item{display:flex;align-items:center;gap:var(--sp-2);padding:var(--sp-2) var(--sp-3);font-family:var(--font-ui);font-size:var(--font-size-sm);color:var(--fg-muted);cursor:pointer;background:none;border:none;width:100%;text-align:left;transition:background .1s,color .1s}.popover-menu-item:hover{background:var(--bg-3);color:var(--fg)}.popover-menu-item.danger:hover{color:var(--red)}.popover-menu-label{font-family:var(--font-accent);font-size:var(--font-size-xs);letter-spacing:.08em;text-transform:uppercase;color:var(--fg-subtle);padding:var(--sp-2) var(--sp-3) var(--sp-1)}.popover-menu-divider{height:1px;background:var(--fg-subtle);margin:var(--sp-1) 0}.tooltip{position:relative;display:inline-block}.tooltip:after{content:attr(data-tip);position:absolute;bottom:calc(100% + 6px);left:50%;transform:translate(-50%);background:var(--bg-3);border:var(--border);color:var(--fg);font-family:var(--font-ui);font-size:var(--font-size-xs);white-space:nowrap;padding:var(--sp-1) var(--sp-2);border-radius:var(--radius);pointer-events:none;opacity:0;transition:opacity .15s;z-index:400}.tooltip:hover:after{opacity:1}.select{appearance:none;width:100%;padding:var(--sp-2) var(--sp-8) var(--sp-2) var(--sp-4);background:var(--bg-2) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23888' d='M6 8L1 3h10z'/%3E%3C/svg%3E") no-repeat right var(--sp-3) center;border:var(--border);border-radius:var(--radius);color:var(--fg);font-family:var(--font-ui);font-size:var(--font-size-md);cursor:pointer;outline:none;transition:border-color .15s}.select:focus{border-color:var(--cyan)}.checkbox,.radio{display:flex;align-items:center;gap:var(--sp-2);font-family:var(--font-ui);font-size:var(--font-size-sm);color:var(--fg);cursor:pointer}.checkbox input[type=checkbox],.radio input[type=radio]{appearance:none;width:16px;height:16px;border:var(--border);border-radius:2px;background:var(--bg-2);cursor:pointer;transition:border-color .15s,background .15s;flex-shrink:0}.checkbox input[type=checkbox]:focus-visible,.radio input[type=radio]:focus-visible{outline:2px solid var(--cyan);outline-offset:2px;box-shadow:var(--focus-ring)}.radio input[type=radio]{border-radius:50%}.checkbox input[type=checkbox]:checked,.radio input[type=radio]:checked{background:var(--cyan);border-color:var(--cyan)}.toggle{display:flex;align-items:center;gap:var(--sp-3);font-family:var(--font-ui);font-size:var(--font-size-sm);cursor:pointer}.toggle-track{width:36px;height:20px;background:var(--bg-3);border:var(--border);border-radius:999px;position:relative;transition:background .15s,border-color .15s;flex-shrink:0}.toggle-track:after{content:"";position:absolute;top:3px;left:3px;width:12px;height:12px;background:var(--fg-muted);border-radius:50%;transition:transform .15s,background .15s}.toggle input:checked+.toggle-track{background:var(--cyan);border-color:var(--cyan)}.toggle input:checked+.toggle-track:after{transform:translate(16px);background:var(--bg)}.toggle input{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.toggle input:focus-visible+.toggle-track{outline:2px solid var(--cyan);outline-offset:2px;box-shadow:var(--focus-ring)}.slider{-webkit-appearance:none;appearance:none;width:100%;height:4px;background:var(--bg-3);border-radius:99px;outline:none;cursor:pointer;transition:opacity .15s}.slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:16px;height:16px;border-radius:50%;background:var(--slider-color, var(--cyan));cursor:pointer;transition:transform .15s,box-shadow .15s;box-shadow:0 0 #6bd1e04d}.slider::-moz-range-thumb{width:16px;height:16px;border:none;border-radius:50%;background:var(--slider-color, var(--cyan));cursor:pointer}.slider::-webkit-slider-thumb:hover{transform:scale(1.25);box-shadow:0 0 0 4px #6bd1e033}.slider:focus::-webkit-slider-thumb{box-shadow:0 0 0 4px #6bd1e04d}.slider.filled{background:linear-gradient(to right,var(--slider-color, var(--cyan)) 0%,var(--slider-color, var(--cyan)) var(--pct, 50%),var(--bg-3) var(--pct, 50%),var(--bg-3) 100%)}.slider.magenta{--slider-color: var(--magenta)}.slider.green{--slider-color: var(--green)}.slider.orange{--slider-color: var(--orange)}.slider.purple{--slider-color: var(--purple)}.slider.red{--slider-color: var(--red)}.slider.sm{height:2px}.slider.sm::-webkit-slider-thumb{width:12px;height:12px}.slider.lg{height:6px}.slider.lg::-webkit-slider-thumb{width:20px;height:20px}.number-input{display:inline-flex;align-items:center;border:var(--border);border-radius:var(--radius);background:var(--bg-2);overflow:hidden;height:2.25rem}.number-input input[type=number]{width:3ch;padding:0;text-align:center;border:none;border-left:var(--border);border-right:var(--border);background:transparent;color:var(--fg);font-family:var(--font-mono);font-size:var(--font-size-sm);outline:none;-moz-appearance:textfield}.number-input input[type=number]::-webkit-outer-spin-button,.number-input input[type=number]::-webkit-inner-spin-button{-webkit-appearance:none}.number-btn{width:2rem;height:100%;display:flex;align-items:center;justify-content:center;background:transparent;border:none;color:var(--fg-muted);cursor:pointer;font-size:1rem;transition:background .1s,color .1s;flex-shrink:0}.number-btn:hover{background:var(--bg-3);color:var(--fg)}input[type=color].color-input{-webkit-appearance:none;appearance:none;width:2.25rem;height:2.25rem;border:var(--border);border-radius:var(--radius);background:none;cursor:pointer;padding:2px;transition:border-color .15s}input[type=color].color-input::-webkit-color-swatch-wrapper{padding:0}input[type=color].color-input::-webkit-color-swatch{border:none;border-radius:4px}input[type=color].color-input:focus{border-color:var(--cyan);outline:none}.input-group{display:flex;flex-direction:column;gap:var(--sp-2)}.input-group label{font-family:var(--font-ui);font-size:var(--font-size-xs);color:var(--fg-muted);letter-spacing:.04em;text-transform:uppercase}.input-row{display:flex;align-items:center;gap:var(--sp-3)}.input-row .slider{flex:1}.input-hint{font-size:var(--font-size-xs);color:var(--fg-subtle);margin-top:var(--sp-1)}.input-date{appearance:none;-webkit-appearance:none;background:var(--bg-2);border:var(--border);border-radius:var(--radius);color:var(--fg);font-family:var(--font-ui);font-size:var(--font-size-sm);padding:var(--sp-2) var(--sp-3);outline:none;transition:border-color .15s;cursor:pointer}.input-date:focus{border-color:var(--cyan)}.input-date::-webkit-calendar-picker-indicator{filter:invert(1);opacity:.4;cursor:pointer;transition:opacity .15s}.input-date::-webkit-calendar-picker-indicator:hover{opacity:.8}[data-theme=light] .input-date::-webkit-calendar-picker-indicator{filter:none;opacity:.5}[data-theme=light] .input-date::-webkit-calendar-picker-indicator:hover{opacity:.85}.input-date::-webkit-datetime-edit{color:var(--fg)}.input-date::-webkit-datetime-edit-fields-wrapper{color:var(--fg)}.input-date::-webkit-datetime-edit-text{color:var(--fg-subtle)}.date-range{display:flex;align-items:center;gap:var(--sp-2)}.date-range-sep{color:var(--fg-subtle);font-size:var(--font-size-sm);flex-shrink:0}.search-wrap{position:relative;display:flex;align-items:center}.search-wrap .search-icon{position:absolute;left:var(--sp-3);color:var(--fg-subtle);pointer-events:none;font-size:.9rem;line-height:1}.search-input{width:100%;padding:var(--sp-2) var(--sp-3) var(--sp-2) 2.25rem;background:var(--bg-2);border:var(--border);border-radius:999px;color:var(--fg);font-family:var(--font-ui);font-size:var(--font-size-sm);outline:none;transition:border-color .15s,background .15s}.search-input::placeholder{color:var(--fg-subtle)}.search-input:focus{border-color:var(--cyan);background:var(--bg-3)}.search-wrap .search-clear{position:absolute;right:var(--sp-3);color:var(--fg-subtle);cursor:pointer;font-size:.9rem;line-height:1;transition:color .1s}.search-wrap .search-clear:hover{color:var(--fg)}.file-drop{border:2px dashed var(--fg-subtle);border-radius:var(--radius);padding:var(--sp-8) var(--sp-4);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--sp-3);text-align:center;cursor:pointer;transition:border-color .2s,background .2s;position:relative}.file-drop input[type=file]{position:absolute;inset:0;opacity:0;cursor:pointer;width:100%;height:100%}.file-drop:hover,.file-drop.dragover{border-color:var(--cyan);background:var(--surface-cyan)}.file-drop-icon{font-size:2rem;opacity:.4}.file-drop-label{font-size:var(--font-size-sm);color:var(--fg-muted)}.file-drop-sub{font-size:var(--font-size-xs);color:var(--fg-subtle)}.dropdown{position:relative;display:inline-block}.dropdown-menu{position:absolute;top:calc(100% + var(--sp-1));left:0;min-width:180px;background:var(--bg-2);border:var(--border);border-radius:var(--radius);padding:var(--sp-1) 0;z-index:200;box-shadow:var(--shadow-lg, 0 8px 24px rgba(0,0,0,.4));display:none;animation:dropdown-in .12s ease}.dropdown.open .dropdown-menu{display:block}.dropdown-item{display:flex;align-items:center;gap:var(--sp-2);padding:var(--sp-2) var(--sp-4);font-family:var(--font-ui);font-size:var(--font-size-sm);color:var(--fg-muted);cursor:pointer;transition:background .1s,color .1s;text-decoration:none;border:none;background:none;width:100%;text-align:left}.dropdown-item:hover{background:var(--bg-3);color:var(--fg)}.dropdown-item.danger:hover{color:var(--magenta)}.dropdown-divider{height:1px;background:var(--fg-subtle);margin:var(--sp-1) 0}.dropdown-label{font-family:var(--font-accent);font-size:var(--font-size-xs);letter-spacing:.08em;text-transform:uppercase;color:var(--fg-subtle);padding:var(--sp-2) var(--sp-4) var(--sp-1)}@keyframes dropdown-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}kbd,.kbd{display:inline-flex;align-items:center;justify-content:center;padding:.15em .45em;font-family:var(--font-ui);font-size:.72em;font-weight:500;line-height:1;color:var(--fg-muted);background:var(--bg-3);border:1px solid var(--fg-subtle);border-bottom-width:2px;border-radius:4px;white-space:nowrap}.kbd-combo{display:inline-flex;align-items:center;gap:.25em}.breadcrumb{display:flex;align-items:center;flex-wrap:wrap;gap:var(--sp-1);font-family:var(--font-ui);font-size:var(--font-size-sm)}.breadcrumb-item{color:var(--fg-muted);text-decoration:none;transition:color .15s}.breadcrumb-item:hover{color:var(--fg)}.breadcrumb-item.active{color:var(--fg);pointer-events:none}.breadcrumb-sep{color:var(--fg-subtle);font-size:.8em;-webkit-user-select:none;user-select:none}.stepper{display:flex;align-items:flex-start;gap:0}.step{display:flex;flex-direction:column;align-items:center;flex:1;position:relative;gap:var(--sp-2)}.step:not(:last-child):after{content:"";position:absolute;top:1rem;left:calc(50% + 1rem);right:calc(-50% + 1rem);height:1px;background:var(--fg-subtle);transition:background .3s}.step.done:not(:last-child):after{background:var(--cyan)}.step-circle{width:2rem;height:2rem;border-radius:50%;border:2px solid var(--fg-subtle);background:var(--bg-2);display:flex;align-items:center;justify-content:center;font-family:var(--font-ui);font-size:var(--font-size-xs);font-weight:700;color:var(--fg-muted);transition:border-color .3s,background .3s,color .3s;z-index:1;flex-shrink:0}.step.active .step-circle{border-color:var(--cyan);color:var(--cyan)}.step.done .step-circle{border-color:var(--cyan);background:var(--cyan);color:var(--bg)}.step-label{font-family:var(--font-ui);font-size:var(--font-size-xs);color:var(--fg-subtle);text-align:center;transition:color .3s}.step.active .step-label{color:var(--fg)}.step.done .step-label{color:var(--fg-muted)}.stepper.vertical{flex-direction:column;gap:0}.stepper.vertical .step{flex-direction:row;align-items:flex-start;flex:none;gap:var(--sp-3);padding-bottom:var(--sp-6)}.stepper.vertical .step:last-child{padding-bottom:0}.stepper.vertical .step:after{top:calc(1rem + 2px);left:1rem;right:auto;width:1px;height:calc(100% - 1rem);background:var(--fg-subtle)}.stepper.vertical .step.done:after{background:var(--cyan)}.stepper.vertical .step-content{padding-top:.25rem}.stepper.vertical .step-title{font-size:var(--font-size-sm);font-weight:600;color:var(--fg);margin-bottom:var(--sp-1)}.stepper.vertical .step-desc{font-size:var(--font-size-xs);color:var(--fg-muted)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:var(--sp-12) var(--sp-6);gap:var(--sp-3);color:var(--fg-muted)}.empty-icon{font-size:2.5rem;opacity:.3;line-height:1}.empty-title{font-family:var(--font-ui);font-size:var(--font-size-md);font-weight:600;color:var(--fg-muted)}.empty-desc{font-size:var(--font-size-sm);color:var(--fg-subtle);max-width:36ch}.divider-label{display:flex;align-items:center;gap:var(--sp-3);margin:var(--sp-4) 0;color:var(--fg-subtle);font-size:var(--font-size-xs);font-family:var(--font-ui);letter-spacing:.06em;text-transform:uppercase}.divider-label:before,.divider-label:after{content:"";flex:1;height:1px;background:var(--fg-subtle)}.tag-list{display:flex;flex-wrap:wrap;gap:var(--sp-2)}.code-block{position:relative;background:var(--bg-3);border:var(--border);border-radius:var(--radius);overflow:hidden}.code-block pre{margin:0;padding:var(--sp-4);overflow-x:auto;font-family:var(--font-mono);font-size:var(--font-size-sm);line-height:1.6;color:var(--fg)}.code-block-header{display:flex;align-items:center;justify-content:space-between;padding:var(--sp-2) var(--sp-4);border-bottom:var(--border);background:var(--bg-2)}.code-lang{font-family:var(--font-mono);font-size:var(--font-size-xs);color:var(--fg-subtle)}.copy-btn{font-family:var(--font-ui);font-size:var(--font-size-xs);color:var(--fg-muted);background:transparent;border:var(--border);border-radius:4px;padding:.2em .6em;cursor:pointer;transition:color .15s,border-color .15s}.copy-btn:hover{color:var(--fg);border-color:var(--fg-muted)}.copy-btn.copied{color:var(--green);border-color:var(--green)}.tree,.tree ul{list-style:none;padding:0;margin:0}.tree ul{padding-left:1rem;position:relative}.tree ul:before{content:"";position:absolute;left:.45rem;top:0;bottom:.75rem;width:1px;background:var(--fg-subtle)}.tree-item{position:relative}.tree ul>.tree-item:before{content:"";position:absolute;left:-.55rem;top:.75rem;width:.5rem;height:1px;background:var(--fg-subtle)}.tree-label{display:flex;align-items:center;gap:var(--sp-2);padding:var(--sp-1) var(--sp-2);border-radius:4px;cursor:pointer;font-family:var(--font-ui);font-size:var(--font-size-sm);color:var(--fg-muted);-webkit-user-select:none;user-select:none;transition:background .1s,color .1s;white-space:nowrap}.tree-label:hover{background:var(--bg-3);color:var(--fg)}.tree-label.active{background:var(--surface-cyan);color:var(--cyan)}.tree-toggle{width:1rem;height:1rem;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:.6rem;color:var(--fg-subtle);transition:transform .15s;transform:rotate(0)}.tree-item.open>.tree-label .tree-toggle{transform:rotate(90deg)}.tree-icon{width:1rem;text-align:center;flex-shrink:0;font-size:.85rem;opacity:.6}.tree-name{flex:1;overflow:hidden;text-overflow:ellipsis}.tree-meta{font-size:var(--font-size-xs);color:var(--fg-subtle);font-family:var(--font-mono);flex-shrink:0}.tree-item>ul{display:none}.tree-item.open>ul{display:block}.tree-item.leaf>.tree-label .tree-toggle{visibility:hidden}.tree-label.drag-over{background:var(--surface-cyan);outline:1px solid var(--cyan)}.layer-panel{background:var(--bg-2);border:var(--border);border-radius:var(--radius);overflow:hidden;display:flex;flex-direction:column}.layer-panel-header{display:flex;align-items:center;justify-content:space-between;padding:var(--sp-2) var(--sp-3);border-bottom:var(--border);font-family:var(--font-ui);font-size:var(--font-size-xs);color:var(--fg-subtle);text-transform:uppercase;letter-spacing:.06em}.layer-list{overflow-y:auto;flex:1}.layer-item{display:flex;align-items:center;gap:var(--sp-2);padding:var(--sp-2) var(--sp-3);border-bottom:1px solid rgba(255,255,255,.04);cursor:pointer;transition:background .1s}.layer-item:hover{background:var(--bg-3)}.layer-item.selected{background:var(--surface-cyan)}.layer-drag{color:var(--fg-subtle);font-size:.7rem;cursor:grab;opacity:.4;flex-shrink:0}.layer-drag:active{cursor:grabbing}.layer-thumb{width:2rem;height:2rem;border-radius:4px;background:var(--bg-3);border:1px solid var(--fg-subtle);flex-shrink:0;overflow:hidden;display:flex;align-items:center;justify-content:center;font-size:.6rem;color:var(--fg-subtle)}.layer-thumb img{width:100%;height:100%;object-fit:contain;image-rendering:pixelated}.layer-name{flex:1;font-family:var(--font-ui);font-size:var(--font-size-xs);color:var(--fg);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.layer-name input{background:transparent;border:none;outline:none;color:inherit;font:inherit;width:100%}.layer-actions{display:flex;align-items:center;gap:2px;flex-shrink:0;opacity:0;transition:opacity .1s}.layer-item:hover .layer-actions,.layer-item.selected .layer-actions{opacity:1}.layer-btn{width:1.5rem;height:1.5rem;border:none;background:transparent;color:var(--fg-subtle);cursor:pointer;border-radius:3px;display:flex;align-items:center;justify-content:center;font-size:.7rem;transition:background .1s,color .1s}.layer-btn:hover{background:var(--bg-3);color:var(--fg)}.layer-btn.danger:hover{color:var(--red)}.layer-btn.active{color:var(--cyan)}.layer-item.hidden{opacity:.4}.layer-item.hidden .layer-thumb{filter:saturate(0)}.layer-add{display:flex;align-items:center;gap:var(--sp-2);padding:var(--sp-2) var(--sp-3);border-top:var(--border);font-family:var(--font-ui);font-size:var(--font-size-xs);color:var(--fg-subtle);cursor:pointer;transition:color .1s}.layer-add:hover{color:var(--fg)}.timeline{display:flex;flex-direction:column;gap:0}.timeline-item{display:grid;grid-template-columns:2rem 1fr;gap:var(--sp-3);position:relative;padding-bottom:var(--sp-6)}.timeline-item:last-child{padding-bottom:0}.timeline-item:not(:last-child):before{content:"";position:absolute;left:1rem;top:1.5rem;bottom:0;width:1px;background:var(--fg-subtle);transform:translate(-50%)}.timeline-dot{width:.75rem;height:.75rem;border-radius:50%;background:var(--timeline-color, var(--cyan));justify-self:center;margin-top:.3rem;position:relative;z-index:1;box-shadow:0 0 0 3px var(--bg-2),0 0 0 4px var(--timeline-color, var(--cyan));transition:transform .15s}.timeline-item:hover .timeline-dot{transform:scale(1.3)}.timeline-item.success{--timeline-color: var(--green)}.timeline-item.warning{--timeline-color: var(--orange)}.timeline-item.danger{--timeline-color: var(--red)}.timeline-item.info{--timeline-color: var(--blue)}.timeline-item.muted{--timeline-color: var(--fg-subtle)}.timeline-dot.hollow{background:var(--bg-2);border:2px solid var(--timeline-color, var(--cyan));box-shadow:0 0 0 3px var(--bg-2)}.timeline-dot.icon{width:1.5rem;height:1.5rem;border-radius:var(--radius);font-size:.7rem;display:flex;align-items:center;justify-content:center;background:var(--surface-cyan);color:var(--timeline-color, var(--cyan));box-shadow:none;margin-top:0}.timeline-content{flex:1;min-width:0}.timeline-title{font-family:var(--font-ui);font-size:var(--font-size-sm);font-weight:600;color:var(--fg);margin-bottom:var(--sp-1);line-height:1.3}.timeline-time{font-family:var(--font-mono);font-size:var(--font-size-xs);color:var(--fg-subtle);margin-bottom:var(--sp-2)}.timeline-body{font-size:var(--font-size-sm);color:var(--fg-muted);line-height:1.55}.timeline.horizontal{flex-direction:row;align-items:flex-start;overflow-x:auto;padding-left:0;padding-top:.25rem}.timeline.horizontal .timeline-item{grid-template-columns:1fr;grid-template-rows:2rem 1fr;align-items:center;justify-items:center;flex:1;min-width:6rem;padding-bottom:0;text-align:center}.timeline.horizontal .timeline-item:not(:last-child):before{left:calc(50% + .5rem);top:1rem;bottom:auto;width:calc(100% - .5rem);height:1px;transform:none}.timeline.horizontal .timeline-dot{justify-self:center;margin-top:0}.timeline.horizontal .timeline-content{grid-row:2;margin-top:var(--sp-2)}.tag-input-wrap{display:flex;flex-wrap:wrap;align-items:center;gap:var(--sp-1);padding:var(--sp-2);background:var(--bg-2);border:var(--border);border-radius:var(--radius);min-height:2.5rem;cursor:text;transition:border-color .15s}.tag-input-wrap:focus-within{border-color:var(--cyan)}.tag-input-wrap input{flex:1;min-width:5rem;background:transparent;border:none;outline:none;color:var(--fg);font-family:var(--font-ui);font-size:var(--font-size-sm);padding:.15rem var(--sp-1)}.tag-input-wrap input::placeholder{color:var(--fg-subtle)}.tag-pill{display:inline-flex;align-items:center;gap:var(--sp-1);padding:.2em .4em .2em .6em;background:var(--bg-3);border:var(--border);border-radius:4px;font-family:var(--font-tag);font-size:var(--font-size-xs);color:var(--fg-muted);white-space:nowrap}.tag-pill.cyan{background:var(--surface-cyan);border-color:#6bd1e04d;color:var(--cyan)}.tag-pill.magenta{background:var(--surface-magenta);border-color:#ff64b54d;color:var(--magenta)}.tag-pill.green{background:var(--surface-green);border-color:#3fc7634d;color:var(--green)}.tag-pill.orange{background:var(--surface-orange);border-color:#ffa25c4d;color:var(--orange)}.tag-pill.purple{background:var(--surface-purple);border-color:#d74bec4d;color:var(--purple)}.tag-pill-remove{background:transparent;border:none;cursor:pointer;color:inherit;opacity:.45;font-size:.85em;line-height:1;padding:0;display:flex;align-items:center;transition:opacity .1s}.tag-pill-remove:hover{opacity:1}.command-backdrop{position:fixed;inset:0;background:#000000a6;z-index:9900;display:flex;align-items:flex-start;justify-content:center;padding-top:14vh;animation:anim-fade-in .12s ease both}.command-backdrop[hidden]{display:none!important}.command-palette{width:min(560px,92vw);background:var(--bg-2);border:var(--border);border-radius:calc(var(--radius) * 1.5);overflow:hidden;box-shadow:var(--shadow-lg, 0 32px 80px rgba(0,0,0,.65)),0 0 0 1px #ffffff0f;animation:anim-slide-up .18s cubic-bezier(.16,1,.3,1) both}.command-input-wrap{display:flex;align-items:center;gap:var(--sp-3);padding:var(--sp-3) var(--sp-4);border-bottom:var(--border)}.command-search-icon{color:var(--fg-subtle);font-size:1rem;flex-shrink:0}.command-input{flex:1;background:transparent;border:none;outline:none;color:var(--fg);font-family:var(--font-ui);font-size:var(--font-size-md)}.command-input::placeholder{color:var(--fg-subtle)}.command-input-hint{font-size:var(--font-size-xs);color:var(--fg-subtle);flex-shrink:0}.command-list{max-height:340px;overflow-y:auto;padding:var(--sp-2) 0}.command-group-label{padding:var(--sp-2) var(--sp-4) var(--sp-1);font-family:var(--font-ui);font-size:var(--font-size-xs);color:var(--fg-subtle);text-transform:uppercase;letter-spacing:.08em}.command-item{display:flex;align-items:center;gap:var(--sp-3);padding:var(--sp-2) var(--sp-4);cursor:pointer;transition:background .08s}.command-item:hover,.command-item.active{background:var(--surface-cyan)}.command-item.active .command-item-label{color:var(--fg)}.command-item-icon{width:1.75rem;height:1.75rem;border-radius:var(--radius);background:var(--bg-3);border:var(--border);display:flex;align-items:center;justify-content:center;font-size:.8rem;flex-shrink:0;color:var(--fg-muted)}.command-item-label{flex:1;font-family:var(--font-ui);font-size:var(--font-size-sm);color:var(--fg-muted)}.command-item-sub{font-size:var(--font-size-xs);color:var(--fg-subtle);margin-top:1px}.command-item-shortcut{display:flex;align-items:center;gap:2px;flex-shrink:0}.command-footer{display:flex;align-items:center;gap:var(--sp-4);padding:var(--sp-2) var(--sp-4);border-top:var(--border);background:var(--bg-3)}.command-footer-hint{display:flex;align-items:center;gap:var(--sp-1);font-size:var(--font-size-xs);color:var(--fg-subtle)}.chat{display:flex;flex-direction:column;gap:var(--sp-3);padding:var(--sp-4)}.chat-row{display:flex;gap:var(--sp-2);align-items:flex-end}.chat-row.mine{flex-direction:row-reverse}.chat-avatar{width:2rem;height:2rem;border-radius:var(--radius);background:var(--bg-3);border:var(--border);display:flex;align-items:center;justify-content:center;font-size:var(--font-size-xs);color:var(--fg-muted);flex-shrink:0}.chat-msg{max-width:72%;padding:var(--sp-3) var(--sp-4);border-radius:var(--radius);font-family:var(--font-body);font-size:var(--font-size-sm);line-height:1.55;position:relative}.chat-msg.theirs{background:var(--bg-2);border:var(--border);border-bottom-left-radius:2px}.chat-msg.mine{background:var(--surface-cyan);border:1px solid rgba(107,209,224,.2);border-bottom-right-radius:2px}.chat-msg.ai{max-width:88%;align-self:center;background:var(--bg-2);border:1px solid var(--fg-subtle);border-left:2px solid var(--cyan);border-radius:var(--radius);padding:var(--sp-4);font-size:var(--font-size-sm)}.chat-msg.ai .chat-ai-label{font-size:var(--font-size-xs);color:var(--cyan);font-family:var(--font-ui);letter-spacing:.06em;text-transform:uppercase;margin-bottom:var(--sp-2);display:block}.chat-meta{font-size:var(--font-size-xs);color:var(--fg-subtle);padding:0 var(--sp-1);margin-top:var(--sp-1)}.chat-row.mine .chat-meta{text-align:right}.chat-divider{text-align:center;font-size:var(--font-size-xs);color:var(--fg-subtle);display:flex;align-items:center;gap:var(--sp-3);margin:var(--sp-2) 0}.chat-divider:before,.chat-divider:after{content:"";flex:1;height:1px;background:var(--fg-subtle)}.chat-typing{display:flex;align-items:center;gap:4px;padding:var(--sp-3) var(--sp-4);background:var(--bg-2);border:var(--border);border-radius:var(--radius);border-bottom-left-radius:2px;width:fit-content}.chat-typing-dot{width:6px;height:6px;border-radius:50%;background:var(--fg-muted);animation:chat-typing-bounce 1.2s ease-in-out infinite}.chat-typing-dot:nth-child(2){animation-delay:.2s}.chat-typing-dot:nth-child(3){animation-delay:.4s}@keyframes chat-typing-bounce{0%,60%,to{transform:translateY(0);opacity:.4}30%{transform:translateY(-4px);opacity:1}}.chat-input-bar{display:flex;gap:var(--sp-2);padding:var(--sp-3) var(--sp-4);border-top:var(--border);background:var(--bg-2);align-items:flex-end}.chat-input-bar .input{flex:1;resize:none;min-height:2.25rem;max-height:8rem;overflow-y:auto;line-height:1.5}.chat-send-btn{width:2.25rem;height:2.25rem;border-radius:var(--radius);background:var(--cyan);color:var(--bg);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:1rem;transition:opacity .15s}.chat-send-btn:hover{opacity:.85}.aspect-16-9{aspect-ratio:16 / 9}.aspect-4-3{aspect-ratio:4 / 3}.aspect-1-1{aspect-ratio:1 / 1}.aspect-3-4{aspect-ratio:3 / 4}.aspect-21-9{aspect-ratio:21 / 9}.img-cover{width:100%;height:100%;object-fit:cover;display:block}.img-zoom{overflow:hidden;display:block}.img-zoom img,.img-zoom .img-cover{transition:transform .4s cubic-bezier(.16,1,.3,1)}.img-zoom:hover img,.img-zoom:hover .img-cover{transform:scale(1.06)}.img-blur-up img{filter:blur(12px);transition:filter .5s ease}.img-blur-up.loaded img{filter:none}.img-frame{border:1px solid var(--fg-subtle);border-radius:var(--radius);overflow:hidden;display:block;background:var(--bg-2)}.img-frame img{width:100%;display:block}.figure{display:flex;flex-direction:column;gap:var(--sp-2)}.figure img{width:100%;display:block;border-radius:var(--radius)}.figure-caption{font-size:var(--font-size-xs);color:var(--fg-subtle);font-family:var(--font-ui);text-align:center;line-height:1.5}.media-card{border-radius:var(--radius);overflow:hidden;border:1px solid rgba(255,255,255,.07);background:var(--bg-2);display:flex;flex-direction:column;transition:transform .25s,border-color .25s,box-shadow .25s}.media-card:hover{transform:translateY(-3px);border-color:#ffffff24;box-shadow:var(--shadow-md, 0 8px 24px rgba(0,0,0,.3))}.media-card-thumb{position:relative;overflow:hidden}.media-card-thumb img{width:100%;display:block;object-fit:cover;transition:transform .4s cubic-bezier(.16,1,.3,1)}.media-card:hover .media-card-thumb img{transform:scale(1.05)}.media-card-thumb:after{content:"";position:absolute;bottom:0;left:0;right:0;height:40%;background:linear-gradient(to top,rgba(0,0,0,.5),transparent);pointer-events:none}.media-card-body{padding:var(--sp-4) var(--sp-6);flex:1;display:flex;flex-direction:column;gap:var(--sp-2)}.media-card-title{font-family:var(--font-display);font-weight:700;font-size:var(--font-size-md);color:var(--fg);line-height:1.3}.media-card-sub{font-size:var(--font-size-sm);color:var(--fg-muted);line-height:1.55;flex:1}.media-card-footer{display:flex;align-items:center;justify-content:space-between;margin-top:var(--sp-2);padding-top:var(--sp-3);border-top:1px solid rgba(255,255,255,.06);font-size:var(--font-size-xs);color:var(--fg-subtle);font-family:var(--font-mono)}.media-card.horizontal{flex-direction:row}.media-card.horizontal .media-card-thumb{width:40%;flex-shrink:0}.media-card.horizontal .media-card-thumb img{height:100%}.media-card.sm .media-card-thumb{min-height:120px}.media-card.md .media-card-thumb{min-height:180px}.media-card.lg .media-card-thumb{min-height:260px}.media-grid{display:grid;gap:var(--sp-3)}.media-grid.cols-2{grid-template-columns:repeat(2,1fr)}.media-grid.cols-3{grid-template-columns:repeat(3,1fr)}.media-grid.cols-4{grid-template-columns:repeat(4,1fr)}.media-grid.auto{grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}.media-grid.mosaic{grid-auto-rows:1fr}.media-grid.mosaic .media-grid-item:first-child{grid-row:span 2}.media-grid-item{position:relative;overflow:hidden;border-radius:var(--radius);background:var(--bg-2)}.media-grid-item img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .35s ease}.media-grid-item:hover img{transform:scale(1.04)}.img-lazy{position:relative;overflow:hidden;background:var(--bg-2)}.img-lazy:before{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.06),transparent);background-size:200% 100%;animation:anim-wave-scan 1.4s ease-in-out infinite;z-index:1;transition:opacity .3s}@keyframes anim-wave-scan{0%{background-position:-200% 0}to{background-position:200% 0}}.img-lazy.loaded:before{opacity:0;pointer-events:none}.img-lazy img{opacity:0;transition:opacity .4s ease;width:100%;display:block;object-fit:cover}.img-lazy.loaded img{opacity:1}.video-wrap{position:relative;width:100%;aspect-ratio:16 / 9;background:var(--bg-1);border-radius:var(--radius);overflow:hidden}.video-wrap iframe,.video-wrap video{position:absolute;inset:0;width:100%;height:100%;border:none}.video-wrap video{object-fit:cover}.media-overlay{position:relative;display:block;overflow:hidden;border-radius:var(--radius)}.media-overlay-content{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:flex-end;padding:var(--sp-4);background:linear-gradient(to top,rgba(0,0,0,.75) 0%,rgba(0,0,0,.3) 50%,transparent 100%);color:#fff;opacity:0;transition:opacity .25s ease}.media-overlay:hover .media-overlay-content,.media-overlay.always .media-overlay-content{opacity:1}.media-overlay-title{font-family:var(--font-display);font-weight:700;font-size:var(--font-size-md);line-height:1.2;margin-bottom:var(--sp-1)}.media-overlay-sub{font-size:var(--font-size-xs);color:#ffffffb3}.img-badge-wrap{position:relative;display:inline-block}.img-badge{position:absolute;font-size:var(--font-size-xs);font-family:var(--font-ui);font-weight:600;padding:2px 8px;border-radius:999px;background:var(--bg-1);color:var(--fg);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border:1px solid rgba(255,255,255,.1);line-height:1.6;pointer-events:none}.img-badge.top-left{top:var(--sp-2);left:var(--sp-2)}.img-badge.top-right{top:var(--sp-2);right:var(--sp-2)}.img-badge.bottom-left{bottom:var(--sp-2);left:var(--sp-2)}.img-badge.bottom-right{bottom:var(--sp-2);right:var(--sp-2)}.img-badge.cyan{background:var(--surface-cyan);color:var(--cyan);border-color:var(--cyan)}.img-badge.green{background:var(--surface-green);color:var(--green);border-color:var(--green)}.img-badge.red{background:var(--surface-red);color:var(--red);border-color:var(--red)}.img-badge.magenta{background:var(--surface-magenta);color:var(--magenta);border-color:var(--magenta)}.img-badge.orange{background:var(--surface-orange);color:var(--orange);border-color:var(--orange)}.gallery{columns:var(--gallery-cols, 3);column-gap:var(--sp-3)}.gallery.cols-2{--gallery-cols: 2}.gallery.cols-3{--gallery-cols: 3}.gallery.cols-4{--gallery-cols: 4}.gallery-item{break-inside:avoid;margin-bottom:var(--sp-3);border-radius:var(--radius);overflow:hidden;display:block;position:relative}.gallery-item img{width:100%;display:block;transition:transform .35s cubic-bezier(.16,1,.3,1)}.gallery-item:hover img{transform:scale(1.03)}.lightbox-thumb{cursor:zoom-in;position:relative;display:block;overflow:hidden;border-radius:var(--radius)}.lightbox-thumb:after{content:"⤢";position:absolute;top:var(--sp-2);right:var(--sp-2);background:#0000008c;color:var(--fg-muted);font-size:.75rem;width:1.5rem;height:1.5rem;border-radius:4px;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .2s}.lightbox-thumb:hover:after{opacity:1}.sprite{display:inline-block;background-repeat:no-repeat;background-size:auto;width:var(--sprite-size, 32px);height:var(--sprite-size, 32px);flex-shrink:0}.sprite.xs,.shuz-char.xs,.shuz-tile.xs{--sprite-size: 16px}.sprite.sm,.shuz-char.sm,.shuz-tile.sm{--sprite-size: 24px}.sprite.md,.shuz-char.md,.shuz-tile.md{--sprite-size: 32px}.sprite.lg,.shuz-char.lg,.shuz-tile.lg{--sprite-size: 48px}.sprite.xl,.shuz-char.xl,.shuz-tile.xl{--sprite-size: 64px}.sprite.s2x,.shuz-char.s2x,.shuz-tile.s2x{--sprite-size: 128px}.sprite-crisp,.sprite.crisp{image-rendering:pixelated;image-rendering:crisp-edges}.sprite-sheet{--sheet-cols: 4;--tile-w: 64;--tile-h: 64}.sprite-tile-0{background-position:calc(0 * -1px * var(--tile-w, 64)) calc(0 * -1px * var(--tile-h, 64))}.sprite-tile-1{background-position:calc(1 * -1px * var(--tile-w, 64)) calc(0 * -1px * var(--tile-h, 64))}.sprite-tile-2{background-position:calc(2 * -1px * var(--tile-w, 64)) calc(0 * -1px * var(--tile-h, 64))}.sprite-tile-3{background-position:calc(3 * -1px * var(--tile-w, 64)) calc(0 * -1px * var(--tile-h, 64))}.sprite-tile-4{background-position:calc(0 * -1px * var(--tile-w, 64)) calc(1 * -1px * var(--tile-h, 64))}.sprite-tile-5{background-position:calc(1 * -1px * var(--tile-w, 64)) calc(1 * -1px * var(--tile-h, 64))}.sprite-tile-6{background-position:calc(2 * -1px * var(--tile-w, 64)) calc(1 * -1px * var(--tile-h, 64))}.sprite-tile-7{background-position:calc(3 * -1px * var(--tile-w, 64)) calc(1 * -1px * var(--tile-h, 64))}.sprite-tile-8{background-position:calc(0 * -1px * var(--tile-w, 64)) calc(2 * -1px * var(--tile-h, 64))}.sprite-tile-9{background-position:calc(1 * -1px * var(--tile-w, 64)) calc(2 * -1px * var(--tile-h, 64))}.sprite-tile-10{background-position:calc(2 * -1px * var(--tile-w, 64)) calc(2 * -1px * var(--tile-h, 64))}.sprite-tile-11{background-position:calc(3 * -1px * var(--tile-w, 64)) calc(2 * -1px * var(--tile-h, 64))}.shuz-tile{display:inline-block;background-image:var(--shuz-img-tileset, url(/assets/tileset-DVtRsfaG.png));background-repeat:no-repeat;background-size:400% 300%;image-rendering:pixelated;width:var(--sprite-size, 64px);height:var(--sprite-size, 64px);flex-shrink:0}.shuz-tile-0{background-position:100% 100%}.shuz-tile-1{background-position:66.667% 100%}.shuz-tile-2{background-position:33.333% 100%}.shuz-tile-3{background-position:0% 100%}.shuz-tile-4{background-position:100% 50%}.shuz-tile-5{background-position:66.667% 50%}.shuz-tile-6{background-position:33.333% 50%}.shuz-tile-7{background-position:0% 50%}.shuz-tile-8{background-position:100% 0%}.shuz-tile-9{background-position:66.667% 0%}.shuz-tile-10{background-position:33.333% 0%}.shuz-tile-11,.shuz-oreo{background-position:0% 0%}.shuz-black{background-position:33.333% 0%}.shuz-gray{background-position:66.667% 0%}.shuz-white{background-position:100% 0%}.shuz-purple{background-position:0% 50%}.shuz-blue{background-position:33.333% 50%}.shuz-cyan{background-position:66.667% 50%}.shuz-green{background-position:100% 50%}.shuz-yellow{background-position:0% 100%}.shuz-orange{background-position:33.333% 100%}.shuz-red{background-position:66.667% 100%}.shuz-pink{background-position:100% 100%}.shuz-tile.avatar{border-radius:50%;outline:2px solid rgba(255,255,255,.15);outline-offset:2px}.sprite-anim{background-position:var(--frame-x, 0) var(--frame-y, 0);transition:none}.shuz-card{display:flex;flex-direction:column;align-items:center;gap:var(--sp-2);padding:var(--sp-3);background:var(--bg-2);border:1px solid rgba(255,255,255,.07);border-radius:var(--radius);transition:transform .2s,border-color .2s;cursor:default}.shuz-card:hover{transform:translateY(-2px);border-color:#ffffff24}.shuz-card-name{font-size:var(--font-size-xs);font-family:var(--font-mono);color:var(--fg-muted);text-transform:lowercase;letter-spacing:.05em}.sprite-grid{display:flex;flex-wrap:wrap;gap:var(--sp-2);align-items:flex-start}.swatch{display:inline-block;width:var(--swatch-size, 2rem);height:var(--swatch-size, 2rem);border-radius:var(--swatch-radius, var(--radius));flex-shrink:0;cursor:default;transition:transform .15s,box-shadow .15s;outline:2px solid transparent;outline-offset:2px;position:relative}.swatch:hover{transform:scale(1.08);box-shadow:0 4px 12px #00000059}.swatch.selected,.swatch:focus-visible{outline-color:var(--fg)}.swatch.round{--swatch-radius: 50%}.swatch.pill{--swatch-radius: 999px;width:calc(var(--swatch-size, 2rem) * 2)}.swatch.xs{--swatch-size: 1rem}.swatch.sm{--swatch-size: 1.5rem}.swatch.lg{--swatch-size: 2.75rem}.swatch.xl{--swatch-size: 3.5rem}.swatch-grid{display:flex;flex-wrap:wrap;gap:var(--sp-2);align-items:center}.swatch-grid.tight{gap:var(--sp-1)}.swatch-grid.loose{gap:var(--sp-3)}.swatch-stack{display:flex;flex-direction:row}.swatch-stack .swatch{margin-left:calc(var(--swatch-size, 2rem) * -.35);border:2px solid var(--bg-1);transition:transform .15s,margin-left .2s}.swatch-stack .swatch:first-child{margin-left:0}.swatch-stack:hover .swatch{margin-left:calc(var(--swatch-size, 2rem) * .1)}.color-chip{display:inline-flex;align-items:center;gap:6px;font-size:var(--font-size-xs);font-family:var(--font-mono);padding:3px 8px 3px 6px;border-radius:999px;border:1px solid rgba(255,255,255,.08);background:var(--bg-2);color:var(--fg-muted);cursor:default;transition:border-color .15s}.color-chip:hover{border-color:#ffffff2e}.color-chip-dot{width:.65rem;height:.65rem;border-radius:50%;flex-shrink:0}.palette-card{border-radius:var(--radius);overflow:hidden;background:var(--bg-2);border:1px solid rgba(255,255,255,.06);display:flex;flex-direction:column;min-width:7rem}.palette-card-swatch{height:4rem;width:100%;flex-shrink:0}.palette-card-body{padding:var(--sp-2) var(--sp-3);display:flex;flex-direction:column;gap:2px}.palette-card-name{font-size:var(--font-size-xs);font-family:var(--font-ui);font-weight:600;color:var(--fg);text-transform:capitalize}.palette-card-hex{font-size:.65rem;font-family:var(--font-mono);color:var(--fg-subtle);letter-spacing:.04em;text-transform:uppercase}.color-scale{display:flex;gap:0;border-radius:var(--radius);overflow:hidden;height:2.5rem}.color-scale-step{flex:1;position:relative;cursor:default;transition:flex .2s ease}.color-scale-step:hover{flex:2}.color-scale-step:after{content:attr(data-label);position:absolute;bottom:4px;left:50%;transform:translate(-50%);font-size:.5rem;font-family:var(--font-mono);color:#fff9;white-space:nowrap;opacity:0;transition:opacity .15s;pointer-events:none}.color-scale-step:hover:after{opacity:1}.palette-row{display:flex;flex-direction:column;gap:var(--sp-2)}.palette-row-strip{height:3rem;border-radius:var(--radius);width:100%}.palette-row-labels{display:flex;justify-content:space-between;font-size:.6rem;font-family:var(--font-mono);color:var(--fg-subtle);padding:0 2px}.color-family{display:flex;flex-direction:column;gap:var(--sp-2)}.color-family-name{font-size:var(--font-size-xs);font-family:var(--font-ui);font-weight:600;color:var(--fg-muted);text-transform:capitalize;letter-spacing:.05em}.color-picker-wrap{display:inline-flex;align-items:center;gap:var(--sp-2);padding:4px 10px 4px 4px;border-radius:999px;border:1px solid rgba(255,255,255,.1);background:var(--bg-2);cursor:pointer;transition:border-color .15s}.color-picker-wrap:hover{border-color:#fff3}.color-picker-wrap input[type=color]{-webkit-appearance:none;appearance:none;width:1.5rem;height:1.5rem;border-radius:50%;border:none;padding:0;cursor:pointer;background:none;overflow:hidden}.color-picker-wrap input[type=color]::-webkit-color-swatch-wrapper{padding:0;border-radius:50%}.color-picker-wrap input[type=color]::-webkit-color-swatch{border:none;border-radius:50%}.color-picker-label{font-size:var(--font-size-xs);font-family:var(--font-mono);color:var(--fg-muted);letter-spacing:.05em;text-transform:uppercase;-webkit-user-select:none;user-select:none}.grid-palette{display:flex;flex-direction:column;gap:var(--sp-1);padding:var(--sp-3);background:var(--bg-2);border:1px solid rgba(255,255,255,.07);border-radius:var(--radius);width:fit-content}.grid-palette-row{display:flex;gap:var(--sp-1);align-items:center}.grid-palette-swatch{width:1.4rem;height:1.4rem;border-radius:2px;cursor:pointer;transition:transform .12s,box-shadow .12s;outline:2px solid transparent;outline-offset:2px;border:1px solid rgba(255,255,255,.08)}.grid-palette-swatch:hover{transform:scale(1.15);box-shadow:0 2px 8px #0006}.grid-palette-swatch.active{outline-color:var(--fg);transform:scale(1.1)}.grid-palette-swatch.erase{background:var(--bg-1);position:relative}.grid-palette-swatch.erase:after{content:"✕";position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:.6rem;color:var(--fg-subtle)}.grid-palette.inline{flex-direction:row;align-items:center;padding:var(--sp-2) var(--sp-3);gap:var(--sp-1)}.grid-palette.inline .grid-palette-row{gap:var(--sp-1)}.grid-palette-divider{width:1px;height:1.2rem;background:#ffffff1a;margin:0 var(--sp-1)}.grid-palette-label{font-size:.6rem;font-family:var(--font-mono);color:var(--fg-subtle);text-transform:uppercase;letter-spacing:.08em}.token-swatch{display:flex;align-items:center;gap:var(--sp-3);padding:var(--sp-2) var(--sp-3);border-radius:var(--radius-sm, 6px);background:var(--bg-2);border:1px solid rgba(255,255,255,.05);transition:background .15s}.token-swatch:hover{background:var(--bg-3)}.token-swatch-dot{width:1.25rem;height:1.25rem;border-radius:var(--radius-sm, 6px);flex-shrink:0}.token-swatch-name{font-size:var(--font-size-xs);font-family:var(--font-mono);color:var(--fg-muted);flex:1}.token-swatch-value{font-size:var(--font-size-xs);font-family:var(--font-mono);color:var(--fg-subtle)}.grid-2d{display:grid;grid-template-columns:repeat(var(--grid-cols, 8),var(--cell-size, 2.5rem));gap:var(--grid-gap, 1px);width:fit-content;background:var(--bg-3);border:1px solid var(--bg-3);border-radius:var(--radius);overflow:hidden}:where(.grid-2d,.grid-chess,.grid-iso) .cell{width:var(--cell-size, 2.5rem);height:var(--cell-size, 2.5rem);background:var(--cell-color, var(--bg-2));display:flex;align-items:center;justify-content:center;font-size:calc(var(--cell-size, 2.5rem) * .45);cursor:pointer;transition:background .1s,transform .1s,box-shadow .1s;position:relative;-webkit-user-select:none;user-select:none}:where(.grid-2d,.grid-chess,.grid-iso) .cell:hover{background:var(--cell-hover, var(--bg-3));z-index:1}:where(.grid-2d,.grid-chess,.grid-iso) .cell.selected{background:var(--surface-cyan);box-shadow:inset 0 0 0 2px var(--cyan);z-index:2}:where(.grid-2d,.grid-chess,.grid-iso) .cell.active{background:var(--surface-cyan);box-shadow:inset 0 0 0 2px var(--cyan);z-index:2}:where(.grid-2d,.grid-chess,.grid-iso) .cell.blocked{background:var(--bg-1);cursor:not-allowed;opacity:.4}:where(.grid-2d,.grid-chess,.grid-iso) .cell.highlight{background:#f8ff5c2e;box-shadow:inset 0 0 0 2px var(--yellow)}:where(.grid-2d,.grid-chess,.grid-iso) .cell.danger{background:var(--surface-red);box-shadow:inset 0 0 0 2px var(--red)}:where(.grid-2d,.grid-chess,.grid-iso) .cell.success{background:var(--surface-green);box-shadow:inset 0 0 0 2px var(--green)}:where(.grid-2d,.grid-chess,.grid-iso) .cell.path{background:#6bd1e01f}:where(.grid-2d,.grid-chess,.grid-iso) .cell.origin{background:var(--surface-green);box-shadow:inset 0 0 0 2px var(--green)}:where(.grid-2d,.grid-chess,.grid-iso) .cell.target{background:var(--surface-magenta);box-shadow:inset 0 0 0 2px var(--magenta)}:where(.grid-2d,.grid-chess,.grid-iso) .cell.cyan{--cell-color: rgba(107,209,224,.25)}:where(.grid-2d,.grid-chess,.grid-iso) .cell.magenta{--cell-color: rgba(255,100,181,.25)}:where(.grid-2d,.grid-chess,.grid-iso) .cell.green{--cell-color: rgba(63,199,99,.25)}:where(.grid-2d,.grid-chess,.grid-iso) .cell.red{--cell-color: rgba(255,96,96,.25)}:where(.grid-2d,.grid-chess,.grid-iso) .cell.orange{--cell-color: rgba(255,162,92,.25)}:where(.grid-2d,.grid-chess,.grid-iso) .cell.yellow{--cell-color: rgba(248,255,92,.2)}:where(.grid-2d,.grid-chess,.grid-iso) .cell.purple{--cell-color: rgba(215,75,236,.25)}:where(.grid-2d,.grid-chess,.grid-iso) .cell.blue{--cell-color: rgba(89,100,211,.25)}:where(.grid-2d,.grid-chess,.grid-iso) .cell.fill-cyan{background:var(--cyan);color:#000}:where(.grid-2d,.grid-chess,.grid-iso) .cell.fill-magenta{background:var(--magenta);color:#000}:where(.grid-2d,.grid-chess,.grid-iso) .cell.fill-green{background:var(--green);color:#000}:where(.grid-2d,.grid-chess,.grid-iso) .cell.fill-red{background:var(--red);color:#000}:where(.grid-2d,.grid-chess,.grid-iso) .cell.fill-orange{background:var(--orange);color:#000}:where(.grid-2d,.grid-chess,.grid-iso) .cell.fill-yellow{background:var(--yellow);color:#000}:where(.grid-2d,.grid-chess,.grid-iso) .cell.fill-purple{background:var(--purple);color:#000}:where(.grid-2d,.grid-chess,.grid-iso) .cell.fill-blue{background:var(--blue);color:#fff}.grid-chess{display:grid;grid-template-columns:repeat(var(--grid-cols, 8),var(--cell-size, 2.5rem));gap:0;width:fit-content;border:2px solid var(--bg-3);border-radius:4px;overflow:hidden}.grid-chess .cell{border-radius:0;gap:0;background:var(--chess-light, #e8d5b0);color:#000}.grid-chess .cell-row:nth-child(odd) .cell:nth-child(2n),.grid-chess .cell-row:nth-child(2n) .cell:nth-child(odd){background:var(--chess-dark, #8b5e3c);color:#fff}.grid-chess .cell:hover{background:#f8ff5c8c!important}.grid-chess .cell.selected{background:#6bd1e099!important;box-shadow:none}.grid-chess .cell.highlight{background:#f8ff5c8c!important;box-shadow:none}.grid-chess.dark .cell{background:var(--chess-light, #4a6741);color:#fff}.grid-chess.dark .cell-row:nth-child(odd) .cell:nth-child(2n),.grid-chess.dark .cell-row:nth-child(2n) .cell:nth-child(odd){background:var(--chess-dark, #eeeed2);color:#000}.grid-coords-wrap{display:inline-flex;flex-direction:column;gap:0;font-family:var(--font-mono);font-size:.6rem;color:var(--fg-subtle)}.grid-coords-row{display:flex;align-items:center}.grid-coord-label{width:1.2rem;text-align:center;flex-shrink:0}.grid-coords-header{display:flex;padding-left:1.2rem}.grid-coords-header span{width:var(--cell-size, 2.5rem);text-align:center}.grid-2d.xs,.grid-chess.xs{--cell-size: 1.5rem}.grid-2d.sm,.grid-chess.sm{--cell-size: 2rem}.grid-2d.lg,.grid-chess.lg{--cell-size: 3.5rem}.grid-2d.xl,.grid-chess.xl{--cell-size: 4.5rem}.grid-iso-wrap{perspective:600px;display:inline-block}.grid-iso{display:grid;grid-template-columns:repeat(var(--grid-cols, 6),var(--cell-size, 2.5rem));gap:var(--grid-gap, 1px);width:fit-content;background:var(--bg-3);border:1px solid var(--bg-3);transform:rotateX(50deg) rotate(-45deg);transform-origin:center center;transform-style:preserve-3d}.grid-iso .cell{border-radius:0;transition:background .1s,transform .15s}.grid-iso .cell:hover{transform:translateZ(6px);background:var(--surface-cyan)}.grid-iso .cell.raised{transform:translateZ(8px);background:var(--bg-3);box-shadow:0 8px #0006}.grid-iso .cell.fill-cyan{transform:translateZ(4px);box-shadow:0 4px #00506499}.grid-iso .cell.fill-green{transform:translateZ(4px);box-shadow:0 4px #003c1499}.grid-iso .cell.fill-red{transform:translateZ(4px);box-shadow:0 4px #64000099}.grid-iso .cell.fill-orange{transform:translateZ(4px);box-shadow:0 4px #64280099}.grid-iso .cell.fill-purple{transform:translateZ(4px);box-shadow:0 4px #3c005099}.grid-pixel{display:grid;grid-template-columns:repeat(var(--grid-cols, 16),var(--cell-size, 1rem));gap:0;width:fit-content;image-rendering:pixelated}.grid-pixel .cell{border-radius:0;width:var(--cell-size, 1rem);height:var(--cell-size, 1rem);font-size:calc(var(--cell-size, 1rem) * .7);border:none;transition:none}.grid-pixel .cell:hover{opacity:.8;background:var(--cell-hover, rgba(255,255,255,.2))}:root{--glass-bg: linear-gradient(160deg, rgba(255,255,255,.085) 0%, rgba(255,255,255,.03) 42%, rgba(0,0,0,.12) 100%);--glass-bg-hover: linear-gradient(160deg, rgba(255,255,255,.13) 0%, rgba(255,255,255,.05) 42%, rgba(0,0,0,.09) 100%);--glass-bg-active: linear-gradient(160deg, rgba(255,255,255,.17) 0%, rgba(255,255,255,.07) 42%, rgba(0,0,0,.07) 100%);--glass-border: rgba(255, 255, 255, .11);--glass-border-strong: rgba(255, 255, 255, .24);--glass-highlight: linear-gradient(90deg, transparent, rgba(255,255,255,.35) 30%, rgba(255,255,255,.55) 50%, rgba(255,255,255,.35) 70%, transparent);--glass-shadow: 0 10px 32px rgba(0, 0, 0, .22);--glass-text: #ffffff;--glass-text-muted: rgba(255, 255, 255, .55);--glass-radius: var(--radius)}.g-btn:before,.g-card:before,.g-toast:before,.g-nav:before,.g-sidebar:before,.g-modal:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:var(--glass-highlight);pointer-events:none;z-index:1}.g-btn{display:inline-flex;align-items:center;justify-content:center;gap:.4em;padding:.55em 1.2em;border-radius:var(--glass-radius);border:1px solid var(--glass-border);background:var(--glass-bg);color:var(--glass-text);font-family:var(--font-ui);font-size:var(--font-size-sm);font-weight:500;cursor:pointer;transition:background .15s,border-color .15s,transform .1s,box-shadow .15s;box-shadow:var(--glass-shadow);white-space:nowrap;text-decoration:none;position:relative;overflow:hidden}.g-btn:hover{background:var(--glass-bg-hover);border-color:var(--glass-border-strong);transform:translateY(-1px)}.g-btn:active{background:var(--glass-bg-active);transform:translateY(0)}.g-btn.pill{border-radius:999px}.g-btn.sm{padding:.35em .85em;font-size:var(--font-size-xs)}.g-btn.lg{padding:.75em 1.8em;font-size:var(--font-size-md)}.g-btn.icon-btn{width:2.25rem;height:2.25rem;padding:0}.g-btn.icon-btn.pill{border-radius:50%}.g-btn.cyan,.g-card.cyan,.g-toast.cyan,.g-nav.cyan,.g-sidebar.cyan,.g-badge.cyan,.g-tag.cyan{--glass-bg: linear-gradient(160deg, rgba(107,209,224,.1) 0%, rgba(107,209,224,.04) 40%, rgba(0,0,0,.06) 100%);--glass-border: rgba(107,209,224,.22);--glass-highlight: linear-gradient(90deg, transparent, rgba(107,209,224,.5) 40%, rgba(107,209,224,.7) 50%, rgba(107,209,224,.5) 60%, transparent)}.g-btn.magenta,.g-card.magenta,.g-toast.magenta,.g-nav.magenta,.g-sidebar.magenta,.g-badge.magenta,.g-tag.magenta{--glass-bg: linear-gradient(160deg, rgba(255,100,181,.1) 0%, rgba(255,100,181,.04) 40%, rgba(0,0,0,.06) 100%);--glass-border: rgba(255,100,181,.22);--glass-highlight: linear-gradient(90deg, transparent, rgba(255,100,181,.5) 40%, rgba(255,100,181,.7) 50%, rgba(255,100,181,.5) 60%, transparent)}.g-btn.green,.g-card.green,.g-toast.green,.g-nav.green,.g-sidebar.green,.g-badge.green,.g-tag.green{--glass-bg: linear-gradient(160deg, rgba(63,199,99,.1) 0%, rgba(63,199,99,.04) 40%, rgba(0,0,0,.06) 100%);--glass-border: rgba(63,199,99,.22);--glass-highlight: linear-gradient(90deg, transparent, rgba(63,199,99,.5) 40%, rgba(63,199,99,.7) 50%, rgba(63,199,99,.5) 60%, transparent)}.g-btn.red,.g-card.red,.g-toast.red,.g-nav.red,.g-sidebar.red,.g-badge.red,.g-tag.red{--glass-bg: linear-gradient(160deg, rgba(255,96,96,.1) 0%, rgba(255,96,96,.04) 40%, rgba(0,0,0,.06) 100%);--glass-border: rgba(255,96,96,.22);--glass-highlight: linear-gradient(90deg, transparent, rgba(255,96,96,.5) 40%, rgba(255,96,96,.7) 50%, rgba(255,96,96,.5) 60%, transparent)}.g-btn.purple,.g-card.purple,.g-toast.purple,.g-nav.purple,.g-sidebar.purple,.g-badge.purple,.g-tag.purple{--glass-bg: linear-gradient(160deg, rgba(215,75,236,.1) 0%, rgba(215,75,236,.04) 40%, rgba(0,0,0,.06) 100%);--glass-border: rgba(215,75,236,.22);--glass-highlight: linear-gradient(90deg, transparent, rgba(215,75,236,.5) 40%, rgba(215,75,236,.7) 50%, rgba(215,75,236,.5) 60%, transparent)}.g-btn.orange,.g-card.orange,.g-toast.orange,.g-nav.orange,.g-sidebar.orange,.g-badge.orange,.g-tag.orange{--glass-bg: linear-gradient(160deg, rgba(255,162,92,.1) 0%, rgba(255,162,92,.04) 40%, rgba(0,0,0,.06) 100%);--glass-border: rgba(255,162,92,.22);--glass-highlight: linear-gradient(90deg, transparent, rgba(255,162,92,.5) 40%, rgba(255,162,92,.7) 50%, rgba(255,162,92,.5) 60%, transparent)}.g-input,.g-textarea,.g-select{display:block;width:100%;padding:.6em 1em;border-radius:var(--glass-radius);border:1px solid var(--glass-border);background:linear-gradient(160deg,#ffffff0a,#ffffff03);color:var(--glass-text);font-family:var(--font-ui);font-size:var(--font-size-sm);outline:none;transition:border-color .15s,background .15s,box-shadow .15s}.g-input::placeholder,.g-textarea::placeholder{color:var(--glass-text-muted)}.g-input:focus,.g-textarea:focus,.g-select:focus{border-color:var(--glass-border-strong);box-shadow:0 0 0 3px #ffffff0f}.g-input.pill,.g-select.pill{border-radius:999px}.g-textarea{resize:vertical;min-height:6rem}.g-search-wrap{position:relative;display:flex;align-items:center}.g-search-wrap .g-input{padding-left:2.2em}.g-search-wrap:before{content:"⌕";position:absolute;left:.7em;color:var(--glass-text-muted);font-size:1rem;pointer-events:none}.g-card{border-radius:var(--glass-radius);border:1px solid var(--glass-border);background:var(--glass-bg);box-shadow:var(--glass-shadow);color:var(--glass-text);position:relative;overflow:hidden}.g-card .g-card-body{padding:var(--sp-6)}.g-card .g-card-header{padding:var(--sp-4) var(--sp-6);border-bottom:1px solid var(--glass-border);font-weight:600;font-family:var(--font-ui)}.g-card .g-card-footer{padding:var(--sp-4) var(--sp-6);border-top:1px solid var(--glass-border);display:flex;align-items:center;gap:var(--sp-3)}.g-card.pill{border-radius:1.5rem}.g-card .muted{color:var(--glass-text-muted)}.g-badge{display:inline-flex;align-items:center;gap:.3em;padding:.2em .65em;border-radius:var(--glass-radius);border:1px solid var(--glass-border);background:linear-gradient(160deg,#ffffff0e,#ffffff04);color:var(--glass-text);font-family:var(--font-ui);font-size:var(--font-size-xs);font-weight:500;white-space:nowrap}.g-badge.pill{border-radius:999px}.g-badge.cyan{border-color:#6bd1e066;color:var(--cyan)}.g-badge.green{border-color:#3fc76366;color:var(--green)}.g-badge.red{border-color:#ff606066;color:var(--red)}.g-badge.magenta{border-color:#ff64b566;color:var(--magenta)}.g-badge.purple{border-color:#d74bec66;color:var(--purple)}.g-badge.orange{border-color:#ffa25c66;color:var(--orange)}.g-tag{display:inline-flex;align-items:center;gap:.4em;padding:.3em .8em;border-radius:var(--glass-radius);border:1px solid var(--glass-border);background:linear-gradient(160deg,#ffffff0d,#ffffff03);color:var(--glass-text);font-family:var(--font-ui);font-size:var(--font-size-xs);transition:background .15s,border-color .15s}.g-tag.pill{border-radius:999px}.g-tag:hover{background:var(--glass-bg-hover);border-color:var(--glass-border-strong)}.g-tag-remove{opacity:.5;cursor:pointer;line-height:1;transition:opacity .1s}.g-tag-remove:hover{opacity:1}.g-toast{display:flex;align-items:center;gap:var(--sp-3);padding:var(--sp-3) var(--sp-4);border-radius:var(--glass-radius);border:1px solid var(--glass-border);background:var(--glass-bg);color:var(--glass-text);font-family:var(--font-ui);font-size:var(--font-size-sm);box-shadow:var(--glass-shadow);min-width:260px;max-width:400px;position:relative;overflow:hidden}.g-toast.pill{border-radius:999px}.g-toast-icon{font-size:1.1em;flex-shrink:0}.g-toast-msg{flex:1}.g-toast-close{opacity:.5;cursor:pointer;transition:opacity .15s;flex-shrink:0}.g-toast-close:hover{opacity:1}.g-toast.info{border-left:3px solid rgba(107,209,224,.7)}.g-toast.success{border-left:3px solid rgba(63,199,99,.7)}.g-toast.error{border-left:3px solid rgba(255,96,96,.7)}.g-toast.warn{border-left:3px solid rgba(255,162,92,.7)}.g-modal-backdrop{position:fixed;inset:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:9000}.g-modal{border-radius:calc(var(--glass-radius) * 2);border:1px solid var(--glass-border);background:var(--glass-bg);color:var(--glass-text);box-shadow:0 24px 64px #0006;width:min(520px,92vw);position:relative;overflow:hidden}.g-modal-header{padding:var(--sp-6) var(--sp-6) var(--sp-4);display:flex;align-items:center;justify-content:space-between;font-family:var(--font-ui);font-weight:600;font-size:var(--font-size-md)}.g-modal-close{opacity:.5;cursor:pointer;font-size:1.2rem;line-height:1;background:none;border:none;color:var(--glass-text);transition:opacity .15s}.g-modal-close:hover{opacity:1}.g-modal-body{padding:var(--sp-4) var(--sp-6);color:var(--glass-text-muted);line-height:1.65}.g-modal-footer{padding:var(--sp-4) var(--sp-6) var(--sp-6);display:flex;justify-content:flex-end;gap:var(--sp-3);border-top:1px solid var(--glass-border)}.g-nav{display:flex;align-items:center;gap:var(--sp-4);padding:var(--sp-3) var(--sp-6);border-radius:var(--glass-radius);border:1px solid var(--glass-border);background:var(--glass-bg);color:var(--glass-text);box-shadow:var(--glass-shadow);position:relative;overflow:hidden}.g-nav.floating{border-radius:999px;padding:var(--sp-2) var(--sp-4);gap:var(--sp-2)}.g-nav.fixed-top{position:fixed;top:0;left:0;right:0;border-radius:0;border-top:none;border-left:none;border-right:none;z-index:500}.g-nav-brand{font-family:var(--font-display);font-weight:900;font-size:var(--font-size-md);margin-right:auto}.g-nav-links{display:flex;align-items:center;gap:var(--sp-1);list-style:none}.g-nav-link{padding:.35em .9em;border-radius:999px;color:var(--glass-text-muted);text-decoration:none;font-size:var(--font-size-sm);font-family:var(--font-ui);transition:background .15s,color .15s}.g-nav-link:hover,.g-nav-link.active{background:linear-gradient(160deg,#ffffff17,#ffffff08);color:var(--glass-text)}.g-sidebar{display:flex;flex-direction:column;gap:var(--sp-1);padding:var(--sp-4);border-radius:var(--glass-radius);border:1px solid var(--glass-border);background:var(--glass-bg);color:var(--glass-text);box-shadow:var(--glass-shadow);min-width:200px;position:relative;overflow:hidden}.g-sidebar-section{font-family:var(--font-mono);font-size:.65rem;letter-spacing:.1em;text-transform:uppercase;color:var(--glass-text-muted);padding:var(--sp-2) var(--sp-3);margin-top:var(--sp-2)}.g-sidebar-item{display:flex;align-items:center;gap:var(--sp-3);padding:var(--sp-2) var(--sp-3);border-radius:calc(var(--glass-radius) - 2px);color:var(--glass-text-muted);text-decoration:none;font-size:var(--font-size-sm);font-family:var(--font-ui);transition:background .15s,color .15s;cursor:pointer;border:none;background:none;width:100%;text-align:left}.g-sidebar-item:hover{background:linear-gradient(160deg,#ffffff12,#ffffff05);color:var(--glass-text)}.g-sidebar-item.active{background:linear-gradient(160deg,#ffffff1a,#ffffff08);color:var(--glass-text)}.g-sidebar.pill .g-sidebar-item{border-radius:999px}.g-divider{height:1px;background:var(--glass-border);margin:var(--sp-2) 0}.g-progress{height:4px;border-radius:999px;background:#ffffff14;overflow:hidden}.g-progress-fill{height:100%;border-radius:999px;background:#ffffff80;transition:width .4s ease}.g-progress.lg{height:8px}.g-avatar{width:2.5rem;height:2.5rem;border-radius:var(--glass-radius);border:1px solid var(--glass-border);background:linear-gradient(160deg,#ffffff0e,#ffffff04);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:var(--font-size-sm);color:var(--glass-text);overflow:hidden;flex-shrink:0}.g-avatar.pill{border-radius:50%}.g-avatar img{width:100%;height:100%;object-fit:cover}.g-avatar.sm{width:1.75rem;height:1.75rem;font-size:var(--font-size-xs)}.g-avatar.lg{width:3.5rem;height:3.5rem;font-size:var(--font-size-lg)}.g-tooltip-wrap{position:relative;display:inline-flex}.g-tooltip{position:absolute;bottom:calc(100% + 6px);left:50%;transform:translate(-50%);padding:.3em .7em;border-radius:var(--glass-radius);border:1px solid var(--glass-border);background:linear-gradient(160deg,#ffffff12,#ffffff05);color:var(--glass-text);font-size:var(--font-size-xs);font-family:var(--font-ui);white-space:nowrap;pointer-events:none;opacity:0;transition:opacity .15s;box-shadow:var(--glass-shadow)}.g-tooltip.pill{border-radius:999px}.g-tooltip-wrap:hover .g-tooltip{opacity:1}.g-btn.light,.g-input.light,.g-textarea.light,.g-select.light,.g-card.light,.g-badge.light,.g-tag.light,.g-nav.light,.g-sidebar.light,.g-toast.light,.g-modal.light,.g-avatar.light,.g-progress.light,[class*=g-].light{--glass-text: #000000;--glass-text-muted: rgba(0, 0, 0, .5);--glass-border: rgba(0, 0, 0, .08);--glass-border-strong: rgba(0, 0, 0, .2);--glass-bg: linear-gradient(160deg, rgba(255,255,255,.5) 0%, rgba(255,255,255,.3) 40%, rgba(255,255,255,.15) 100%);--glass-bg-hover: linear-gradient(160deg, rgba(255,255,255,.65) 0%, rgba(255,255,255,.45) 40%, rgba(255,255,255,.25) 100%);--glass-highlight: linear-gradient(90deg, transparent, rgba(255,255,255,.7) 30%, rgba(255,255,255,.9) 50%, rgba(255,255,255,.7) 70%, transparent)}:where(.btn,.input,.textarea,.select,.input-date,.search-input,.slider,.number-btn,.color-input,.tab,.accordion-trigger,.modal-close,.navbar-toggle,.dropdown-item,.tag-pill-remove,.chip-remove,.g-btn,.g-input,.g-textarea,.g-select,input,select,textarea,button,a,summary,[tabindex]):focus-visible{outline:2px solid var(--cyan);outline-offset:2px;box-shadow:var(--focus-ring)}:where(.btn,.number-btn,.modal-close,.tag-pill-remove,.chip-remove,.g-btn):disabled,:where(.btn,.number-btn,.modal-close,.tag-pill-remove,.chip-remove,.g-btn)[aria-disabled=true]{cursor:not-allowed;opacity:.45;pointer-events:none;box-shadow:none}:where(input,select,textarea):disabled{cursor:not-allowed;opacity:.55}.file-drop:focus-within{border-color:var(--cyan);box-shadow:var(--focus-ring)}@media(prefers-reduced-motion:reduce){*,*:before,*:after{scroll-behavior:auto!important;animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important}}[hidden]{display:none!important}html,body,#root{height:100%}body{overflow:hidden}.app{height:100%;display:flex;flex-direction:column}.app-head{display:flex;align-items:center;gap:var(--sp-6);padding:var(--sp-3) var(--sp-5);border-bottom:var(--border)}.app-title{font-size:var(--font-size-xl);font-weight:var(--font-weight-black);letter-spacing:.04em;margin:0;background:linear-gradient(90deg,var(--cyan),var(--magenta));-webkit-background-clip:text;background-clip:text;color:transparent}.app-tabs{flex:0 0 auto}.app-progress{margin-left:auto;display:flex;align-items:center;gap:var(--sp-3);font-family:var(--font-ui);font-weight:var(--font-weight-bold)}.app-progress .progress{width:120px}.app-main{flex:1;min-height:0}.app-foot{padding:var(--sp-1) var(--sp-5);font-size:var(--font-size-xs);border-top:var(--border)}.app-load{display:grid;place-items:center;height:100%}.map-view{position:relative;height:100%}.railmap{position:relative;width:100%;height:100%;overflow:hidden;background:var(--bg);cursor:crosshair;touch-action:none}.railmap canvas{display:block;width:100%;height:100%;image-rendering:pixelated}.railmap-static{aspect-ratio:4 / 3;height:auto;border:var(--border)}.railmap-name{position:absolute;top:var(--sp-3);left:var(--sp-3);padding:var(--sp-1) var(--sp-3);background:var(--bg-1);border:var(--border);font-family:var(--font-ja-display);font-weight:var(--font-weight-bold);pointer-events:none}.railmap-zoom{position:absolute;bottom:var(--sp-3);left:var(--sp-3);display:flex;flex-direction:column;gap:2px}.railmap-legend{position:absolute;bottom:var(--sp-3);right:var(--sp-3);display:flex;gap:var(--sp-3);padding:var(--sp-1) var(--sp-3);background:var(--bg-1);border:var(--border);font-size:var(--font-size-xs);font-family:var(--font-ja)}.railmap-legend span{display:flex;align-items:center;gap:4px}.railmap-legend i{width:8px;height:8px;display:inline-block}.map-detail{position:absolute;top:var(--sp-3);right:var(--sp-3);width:320px;max-height:calc(100% - var(--sp-6));overflow-y:auto}.line-detail{display:flex;flex-direction:column;gap:var(--sp-3)}.line-detail-head{display:flex;align-items:center;gap:var(--sp-3)}.line-detail-head h3{margin:0;flex:1}.line-detail-op{font-size:var(--font-size-sm)}.line-detail-facts{display:flex;flex-direction:column;gap:var(--sp-1);font-size:var(--font-size-sm);font-family:var(--font-ja)}.line-detail-sta{font-size:var(--font-size-xs);line-height:1.8;max-height:7.2em;overflow-y:auto}.known-btn{width:100%}.known-btn.known-yes{border-color:var(--green);color:var(--green)}.zukan{display:flex;height:100%;min-height:0}.zukan-nav{width:200px;flex:0 0 auto;overflow-y:auto;border-right:var(--border);padding:var(--sp-3)}.zukan-area-name{font-family:var(--font-ja-display);font-weight:var(--font-weight-bold);font-size:var(--font-size-xs);color:var(--fg-subtle);margin:var(--sp-3) 0 var(--sp-1)}.zukan-pref{display:flex;justify-content:space-between;width:100%;padding:2px var(--sp-2);background:none;border:none;color:var(--fg);font-family:var(--font-ja);font-size:var(--font-size-sm);cursor:pointer}.zukan-pref:hover{background:var(--surface-neutral-hover)}.zukan-pref.active{background:var(--surface-cyan);color:var(--cyan)}.zukan-main{flex:1;overflow-y:auto;padding:var(--sp-5);min-width:0}.zukan-head{display:flex;align-items:baseline;gap:var(--sp-4);margin-bottom:var(--sp-4)}.zukan-head h2{margin:0}.zukan-group{margin-bottom:var(--sp-4)}.zukan-group-name{font-family:var(--font-ja-display);font-weight:var(--font-weight-bold);font-size:var(--font-size-sm);margin-bottom:var(--sp-2)}.zukan-chips{display:flex;flex-wrap:wrap;gap:var(--sp-2)}.zukan-detail{width:340px;flex:0 0 auto;overflow-y:auto;padding:var(--sp-3);border-left:var(--border)}.line-chip{padding:var(--sp-1) var(--sp-3);border:1px solid var(--c);background:transparent;color:var(--c);font-family:var(--font-ja);font-size:var(--font-size-sm);cursor:pointer;opacity:.55}.line-chip:hover{opacity:.85}.line-chip.known{background:var(--c);color:var(--bg);opacity:1;font-weight:var(--font-weight-bold)}.quiz{max-width:640px;margin:0 auto;padding:var(--sp-6) var(--sp-5);display:flex;flex-direction:column;gap:var(--sp-4);height:100%;overflow-y:auto}.quiz-menu{justify-content:center}.quiz-mode{text-align:left;cursor:pointer;border:var(--border)}.quiz-mode:hover{border-color:var(--cyan)}.quiz-mode h3{margin:0 0 var(--sp-1)}.quiz-head{display:flex;align-items:center;gap:var(--sp-4)}.quiz-dots{display:flex;gap:4px}.quiz-dots i{width:10px;height:10px;background:var(--bg-3)}.quiz-dots i.now{background:var(--fg-muted)}.quiz-dots i.ok{background:var(--green)}.quiz-dots i.ng{background:var(--red)}.quiz-prompt{margin:0}.quiz-options{display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-2)}.quiz-opt{font-family:var(--font-ja)}.quiz-opt.right{border-color:var(--green);color:var(--green)}.quiz-opt.wrong{border-color:var(--red);color:var(--red)}.quiz-next{display:flex;align-items:center;justify-content:space-between;gap:var(--sp-3);font-size:var(--font-size-sm)}.quiz-result{align-items:center;text-align:center}.quiz-review{display:flex;flex-wrap:wrap;gap:var(--sp-2);justify-content:center}.quiz-actions{display:flex;gap:var(--sp-3)}@media(max-width:720px){.app-head{flex-wrap:wrap;gap:var(--sp-3)}.zukan-nav{width:132px}.zukan{flex-wrap:wrap}.zukan-detail{width:100%;border-left:none;border-top:var(--border)}.map-detail{width:calc(100% - var(--sp-6));max-height:55%}.quiz-options{grid-template-columns:1fr}}
