/* ════════════════════════════════════════════════════════
   VEDEM RACING — Main Stylesheet
   vedem-site/css/main.css
════════════════════════════════════════════════════════ */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
  --bg:#0b0b0b;--bg2:#111111;--surface:#161616;--surface2:#1c1c1c;--surface3:#222222;
  --border:#272727;--border2:#333333;--text:#e6e2d9;--text-dim:#a09a92;--muted:#5a5550;
  --gold:#c8a45a;--orange:#e05c2a;--blue:#5a8fc8;--rf1:#c8a45a;--gtv:#e05c2a;--giulia:#5a8fc8;
  --nav-h:72px;
}
html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--text);font-family:'Barlow',sans-serif;font-weight:300;overflow-x:hidden;cursor:none}

/* cursor */
.cursor{position:fixed;width:10px;height:10px;background:var(--gold);border-radius:50%;pointer-events:none;z-index:9999;transform:translate(-50%,-50%);transition:width .2s,height .2s,opacity .2s;mix-blend-mode:difference}
.cursor.big{width:40px;height:40px;opacity:.5}

/* film grain */
body::after{content:'';position:fixed;inset:0;pointer-events:none;z-index:9000;opacity:.028;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)'/%3E%3C/svg%3E");background-size:200px}

/* ── nav ── */
nav{position:fixed;top:0;left:0;right:0;height:var(--nav-h);display:flex;align-items:center;justify-content:space-between;padding:0 3rem;z-index:1000;transition:background .4s,border-bottom .4s}
nav.scrolled{background:rgba(11,11,11,.97);backdrop-filter:blur(16px);border-bottom:1px solid var(--border)}
.nav-logo{font-family:'Barlow Condensed',sans-serif;font-weight:900;font-size:1.5rem;letter-spacing:.18em;text-transform:uppercase;text-decoration:none;color:var(--text);display:flex;align-items:center;gap:.6rem}
.nav-logo .logo-mark{width:36px;height:36px;border:2px solid var(--gold);display:flex;align-items:center;justify-content:center;font-size:.85rem;color:var(--gold);flex-shrink:0}
/* Swap .logo-mark for <img src="images/logo.svg" alt="Vedem Racing"> when ready */
.nav-logo span{color:var(--gold)}
.nav-links{display:flex;align-items:center;gap:2.5rem;list-style:none}
.nav-links a{font-family:'Barlow Condensed',sans-serif;font-weight:600;font-size:.8rem;letter-spacing:.2em;text-transform:uppercase;text-decoration:none;color:var(--muted);transition:color .2s;position:relative}
.nav-links a::after{content:'';position:absolute;bottom:-3px;left:0;right:100%;height:1px;background:var(--gold);transition:right .25s ease}
.nav-links a:hover{color:var(--text)}
.nav-links a:hover::after{right:0}
.nav-cta{font-family:'Barlow Condensed',sans-serif;font-weight:700;font-size:.75rem;letter-spacing:.2em;text-transform:uppercase;color:var(--bg)!important;background:var(--gold);padding:.5rem 1.2rem;text-decoration:none;transition:background .2s,color .2s!important}
.nav-cta::after{display:none!important}
.nav-cta:hover{background:var(--text)!important;color:var(--bg)!important}
.nav-hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:4px}
.nav-hamburger span{display:block;width:24px;height:2px;background:var(--text);transition:all .3s}

#mobile-menu{display:none;position:fixed;inset:0;background:rgba(11,11,11,.98);z-index:999;flex-direction:column;align-items:center;justify-content:center;gap:2rem}
#mobile-menu a.mob-link{font-family:'Barlow Condensed',sans-serif;font-weight:900;font-size:2.5rem;letter-spacing:.1em;text-transform:uppercase;color:var(--text);text-decoration:none}
#mobile-menu a.mob-cta{font-family:'Barlow Condensed',sans-serif;font-weight:700;font-size:.85rem;letter-spacing:.2em;text-transform:uppercase;color:var(--bg);background:var(--gold);padding:1rem 2.5rem;text-decoration:none;margin-top:1rem}
#mobile-menu .mob-close{position:absolute;top:2rem;right:2rem;background:none;border:none;color:var(--muted);font-size:2rem;cursor:pointer;line-height:1}

/* ── hero ── */
#hero{min-height:100vh;display:flex;flex-direction:column;justify-content:flex-end;padding:0 3rem 5rem;position:relative;overflow:hidden}
.hero-bg{position:absolute;inset:0;background:var(--bg)}
.hero-bg-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center;z-index:0;opacity:.55}
/* Add hero image: background-image:url('images/hero.jpg');background-size:cover;background-position:center */
.hero-bg::before{content:'';position:absolute;inset:0;background:repeating-linear-gradient(0deg,transparent,transparent 60px,rgba(255,255,255,.012) 60px,rgba(255,255,255,.012) 61px),repeating-linear-gradient(90deg,transparent,transparent 60px,rgba(255,255,255,.012) 60px,rgba(255,255,255,.012) 61px)}
.hero-bg::after{content:'';position:absolute;inset:0;background:linear-gradient(to top,rgba(11,11,11,1) 0%,rgba(11,11,11,.6) 40%,rgba(11,11,11,.2) 100%)}
.hero-img-placeholder{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;z-index:0}
.hero-img-placeholder .img-note{font-family:'Space Mono',monospace;font-size:.65rem;color:var(--muted);letter-spacing:.15em;text-transform:uppercase;background:rgba(11,11,11,.7);padding:.6rem 1.2rem;border:1px dashed var(--border2);z-index:1}
.hero-content{position:relative;z-index:10;max-width:1100px}
.hero-eyebrow{font-family:'Space Mono',monospace;font-size:.62rem;color:var(--gold);letter-spacing:.3em;text-transform:uppercase;margin-bottom:1.2rem;display:flex;align-items:center;gap:.8rem}
.hero-eyebrow::before{content:'';display:block;width:32px;height:1px;background:var(--gold)}
.hero-headline{font-family:'Barlow Condensed',sans-serif;font-weight:900;font-size:clamp(4.5rem,10vw,9rem);line-height:.92;text-transform:uppercase;letter-spacing:-.02em;margin-bottom:2rem}
.hero-headline .line-accent{color:var(--gold)}
.hero-headline .line-italic{font-style:italic;color:var(--text-dim)}
.hero-sub{font-size:1rem;color:var(--text-dim);max-width:480px;line-height:1.7;margin-bottom:2.5rem}
.hero-actions{display:flex;align-items:center;gap:1.5rem;flex-wrap:wrap}
.hero-stats{position:absolute;right:3rem;bottom:5rem;z-index:10;display:flex;flex-direction:column;gap:1.5rem;text-align:right}
.stat-num{font-family:'Barlow Condensed',sans-serif;font-weight:900;font-size:2.8rem;line-height:1;color:var(--text)}
.stat-num span{color:var(--gold);font-size:1.4rem}
.stat-label{font-family:'Space Mono',monospace;font-size:.55rem;color:var(--muted);letter-spacing:.15em;text-transform:uppercase}
.hero-scroll-hint{position:absolute;bottom:2rem;left:50%;transform:translateX(-50%);z-index:10;display:flex;flex-direction:column;align-items:center;gap:.5rem}
.scroll-line{width:1px;height:48px;background:linear-gradient(to bottom,transparent,var(--gold));animation:scrollPulse 2s ease-in-out infinite}
@keyframes scrollPulse{0%,100%{opacity:.3;transform:scaleY(1)}50%{opacity:1;transform:scaleY(1.1)}}
.scroll-text{font-family:'Space Mono',monospace;font-size:.5rem;color:var(--muted);letter-spacing:.2em;text-transform:uppercase;writing-mode:vertical-rl}

/* ── buttons ── */
.btn-primary{font-family:'Barlow Condensed',sans-serif;font-weight:700;font-size:.85rem;letter-spacing:.2em;text-transform:uppercase;color:var(--bg);background:var(--gold);padding:.9rem 2rem;text-decoration:none;transition:background .2s,transform .15s;display:inline-block}
.btn-primary:hover{background:var(--text);transform:translateY(-1px)}
.btn-ghost{font-family:'Barlow Condensed',sans-serif;font-weight:700;font-size:.85rem;letter-spacing:.2em;text-transform:uppercase;color:var(--text);border:1px solid var(--border2);padding:.9rem 2rem;text-decoration:none;transition:border-color .2s,color .2s,transform .15s;display:inline-block}
.btn-ghost:hover{border-color:var(--gold);color:var(--gold);transform:translateY(-1px)}

/* ── section utils ── */
section{position:relative}
.section-inner{max-width:1200px;margin:0 auto;padding:6rem 3rem}
.section-label{font-family:'Space Mono',monospace;font-size:.6rem;color:var(--gold);letter-spacing:.3em;text-transform:uppercase;display:flex;align-items:center;gap:.8rem;margin-bottom:1rem}
.section-label::before{content:'';display:block;width:24px;height:1px;background:var(--gold)}
.section-title{font-family:'Barlow Condensed',sans-serif;font-weight:900;font-size:clamp(2.5rem,5vw,4rem);line-height:.95;text-transform:uppercase;letter-spacing:-.01em}
.section-title em{font-style:italic;color:var(--text-dim)}
.section-title .accent{color:var(--gold)}
.section-rule{width:40px;height:3px;background:var(--gold);margin:1.5rem 0 3rem}

/* ── marquee ── */
.marquee-strip{background:var(--gold);padding:.7rem 0;overflow:hidden;white-space:nowrap}
.marquee-inner{display:inline-flex;animation:marquee 20s linear infinite}
.marquee-item{font-family:'Barlow Condensed',sans-serif;font-weight:900;font-size:.85rem;letter-spacing:.25em;text-transform:uppercase;color:var(--bg);padding:0 2rem}
.marquee-dot{color:rgba(11,11,11,.35);padding:0 .5rem}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ── about ── */
#about{background:var(--bg);border-top:1px solid var(--border)}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center}
.about-image-slot{position:relative;aspect-ratio:4/5;background:var(--surface);border:1px dashed var(--border2);display:flex;align-items:center;justify-content:center;overflow:hidden}
.about-image-slot::before{content:'';position:absolute;top:1rem;left:1rem;right:-1rem;bottom:-1rem;border:1px solid var(--border);z-index:0}
.about-image-slot img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
/* To add image: <img src="images/shop.jpg" alt="Vedem Racing shop"> */
.img-slot-label{font-family:'Space Mono',monospace;font-size:.6rem;color:var(--muted);letter-spacing:.15em;text-transform:uppercase;text-align:center;z-index:1}
.about-body{font-size:.95rem;color:var(--text-dim);line-height:1.85;margin-bottom:1.2rem}
.about-body strong{color:var(--text);font-weight:500}
.about-values{display:grid;grid-template-columns:1fr 1fr;gap:1px;margin-top:2.5rem;border:1px solid var(--border)}
.about-value{padding:1.2rem 1.4rem;background:var(--surface);border:1px solid var(--border)}
.about-value-num{font-family:'Barlow Condensed',sans-serif;font-weight:900;font-size:2rem;color:var(--gold);line-height:1;margin-bottom:.2rem}
.about-value-label{font-family:'Barlow Condensed',sans-serif;font-weight:700;font-size:.8rem;letter-spacing:.1em;text-transform:uppercase;color:var(--text);margin-bottom:.3rem}
.about-value-desc{font-size:.75rem;color:var(--muted);line-height:1.5}

/* ── builds ── */
#builds{background:var(--bg2);border-top:1px solid var(--border)}
.build-tabs{display:flex;border-bottom:1px solid var(--border);margin-bottom:0}
.tab-btn{background:none;border:none;border-bottom:3px solid transparent;padding:1.1rem 2.2rem 1.1rem 0;cursor:none;font-family:'Barlow Condensed',sans-serif;font-weight:700;font-size:.95rem;letter-spacing:.15em;text-transform:uppercase;color:var(--muted);transition:color .2s;margin-bottom:-1px;display:flex;align-items:center;gap:.6rem}
.tab-btn:hover{color:var(--text)}
.tab-btn.active{color:var(--text)}
.tab-btn.active.rf1{border-bottom-color:var(--rf1)}
.tab-btn.active.gtv{border-bottom-color:var(--gtv)}
.tab-btn.active.giulia{border-bottom-color:var(--giulia)}
.tab-dot{width:8px;height:8px;border-radius:50%;display:inline-block;opacity:.5}
.tab-btn.active .tab-dot{opacity:1}
.dot-rf1{background:var(--rf1)}.dot-gtv{background:var(--gtv)}.dot-giulia{background:var(--giulia)}
.build-panel{display:none;padding-top:3rem;animation:fadeIn .3s ease}
.build-panel.active{display:block}
.build-overview{display:grid;grid-template-columns:1fr 1.3fr;gap:2.5rem;margin-bottom:3rem}
.build-info h2{font-family:'Barlow Condensed',sans-serif;font-weight:900;font-size:3.2rem;text-transform:uppercase;line-height:.92;letter-spacing:-.01em;margin-bottom:.3rem}
.build-info .subtitle{font-family:'Space Mono',monospace;font-size:.6rem;color:var(--muted);letter-spacing:.15em;text-transform:uppercase;margin-bottom:1rem}
.build-info>p{font-size:.88rem;line-height:1.8;color:var(--text-dim);max-width:360px}
.build-divider{width:36px;height:2px;margin:.8rem 0 1rem}
.build-meta{display:flex;flex-direction:column;gap:.7rem;margin-top:1.2rem}
.meta-item{display:flex;gap:1rem;align-items:baseline}
.meta-label{font-family:'Space Mono',monospace;font-size:.58rem;color:var(--muted);text-transform:uppercase;letter-spacing:.1em;width:90px;flex-shrink:0}
.meta-val{color:var(--text);font-size:.8rem}
.progress-card{background:var(--surface);border:1px solid var(--border);padding:2rem}
.progress-card h3{font-family:'Barlow Condensed',sans-serif;font-weight:700;font-size:.8rem;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);margin-bottom:1.6rem}
.overall-progress{margin-bottom:2rem;display:flex;align-items:center;gap:1.4rem}
.big-pct{font-family:'Barlow Condensed',sans-serif;font-weight:900;font-size:3.8rem;line-height:1;min-width:95px}
.big-pct span{font-size:1.4rem;color:var(--muted)}
.overall-bar-wrap{flex:1}
.overall-label{font-size:.65rem;color:var(--muted);letter-spacing:.1em;text-transform:uppercase;margin-bottom:.4rem;font-family:'Space Mono',monospace}
.bar-track{width:100%;height:5px;background:var(--border);position:relative;overflow:hidden}
.bar-fill{height:100%;transition:width 1.2s cubic-bezier(.16,1,.3,1);width:0;position:relative}
.bar-fill::after{content:'';position:absolute;right:0;top:0;width:18px;height:100%;background:rgba(255,255,255,.3);filter:blur(3px)}
.phase-rows{display:flex;flex-direction:column;gap:.9rem}
.phase-header{display:flex;justify-content:space-between;margin-bottom:.35rem}
.phase-name{font-size:.72rem;color:var(--text);letter-spacing:.04em}
.phase-pct{font-family:'Space Mono',monospace;font-size:.6rem;color:var(--muted)}
.updates-header{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:1.2rem;border-bottom:1px solid var(--border);padding-bottom:.8rem}
.updates-header h3{font-family:'Barlow Condensed',sans-serif;font-weight:700;font-size:1.1rem;letter-spacing:.1em;text-transform:uppercase}
.update-count{font-family:'Space Mono',monospace;font-size:.62rem;color:var(--muted);letter-spacing:.1em}
.update-list{display:flex;flex-direction:column}
.update-item{position:relative;border-bottom:1px solid var(--border);cursor:none;transition:background .15s}
.update-item:last-child{border-bottom:none}
.update-item:hover{background:rgba(255,255,255,.015)}
.update-item.open{background:rgba(255,255,255,.022)}
.update-item::before{content:'';position:absolute;left:74px;top:0;bottom:0;width:1px;background:var(--border);pointer-events:none}
.update-item::after{content:'';position:absolute;left:70px;top:1.8rem;width:9px;height:9px;border-radius:50%;background:var(--border);border:2px solid var(--bg2);transition:background .25s,transform .25s;pointer-events:none}
.update-item[data-color="rf1"].open::after{background:var(--rf1);transform:scale(1.3)}
.update-item[data-color="gtv"].open::after{background:var(--gtv);transform:scale(1.3)}
.update-item[data-color="giulia"].open::after{background:var(--giulia);transform:scale(1.3)}
.update-header{display:grid;grid-template-columns:78px 1fr auto;gap:1.4rem;padding:1.4rem .5rem 1.4rem 0;align-items:start}
.update-date{font-family:'Space Mono',monospace;font-size:.58rem;color:var(--muted);letter-spacing:.05em;line-height:1.6;text-transform:uppercase;padding-top:.2rem}
.update-tag{display:inline-block;font-family:'Barlow Condensed',sans-serif;font-weight:700;font-size:.58rem;letter-spacing:.15em;text-transform:uppercase;padding:.12rem .55rem;margin-bottom:.45rem;border:1px solid currentColor}
.tag-fab{color:#c8a45a}.tag-engine{color:#e05c2a}.tag-design{color:#5a8fc8}.tag-testing{color:#7ac87a}.tag-planning{color:#c87ac8}.tag-suspension{color:#c8c87a}.tag-electrical{color:#7ac8c8}
.update-title{font-family:'Barlow Condensed',sans-serif;font-weight:700;font-size:1.1rem;letter-spacing:.03em;color:var(--text);margin-bottom:.3rem;transition:color .2s}
.update-item.open .update-title,.update-item:hover .update-title{color:#fff}
.update-preview{font-size:.8rem;color:var(--muted);line-height:1.55}
.update-chevron{display:flex;align-items:center;justify-content:center;width:26px;height:26px;margin-top:.2rem;flex-shrink:0;color:var(--muted);transition:transform .35s cubic-bezier(.34,1.56,.64,1),color .2s}
.update-item.open .update-chevron{transform:rotate(180deg);color:var(--text)}
.update-chevron svg{width:13px;height:13px}
.update-drawer{display:grid;grid-template-rows:0fr;transition:grid-template-rows .42s cubic-bezier(.16,1,.3,1);margin-left:92px}
.update-item.open .update-drawer{grid-template-rows:1fr}
.update-drawer-inner{overflow:hidden;min-height:0}
.update-drawer-content{padding-bottom:1.8rem;padding-right:1rem}
.drawer-divider{width:100%;height:1px;background:var(--border2);margin-bottom:1.2rem}
.drawer-details{display:flex;flex-wrap:wrap;gap:.5rem 2rem;margin-bottom:1.2rem;padding:.9rem 1.1rem;background:var(--surface2);border-left:2px solid var(--border2)}
.drawer-detail-item{display:flex;gap:.5rem;align-items:baseline;font-size:.76rem}
.drawer-detail-label{font-family:'Space Mono',monospace;font-size:.55rem;color:var(--muted);text-transform:uppercase;letter-spacing:.1em;white-space:nowrap}
.drawer-detail-val{color:var(--text)}
.drawer-body{font-size:.86rem;color:var(--text-dim);line-height:1.8;margin-bottom:1.2rem;max-width:680px}
.drawer-body p+p{margin-top:.75rem}
.drawer-images-label{font-family:'Space Mono',monospace;font-size:.55rem;color:var(--muted);text-transform:uppercase;letter-spacing:.1em;margin-bottom:.55rem}
.drawer-images{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:.5rem}
.img-placeholder{aspect-ratio:4/3;background:var(--surface3);border:1px dashed var(--border2);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.3rem;color:var(--muted);font-family:'Space Mono',monospace;font-size:.5rem;letter-spacing:.1em;text-transform:uppercase;transition:border-color .2s,background .2s;cursor:none}
.img-placeholder:hover{border-color:var(--gold);background:rgba(200,164,90,.04)}
.img-placeholder svg{width:17px;height:17px;opacity:.3}
/* Replace placeholder with: <img src="images/build-photo.jpg" alt="description"> */

/* ── videos ── */
#videos{background:var(--bg);border-top:1px solid var(--border)}
.videos-intro{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:end;margin-bottom:3.5rem}
.videos-intro p{font-size:.9rem;color:var(--text-dim);line-height:1.8}
.yt-link{display:inline-flex;align-items:center;gap:.6rem;font-family:'Barlow Condensed',sans-serif;font-weight:700;font-size:.8rem;letter-spacing:.15em;text-transform:uppercase;color:var(--gold);text-decoration:none;border-bottom:1px solid var(--gold);padding-bottom:.1rem;margin-top:1rem;transition:color .2s,border-color .2s}
.yt-link:hover{color:var(--text);border-color:var(--text)}
.video-grid{display:grid;grid-template-columns:2fr 1fr 1fr;grid-template-rows:auto auto;gap:.6rem}
.video-card{position:relative;overflow:hidden;background:var(--surface);cursor:none}
.video-card.featured{grid-row:1/3}
.video-thumb{aspect-ratio:16/9;background:var(--surface2);border:1px dashed var(--border2);display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;transition:transform .4s ease}
.video-card.featured .video-thumb{aspect-ratio:9/12}
.video-card:hover .video-thumb{transform:scale(1.03)}
.video-thumb img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
/* Add thumbnails: <img src="images/thumb-video-1.jpg" alt="title"> inside .video-thumb */
.video-play{position:absolute;width:52px;height:52px;background:rgba(11,11,11,.85);border:1px solid var(--gold);border-radius:50%;display:flex;align-items:center;justify-content:center;z-index:2;transition:background .2s,transform .2s}
.video-card:hover .video-play{background:var(--gold);transform:scale(1.1)}
.video-play svg{width:18px;height:18px;fill:var(--gold);margin-left:3px}
.video-card:hover .video-play svg{fill:var(--bg)}
.video-slot-label{font-family:'Space Mono',monospace;font-size:.55rem;color:var(--muted);letter-spacing:.12em;text-transform:uppercase;text-align:center;z-index:1}
.video-info{padding:1rem 1.1rem 1.1rem;border:1px solid var(--border);border-top:none}
.video-tag{font-family:'Space Mono',monospace;font-size:.55rem;color:var(--gold);letter-spacing:.15em;text-transform:uppercase;margin-bottom:.35rem}
.video-title{font-family:'Barlow Condensed',sans-serif;font-weight:700;font-size:1rem;letter-spacing:.02em;color:var(--text);line-height:1.2;margin-bottom:.3rem}
.video-meta{font-family:'Space Mono',monospace;font-size:.55rem;color:var(--muted);letter-spacing:.1em}
.video-cta-row{margin-top:2.5rem;text-align:center}

/* ── sponsors ── */
#sponsors{background:var(--bg2);border-top:1px solid var(--border)}
.sponsors-intro{max-width:560px;margin-bottom:4rem}
.sponsors-intro p{font-size:.9rem;color:var(--text-dim);line-height:1.8;margin-top:1rem}
.sponsor-tier{margin-bottom:3.5rem}
.tier-label{font-family:'Space Mono',monospace;font-size:.58rem;color:var(--muted);letter-spacing:.2em;text-transform:uppercase;margin-bottom:1.2rem;display:flex;align-items:center;gap:.8rem}
.tier-label::after{content:'';flex:1;height:1px;background:var(--border)}
.tier-label.primary{color:var(--gold)}
.tier-label.primary::before{content:'★ '}
.tier-label.secondary{color:var(--text-dim)}
.tier-label.community{color:var(--muted)}
.sponsor-grid{display:grid;gap:.6rem}
.sponsor-grid.primary{grid-template-columns:repeat(2,1fr)}
.sponsor-grid.secondary{grid-template-columns:repeat(3,1fr)}
.sponsor-grid.community{grid-template-columns:repeat(4,1fr)}
.sponsor-card{background:var(--surface);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;text-decoration:none;transition:border-color .25s,background .25s;position:relative;overflow:hidden;cursor:none}
.sponsor-card:hover{border-color:var(--gold);background:var(--surface2)}
.sponsor-card::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(200,164,90,.04) 0%,transparent 60%);opacity:0;transition:opacity .3s}
.sponsor-card:hover::before{opacity:1}
.sponsor-card.primary-card{padding:2.5rem;aspect-ratio:3/1}
.sponsor-card.secondary-card{padding:1.8rem;aspect-ratio:3/1}
.sponsor-card.community-card{padding:1.2rem;aspect-ratio:2.5/1}
.sponsor-logo-placeholder{display:flex;flex-direction:column;align-items:center;gap:.4rem;text-align:center}
/* Replace with: <img src="images/sponsor-name.svg" alt="Sponsor Name"> */
.sponsor-card img{max-width:80%;max-height:60%;object-fit:contain;filter:brightness(.6) contrast(1.2);transition:filter .25s}
.sponsor-card:hover img{filter:brightness(1) contrast(1)}
.sponsor-name{font-family:'Barlow Condensed',sans-serif;font-weight:700;font-size:1.1rem;letter-spacing:.1em;text-transform:uppercase;color:var(--text-dim)}
.sponsor-card.primary-card .sponsor-name{font-size:1.4rem;color:var(--text)}
.sponsor-category{font-family:'Space Mono',monospace;font-size:.5rem;color:var(--muted);letter-spacing:.12em;text-transform:uppercase}
.sponsor-cta-box{margin-top:3rem;border:1px solid var(--border2);padding:2.5rem 3rem;display:flex;align-items:center;justify-content:space-between;gap:2rem;background:var(--surface);position:relative;overflow:hidden}
.sponsor-cta-box::before{content:'';position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--gold)}
.sponsor-cta-text h3{font-family:'Barlow Condensed',sans-serif;font-weight:900;font-size:1.8rem;text-transform:uppercase;letter-spacing:.02em;margin-bottom:.3rem}
.sponsor-cta-text p{font-size:.85rem;color:var(--text-dim);max-width:400px;line-height:1.6}

/* ── support ── */
#support{background:var(--bg);border-top:1px solid var(--border);overflow:hidden}
#support .section-inner{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center}
.support-body{font-size:.9rem;color:var(--text-dim);line-height:1.85;margin:1.5rem 0 2rem}
.patreon-tiers{display:flex;flex-direction:column;gap:.6rem;margin-bottom:2rem}
.patreon-tier{display:flex;align-items:center;justify-content:space-between;padding:.9rem 1.2rem;background:var(--surface);border:1px solid var(--border);border-left:3px solid;transition:border-color .2s,background .2s}
.patreon-tier:hover{background:var(--surface2)}
.patreon-tier.t1{border-left-color:var(--muted)}.patreon-tier.t2{border-left-color:var(--gold)}.patreon-tier.t3{border-left-color:var(--orange)}
.tier-name{font-family:'Barlow Condensed',sans-serif;font-weight:700;font-size:.95rem;letter-spacing:.08em;text-transform:uppercase}
.tier-price{font-family:'Space Mono',monospace;font-size:.8rem;color:var(--gold)}
.tier-perks{font-size:.72rem;color:var(--muted);margin-top:.15rem}
.support-visual{position:relative}
.support-img-slot{aspect-ratio:1;background:var(--surface);border:1px dashed var(--border2);display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}
.support-img-slot::after{content:'';position:absolute;inset:0;background:linear-gradient(135deg,transparent 60%,rgba(200,164,90,.06) 100%)}
.corner-mark{position:absolute;width:20px;height:20px;border-color:var(--gold);border-style:solid;opacity:.4}
.corner-mark.tl{top:12px;left:12px;border-width:2px 0 0 2px}
.corner-mark.tr{top:12px;right:12px;border-width:2px 2px 0 0}
.corner-mark.bl{bottom:12px;left:12px;border-width:0 0 2px 2px}
.corner-mark.br{bottom:12px;right:12px;border-width:0 2px 2px 0}
.support-stat-badge{position:absolute;bottom:-1.5rem;right:-1.5rem;background:var(--gold);color:var(--bg);padding:1.2rem 1.5rem;text-align:center}
.badge-num{font-family:'Barlow Condensed',sans-serif;font-weight:900;font-size:2.2rem;line-height:1;display:block}
.badge-label{font-family:'Space Mono',monospace;font-size:.5rem;letter-spacing:.1em;text-transform:uppercase;display:block;margin-top:.2rem}

/* ── footer ── */
footer{background:#080808;border-top:1px solid var(--border)}
.footer-inner{max-width:1200px;margin:0 auto;padding:4rem 3rem 2rem}
.footer-top{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:3rem;margin-bottom:3rem;padding-bottom:3rem;border-bottom:1px solid var(--border)}
.footer-brand .logo-text{font-family:'Barlow Condensed',sans-serif;font-weight:900;font-size:1.6rem;letter-spacing:.2em;text-transform:uppercase;color:var(--text);margin-bottom:.8rem}
.footer-brand .logo-text span{color:var(--gold)}
.footer-brand p{font-size:.82rem;color:var(--muted);line-height:1.7;max-width:260px;margin-bottom:1.2rem}
.social-links{display:flex;gap:.6rem}
.social-link{width:34px;height:34px;border:1px solid var(--border);display:flex;align-items:center;justify-content:center;color:var(--muted);text-decoration:none;font-size:.75rem;font-family:'Barlow Condensed',sans-serif;font-weight:700;transition:border-color .2s,color .2s;cursor:none}
.social-link:hover{border-color:var(--gold);color:var(--gold)}
.social-link svg{width:14px;height:14px;fill:currentColor}
.footer-col h4{font-family:'Barlow Condensed',sans-serif;font-weight:700;font-size:.78rem;letter-spacing:.2em;text-transform:uppercase;color:var(--text);margin-bottom:1.1rem}
.footer-col ul{list-style:none;display:flex;flex-direction:column;gap:.6rem}
.footer-col ul a{font-size:.82rem;color:var(--muted);text-decoration:none;transition:color .2s}
.footer-col ul a:hover{color:var(--gold)}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}
.footer-bottom p{font-family:'Space Mono',monospace;font-size:.58rem;color:var(--muted);letter-spacing:.1em;text-transform:uppercase}

/* ── animations ── */
@keyframes fadeIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
@keyframes heroReveal{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}
.hero-content>*{opacity:0;animation:heroReveal .9s ease forwards}
.hero-eyebrow{animation-delay:.2s}.hero-headline{animation-delay:.4s}.hero-sub{animation-delay:.55s}.hero-actions{animation-delay:.7s}
.hero-stats{opacity:0;animation:heroReveal .9s ease .8s forwards}
.reveal{opacity:0;transform:translateY(24px);transition:opacity .7s ease,transform .7s ease}
.reveal.visible{opacity:1;transform:translateY(0)}
.reveal-delay-1{transition-delay:.1s}.reveal-delay-2{transition-delay:.2s}.reveal-delay-3{transition-delay:.3s}

/* ── responsive ── */
@media(max-width:900px){
  nav{padding:0 1.5rem}.nav-links{display:none}.nav-hamburger{display:flex}
  #hero{padding:0 1.5rem 4rem}.hero-stats{display:none}
  .section-inner{padding:4rem 1.5rem}
  .about-grid{grid-template-columns:1fr;gap:2.5rem}.about-image-slot{aspect-ratio:16/9}
  .build-overview{grid-template-columns:1fr}
  .videos-intro{grid-template-columns:1fr;gap:1.5rem}
  .video-grid{grid-template-columns:1fr 1fr;grid-template-rows:auto}
  .video-card.featured{grid-row:auto}.video-card.featured .video-thumb{aspect-ratio:16/9}
  .sponsor-grid.primary{grid-template-columns:1fr}.sponsor-grid.secondary{grid-template-columns:repeat(2,1fr)}.sponsor-grid.community{grid-template-columns:repeat(2,1fr)}
  .sponsor-cta-box{flex-direction:column;align-items:flex-start}
  #support .section-inner{grid-template-columns:1fr}.support-visual{display:none}
  .footer-top{grid-template-columns:1fr 1fr}
  .update-drawer{margin-left:0}.update-header{grid-template-columns:60px 1fr auto;gap:1rem}
  .update-item::before{left:56px}.update-item::after{left:52px}
}
@media(max-width:560px){
  .hero-headline{font-size:3.5rem}.video-grid{grid-template-columns:1fr}.about-values{grid-template-columns:1fr}
  .footer-top{grid-template-columns:1fr;gap:2rem}.sponsor-grid.secondary{grid-template-columns:1fr}.sponsor-grid.community{grid-template-columns:repeat(2,1fr)}
}