.skip-link{z-index:10000;background:var(--accent,#8b2a1a);color:#fff;border-radius:0 0 4px 4px;padding:8px 16px;font-weight:600;text-decoration:none;position:absolute;top:-100%;left:16px}.skip-link:focus{top:0}:root{--bg:#f5f1eb;--bg-elev:#faf7f1;--bg-deep:#efeadd;--ink:#2a2520;--ink-2:#4a4234;--ink-soft:#8b816e;--rule:#e0d9c9;--accent:#c96442;--accent-soft:#e5b79e;--accent-deep:#a04e30;--font-serif:"Fraunces", Georgia, "Songti SC", "STSong", "Times New Roman", serif;--font-sans:"DM Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", "PingFang SC", "Microsoft YaHei", system-ui, sans-serif;--font-mono:"JetBrains Mono", "Cascadia Code", "SF Mono", Consolas, "Courier New", monospace;--t-fast:.24s;--t-base:.6s;--t-slow:1.2s;--t-cine:1.8s;--ease-out-expo:cubic-bezier(.22, 1, .36, 1);--ease-in-out-expo:cubic-bezier(.65, 0, .35, 1)}*{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{background:var(--bg);color:var(--ink);font-family:var(--font-sans);-webkit-font-smoothing:antialiased;background-image:radial-gradient(circle at 1px 1px,#3c321e0a 1px,#0000 0);background-size:24px 24px;font-size:16px;line-height:1.6}::selection{background:var(--accent-soft);color:var(--ink)}nav.top{z-index:50;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--rule);background:#f5f1ebd9;position:sticky;top:0}.nav-inner{justify-content:space-between;align-items:center;max-width:1100px;margin:0 auto;padding:16px 32px;display:flex}.brand{font-family:var(--font-serif);letter-spacing:-.01em;align-items:center;gap:10px;font-size:22px;font-style:italic;font-weight:500;display:flex}.brand .dot{color:var(--accent)}.brand-mini{object-fit:cover;border:1.5px solid var(--rule);border-radius:50%;width:28px;height:28px}.nav-links{gap:28px;display:flex}.nav-links a{color:var(--ink-2);font-size:14px;text-decoration:none;transition:color .2s;position:relative}.nav-links a:hover{color:var(--accent)}.nav-links a:after{content:"";background:var(--accent);width:0;height:1.5px;transition:width .25s;position:absolute;bottom:-4px;left:0}.nav-links a:hover:after{width:100%}@media (max-width:640px){.nav-links{gap:16px}.nav-links a{font-size:13px}.nav-inner{padding:12px 20px}.brand{font-size:18px}.brand-mini{width:24px;height:24px}}main{max-width:1100px;margin:0 auto;padding:0 32px}@media (max-width:640px){main{padding:0 20px}}section{border-bottom:1px solid var(--rule);padding:80px 0}section:last-child{border-bottom:none}.label{font-family:var(--font-mono);letter-spacing:.18em;text-transform:uppercase;color:var(--ink-soft);align-items:center;gap:10px;margin-bottom:20px;font-size:11px;display:flex}.label:before{content:"";background:var(--accent);width:24px;height:1px}h1.display{font-family:var(--font-serif);letter-spacing:-.02em;max-width:14ch;margin-bottom:32px;font-size:clamp(40px,7vw,76px);font-weight:400;line-height:1.05}h1.display em{color:var(--accent);font-style:italic;font-weight:300}h2{font-family:var(--font-serif);letter-spacing:-.015em;max-width:20ch;margin-bottom:32px;font-size:clamp(28px,4vw,40px);font-weight:500;line-height:1.15}h2 em{color:var(--ink-soft);font-style:italic;font-weight:300}p.lead{color:var(--ink-2);max-width:58ch;margin-bottom:32px;font-size:19px;line-height:1.55}.hero{padding:100px 0 80px}.hero-meta{border-top:1px dashed var(--rule);font-family:var(--font-mono);color:var(--ink-soft);letter-spacing:.08em;flex-wrap:wrap;gap:clamp(12px,3vw,28px);margin-top:clamp(24px,5vh,48px);padding-top:28px;font-size:clamp(10px,1.2vw,12px);display:flex}.hero-meta span{opacity:.7;transition:opacity .3s,transform .3s}.hero-meta span:hover{opacity:1;transform:translateY(-1px)}.hero-meta strong{color:var(--ink);font-weight:500}.replay-intro-btn{border:none;border-bottom:1px dotted var(--rule);font-family:var(--font-mono);letter-spacing:.12em;color:var(--ink-soft);cursor:pointer;background:0 0;margin-top:20px;padding:6px 0;font-size:10px;transition:color .25s,border-color .25s;display:inline-block}.replay-intro-btn:hover{color:var(--accent);border-color:var(--accent-soft)}.pulse{background:var(--accent);border-radius:50%;width:6px;height:6px;margin-right:6px;animation:2s infinite pulse;display:inline-block}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.8)}}@keyframes skPulse{0%,to{opacity:.5}50%{opacity:.2}}.about-grid{grid-template-columns:1.4fr 1fr;align-items:start;gap:64px;display:grid}@media (max-width:760px){.about-grid{grid-template-columns:1fr;gap:40px}}.about-text p{color:var(--ink-2);margin-bottom:18px}.about-text p:last-child{margin-bottom:0}.about-text a{color:var(--accent);border-bottom:1px dashed var(--accent-soft);text-decoration:none}.about-text a:hover{border-bottom-style:solid}.portrait-stack{gap:24px;display:grid}.portrait{border:1px solid var(--rule);background:var(--bg-elev);box-shadow:0 1px 0 var(--rule), 0 8px 24px -16px #3c281426;border-radius:3px;padding:12px 12px 14px}.portrait img{aspect-ratio:1;object-fit:cover;filter:contrast(1.02)saturate(.95);border-radius:2px;width:100%;display:block}.portrait-caption{font-family:var(--font-mono);color:var(--ink-soft);justify-content:space-between;margin-top:12px;font-size:11px;display:flex}.portrait-caption .glyph{color:var(--accent)}.sidecard{background:var(--bg-elev);border:1px solid var(--rule);border-radius:4px;padding:24px;font-size:14px}.sidecard h3{font-family:var(--font-mono);letter-spacing:.15em;text-transform:uppercase;color:var(--ink-soft);margin-bottom:16px;font-size:11px;font-weight:500}.sidecard ul{list-style:none}.sidecard li{border-bottom:1px dotted var(--rule);justify-content:space-between;gap:12px;padding:9px 0;display:flex}.sidecard li:last-child{border-bottom:none}.sidecard li span:first-child{color:var(--ink-soft);flex-shrink:0}.sidecard li span:last-child{color:var(--ink-2);text-align:right}.work-grid{background:var(--rule);border:1px solid var(--rule);grid-template-columns:repeat(2,1fr);gap:4px;display:grid}@media (max-width:640px){.work-grid{grid-template-columns:1fr}}.work-card{background:var(--bg-elev);cursor:pointer;color:inherit;padding:36px 32px;text-decoration:none;transition:background .25s;display:block;position:relative}.work-card:hover{background:var(--bg-deep)}.work-card:hover .arrow{color:var(--accent);transform:translate(4px,-4px)}.work-card .year{font-family:var(--font-mono);color:var(--ink-soft);letter-spacing:.1em;font-size:11px}.work-card h3{font-family:var(--font-serif);letter-spacing:-.01em;word-break:break-word;margin:8px 0 12px;font-size:22px;font-weight:500}.work-card h3 .repo-mono{font-family:var(--font-mono);font-size:16px;font-weight:500}.work-card p{color:var(--ink-2);margin-bottom:20px;font-size:15px}.work-card .tags{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.tag{font-family:var(--font-mono);background:var(--bg-deep);color:var(--ink-soft);letter-spacing:.05em;border-radius:2px;padding:3px 8px;font-size:10px}.tag.star{color:var(--accent);background:0 0;padding:0}.arrow{color:var(--ink-soft);font-size:18px;transition:all .25s;position:absolute;top:32px;right:32px}.post{border-bottom:1px solid var(--rule);color:inherit;grid-template-columns:100px 1fr auto;align-items:baseline;gap:32px;padding:24px 0;text-decoration:none;transition:padding-left .2s;display:grid}.post:hover{padding-left:8px}.post:hover .post-title{color:var(--accent)}.post:last-child{border-bottom:none}.post-date{font-family:var(--font-mono);color:var(--ink-soft);font-size:12px}.post-title{font-family:var(--font-serif);letter-spacing:-.01em;font-size:20px;font-weight:500;transition:color .2s}.post-meta{font-family:var(--font-mono);color:var(--ink-soft);text-align:right;white-space:nowrap;font-size:11px}@media (max-width:640px){.post{grid-template-columns:1fr;gap:6px}.post-meta{text-align:left}}.guestbook-form{flex-wrap:wrap;gap:8px;margin-bottom:28px;display:flex}.guestbook-form input,.guestbook-form textarea,.contact-form input,.contact-form textarea{font-family:var(--font-sans);border:1px solid var(--rule);background:var(--bg-elev);color:var(--ink);border-radius:3px;outline:none;padding:12px 14px;font-size:15px;transition:border-color .2s}.guestbook-form input:focus,.guestbook-form textarea:focus,.contact-form input:focus,.contact-form textarea:focus{border-color:var(--accent)}.guestbook-form input{flex:0 0 180px}.guestbook-form textarea{resize:none;flex:1;min-width:200px;min-height:44px}button.send{font-family:var(--font-sans);background:var(--ink);color:var(--bg);cursor:pointer;border:none;border-radius:3px;padding:12px 22px;font-size:14px;font-weight:500;transition:background .2s,transform .1s}button.send:hover{background:var(--accent)}button.send:active{transform:scale(.98)}button.send:disabled{opacity:.5;cursor:not-allowed}.entry{border-bottom:1px dashed var(--rule);padding:18px 0;animation:.4s fadeIn}.entry:last-child{border-bottom:none}@keyframes fadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.entry-head{justify-content:space-between;margin-bottom:6px;font-size:13px;display:flex}.entry-name{color:var(--ink);font-weight:500}.entry-time{font-family:var(--font-mono);color:var(--ink-soft);font-size:11px}.entry-msg{color:var(--ink-2);font-size:15px}.contact-form{gap:12px;max-width:520px;display:grid}.contact-form .row{grid-template-columns:1fr 1fr;gap:12px;display:grid}@media (max-width:540px){.contact-form .row{grid-template-columns:1fr}}.contact-form textarea{resize:vertical;min-height:120px}.form-ok{background:var(--accent-soft);color:var(--accent-deep);border-radius:3px;margin-top:12px;padding:12px 16px;font-size:14px;animation:.4s fadeIn}.form-err{color:#8b2a1a;background:#f5d5c8;border-radius:3px;margin-top:12px;padding:12px 16px;font-size:14px}footer{text-align:center;max-width:1100px;font-family:var(--font-mono);color:var(--ink-soft);letter-spacing:.05em;margin:0 auto;padding:40px 32px 60px;font-size:11px}footer .accent{color:var(--accent)}footer a{color:var(--ink-soft);border-bottom:1px dotted var(--rule);text-decoration:none}footer a:hover{color:var(--accent)}.notfound-link:hover{background:var(--accent)!important}.hamburger{cursor:pointer;color:var(--ink-2);background:0 0;border:none;padding:4px;font-size:24px;line-height:1;display:none}.mobile-menu{z-index:100;background:var(--bg);flex-direction:column;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.mobile-close{cursor:pointer;color:var(--ink-2);background:0 0;border:none;font-size:32px;position:absolute;top:20px;right:28px}.mobile-links{flex-direction:column;align-items:center;gap:24px;display:flex}.mobile-link{font-family:var(--font-serif);color:var(--ink);font-size:clamp(28px,4vw,40px);font-style:italic;font-weight:500;text-decoration:none;transition:color .2s}.mobile-link:hover{color:var(--accent)}@media (max-width:700px){.nav-links{display:none}.hamburger{display:block}}.footer-sitemap{border-bottom:1px solid var(--rule);justify-content:center;gap:64px;margin-bottom:24px;padding-bottom:24px;display:flex}.footer-group{text-align:left;flex-direction:column;gap:8px;display:flex}.footer-group-title{font-family:var(--font-mono);letter-spacing:.1em;color:var(--ink-soft);text-transform:uppercase;margin-bottom:4px;font-size:11px}.footer-group a{color:var(--ink-2);font-size:14px;text-decoration:none;transition:color .2s}.footer-group a:hover{color:var(--accent)}.footer-bottom{color:var(--ink-soft);font-family:var(--font-mono);letter-spacing:.05em;font-size:11px}.footer-bottom .accent{color:var(--accent)}.footer-bottom a{color:var(--ink-soft);border-bottom:1px dotted var(--rule);text-decoration:none}.footer-bottom a:hover{color:var(--accent)}@media (max-width:500px){.footer-sitemap{flex-wrap:wrap;gap:32px}}.webring{font-family:var(--font-mono);justify-content:center;align-items:center;gap:16px;margin-bottom:16px;padding:16px 0;font-size:12px;display:flex}.webring-link{color:var(--ink-soft);text-decoration:none;transition:color .2s}.webring-link:hover{color:var(--accent)}.webring-name{color:var(--accent);font-weight:500}.admin-nav{background:var(--ink);color:var(--bg);border-bottom:1px solid #3d3528}.admin-nav-inner{justify-content:space-between;align-items:center;max-width:1100px;margin:0 auto;padding:12px 32px;display:flex}.admin-nav-links{align-items:center;gap:24px;display:flex}.admin-nav-links a{color:var(--bg);font-size:13px;font-family:var(--font-mono);letter-spacing:.05em;text-decoration:none;transition:color .2s}.admin-nav-links a:hover{color:var(--accent-soft)}.admin-table{border-collapse:collapse;width:100%}.admin-table th{text-align:left;font-family:var(--font-mono);letter-spacing:.08em;text-transform:uppercase;color:var(--ink-soft);border-bottom:1px solid var(--rule);padding:12px;font-size:11px}.admin-table td{border-bottom:1px dashed var(--rule);padding:14px 12px;font-size:14px}.admin-table tr:hover td{background:var(--bg-deep)}.admin-mono{font-family:var(--font-mono);color:var(--ink-soft);font-size:12px!important}.admin-actions{justify-content:flex-end;gap:8px;display:flex}.admin-badge{font-family:var(--font-mono);letter-spacing:.05em;border-radius:2px;padding:3px 8px;font-size:10px;display:inline-block}.admin-badge-live{background:var(--accent-soft);color:var(--accent-deep)}.admin-badge-draft{background:var(--bg-deep);color:var(--ink-soft)}.admin-btn{font-family:var(--font-mono);letter-spacing:.05em;border:1px solid var(--rule);background:var(--bg-elev);color:var(--ink-2);cursor:pointer;border-radius:3px;padding:6px 14px;font-size:12px;text-decoration:none;transition:border-color .2s,background .2s;display:inline-block}.admin-btn:hover{border-color:var(--accent);background:var(--bg-deep)}.admin-btn-danger{color:var(--accent-deep);border-color:var(--accent-soft)}.admin-btn-danger:hover{border-color:var(--accent-deep);background:#f5d5c8}.admin-form{gap:4px;max-width:720px;display:grid}.admin-form-group{flex-direction:column;gap:6px;display:flex}.admin-form-group input,.admin-form-group textarea{font-family:var(--font-sans);border:1px solid var(--rule);background:var(--bg-elev);color:var(--ink);border-radius:3px;outline:none;padding:12px 14px;font-size:15px;transition:border-color .2s}.admin-form-group input:focus,.admin-form-group textarea:focus{border-color:var(--accent)}.admin-form-group textarea{resize:vertical}.admin-form-row{flex-wrap:wrap;align-items:flex-start;gap:24px;display:flex}.admin-form-actions{align-items:center;gap:12px;margin-top:20px;display:flex}.coffee-btn{font-family:var(--font-sans);border-radius:3px;align-items:center;gap:8px;font-size:13px;font-weight:500;text-decoration:none;transition:all .2s;display:inline-flex}.coffee-btn-sm{border:1px solid var(--rule);color:var(--ink-2);background:0 0;padding:6px 14px}.coffee-btn-sm:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-soft)}.coffee-btn-lg{background:var(--accent);color:#fff;border:none;padding:14px 28px;font-size:16px}.coffee-btn-lg:hover{background:var(--accent-deep);transform:scale(1.02)}.coffee-emoji{font-size:1.1em}.annotation-sidebar{background:var(--bg-elev);border-left:1px solid var(--rule);z-index:30;width:280px;padding:24px 20px;position:fixed;top:80px;bottom:0;right:0;overflow-y:auto}@media (max-width:1023px){.annotation-sidebar{display:none}}.annotation-card{background:var(--bg);border:1px solid var(--rule);border-radius:3px;margin-bottom:10px;padding:12px;font-size:13px;position:relative}.annotation-text{color:var(--ink-soft);word-break:break-word;margin-bottom:6px;font-style:italic;line-height:1.4}.annotation-note{color:var(--ink-2);word-break:break-word;line-height:1.4}.annotation-delete{cursor:pointer;color:var(--ink-soft);background:0 0;border:none;font-size:16px;line-height:1;position:absolute;top:8px;right:8px}.annotation-delete:hover{color:var(--accent)}.reveal{opacity:0;transition:opacity .6s,transform .6s;transform:translateY(8px)}.reveal.visible{opacity:1;transform:translateY(0)}@media (prefers-reduced-motion:reduce){.reveal{opacity:1;transition:none;transform:none}}@media (hover:hover){.hover-zoom{transform-origin:50% 60%;transition:transform .35s cubic-bezier(.2,.8,.25,1);display:inline-block}.hover-zoom:hover{transform:scale(1.05)}@media (prefers-reduced-motion:reduce){.hover-zoom{transition:none}.hover-zoom:hover{transform:none}}}.konami-overlay{z-index:9999;cursor:pointer;background:#2a2520d9;justify-content:center;align-items:center;animation:.5s fadeIn;display:flex;position:fixed;inset:0}.konami-toast{background:var(--bg-elev);text-align:center;cursor:default;border-radius:6px;padding:40px 48px;box-shadow:0 16px 48px #0003}.prose{color:var(--ink-2);font-size:17px;line-height:1.7}.prose h2{font-family:var(--font-serif);color:var(--ink);letter-spacing:-.01em;margin:48px 0 16px;font-size:28px}.prose h3{font-family:var(--font-serif);color:var(--ink);margin:36px 0 12px;font-size:22px}.prose p{margin-bottom:20px}.prose strong{color:var(--ink);font-weight:600}.prose code{font-family:var(--font-mono);background:var(--bg-deep);color:var(--accent-deep);border-radius:2px;padding:2px 6px;font-size:14px}.prose pre{background:var(--ink);color:var(--bg);border-radius:4px;margin:24px 0;padding:20px 24px;font-size:14px;line-height:1.5;overflow-x:auto}.prose pre code{color:inherit;font-size:inherit;background:0 0;padding:0}.prose ul,.prose ol{margin:0 0 20px 24px}.prose li{margin-bottom:8px}.prose blockquote{border-left:3px solid var(--accent);color:var(--ink-soft);margin:24px 0;padding:4px 0 4px 20px;font-style:italic}.prose a{color:var(--accent);border-bottom:1px dashed var(--accent-soft);text-decoration:none}.prose a:hover{border-bottom-style:solid}.locale-switcher{font-family:var(--font-mono);align-items:center;gap:0;margin-left:12px;font-size:11px;display:inline-flex}.locale-sep{color:var(--rule);margin:0 2px}.locale-btn{color:var(--ink-soft);cursor:pointer;font-family:inherit;font-size:inherit;background:0 0;border:none;border-radius:2px;padding:2px 4px}.locale-btn:hover{color:var(--ink)}.locale-active{color:var(--accent);font-weight:500}.prose hr{border:none;border-top:1px solid var(--rule);margin:40px 0}.chat-panel{border:1px solid var(--rule);background:var(--bg-elev);border-radius:4px;max-width:640px;overflow:hidden}.chat-messages{flex-direction:column;gap:12px;height:400px;padding:20px;display:flex;overflow-y:auto}.chat-empty{text-align:center;color:var(--ink-soft);padding:60px 0;font-size:14px}.chat-msg{display:flex}.chat-msg-user{justify-content:flex-end}.chat-msg-bot{justify-content:flex-start}.chat-bubble{border-radius:12px;max-width:80%;padding:10px 16px;font-size:15px;line-height:1.5}.chat-msg-user .chat-bubble{background:var(--accent);color:#fff;border-bottom-right-radius:4px}.chat-msg-bot .chat-bubble{background:var(--bg-deep);color:var(--ink-2);border-bottom-left-radius:4px}.chat-typing{gap:4px;padding:14px 18px;display:flex}.chat-typing span{background:var(--ink-soft);border-radius:50%;width:6px;height:6px;animation:1.4s infinite both chatTyping}.chat-typing span:nth-child(2){animation-delay:.2s}.chat-typing span:nth-child(3){animation-delay:.4s}@keyframes chatTyping{0%,60%,to{opacity:.3}30%{opacity:1}}.chat-input-row{border-top:1px solid var(--rule);background:var(--bg);gap:8px;padding:12px 16px;display:flex}.chat-header{border-bottom:1px solid var(--rule);background:var(--bg-deep);justify-content:space-between;align-items:center;padding:12px 16px;display:flex}.chat-header-label{font-family:var(--font-mono);letter-spacing:.08em;text-transform:uppercase;color:var(--ink-soft);font-size:11px}.bot-status-badge{font-family:var(--font-mono);background:var(--bg);color:var(--ink-soft);border-radius:12px;align-items:center;gap:6px;padding:4px 10px;font-size:11px;display:inline-flex}.bot-online{color:#3b7a3b}.bot-offline{color:var(--accent-deep)}.bot-dot{background:currentColor;border-radius:50%;flex-shrink:0;width:6px;height:6px}.chat-ts{font-family:var(--font-mono);color:var(--ink-soft);margin-top:4px;font-size:10px;display:block}.chat-show-more{font-family:var(--font-mono);color:var(--accent);cursor:pointer;background:0 0;border:none;margin-top:4px;padding:2px 0;font-size:10px;display:block}.chat-show-more:hover{color:var(--accent-deep)}.chat-msg-bot .chat-bubble{font-family:var(--font-serif)}.chat-msg-user .chat-ts{text-align:right}.chat-input-row textarea{font-family:var(--font-sans);border:1px solid var(--rule);background:var(--bg-elev);color:var(--ink);resize:none;border-radius:12px;outline:none;flex:1;min-height:44px;padding:10px 14px;font-size:14px;line-height:1.5}.chat-input-row input:focus,.chat-input-row textarea:focus{border-color:var(--accent-soft)}.chat-input-row button{font-family:var(--font-mono);background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:20px;padding:10px 20px;font-size:12px;transition:background .2s}.chat-input-row button:hover:not(:disabled){background:var(--accent-deep)}.chat-input-row button:disabled{opacity:.4;cursor:not-allowed}@media (max-width:640px){.chat-messages{height:360px;padding:14px}.chat-bubble{max-width:88%;font-size:14px}}.journey-section{justify-content:center;align-items:center;min-height:100dvh;display:flex;position:relative;overflow:hidden}.journey-hero-title{font-family:var(--font-serif);text-align:center;font-size:clamp(3rem,1rem + 7vw,8rem);font-style:italic}.journey-demo-text{font-family:var(--font-serif);text-align:center;font-size:clamp(4rem,2rem + 8vw,10rem);font-style:italic}.journey-placeholder{font-family:var(--font-mono);color:var(--ink-soft);text-align:center;border:1px dashed var(--rule);border-radius:4px;padding:32px 48px;font-size:14px}.journey-end-link{font-family:var(--font-sans);color:var(--accent);font-size:18px;text-decoration:none;transition:color .2s}.journey-end-link:hover{color:var(--accent-deep)}.train-section{background:#0a0a0f;flex-direction:column;justify-content:center;align-items:center;min-height:100dvh;display:flex;position:relative;overflow:hidden}.train-window{aspect-ratio:16/9;border-radius:16px;width:min(90vw,1100px);max-height:70vh;position:relative;overflow:hidden}.train-viewport{position:absolute;inset:0;overflow:hidden}.train-static-bg{background-position:50%;background-size:cover;width:100%;height:100%}.parallax-layer{background-position:50%;background-size:cover;position:absolute;inset:0}.parallax-layer--bg{z-index:1;width:120%;left:-10%}.parallax-layer--mid{z-index:2;width:180%;left:-40%}.parallax-layer--fg{z-index:3;width:250%;left:-75%}@media (prefers-reduced-motion:reduce){.parallax-layer,.parallax-layer--bg,.parallax-layer--mid,.parallax-layer--fg{transform:none!important}}.train-frame{z-index:10;pointer-events:none;position:absolute;inset:0}.train-frame-svg{width:100%;height:100%}.train-vignette{z-index:11;pointer-events:none;background:radial-gradient(#0000 55%,#0000008c 100%);position:absolute;inset:0}.train-caption{z-index:20;text-align:center;position:absolute;bottom:clamp(24px,5vh,60px);left:50%;transform:translate(-50%)}.train-caption p{font-family:var(--font-serif);color:#e8e0d4;text-shadow:0 2px 12px #0009;margin:0;font-size:clamp(18px,2.5vw,28px);font-style:italic}@media (max-width:768px){.train-window{aspect-ratio:4/3;width:94vw}.train-caption p{font-size:16px}}.hero .display em{color:var(--accent);font-style:italic;transition:color .6s;display:inline-block}.hero .lead span{transition:opacity .5s,transform .5s;display:inline-block}.cursor-glow{pointer-events:none;z-index:0;background:radial-gradient(circle,#c964421f 0%,#0000 70%);border-radius:50%;width:300px;height:300px;transition:opacity .4s;position:fixed;top:0;left:0;transform:translate(-50%,-50%)}html.lenis,html.lenis body{height:auto}.lenis.lenis-smooth{scroll-behavior:auto!important}.lenis.lenis-smooth [data-lenis-prevent]{overscroll-behavior:contain}.lenis.lenis-stopped{overflow:clip}.lenis.lenis-smooth iframe{pointer-events:none}@media (prefers-reduced-motion:reduce){.lenis.lenis-smooth{scroll-behavior:auto!important}}.opening-overlay{z-index:10000;cursor:none;background:#f4efe6;flex-direction:column;justify-content:center;align-items:center;display:flex;position:fixed;inset:0;overflow:hidden}.opening-bg-wrap{z-index:0;pointer-events:none;position:absolute;inset:-40px;overflow:hidden}.opening-bg-video{object-fit:cover;opacity:.17;filter:saturate(.5)contrast(.9)brightness(1.4);pointer-events:none;width:100%;height:100%;position:absolute;inset:0}.opening-bg-shade{background:radial-gradient(60% 45% at 50% 42%,#0000 0%,#f4efe68c 58%,#f4efe6eb 100%);position:absolute;inset:0}.opening-miku-glow{pointer-events:none;background:radial-gradient(38% 48% at 52% 46%,#fffaf52e 0%,#0000 55%),radial-gradient(22% 32% at 48% 48%,#c8462c0f 0%,#0000 48%);position:absolute;inset:0}.opening-beam{z-index:2;pointer-events:none;clip-path:polygon(20% 0%,80% 0%,75% 100%,25% 100%);background:linear-gradient(#c964420f 0%,#c9644205 35%,#c9644201 60%,#0000 80%);width:55vw;height:100%;animation:6s ease-in-out infinite beamBreath;position:absolute;top:0;left:50%;transform:translate(-50%)}@keyframes beamBreath{0%,to{opacity:.35}50%{opacity:.65}}.opening-fog{z-index:3;pointer-events:none;background:radial-gradient(55% 38% at 18% 75%,#c8b4a040 0%,#0000 55%),radial-gradient(45% 32% at 82% 25%,#c8b4a033 0%,#0000 50%);position:absolute;inset:0}.opening-spot{z-index:4;pointer-events:none;background:radial-gradient(50% 60% at 50% 42%,#c964420a 0%,#0000 62%);position:absolute;inset:0}.opening-vignette{z-index:6;pointer-events:none;background:radial-gradient(72% 72% at 50% 46%,#0000 26%,#f4efe661 55%,#f4efe6ad 82%,#f4efe6f0 100%);position:absolute;inset:0}.opening-aura{pointer-events:none;z-index:9998;will-change:left,top;background:radial-gradient(circle,#c8462c40 0%,#c8462c14 50%,#0000 70%);border:1px solid #c8462c4d;border-radius:50%;width:180px;height:180px;transition:transform .4s;position:fixed;box-shadow:0 0 60px #c8462c26,0 0 120px #c8462c0f,inset 0 0 30px #c8462c0f}.opening-spotlight{pointer-events:none;z-index:5;mix-blend-mode:soft-light;will-change:left,top;background:radial-gradient(circle,#ffffff47 0%,#ffffff1a 38%,#0000 62%);border-radius:50%;width:260px;height:260px;transition:opacity .2s;position:fixed}.opening-inner{text-align:center;z-index:10;width:100%;max-width:1100px;padding:60px 40px;position:relative;overflow:hidden}.opening-mark{font-family:var(--font-serif);letter-spacing:.32em;color:var(--accent);text-transform:uppercase;justify-content:center;align-items:center;gap:16px;margin-bottom:60px;font-size:12px;font-style:italic;display:flex}.opening-mark:before,.opening-mark:after{content:"";opacity:.4;background:var(--accent);flex-shrink:0;width:32px;height:1px;display:inline-block}.opening-title{font-family:"Fraunces",var(--font-serif);letter-spacing:.05em;color:#0000;-webkit-text-stroke:2.5px var(--ink);text-align:center;overflow-wrap:break-word;word-break:keep-all;transition:opacity .55s var(--ease-out-expo,cubic-bezier(.22,1,.36,1)),-webkit-text-stroke-color .7s var(--ease-out-expo,cubic-bezier(.22,1,.36,1));margin:0;font-size:clamp(56px,13vw,150px);font-weight:300;line-height:.9}.opening-title em{font-family:"Fraunces",var(--font-serif);-webkit-text-stroke-color:var(--accent);-webkit-text-stroke-width:3px;font-style:italic;font-weight:600}.opening-sub{font-family:var(--font-serif);color:var(--ink-2);max-width:560px;margin-top:36px;margin-left:auto;margin-right:auto;font-size:clamp(14px,1.4vw,19px);font-style:italic;font-weight:400;line-height:1.7}.opening-enter{color:var(--ink);border:1px solid var(--rule);font-family:var(--font-sans);letter-spacing:.32em;text-transform:uppercase;background:0 0;border-radius:999px;align-items:center;gap:14px;margin-top:56px;padding:18px 32px;font-size:12px;font-weight:400;transition:border-color .35s,color .35s,padding .35s,box-shadow .35s;display:inline-flex;cursor:pointer!important}.opening-enter:hover{border-color:var(--accent);color:var(--accent);padding:18px 40px;box-shadow:0 0 32px #c8462c2e}.opening-enter-arrow{background:currentColor;width:22px;height:1px;transition:width .35s;display:inline-block}.opening-enter:hover .opening-enter-arrow{width:40px}.opening-deco{justify-content:center;align-items:center;gap:10px;margin-top:44px;display:flex}.opening-deco-l{opacity:.22;background:var(--accent);width:72px;height:1px}.opening-deco-dot{background:var(--accent);opacity:.35;border-radius:50%;width:3px;height:3px}.opening-dissolve{z-index:50;pointer-events:none;background:radial-gradient(circle,#f7f2e9 0%,#f4efe6 70%,#efeadd 100%);position:absolute;inset:0;box-shadow:inset 0 0 120px 40px #efeaddb3}.opening-orbit-ring{pointer-events:none;z-index:5;position:absolute;inset:0}.opening-orbit-word{transform-origin:0 0;font-family:var(--font-mono);letter-spacing:.15em;color:var(--ink-soft);white-space:nowrap;transform:rotate(var(--angle)) translateX(var(--radius));pointer-events:none;font-size:10px;position:absolute;top:50%;left:50%}.opening-orbit-word-inner{opacity:.35;animation:orbitSpin var(--spin-duration,60s) linear infinite;border:1px solid #c8462c1f;border-radius:999px;padding:4px 12px;display:inline-block}@keyframes orbitSpin{to{transform:rotate(360deg)}}@media (max-height:750px){.opening-inner{padding:40px 40px 90px}.opening-mark{margin-bottom:32px}.opening-sub{margin-top:20px}}@media (max-width:768px){.opening-orbit-word{display:none}.opening-aura{width:100px;height:100px}.opening-spotlight{width:160px;height:160px}}@media (max-width:640px){.opening-inner{padding:44px 22px 120px}.opening-title{font-size:clamp(40px,10vw,62px)}.opening-sub{font-size:clamp(13px,3.8vw,16px)}.opening-enter{margin-top:24px;padding:14px 24px;font-size:10px}}@media (prefers-reduced-motion:reduce){.opening-beam,.opening-spot,.opening-orbit-word-inner{animation:none}}.return-to-opening{z-index:9999;font-family:"Fraunces", var(--font-serif);color:var(--accent);background:var(--bg);border:1px solid var(--accent);box-shadow:3px 3px 0 var(--accent);cursor:pointer;border-radius:4px;padding:10px 20px;font-size:13px;font-style:italic;font-weight:500;transition:transform .2s,box-shadow .2s,background .2s,opacity .35s;position:fixed;top:20px;left:20px}.return-to-opening:hover{box-shadow:5px 5px 0 var(--accent);background:var(--bg-elev);transform:translate(-1px,-1px)}.return-to-opening:active{box-shadow:1px 1px 0 var(--accent);transform:translate(2px,2px)}.return-to-opening.hidden{opacity:0;pointer-events:none}.cream-fluid-canvas{z-index:40;pointer-events:none;transition:opacity .8s cubic-bezier(.65,0,.35,1);position:fixed;inset:0}.opening-replaying .opening-enter,.opening-replaying .opening-orbit-ring,.opening-replaying .opening-aura,.opening-replaying .opening-spotlight{opacity:0;pointer-events:none;transition:opacity .55s var(--ease-out-expo,cubic-bezier(.22, 1, .36, 1))}.opening-replaying .opening-deco,.opening-replaying .opening-mark,.opening-replaying .opening-sub{opacity:0;animation:creamTextReveal .7s 2.2s var(--ease-out-expo,cubic-bezier(.22, 1, .36, 1)) forwards}.opening-replaying .opening-bg-video{transition:opacity .6s,filter .6s;opacity:.8!important;filter:saturate(.6)contrast(.85)brightness(1.2)!important}.opening-replaying .opening-inner{z-index:60;pointer-events:none}.opening-replaying .opening-title{opacity:0;animation:.8s cubic-bezier(.65,0,.35,1) 1.8s forwards creamTextReveal}@keyframes creamTextReveal{0%{opacity:0}to{opacity:1}}@media (prefers-reduced-motion:reduce){.cream-fluid-canvas{display:none}.opening-replaying .opening-title{opacity:1;animation:none}}@keyframes orbit-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes orbit-counter{0%{transform:rotate(0)}to{transform:rotate(-360deg)}}.journey-planets{flex-direction:column;gap:32px}.journey-planets__orrery{justify-content:center;align-items:center;width:420px;height:420px;display:flex;position:relative}@media (max-width:500px){.journey-planets__orrery{width:280px;height:280px;transform:scale(.75)}}.journey-sun{background:var(--accent);z-index:2;border-radius:50%;justify-content:center;align-items:center;width:52px;height:52px;display:flex;position:absolute;box-shadow:0 0 32px #c9644280}.journey-sun__core{font-family:var(--font-mono);color:var(--bg-elev);letter-spacing:.06em;font-size:11px}.journey-orb-group{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.journey-planets__caption{font-family:var(--font-mono);color:var(--ink-soft);letter-spacing:.12em;text-transform:uppercase;font-size:11px}.journey-timeline{align-items:flex-start;padding:80px 10vw}.journey-timeline__inner{flex-direction:column;gap:48px;max-width:560px;display:flex;position:relative}.journey-mile-line{background:var(--rule);width:1px;position:absolute;top:0;bottom:0;left:18px}.journey-mile{z-index:1;align-items:flex-start;gap:28px;display:flex;position:relative}.journey-mile__glyph{background:var(--bg-elev);border:1px solid var(--rule);width:38px;height:38px;color:var(--accent);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:18px;display:flex}.journey-mile__year{font-family:var(--font-mono);color:var(--accent);letter-spacing:.14em;margin-bottom:4px;font-size:10px}.journey-mile__label{font-family:var(--font-serif,serif);color:var(--ink);margin-bottom:8px;font-size:20px}.journey-mile__body{color:var(--ink-soft);max-width:44ch;font-size:14px;line-height:1.7}
