@import"https://fonts.googleapis.com/css2?family=Shippori+Mincho:wght@400;600;700;800&family=Inter:wght@300;400;500;600;700&family=Zen+Maru+Gothic:wght@400;500;700&display=swap";:root{--bg-primary: #faf8f5;--bg-secondary: #f0ece4;--bg-card: rgba(255, 255, 255, .92);--bg-card-hover: rgba(255, 255, 255, 1);--bg-glass: rgba(255, 255, 255, .5);--text-primary: #1c1917;--text-secondary: #57534e;--text-muted: #a8a29e;--japan-red: #c0392b;--japan-red-soft: #e8594d;--japan-ink: #1c1917;--japan-gold: #b7871c;--japan-mist: #e8e0d5;--japan-matcha: #4a7c59;--japan-sakura: #c9677d;--card-border: rgba(0,0,0,.06);--card-border-hover: rgba(0,0,0,.12);--card-highlight-border: rgba(0,0,0,.1);--nav-dot-border: rgba(0,0,0,.1);--nav-dot-hover-bg: rgba(192,57,43,.08);--tip-food-bg: rgba(183,135,28,.06);--tip-food-border: rgba(183,135,28,.15);--tip-pro-bg: rgba(74,124,89,.06);--tip-pro-border: rgba(74,124,89,.15);--orb-opacity: .12;--day1-primary: #3b4f8c;--day1-secondary: #6b7fc4;--day1-bg: #eef0f8;--day1-glow: rgba(107,127,196,.08);--day2-primary: #2d6a4f;--day2-secondary: #52b788;--day2-bg: #edf7f1;--day2-glow: rgba(82,183,136,.08);--day3-primary: #9c4221;--day3-secondary: #e06c2e;--day3-bg: #fdf0e7;--day3-glow: rgba(224,108,46,.08);--day4-primary: #8b2252;--day4-secondary: #d4547a;--day4-bg: #fceef4;--day4-glow: rgba(212,84,122,.08);--day5-primary: #5c4827;--day5-secondary: #c99a3e;--day5-bg: #fdf6e7;--day5-glow: rgba(201,154,62,.08);--shadow-xs: 0 1px 3px rgba(0,0,0,.04);--shadow-sm: 0 1px 8px rgba(0,0,0,.06);--shadow-md: 0 4px 24px rgba(0,0,0,.08);--shadow-lg: 0 12px 48px rgba(0,0,0,.1);--shadow-glow-indigo: 0 0 20px rgba(59,79,140,.12);--shadow-glow-sakura: 0 0 20px rgba(201,103,125,.12);--space-xs: .25rem;--space-sm: .5rem;--space-md: 1rem;--space-lg: 1.5rem;--space-xl: 2rem;--space-2xl: 3rem;--space-3xl: 4rem;--space-4xl: 6rem;--font-body: "Inter", -apple-system, BlinkMacSystemFont, sans-serif;--font-heading: "Shippori Mincho", "Noto Serif JP", Georgia, serif;--font-accent: "Zen Maru Gothic", var(--font-body);--text-xs: .75rem;--text-sm: .875rem;--text-base: 1rem;--text-lg: 1.125rem;--text-xl: 1.25rem;--text-2xl: 1.5rem;--text-3xl: 2rem;--text-4xl: 2.75rem;--text-5xl: 3.5rem;--radius-sm: .375rem;--radius-md: .75rem;--radius-lg: 1rem;--radius-xl: 1.5rem;--radius-full: 9999px;--transition-fast: .15s cubic-bezier(.4,0,.2,1);--transition-base: .28s cubic-bezier(.4,0,.2,1);--transition-slow: .5s cubic-bezier(.4,0,.2,1)}[data-theme=dark]{--bg-primary: #0e0d0c;--bg-secondary: #161412;--bg-card: rgba(30, 26, 22, .88);--bg-card-hover: rgba(40,34,28,.95);--bg-glass: rgba(255,255,255,.04);--text-primary: #e8e5df;--text-secondary: #a09890;--text-muted: #635d57;--card-border: rgba(255,255,255,.06);--card-border-hover: rgba(255,255,255,.12);--card-highlight-border: rgba(255,255,255,.1);--nav-dot-border: rgba(255,255,255,.09);--nav-dot-hover-bg: rgba(192,57,43,.18);--tip-food-bg: rgba(183,135,28,.1);--tip-food-border: rgba(183,135,28,.2);--tip-pro-bg: rgba(74,124,89,.1);--tip-pro-border: rgba(74,124,89,.2);--orb-opacity: .25;--day1-bg: #131720;--day1-glow: rgba(107,127,196,.12);--day2-bg: #0f1a14;--day2-glow: rgba(82,183,136,.12);--day3-bg: #1a1108;--day3-glow: rgba(224,108,46,.12);--day4-bg: #1a0d13;--day4-glow: rgba(212,84,122,.12);--day5-bg: #16130a;--day5-glow: rgba(201,154,62,.12);--shadow-xs: 0 1px 3px rgba(0,0,0,.3);--shadow-sm: 0 1px 8px rgba(0,0,0,.4);--shadow-md: 0 4px 24px rgba(0,0,0,.5);--shadow-lg: 0 12px 48px rgba(0,0,0,.6);--shadow-glow-indigo: 0 0 20px rgba(107,127,196,.15);--shadow-glow-sakura: 0 0 20px rgba(212,84,122,.15)}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-body);background:var(--bg-primary);color:var(--text-primary);line-height:1.7;overflow-x:hidden;transition:background var(--transition-slow),color var(--transition-base)}h1,h2,h3,h4{font-family:var(--font-heading);line-height:1.25}::selection{background:#c0392b26;color:var(--text-primary)}::-webkit-scrollbar{width:5px}::-webkit-scrollbar-track{background:var(--bg-primary)}::-webkit-scrollbar-thumb{background:linear-gradient(180deg,var(--japan-red),var(--japan-sakura));border-radius:99px}.container{max-width:860px;margin:0 auto;padding:0 var(--space-lg)}@keyframes fadeInUp{0%{opacity:0;transform:translateY(28px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-12px)}}@keyframes floatSlow{0%,to{transform:translateY(0) rotate(0)}50%{transform:translateY(-8px) rotate(3deg)}}@keyframes shimmerLine{0%{transform:scaleX(0);transform-origin:left}50%{transform:scaleX(1);transform-origin:left}50.01%{transform:scaleX(1);transform-origin:right}to{transform:scaleX(0);transform-origin:right}}@keyframes pulseRed{0%,to{box-shadow:0 0 4px #c0392b4d}50%{box-shadow:0 0 14px #c0392b80}}@keyframes softPulse{0%,to{opacity:.4}50%{opacity:.7}}@keyframes petals{0%{transform:translateY(-20px) rotate(0);opacity:0}10%{opacity:.8}90%{opacity:.6}to{transform:translateY(110vh) rotate(720deg);opacity:0}}@keyframes revealLine{0%{transform:scaleY(0)}to{transform:scaleY(1)}}@keyframes gradientShift{0%,to{background-position:0% 50%}50%{background-position:100% 50%}}@keyframes wave{0%,to{d:path("M0,30 Q30,10 60,30 Q90,50 120,30 L120,60 L0,60 Z")}50%{d:path("M0,20 Q30,40 60,20 Q90,0 120,20 L120,60 L0,60 Z")}}.theme-toggle{position:absolute;top:var(--space-lg);right:var(--space-lg);z-index:100;background:var(--bg-card);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--card-border);border-radius:var(--radius-full);width:42px;height:42px;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:var(--shadow-sm);transition:all var(--transition-base)}.theme-toggle:hover{background:var(--bg-card-hover);border-color:var(--card-border-hover);transform:scale(1.08);box-shadow:var(--shadow-md)}.theme-toggle__icon{font-size:1.1rem;line-height:1;transition:transform var(--transition-base)}.theme-toggle:hover .theme-toggle__icon{transform:rotate(15deg)}.hero{position:relative;min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:7rem var(--space-2xl) 3rem;overflow:hidden;background:linear-gradient(180deg,#fff5f5,#fdf8f2 40%,#f5eceb)}[data-theme=dark] .hero{background:linear-gradient(180deg,#2a0f0f,#110e0c 40%,#0e0b0a)}.hero__canvas{position:absolute;inset:0;width:100%;height:100%;pointer-events:none;opacity:0;transition:opacity 1.2s ease .3s}.hero--visible .hero__canvas{opacity:1}.hero__circle{position:absolute;border-radius:50%;pointer-events:none}.hero__circle--1{width:520px;height:520px;background:radial-gradient(circle,rgba(192,57,43,.06) 0%,transparent 70%);top:-160px;right:-100px;animation:floatSlow 12s ease-in-out infinite}.hero__circle--2{width:380px;height:380px;background:radial-gradient(circle,rgba(183,135,28,.05) 0%,transparent 70%);bottom:-80px;left:-80px;animation:floatSlow 15s ease-in-out infinite 3s}[data-theme=dark] .hero__circle--1{background:radial-gradient(circle,rgba(192,57,43,.15) 0%,transparent 70%)}[data-theme=dark] .hero__circle--2{background:radial-gradient(circle,rgba(183,135,28,.1) 0%,transparent 70%)}.hero__content{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;text-align:center;max-width:700px;width:100%;opacity:0;transform:translateY(28px);transition:opacity .85s ease,transform .85s ease}.hero--visible .hero__content{opacity:1;transform:translateY(0)}.hero__badge{display:inline-flex;align-items:center;gap:var(--space-sm);background:#c0392b12;border:1px solid rgba(192,57,43,.15);border-radius:var(--radius-full);padding:.35rem var(--space-md);font-size:var(--text-xs);font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--japan-red);margin-bottom:var(--space-md)}.hero__badge-dot{width:5px;height:5px;border-radius:50%;background:var(--japan-red);opacity:.6;flex-shrink:0;animation:softPulse 2s ease-in-out infinite}.hero__kana{font-family:var(--font-accent);font-size:var(--text-sm);letter-spacing:.3em;color:var(--text-muted);margin-bottom:var(--space-lg)}.hero__title{display:flex;flex-direction:column;align-items:center;gap:.1em;margin-bottom:var(--space-xl);width:100%;padding:.1em var(--space-md)}.hero__title-main{font-size:clamp(2.4rem,7.5vw,5rem);font-weight:800;color:var(--text-primary);letter-spacing:-.02em;line-height:1.1}.hero__title-accent{font-size:clamp(2rem,6.5vw,4.2rem);font-weight:700;letter-spacing:-.01em;line-height:1.1;background:linear-gradient(135deg,#b52a2a,#d4577a 55%,#c0392b);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;padding:.05em .1em .3em}.hero__route{display:flex;align-items:center;flex-wrap:wrap;justify-content:center;gap:.2rem .1rem;margin-bottom:var(--space-xl);font-size:var(--text-base);color:var(--text-secondary)}.hero__route-item{display:flex;align-items:center;gap:.15rem}.hero__route-city{font-weight:500}.hero__route-arrow{color:var(--text-muted);margin:0 .2rem;font-size:var(--text-sm)}.hero__stats{display:flex;align-items:center;gap:var(--space-lg);margin-bottom:var(--space-3xl);padding:var(--space-md) var(--space-xl);background:var(--bg-card);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--card-border);border-radius:var(--radius-full);box-shadow:var(--shadow-sm)}.hero__stat{display:flex;flex-direction:column;align-items:center;gap:2px}.hero__stat-num{font-family:var(--font-heading);font-size:var(--text-lg);font-weight:700;color:var(--text-primary);line-height:1}.hero__stat-label{font-size:var(--text-xs);color:var(--text-muted);letter-spacing:.08em;text-transform:uppercase}.hero__stat-divider{width:1px;height:28px;background:var(--card-border)}.hero__nav{display:grid;grid-template-columns:repeat(5,1fr);gap:var(--space-sm);width:100%;max-width:680px}.hero__nav-pill{display:flex;flex-direction:column;align-items:center;gap:4px;padding:var(--space-md) var(--space-xs);background:var(--bg-card);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid var(--card-border);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-base);box-shadow:var(--shadow-xs);position:relative;overflow:hidden}.hero__nav-pill:after{content:"";position:absolute;bottom:0;left:20%;right:20%;height:2px;background:var(--japan-red);border-radius:2px 2px 0 0;opacity:0;transition:opacity var(--transition-base),left var(--transition-base),right var(--transition-base)}.hero__nav-pill:hover:after{opacity:.6;left:10%;right:10%}.hero__nav-pill:hover{background:var(--bg-card-hover);border-color:var(--card-border-hover);transform:translateY(-3px);box-shadow:var(--shadow-md)}.hero__nav-kanji{font-family:var(--font-heading);font-size:var(--text-2xl);font-weight:800;color:var(--japan-red);line-height:1}.hero__nav-text{display:flex;flex-direction:column;align-items:center;gap:2px}.hero__nav-label{font-size:var(--text-xs);font-weight:700;color:var(--text-primary);white-space:nowrap}.hero__nav-sub{font-size:.65rem;color:var(--text-muted);white-space:nowrap}.hero__scroll{position:relative;z-index:1;margin-top:var(--space-2xl);display:flex;flex-direction:column;align-items:center;gap:4px;opacity:0;transition:opacity 1s ease 1.2s;text-decoration:none;color:var(--text-muted)}.hero--visible .hero__scroll{opacity:1}.hero__scroll-label{font-size:var(--text-xs);letter-spacing:.15em;text-transform:uppercase}.hero__scroll-icon{font-size:var(--text-base);animation:float 2s ease-in-out infinite}@media(max-width:560px){.hero{padding:6rem var(--space-lg) 3rem}.hero__stats{gap:var(--space-md);padding:var(--space-sm) var(--space-lg)}.hero__nav{grid-template-columns:repeat(3,1fr);max-width:100%}.hero__nav-pill{padding:var(--space-sm) var(--space-xs)}.hero__nav-sub{display:none}.hero__route-arrow{margin:0 .1rem}.hero__scroll{margin-top:var(--space-xl)}}.tl{position:relative;margin-bottom:var(--space-lg);opacity:0;transform:translate(-16px);transition:opacity .5s ease,transform .5s ease}.tl--visible{opacity:1;transform:translate(0)}.tl__dot{position:absolute;left:calc(-1 * var(--space-3xl) + 5px);top:1.15rem;width:14px;height:14px;border-radius:50%;border:2.5px solid currentColor;background:currentColor;z-index:1;transition:all var(--transition-base);animation:pulseRed 2.4s ease-in-out infinite}.tl--day1 .tl__dot{color:var(--day1-secondary)}.tl--day2 .tl__dot{color:var(--day2-secondary)}.tl--day3 .tl__dot{color:var(--day3-secondary)}.tl--day4 .tl__dot{color:var(--day4-secondary)}.tl--day5 .tl__dot{color:var(--day5-secondary)}.tl__card{background:var(--bg-card);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid var(--card-border);border-radius:var(--radius-lg);padding:var(--space-lg) var(--space-xl);box-shadow:var(--shadow-sm);transition:background var(--transition-base),border-color var(--transition-base);position:relative;overflow:hidden}.tl__card:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;border-radius:3px 0 0 3px;opacity:1}.tl--day1 .tl__card:before{background:var(--day1-secondary)}.tl--day2 .tl__card:before{background:var(--day2-secondary)}.tl--day3 .tl__card:before{background:var(--day3-secondary)}.tl--day4 .tl__card:before{background:var(--day4-secondary)}.tl--day5 .tl__card:before{background:var(--day5-secondary)}.tl__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-sm);gap:var(--space-sm)}.tl__time-badge{display:flex;align-items:center;gap:var(--space-xs)}.tl__icon{font-size:1.1rem;line-height:1}.tl__time{font-size:var(--text-xs);font-weight:700;letter-spacing:.08em;text-transform:uppercase}.tl--day1 .tl__time{color:var(--day1-primary)}.tl--day2 .tl__time{color:var(--day2-primary)}.tl--day3 .tl__time{color:var(--day3-primary)}.tl--day4 .tl__time{color:var(--day4-primary)}.tl--day5 .tl__time{color:var(--day5-primary)}.tl__category{font-size:.65rem;color:var(--text-muted);letter-spacing:.08em;font-weight:600;text-transform:uppercase;white-space:nowrap;background:#00000008;border-radius:var(--radius-full);padding:.15rem .5rem}[data-theme=dark] .tl__category{background:#ffffff0d}.tl__title{font-family:var(--font-body);font-size:var(--text-lg);font-weight:600;margin-bottom:var(--space-xs);color:var(--text-primary);line-height:1.35}.tl__desc{font-size:var(--text-sm);color:var(--text-secondary);line-height:1.75}.tl__callout{display:flex;align-items:flex-start;gap:var(--space-sm);margin-top:var(--space-md);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);font-size:var(--text-sm);line-height:1.65}.tl__callout--food{background:var(--tip-food-bg);border:1px solid var(--tip-food-border);color:var(--japan-gold)}.tl__callout--tip{background:var(--tip-pro-bg);border:1px solid var(--tip-pro-border);color:var(--japan-matcha)}[data-theme=dark] .tl__callout--food{color:#d4a843}[data-theme=dark] .tl__callout--tip{color:#6db88a}@media(max-width:600px){.tl__card{padding:var(--space-md) var(--space-lg)}.tl__dot{left:calc(-1 * var(--space-2xl) + 3px)}}.day-section{position:relative;overflow:hidden;transition:background var(--transition-slow)}.day-section--1{background:var(--day1-bg)}.day-section--2{background:var(--day2-bg)}.day-section--3{background:var(--day3-bg)}.day-section--4{background:var(--day4-bg)}.day-section--5{background:var(--day5-bg)}.day-section:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;opacity:0;transition:opacity .8s ease .2s}.day-section--visible:before{opacity:.7}.day-section--1:before{background:linear-gradient(90deg,transparent,var(--day1-secondary),transparent)}.day-section--2:before{background:linear-gradient(90deg,transparent,var(--day2-secondary),transparent)}.day-section--3:before{background:linear-gradient(90deg,transparent,var(--day3-secondary),transparent)}.day-section--4:before{background:linear-gradient(90deg,transparent,var(--day4-secondary),transparent)}.day-section--5:before{background:linear-gradient(90deg,transparent,var(--day5-secondary),transparent)}.day-section:after{content:"";position:absolute;top:-120px;right:-80px;width:400px;height:400px;border-radius:50%;pointer-events:none;opacity:0;transition:opacity 1.2s ease .5s}.day-section--visible:after{opacity:1}.day-section--1:after{background:radial-gradient(circle,var(--day1-glow) 0%,transparent 70%)}.day-section--2:after{background:radial-gradient(circle,var(--day2-glow) 0%,transparent 70%)}.day-section--3:after{background:radial-gradient(circle,var(--day3-glow) 0%,transparent 70%)}.day-section--4:after{background:radial-gradient(circle,var(--day4-glow) 0%,transparent 70%)}.day-section--5:after{background:radial-gradient(circle,var(--day5-glow) 0%,transparent 70%)}.day-section__banner{padding:var(--space-3xl) 0 var(--space-xl);opacity:0;transform:translateY(-20px);transition:opacity .7s ease,transform .7s ease}.day-section--visible .day-section__banner{opacity:1;transform:translateY(0)}.day-section__banner-inner{display:flex;align-items:flex-start;gap:var(--space-xl)}.day-section__day-label{display:flex;flex-direction:column;align-items:center;gap:var(--space-xs);flex-shrink:0}.day-section__motif{font-size:2.2rem;line-height:1;filter:drop-shadow(0 2px 4px rgba(0,0,0,.1))}.day-section__day-num{font-family:var(--font-heading);font-size:var(--text-xs);font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted);white-space:nowrap}.day-section__banner-text{flex:1}.day-section__title{font-size:clamp(1.6rem,4vw,2.4rem);font-weight:700;margin-bottom:var(--space-xs);color:var(--text-primary)}.day-section--1 .day-section__title{color:var(--day1-primary)}.day-section--2 .day-section__title{color:var(--day2-primary)}.day-section--3 .day-section__title{color:var(--day3-primary)}.day-section--4 .day-section__title{color:var(--day4-primary)}.day-section--5 .day-section__title{color:var(--day5-primary)}.day-section__meta{font-size:var(--text-sm);color:var(--text-secondary);display:flex;align-items:center;gap:var(--space-xs);flex-wrap:wrap;margin-bottom:var(--space-xs)}.day-section__sep{color:var(--text-muted);margin:0 2px}.day-section__subtitle{font-style:italic}.day-section__mood{font-size:var(--text-xs);font-weight:600;letter-spacing:.12em;text-transform:uppercase;opacity:.45;color:var(--text-primary)}.day-section__body{padding:0 0 var(--space-4xl)}.day-section__timeline{position:relative;padding-left:var(--space-3xl)}.day-section__timeline-track{position:absolute;left:11px;top:var(--space-md);bottom:var(--space-md);width:2px;border-radius:2px;opacity:0;transition:opacity .8s ease .4s}.day-section--visible .day-section__timeline-track{opacity:.3}.day-section--1 .day-section__timeline-track{background:linear-gradient(to bottom,var(--day1-secondary),transparent)}.day-section--2 .day-section__timeline-track{background:linear-gradient(to bottom,var(--day2-secondary),transparent)}.day-section--3 .day-section__timeline-track{background:linear-gradient(to bottom,var(--day3-secondary),transparent)}.day-section--4 .day-section__timeline-track{background:linear-gradient(to bottom,var(--day4-secondary),transparent)}.day-section--5 .day-section__timeline-track{background:linear-gradient(to bottom,var(--day5-secondary),transparent)}@media(max-width:640px){.day-section__banner{padding:var(--space-2xl) 0 var(--space-lg)}.day-section__banner-inner{gap:var(--space-md)}.day-section__motif{font-size:1.8rem}.day-section__timeline{padding-left:var(--space-2xl)}.day-section__timeline-track{left:9px}}.footer{position:relative;background:var(--bg-secondary);padding:var(--space-4xl) var(--space-lg) var(--space-3xl);overflow:hidden}.footer:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--day1-secondary),var(--day2-secondary),var(--day3-secondary),var(--day4-secondary),var(--day5-secondary));opacity:.5}.footer__inner{max-width:860px;margin:0 auto;text-align:center;display:flex;flex-direction:column;align-items:center;gap:var(--space-sm)}.footer__torii{font-size:2.5rem;margin-bottom:var(--space-sm);filter:drop-shadow(0 2px 6px rgba(0,0,0,.1))}.footer__name{font-family:var(--font-heading);font-size:var(--text-xl);font-weight:700;color:var(--text-primary)}.footer__route{font-size:var(--text-sm);color:var(--text-secondary);letter-spacing:.02em}.footer__dates{font-size:var(--text-xs);font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--japan-gold);margin-top:var(--space-xs)}.footer__tagline{font-family:var(--font-accent);font-size:var(--text-base);color:var(--text-muted);margin-top:var(--space-md);letter-spacing:.04em}.gate{position:fixed;inset:0;z-index:9999;display:flex;align-items:center;justify-content:center;padding:var(--space-lg);background:linear-gradient(180deg,#fff5f5,#fdf8f2 40%,#f5eceb);overflow:hidden;transition:opacity .6s ease,transform .6s ease}[data-theme=dark] .gate{background:linear-gradient(180deg,#2a0f0f,#1a0a08 40%,#120808)}.gate--success{opacity:0;pointer-events:none}.gate__canvas{position:absolute;inset:0;width:100%;height:100%;pointer-events:none}.gate__petals{position:absolute;inset:0;pointer-events:none;overflow:hidden}.gate__petal{position:absolute;top:-30px;font-size:1.1rem;animation:petals linear infinite;opacity:0}.gate__card{position:relative;z-index:1;background:var(--bg-card);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--card-border);border-radius:var(--radius-xl);padding:var(--space-3xl) var(--space-2xl);max-width:420px;width:100%;text-align:center;box-shadow:var(--shadow-lg)}.gate__card .theme-toggle{position:absolute;top:var(--space-md);right:var(--space-md);width:38px;height:38px;box-shadow:var(--shadow-xs)}@keyframes shake{0%,to{transform:translate(0)}15%{transform:translate(-8px)}30%{transform:translate(8px)}45%{transform:translate(-6px)}60%{transform:translate(6px)}75%{transform:translate(-3px)}90%{transform:translate(3px)}}.gate__card--shake{animation:shake .55s cubic-bezier(.36,.07,.19,.97) both}.gate__icon{font-size:3rem;margin-bottom:var(--space-md);display:block;filter:drop-shadow(0 4px 8px rgba(0,0,0,.1))}.gate__kana{font-family:var(--font-accent);font-size:var(--text-sm);letter-spacing:.3em;color:var(--japan-red);opacity:.55;margin-bottom:var(--space-xs)}.gate__title{font-family:var(--font-heading);font-size:var(--text-3xl);font-weight:800;color:var(--text-primary);margin-bottom:var(--space-sm)}.gate__subtitle{font-size:var(--text-sm);color:var(--text-secondary);line-height:1.7;margin-bottom:var(--space-2xl)}.gate__hidden-input{position:absolute;opacity:0;pointer-events:none;width:1px;height:1px;overflow:hidden;border:none;outline:none}.gate__display{position:relative;display:flex;align-items:center;justify-content:center;height:56px;padding:0 var(--space-lg);border-radius:var(--radius-md);border:1.5px solid var(--card-border);background:var(--bg-primary);cursor:text;transition:border-color var(--transition-base),box-shadow var(--transition-base);overflow:hidden}.gate__display:focus-within{border-color:var(--japan-red);box-shadow:0 0 0 3px #c0392b14}.gate__display--error{border-color:#e74c3c;box-shadow:0 0 0 3px #e74c3c14}.gate__real-input{position:absolute;inset:0;opacity:0;width:100%;border:none;outline:none;background:transparent;cursor:text;font-size:1rem;caret-color:transparent}.gate__placeholder{font-size:var(--text-base);color:var(--text-muted);letter-spacing:.05em;pointer-events:none;-webkit-user-select:none;user-select:none}.gate__masked{font-size:1.5rem;letter-spacing:.2em;color:var(--text-primary);pointer-events:none;-webkit-user-select:none;user-select:none;display:flex;align-items:center;gap:2px}.gate__last-char{font-size:1.2rem;font-weight:700;color:var(--japan-red);letter-spacing:0;display:inline-block;animation:charPop .15s ease}@keyframes charPop{0%{transform:scale(.6);opacity:.4}to{transform:scale(1);opacity:1}}.gate__error-slot{height:22px;display:flex;align-items:center;justify-content:center}.gate__error{font-size:var(--text-sm);color:#e74c3c}.gate__btn{width:100%;padding:var(--space-md) var(--space-xl);font-family:var(--font-body);font-size:var(--text-base);font-weight:700;letter-spacing:.06em;color:#fff;background:linear-gradient(135deg,#c0392b,#d4577a);border:none;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-base);box-shadow:0 4px 16px #c0392b33}.gate__btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 24px #c0392b4d}.gate__btn:active:not(:disabled){transform:translateY(0)}.gate__btn--success{background:linear-gradient(135deg,#27ae60,#2ecc71);box-shadow:0 4px 16px #27ae6040}.gate__btn:disabled{cursor:default}.gate__hint{margin-top:var(--space-xl);font-size:var(--text-xs);color:var(--text-muted);letter-spacing:.08em}@media(max-width:480px){.gate{padding:var(--space-md);align-items:center}.gate__card{padding:var(--space-2xl) var(--space-lg);border-radius:var(--radius-lg)}.gate__icon{font-size:2.4rem;margin-bottom:var(--space-sm)}.gate__kana{font-size:var(--text-xs);margin-bottom:.15rem}.gate__title{font-size:1.6rem;margin-bottom:var(--space-xs)}.gate__subtitle{font-size:var(--text-xs);margin-bottom:var(--space-lg);line-height:1.6}.gate__display{height:48px;padding:0 var(--space-md)}.gate__btn{padding:var(--space-sm) var(--space-lg);font-size:var(--text-sm)}.gate__hint{margin-top:var(--space-lg);font-size:.65rem}.gate__error-slot{height:18px}.gate__card .theme-toggle{top:var(--space-sm);right:var(--space-sm);width:34px;height:34px}.gate__card .theme-toggle__icon{font-size:.95rem}}.app{min-height:100vh}.app__days{background:var(--bg-primary)}
