/* ============================
   虹の和盆祭り — Renewal Styles
   ============================ */
:root{
  --ink:#0a0712;
  --ink-2:#140d22;
  --ink-3:#1a1338;
  --paper:#ede4d3;
  --paper-2:#f6efdf;
  --beni:#c2342e;
  --beni-2:#a8281e;
  --hi:#e23a2a;
  --gold:#e9b949;
  --gold-2:#f1d27a;
  --moon:#f5ead4;
  --indigo:#1c2a6b;
  --aka:#d62828;
  --line:rgba(245,234,212,.18);
  --serif:"Shippori Mincho B1","Yu Mincho","Hiragino Mincho ProN",serif;
  --display:"Yuji Syuku","Shippori Mincho B1",serif;
  --sans:"Noto Sans JP","Hiragino Sans",sans-serif;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--ink);color:var(--paper);font-family:var(--sans);-webkit-font-smoothing:antialiased;text-rendering:geometricPrecision;overflow-x:hidden}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
em{font-style:normal;color:var(--gold-2);background:linear-gradient(180deg,transparent 55%,rgba(233,185,73,.25) 55%)}

.container{max-width:1240px;margin:0 auto;padding:0 28px;position:relative;z-index:2}

/* ノイズ */
.grain{position:fixed;inset:0;pointer-events:none;z-index:60;mix-blend-mode:overlay;opacity:.18;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0.95 0 0 0 0 0.92 0 0 0 0 0.83 0 0 0 0.55 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>")}

/* カーソル光彩 */
.cursor-glow{position:fixed;width:520px;height:520px;border-radius:50%;pointer-events:none;z-index:1;transform:translate(-50%,-50%);
  background:radial-gradient(circle,rgba(233,185,73,.18),rgba(226,58,42,.08) 40%,transparent 70%);
  filter:blur(20px);transition:opacity .3s;opacity:.85;will-change:left,top}

/* 浮遊漢字 */
.floating-kanji{position:fixed;inset:0;pointer-events:none;z-index:0;overflow:hidden}
.floating-kanji span{position:absolute;left:var(--x);top:var(--y);font-family:var(--display);font-size:calc(160px * var(--s));color:rgba(245,234,212,.04);font-weight:800;animation:floatY 14s ease-in-out infinite;animation-delay:var(--d);user-select:none}
@keyframes floatY{0%,100%{transform:translateY(0) rotate(-3deg)}50%{transform:translateY(-30px) rotate(2deg)}}

/* ========== HEADER ========== */
.site-header{position:fixed;top:0;left:0;right:0;z-index:50;display:flex;justify-content:space-between;align-items:center;padding:18px 32px;
  background:linear-gradient(180deg,rgba(10,7,18,.85),rgba(10,7,18,0));backdrop-filter:blur(8px);transition:padding .25s,background .25s}
.site-header.scrolled{padding:12px 32px;background:rgba(10,7,18,.92)}
.logo{display:flex;align-items:center;gap:12px}
.logo-mark{width:42px;height:42px;border-radius:50%;background:radial-gradient(circle at 30% 30%,#ff6055,#9c1a13);display:grid;place-items:center;box-shadow:0 0 24px rgba(226,58,42,.45),inset 0 0 14px rgba(0,0,0,.4);position:relative}
.logo-mark::before{content:"";position:absolute;inset:-3px;border-radius:50%;border:1px dashed rgba(245,234,212,.35);animation:spin 16s linear infinite}
.logo-mark span{font-family:var(--display);font-size:22px;color:var(--paper);font-weight:700;line-height:1}
.logo-text{font-family:var(--serif);font-weight:700;letter-spacing:.04em;font-size:18px;line-height:1.1;display:flex;flex-direction:column}
.logo-text small{font-family:var(--sans);font-weight:400;font-size:10px;letter-spacing:.3em;opacity:.6}

.site-nav{display:flex;gap:26px;align-items:center}
.site-nav a{font-family:var(--serif);font-size:14px;letter-spacing:.06em;opacity:.85;position:relative;padding:6px 0;transition:opacity .2s}
.site-nav a:not(.nav-cta)::after{content:"";position:absolute;left:0;right:0;bottom:0;height:1px;background:var(--gold);transform:scaleX(0);transform-origin:left;transition:transform .35s cubic-bezier(.7,.2,.2,1)}
.site-nav a:not(.nav-cta):hover{opacity:1}
.site-nav a:not(.nav-cta):hover::after{transform:scaleX(1)}
.nav-cta{border:1px solid var(--line);padding:8px 16px;border-radius:99px;background:rgba(226,58,42,.1)}
.nav-cta:hover{background:var(--beni);border-color:var(--beni)}

@keyframes spin{to{transform:rotate(360deg)}}

/* ========== HERO ========== */
.hero{position:relative;min-height:100vh;overflow:hidden;
  background:
    radial-gradient(ellipse at 50% 110%,rgba(28,42,107,.35),transparent 60%),
    radial-gradient(ellipse at 70% 0%,rgba(226,58,42,.18),transparent 50%),
    linear-gradient(180deg,#0b0820 0%,#120930 45%,#1a0a2a 85%,#240814 100%)}
.hero-bg{position:absolute;inset:0;z-index:0;pointer-events:none;
  background:url("images/top_header_njw3.jpg") center 30% / cover no-repeat;
  opacity:.14;mix-blend-mode:screen;filter:saturate(1.15) contrast(1.05)}
.hero-bg::after{content:"";position:absolute;inset:0;
  background:radial-gradient(ellipse at 50% 50%,transparent 30%,rgba(11,8,32,.55) 70%,rgba(11,8,32,.95) 100%)}
.hero::before{content:"";position:absolute;inset:0;background-image:radial-gradient(1px 1px at 25% 30%,#fff,transparent),radial-gradient(1px 1px at 60% 50%,#fff8,transparent),radial-gradient(1px 1px at 80% 20%,#fff,transparent),radial-gradient(1px 1px at 10% 70%,#fff8,transparent),radial-gradient(1px 1px at 40% 80%,#fffa,transparent),radial-gradient(2px 2px at 90% 60%,#fff,transparent);background-size:600px 600px;opacity:.6;animation:twinkle 5s ease-in-out infinite alternate}
@keyframes twinkle{from{opacity:.35}to{opacity:.75}}

/* 満月 */
.moon{position:absolute;top:8%;right:8%;width:380px;height:380px;z-index:1}
.moon-core{position:absolute;inset:0;border-radius:50%;
  background:radial-gradient(circle at 35% 35%,#fffaee,#f5ead4 40%,#d9c594 80%);
  box-shadow:0 0 80px rgba(245,234,212,.55),0 0 160px rgba(245,234,212,.35),inset -30px -40px 80px rgba(120,90,40,.35)}
.moon-core::after{content:"";position:absolute;width:60px;height:60px;border-radius:50%;background:rgba(180,150,80,.18);top:30%;left:25%;box-shadow:120px 30px 0 -10px rgba(180,150,80,.14),60px 150px 0 -15px rgba(180,150,80,.16)}
.moon-halo{position:absolute;inset:-40px;border-radius:50%;border:1px solid rgba(245,234,212,.12);animation:halo 6s ease-in-out infinite}
.moon-halo::before,.moon-halo::after{content:"";position:absolute;border-radius:50%;border:1px solid rgba(245,234,212,.08)}
.moon-halo::before{inset:-40px}
.moon-halo::after{inset:-80px;border-color:rgba(245,234,212,.05)}
@keyframes halo{0%,100%{transform:scale(1);opacity:.7}50%{transform:scale(1.08);opacity:1}}

/* 山 */
.mountains{position:absolute;left:0;right:0;bottom:0;width:100%;height:38vh;z-index:2;opacity:.85}

/* 提灯 */
.lanterns{position:absolute;top:0;left:0;right:0;display:flex;justify-content:space-around;padding:0 4%;z-index:3;pointer-events:none}
.lantern{position:relative;width:64px;height:84px;margin-top:calc(20px + var(--i) * 6px);transform-origin:top center;animation:sway 4.6s ease-in-out infinite;animation-delay:calc(var(--i) * .35s);filter:drop-shadow(0 12px 18px rgba(226,58,42,.35))}
.lantern::before{content:"";position:absolute;left:50%;top:-30px;width:1px;height:30px;background:linear-gradient(180deg,transparent,rgba(245,234,212,.4));transform:translateX(-50%)}
.lantern::after{content:"";position:absolute;inset:0;border-radius:50% / 38%;background:radial-gradient(circle at 50% 35%,#ff8a55,#d62828 65%,#7a1818);
  box-shadow:inset 0 -6px 18px rgba(0,0,0,.5),inset 0 6px 12px rgba(255,255,200,.25),0 0 30px rgba(226,58,42,.6);
  border-top:5px solid #1a0a08;border-bottom:5px solid #1a0a08}
.lantern .ko{position:absolute;inset:0;display:grid;place-items:center;font-family:var(--display);font-size:22px;color:#fef4cf;z-index:2;text-shadow:0 0 6px rgba(255,210,120,.65);font-weight:800}
@keyframes sway{0%,100%{transform:rotate(-4deg)}50%{transform:rotate(4deg)}}

/* 波紋 */
.ripples{position:absolute;left:50%;bottom:-100px;width:1px;height:1px;z-index:2}
.ripples span{position:absolute;left:50%;top:50%;width:200px;height:200px;border-radius:50%;border:1px solid rgba(233,185,73,.35);transform:translate(-50%,-50%) scale(0);animation:ripple 5s linear infinite}
.ripples span:nth-child(2){animation-delay:1.25s}
.ripples span:nth-child(3){animation-delay:2.5s}
.ripples span:nth-child(4){animation-delay:3.75s}
@keyframes ripple{0%{transform:translate(-50%,-50%) scale(0);opacity:.8}100%{transform:translate(-50%,-50%) scale(8);opacity:0}}

/* 花びら */
.petals{position:absolute;inset:0;overflow:hidden;z-index:3;pointer-events:none}

/* hero inner */
.hero-inner{position:relative;z-index:5;max-width:1100px;margin:0 auto;padding:160px 28px 120px;text-align:center}
.hero-tags{display:flex;gap:10px;justify-content:center;margin-bottom:24px;flex-wrap:wrap}
.tag{display:inline-flex;align-items:center;padding:6px 14px;border:1px solid var(--line);border-radius:99px;font-size:12px;letter-spacing:.16em;color:var(--gold-2);background:rgba(0,0,0,.25);backdrop-filter:blur(4px)}

.hero-title{font-family:var(--display);font-weight:800;font-size:clamp(48px,9.5vw,140px);line-height:.96;margin:0 0 28px;letter-spacing:.02em;
  text-shadow:0 0 80px rgba(226,58,42,.25);display:inline-flex;gap:.02em;flex-wrap:nowrap;justify-content:center;white-space:nowrap}
.kchar{display:inline-block;opacity:0;transform:translateY(40px) rotateX(-40deg);animation:reveal .9s cubic-bezier(.18,.7,.2,1.05) forwards;animation-delay:calc(var(--i,0) * .12s + .1s);
  background:linear-gradient(180deg,#fff8e0 0%,#f1d27a 45%,#e23a2a 100%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent}
.kchar.dot{transform:none;font-size:.5em;align-self:center;background:none;-webkit-text-fill-color:#e9b949;color:#e9b949}
@keyframes reveal{to{opacity:1;transform:translateY(0) rotateX(0)}}

.hero-sub{font-family:var(--serif);font-size:clamp(15px,1.6vw,20px);line-height:2;opacity:0;animation:fadeUp 1s ease .9s forwards;letter-spacing:.12em}
@keyframes fadeUp{from{opacity:0;transform:translateY(20px)}to{opacity:.92;transform:translateY(0)}}

/* countdown */
.countdown{display:inline-flex;gap:8px;margin:42px auto 28px;padding:16px 22px;border:1px solid var(--line);border-radius:14px;
  background:linear-gradient(180deg,rgba(245,234,212,.04),rgba(245,234,212,.01));backdrop-filter:blur(8px);opacity:0;animation:fadeUp 1s ease 1.2s forwards}
.countdown > div{min-width:74px;text-align:center;padding:0 10px;border-right:1px dashed rgba(245,234,212,.18)}
.countdown > div:last-child{border:none}
.countdown b{font-family:var(--display);display:block;font-size:34px;color:var(--gold-2);font-weight:800;line-height:1;letter-spacing:.02em;text-shadow:0 0 14px rgba(233,185,73,.4)}
.countdown small{font-family:var(--serif);font-size:11px;opacity:.6;letter-spacing:.18em;margin-top:4px;display:block}

.hero-cta{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-top:10px;opacity:0;animation:fadeUp 1s ease 1.4s forwards}

.btn{position:relative;display:inline-flex;align-items:center;justify-content:center;padding:14px 28px;border-radius:99px;font-family:var(--serif);font-size:14px;letter-spacing:.14em;border:1px solid var(--line);overflow:hidden;cursor:pointer;transition:transform .25s}
.btn span{position:relative;z-index:2}
.btn::before{content:"";position:absolute;inset:0;transition:transform .5s cubic-bezier(.7,.2,.2,1);transform-origin:left}
.btn-primary{background:linear-gradient(180deg,#e23a2a,#9c1a13);border-color:#7a1818;color:#fff8e0;box-shadow:0 10px 30px -10px rgba(226,58,42,.6),inset 0 1px 0 rgba(255,255,255,.15)}
.btn-primary::before{background:linear-gradient(180deg,#f15a4a,#b22a20);transform:scaleX(0)}
.btn-primary:hover::before{transform:scaleX(1)}
.btn-primary:hover{transform:translateY(-2px)}
.btn-ghost{background:rgba(245,234,212,.04);color:var(--paper)}
.btn-ghost:hover{background:rgba(245,234,212,.1)}

.hero-date{display:flex;align-items:center;justify-content:center;gap:24px;margin-top:48px;opacity:0;animation:fadeUp 1s ease 1.6s forwards}
.hero-date .vline{width:1px;height:60px;background:linear-gradient(180deg,transparent,var(--gold),transparent)}
.hd-year{font-family:var(--display);font-size:36px;letter-spacing:.18em;color:var(--gold-2);font-weight:800}
.hd-md{font-family:var(--serif);font-size:20px;letter-spacing:.2em;margin-top:4px}
.hd-time{font-family:var(--serif);font-size:14px;letter-spacing:.3em;opacity:.7;margin-top:4px}

.scroll-hint{position:absolute;bottom:24px;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:8px;z-index:5;opacity:.6;font-size:11px;letter-spacing:.4em;font-family:var(--serif)}
.scroll-hint i{width:1px;height:42px;background:linear-gradient(180deg,var(--paper),transparent);animation:scrollLine 1.6s ease-in-out infinite}
@keyframes scrollLine{0%{transform:scaleY(0);transform-origin:top}50%{transform:scaleY(1);transform-origin:top}51%{transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}

/* ============ TICKER ============ */
.ticker{position:relative;background:linear-gradient(90deg,#c2342e,#9c1a13);border-top:1px solid #7a1818;border-bottom:1px solid #7a1818;overflow:hidden;padding:14px 0;z-index:4}
.ticker::before,.ticker::after{content:"";position:absolute;top:0;bottom:0;width:120px;z-index:2;pointer-events:none}
.ticker::before{left:0;background:linear-gradient(90deg,#9c1a13,transparent)}
.ticker::after{right:0;background:linear-gradient(-90deg,#9c1a13,transparent)}
.ticker-track{display:flex;gap:28px;align-items:center;white-space:nowrap;animation:scroll-x 32s linear infinite;font-family:var(--display);letter-spacing:.18em;font-size:18px;color:#fff4d8}
.ticker-track .dot{width:8px;height:8px;background:var(--gold);border-radius:50%;flex-shrink:0}
@keyframes scroll-x{to{transform:translateX(-50%)}}

/* ============ ABOUT ============ */
.about{position:relative;padding:140px 0;background:linear-gradient(180deg,#240814 0%,#180524 40%,#0e0418 100%)}
.about::before{content:"";position:absolute;inset:0;background-image:radial-gradient(circle at 20% 30%,rgba(226,58,42,.08),transparent 30%),radial-gradient(circle at 80% 70%,rgba(28,42,107,.18),transparent 35%);pointer-events:none}

.eyebrow{font-family:var(--serif);font-size:12px;letter-spacing:.45em;color:var(--gold);text-transform:uppercase;margin-bottom:18px;position:relative;padding-left:32px}
.eyebrow::before{content:"";position:absolute;left:0;top:50%;width:22px;height:1px;background:var(--gold)}
.eyebrow.center{padding-left:0;padding-top:24px;text-align:center}
.eyebrow.center::before{left:50%;top:8px;transform:translateX(-50%);width:36px}

.sec-title{font-family:var(--display);font-size:clamp(36px,4.4vw,68px);font-weight:800;line-height:1.15;letter-spacing:.04em;margin:0 0 28px}
.sec-title.center{text-align:center}

.about-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:80px;align-items:center}
.about-text .lead{font-family:var(--serif);font-size:20px;line-height:2;letter-spacing:.1em;margin:18px 0 14px;opacity:.95}
.about-text .body{font-family:var(--serif);font-size:15px;line-height:2;letter-spacing:.08em;opacity:.7}

.pillars{list-style:none;padding:0;margin:36px 0 0;display:flex;flex-direction:column;gap:14px}
.pillars li{display:grid;grid-template-columns:60px 1fr;gap:18px;align-items:center;padding:18px 22px;border:1px solid var(--line);border-radius:14px;background:linear-gradient(135deg,rgba(245,234,212,.03),rgba(245,234,212,.01));transition:transform .25s,border-color .25s}
.pillars li:hover{transform:translateX(6px);border-color:var(--gold)}
.pillars .num{font-family:var(--display);font-size:38px;color:var(--gold-2);text-align:center;font-weight:800;line-height:1}
.pillars b{font-family:var(--serif);font-size:18px;letter-spacing:.08em;margin-right:14px}
.pillars span{font-size:13px;opacity:.7;letter-spacing:.06em}

/* photo card */
.about-visual{display:grid;place-items:center}
.photo-card{position:relative;width:min(440px,92%);margin:0;padding:14px 14px 18px;
  background:linear-gradient(160deg,#f6efdf,#e9d8b3);color:#2a1810;border-radius:6px;
  box-shadow:0 30px 60px -20px rgba(0,0,0,.7),0 0 0 1px rgba(245,234,212,.18);
  transform:rotate(-3deg);transition:transform .6s cubic-bezier(.18,.7,.2,1.05)}
.photo-card:hover{transform:rotate(0deg) scale(1.02)}
.photo-card::before{content:"";position:absolute;inset:0;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.6'/><feColorMatrix values='0 0 0 0 0.3 0 0 0 0 0.15 0 0 0 0 0.1 0 0 0 0.18 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");mix-blend-mode:multiply;border-radius:6px;pointer-events:none;opacity:.4}
.photo-frame{position:relative;aspect-ratio:3/4;overflow:hidden;border-radius:3px;box-shadow:inset 0 0 0 1px rgba(122,24,24,.18),0 6px 18px -8px rgba(0,0,0,.4)}
.photo-frame img{width:100%;height:100%;object-fit:cover;display:block;filter:saturate(1.05) contrast(1.04)}
.photo-tape{position:absolute;width:96px;height:22px;background:rgba(233,185,73,.55);backdrop-filter:blur(2px);box-shadow:0 2px 6px rgba(0,0,0,.18);pointer-events:none}
.photo-tape::after{content:"";position:absolute;inset:0;background-image:repeating-linear-gradient(45deg,transparent 0 6px,rgba(255,255,255,.15) 6px 8px)}
.tape-tl{top:-8px;left:-22px;transform:rotate(-18deg)}
.tape-br{bottom:-8px;right:-22px;transform:rotate(-18deg)}
.photo-card figcaption{margin-top:14px;text-align:center;font-family:var(--serif);font-size:12px;letter-spacing:.18em;color:#5a3018;opacity:.75}
.seal{position:absolute;top:-14px;right:-14px;width:74px;height:74px;border-radius:50%;background:var(--beni);color:#fff4d8;font-family:var(--display);font-size:22px;font-weight:800;display:grid;place-items:center;letter-spacing:.05em;line-height:1.1;text-align:center;box-shadow:0 4px 12px rgba(122,24,24,.4),inset 0 0 0 3px #9c1a13,inset 0 0 0 5px var(--beni);z-index:4;transform:rotate(8deg)}
.stamp{position:absolute;bottom:42px;left:-12px;font-family:var(--display);font-size:18px;letter-spacing:.18em;color:var(--beni);border:2px solid var(--beni);padding:8px 14px;border-radius:4px;z-index:4;transform:rotate(-6deg);background:rgba(255,250,238,.92);box-shadow:0 4px 10px rgba(0,0,0,.18)}

/* ============ INFO ============ */
.info{position:relative;padding:140px 0;background:linear-gradient(180deg,#0e0418 0%,#0a0712 100%)}
.info-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-top:60px}
.card{position:relative;padding:30px 26px;border:1px solid var(--line);border-radius:18px;background:
  linear-gradient(180deg,rgba(245,234,212,.05),rgba(245,234,212,.02));
  overflow:hidden;transition:transform .3s,border-color .3s;backdrop-filter:blur(6px)}
.card::before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--beni),var(--gold),var(--beni));opacity:.6}
.card::after{content:"";position:absolute;inset:0;background:radial-gradient(circle at 50% 100%,rgba(226,58,42,.18),transparent 60%);opacity:0;transition:opacity .3s;pointer-events:none}
.card:hover{transform:translateY(-6px);border-color:var(--gold)}
.card:hover::after{opacity:1}
.card-label{font-family:var(--serif);font-size:11px;letter-spacing:.4em;color:var(--gold);margin:0 0 18px}
.card-main{display:flex;align-items:flex-end;gap:14px;min-height:90px}
.card-main .big{font-family:var(--display);font-size:88px;font-weight:800;line-height:.85;color:var(--paper);letter-spacing:-.03em}
.card-main .big2{font-family:var(--display);font-size:44px;font-weight:800;line-height:1;color:var(--paper);display:block}
.card-main > div{display:flex;flex-direction:column;gap:4px}
.card-main span{font-family:var(--serif);letter-spacing:.1em;font-size:14px}
.card-main small{font-size:12px;opacity:.6;letter-spacing:.2em}
.card-main.time{font-family:var(--display);font-size:36px;font-weight:800;color:var(--gold-2);align-items:center;gap:14px}
.card-main.time i{font-style:normal;font-size:22px;opacity:.6}
.card-main.place{flex-direction:column;align-items:flex-start;gap:6px}
.card-main.fee{flex-direction:column;align-items:flex-start;gap:6px}
.card-main.fee .big2{color:var(--hi);text-shadow:0 0 24px rgba(226,58,42,.4)}
.card-foot{margin:18px 0 0;font-size:12px;opacity:.6;letter-spacing:.08em;padding-top:14px;border-top:1px dashed var(--line)}

/* ============ PROGRAM ============ */
.program{padding:140px 0;background:
  linear-gradient(180deg,#0a0712,#100620 50%,#180524);position:relative;overflow:hidden}
.program::before{content:"祭";position:absolute;font-family:var(--display);font-size:60vw;font-weight:800;color:rgba(226,58,42,.025);right:-10%;top:-10%;line-height:1;pointer-events:none;z-index:0}

.timeline{list-style:none;padding:0;margin:60px 0 0;position:relative}
.timeline::before{content:"";position:absolute;left:140px;top:8px;bottom:8px;width:1px;background:linear-gradient(180deg,transparent,var(--gold),var(--beni),transparent)}
.timeline li{display:grid;grid-template-columns:160px 1fr;gap:48px;padding:24px 0;position:relative;align-items:flex-start}
.timeline li::before{content:"";position:absolute;left:135px;top:30px;width:12px;height:12px;border-radius:50%;background:var(--gold);box-shadow:0 0 0 4px rgba(233,185,73,.2),0 0 24px rgba(233,185,73,.6);z-index:2}
.timeline .t-time{font-family:var(--display);font-size:30px;color:var(--gold-2);font-weight:800;letter-spacing:.04em}
.timeline .t-body{display:flex;flex-direction:column;gap:8px;padding-top:4px}
.timeline .t-body b{font-family:var(--serif);font-size:22px;letter-spacing:.1em}
.timeline .t-body span{opacity:.7;font-size:14px;letter-spacing:.06em;line-height:1.8}
.note{margin-top:40px;font-size:12px;opacity:.55;letter-spacing:.1em;text-align:center}

/* ============ STATS ============ */
.stats{padding:80px 0;background:linear-gradient(90deg,#7a1818,#c2342e,#7a1818);border-top:1px solid #4a0a0a;border-bottom:1px solid #4a0a0a;position:relative;overflow:hidden}
.stats::before{content:"";position:absolute;inset:0;background-image:repeating-linear-gradient(45deg,transparent 0,transparent 14px,rgba(0,0,0,.06) 14px,rgba(0,0,0,.06) 15px);opacity:.5}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:30px;text-align:center;position:relative;z-index:2}
.stats-grid b{font-family:var(--display);font-size:80px;font-weight:800;display:block;color:#fff4d8;line-height:1;letter-spacing:-.02em;text-shadow:0 4px 24px rgba(0,0,0,.4)}
.stats-grid small{font-family:var(--serif);font-size:14px;letter-spacing:.2em;color:rgba(255,244,216,.85);display:block;margin-top:10px}

/* ============ SPONSORS ============ */
.sponsors{padding:140px 0;background:linear-gradient(180deg,#180524,#0a0712);position:relative}
.muted{opacity:.65}
.muted.center{text-align:center;font-family:var(--serif);letter-spacing:.08em;margin-bottom:50px}

.sponsor-marquee{margin:40px -40px 50px;overflow:hidden;mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);-webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent)}
.sp-track{display:flex;gap:40px;align-items:center;animation:scroll-x 60s linear infinite;width:max-content}
.sp-track img{height:60px;width:auto;object-fit:contain;filter:brightness(0) invert(1);opacity:.5;transition:opacity .3s,filter .3s}
.sp-track img:hover{opacity:1;filter:none}

.sponsor-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:14px}
.sponsor-grid img{aspect-ratio:4/2.2;width:100%;object-fit:contain;padding:18px;background:rgba(245,234,212,.04);border:1px solid var(--line);border-radius:10px;transition:transform .25s,background .25s,border-color .25s;filter:brightness(.95)}
.sponsor-grid img:hover{transform:translateY(-4px);background:rgba(245,234,212,.1);border-color:var(--gold);filter:none}

/* ============ ACCESS ============ */
.access{padding:140px 0;background:linear-gradient(180deg,#0a0712,#120628);position:relative}
.access-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:80px;align-items:center}
.access-list{display:grid;grid-template-columns:80px 1fr;gap:14px 24px;margin:30px 0 30px}
.access-list dt{font-family:var(--serif);font-size:13px;letter-spacing:.2em;color:var(--gold);padding-top:6px}
.access-list dd{margin:0;font-family:var(--serif);font-size:15px;letter-spacing:.08em;padding:6px 0;border-bottom:1px dashed var(--line)}

.map-wrap{position:relative;aspect-ratio:4/3;border-radius:18px;overflow:hidden;border:1px solid var(--line);box-shadow:0 20px 60px -20px rgba(0,0,0,.6)}
.map-wrap iframe{position:absolute;inset:0;width:100%;height:100%;border:0;filter:grayscale(.4) saturate(.7) brightness(.9)}
.map-frame{position:absolute;inset:0;pointer-events:none;border:6px solid rgba(245,234,212,.06);border-radius:18px;box-shadow:inset 0 0 60px rgba(0,0,0,.5)}

/* ============ CONTACT CTA ============ */
.contact-cta{padding:120px 0;background:linear-gradient(180deg,#120628,#0a0712);position:relative;overflow:hidden}
.contact-cta::before{content:"";position:absolute;left:50%;top:0;transform:translateX(-50%);width:900px;height:900px;border-radius:50%;background:radial-gradient(circle,rgba(226,58,42,.18),transparent 60%);pointer-events:none}
.cc-paper{position:relative;max-width:880px;margin:0 auto;padding:80px 48px;border:1px solid var(--line);border-radius:24px;background:linear-gradient(180deg,rgba(245,234,212,.06),rgba(245,234,212,.02));text-align:center;backdrop-filter:blur(8px)}
.cc-paper::before{content:"";position:absolute;inset:8px;border:1px dashed rgba(245,234,212,.15);border-radius:18px;pointer-events:none}
.cc-actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-top:36px}

/* ============ FOOTER ============ */
.site-footer{background:#06040d;padding:80px 0 30px;position:relative;border-top:1px solid var(--line)}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:60px;padding-bottom:60px;border-bottom:1px solid var(--line)}
.logo-foot{margin-bottom:14px}
.small{font-size:13px;line-height:1.9;letter-spacing:.06em}
.ft-h{font-family:var(--serif);font-size:13px;letter-spacing:.3em;color:var(--gold);margin:0 0 18px}
.site-footer ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px}
.site-footer ul a{font-size:14px;opacity:.75;transition:opacity .2s,color .2s}
.site-footer ul a:hover{opacity:1;color:var(--gold)}
.copy{text-align:center;font-size:12px;opacity:.5;letter-spacing:.2em;padding-top:30px}

/* ============ RESPONSIVE ============ */
@media (max-width:960px){
  .site-nav{display:none}
  .moon{width:240px;height:240px;top:6%;right:-6%}
  .hero-inner{padding:140px 20px 80px}
  .hero-date{flex-direction:column;gap:14px}
  .hero-date .vline{width:60px;height:1px;background:linear-gradient(90deg,transparent,var(--gold),transparent)}
  .about-grid{grid-template-columns:1fr;gap:50px}
  .info-cards{grid-template-columns:repeat(2,1fr)}
  .timeline::before{left:64px}
  .timeline li{grid-template-columns:80px 1fr;gap:24px}
  .timeline li::before{left:59px}
  .timeline .t-time{font-size:22px}
  .stats-grid{grid-template-columns:repeat(2,1fr);gap:40px 20px}
  .stats-grid b{font-size:56px}
  .access-grid{grid-template-columns:1fr;gap:40px}
  .footer-grid{grid-template-columns:1fr;gap:36px}
  .lantern{width:46px;height:60px;margin-top:calc(14px + var(--i) * 4px)}
  .lantern .ko{font-size:16px}
  .cc-paper{padding:60px 26px}
}
@media (max-width:540px){
  .info-cards{grid-template-columns:1fr}
  .countdown{padding:12px 14px;gap:4px}
  .countdown > div{min-width:58px;padding:0 6px}
  .countdown b{font-size:26px}
  .card-main .big{font-size:64px}
  .sponsor-grid{grid-template-columns:repeat(2,1fr)}
}

/* prefers-reduced-motion */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:0.001s !important;animation-iteration-count:1 !important;transition-duration:0.001s !important}
}
