:root {
    --paper: #f2efe9;
    --paper-2: #e9e4da;
    --ink: #121212;
    --ink-2: #38362f;
    --muted: #7c7669;
    --line: rgba(18, 18, 18, 0.14);
    --line-2: rgba(18, 18, 18, 0.08);
    --accent: #1f47ff;
    --accent-ink: #0e2bb0;
    --maxw: 1440px;
    --ease: cubic-bezier(0.19, 1, 0.22, 1);
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; text-size-adjust: 100%; }
body {
    margin: 0;
    font-family: 'Inter', system-ui, -apple-system, sans-serif;
    background: var(--paper);
    color: var(--ink);
    -webkit-font-smoothing: antialiased;
    text-rendering: optimizeLegibility;
    overflow-x: hidden;
    font-size: 17px;
    line-height: 1.6;
}
::selection { background: var(--accent); color: #fff; }
a { color: inherit; text-decoration: none; }
img { max-width: 100%; display: block; }

.wrap { max-width: var(--maxw); margin: 0 auto; padding: 0 clamp(24px, 5vw, 80px); }
.sec { padding: clamp(110px, 17vh, 240px) 0; }
.bleed { width: 100vw; margin-left: calc(50% - 50vw); }

/* Typography */
.serif { font-family: 'Fraunces', Georgia, serif; }
.kicker {
    display: inline-flex; align-items: center; gap: 12px;
    font-size: 12px; font-weight: 600; letter-spacing: 0.26em; text-transform: uppercase;
    color: var(--muted);
}
.kicker::before { content: ""; width: 34px; height: 1px; background: var(--accent); }
.kicker.solo::before { display: none; }

.h-display {
    font-family: 'Fraunces', Georgia, serif;
    font-weight: 600; font-optical-sizing: auto;
    font-size: clamp(3.2rem, 10vw, 10rem);
    line-height: 0.9; letter-spacing: -0.025em; margin: 0;
}
.h-2 {
    font-family: 'Fraunces', Georgia, serif;
    font-weight: 600;
    font-size: clamp(2.4rem, 6vw, 5.4rem);
    line-height: 0.96; letter-spacing: -0.02em; margin: 0;
}
.h-3 {
    font-family: 'Fraunces', Georgia, serif;
    font-weight: 600;
    font-size: clamp(1.7rem, 3vw, 2.8rem);
    line-height: 1.02; letter-spacing: -0.015em; margin: 0;
}
.accent { color: var(--accent); }
.lead { font-size: clamp(1.15rem, 1.7vw, 1.5rem); line-height: 1.55; color: var(--ink-2); font-weight: 400; }
.muted { color: var(--muted); }

/* Buttons */
.btn {
    display: inline-flex; align-items: center; gap: 12px;
    font-size: 15px; font-weight: 500; padding: 17px 30px; border-radius: 0;
    border: 1px solid var(--ink); transition: all 0.4s var(--ease); cursor: pointer; background: transparent;
}
.btn .ar { transition: transform 0.4s var(--ease); }
.btn:hover .ar { transform: translateX(6px); }
.btn-solid { background: var(--ink); color: var(--paper); }
.btn-solid:hover { background: var(--accent); border-color: var(--accent); color: #fff; }
.btn-line:hover { background: var(--ink); color: var(--paper); }

/* ---------------- NAV ---------------- */
.site-nav {
    display: block; position: fixed; inset: 0 0 auto 0; z-index: 1000;
    border-bottom: 1px solid transparent;
    transition: background 0.5s var(--ease), border-color 0.5s var(--ease), backdrop-filter 0.5s var(--ease);
}
.site-nav.scrolled {
    background: rgba(242, 239, 233, 0.82);
    -webkit-backdrop-filter: blur(16px); backdrop-filter: blur(16px);
    border-bottom-color: var(--line);
}
.nav-inner { display: flex; align-items: center; justify-content: space-between; height: 92px; transition: height 0.5s var(--ease); }
.site-nav.scrolled .nav-inner { height: 72px; }
.brand { display: flex; align-items: baseline; gap: 10px; font-family: 'Fraunces', serif; font-weight: 600; font-size: 1.5rem; letter-spacing: -0.02em; }
.brand b { font-weight: 600; }
.brand i { font-style: normal; color: var(--accent); }
.brand small { font-family: 'Inter', sans-serif; font-size: 10px; letter-spacing: 0.24em; text-transform: uppercase; color: var(--muted); font-weight: 600; }
.nav-links { display: flex; align-items: center; gap: 40px; }
.nav-links a { font-size: 14.5px; font-weight: 500; color: var(--ink-2); transition: color 0.3s var(--ease); }
.nav-links a:hover { color: var(--accent); }
.nav-links a.nav-cta { border: 1px solid var(--ink); padding: 11px 22px; }
.nav-links a.nav-cta:hover { background: var(--ink); color: var(--paper); }
.nav-toggle { display: none; background: none; border: 0; font-size: 26px; cursor: pointer; line-height: 1; }

/* ---------------- HERO ---------------- */
.hero { padding-top: clamp(150px, 22vh, 260px); padding-bottom: clamp(40px, 6vh, 90px); }
.hero-top { display: grid; grid-template-columns: 1fr auto; align-items: end; gap: 40px; }
.hero h1 { margin-top: 30px; max-width: 14ch; }
.hero-side { text-align: right; max-width: 320px; }
.hero-side p { margin: 0 0 24px; color: var(--ink-2); font-size: 1.05rem; line-height: 1.55; }
.hero-row { margin-top: clamp(48px, 7vh, 90px); display: grid; grid-template-columns: repeat(12, 1fr); gap: 30px; align-items: end; }
.hero-stats { grid-column: 1 / 8; display: flex; gap: clamp(28px, 4vw, 64px); flex-wrap: wrap; }
.hero-stat .n { font-family: 'Fraunces', serif; font-weight: 600; font-size: clamp(2.2rem, 3.4vw, 3.4rem); line-height: 1; letter-spacing: -0.03em; }
.hero-stat .l { font-size: 13.5px; color: var(--muted); margin-top: 8px; max-width: 18ch; }
.hero-actions { grid-column: 9 / 13; display: flex; gap: 14px; justify-content: flex-end; flex-wrap: wrap; }

.hero-figure { margin-top: clamp(60px, 9vh, 130px); position: relative; }
.hero-figure img { width: 100%; height: clamp(360px, 64vh, 760px); object-fit: cover; filter: grayscale(0.2) contrast(1.02); }
.hero-figure figcaption {
    position: absolute; left: clamp(24px, 5vw, 80px); bottom: 0; transform: translateY(50%);
    background: var(--paper); padding: 22px 28px; max-width: 360px; border: 1px solid var(--line);
}
.hero-figure figcaption .t { font-size: 13px; letter-spacing: 0.04em; color: var(--ink-2); line-height: 1.5; }

/* ---------------- MANIFESTO ---------------- */
.manifesto { background: var(--ink); color: var(--paper); }
.manifesto .wrap { display: grid; grid-template-columns: repeat(12, 1fr); gap: 30px; }
.manifesto .kicker { grid-column: 1 / 3; color: rgba(255,255,255,0.6); }
.manifesto .statement { grid-column: 3 / 13; }
.manifesto .statement p { font-family: 'Fraunces', serif; font-weight: 500; font-size: clamp(1.7rem, 3.4vw, 3.2rem); line-height: 1.18; letter-spacing: -0.015em; margin: 0; color: var(--paper); }
.manifesto .statement p .dim { color: rgba(255,255,255,0.45); }

/* ---------------- INDEX LIST (capabilities) ---------------- */
.section-head { display: grid; grid-template-columns: repeat(12, 1fr); gap: 30px; align-items: end; margin-bottom: clamp(50px, 7vh, 96px); }
.section-head .kicker { grid-column: 1 / 4; }
.section-head h2 { grid-column: 1 / 9; margin-top: 22px; }
.section-head .note { grid-column: 9 / 13; color: var(--muted); align-self: end; font-size: 1.02rem; }

.index { border-top: 1px solid var(--ink); }
.index-row {
    display: grid; grid-template-columns: 90px 1.1fr 1.4fr 40px; gap: 30px; align-items: baseline;
    padding: clamp(28px, 4vh, 48px) 0; border-bottom: 1px solid var(--line);
    transition: padding-left 0.45s var(--ease), background 0.45s var(--ease);
}
.index-row:hover { padding-left: 20px; background: linear-gradient(90deg, var(--paper-2), transparent 60%); }
.index-row .ix { font-family: 'Fraunces', serif; font-size: 1.1rem; color: var(--accent); font-weight: 600; }
.index-row h3 { font-family: 'Fraunces', serif; font-weight: 600; font-size: clamp(1.5rem, 2.6vw, 2.4rem); letter-spacing: -0.02em; line-height: 1.02; margin: 0; }
.index-row p { margin: 0; color: var(--ink-2); font-size: 1.02rem; line-height: 1.55; }
.index-row .go { font-size: 1.4rem; color: var(--muted); justify-self: end; transition: transform 0.45s var(--ease), color 0.45s var(--ease); }
.index-row:hover .go { transform: translateX(8px); color: var(--accent); }

/* ---------------- SPOTLIGHT (DBA/VGM/Plaka) ---------------- */
.spot { display: grid; grid-template-columns: repeat(12, 1fr); gap: clamp(30px, 5vw, 80px); align-items: center; }
.spot + .spot { margin-top: clamp(90px, 13vh, 190px); }
.spot .spot-media { grid-column: span 6; }
.spot .spot-media img { width: 100%; height: clamp(380px, 56vh, 640px); object-fit: cover; filter: grayscale(0.2); }
.spot .spot-body { grid-column: span 6; }
.spot:nth-child(even) .spot-media { order: 2; }
.spot .big-no { font-family: 'Fraunces', serif; font-size: clamp(3rem, 6vw, 6rem); line-height: 0.9; color: var(--accent); font-weight: 600; }
.spot .spot-body h3 { margin: 18px 0 0; }
.spot .spot-body p { margin: 26px 0 0; color: var(--ink-2); font-size: 1.12rem; line-height: 1.6; max-width: 42ch; }
.spot .spot-meta { margin: 34px 0 0; padding: 0; list-style: none; display: flex; flex-direction: column; }
.spot .spot-meta li { padding: 16px 0; border-top: 1px solid var(--line); font-size: 15px; display: flex; justify-content: space-between; gap: 20px; }
.spot .spot-meta li span:last-child { color: var(--muted); }

/* ---------------- MODULES (editorial grid, no cards) ---------------- */
.mods { display: grid; grid-template-columns: repeat(3, 1fr); gap: 0 clamp(30px, 4vw, 64px); border-top: 1px solid var(--ink); }
.mod {
    padding: clamp(30px, 4vh, 44px) 0; border-bottom: 1px solid var(--line);
    display: grid; grid-template-columns: auto 1fr; column-gap: 18px; align-content: start;
    transition: opacity 0.4s var(--ease);
}
.mod .mn { font-family: 'Fraunces', serif; font-size: 0.95rem; color: var(--accent); font-weight: 600; grid-row: 1; }
.mod h4 { grid-column: 2; font-family: 'Fraunces', serif; font-weight: 600; font-size: 1.3rem; letter-spacing: -0.01em; margin: 0; line-height: 1.1; }
.mod p { grid-column: 2; margin: 10px 0 0; font-size: 14.5px; line-height: 1.55; color: var(--muted); }
.mods:hover .mod { opacity: 0.45; }
.mods:hover .mod:hover { opacity: 1; }

/* ---------------- SECTORS (full-bleed bands) ---------------- */
.sector { position: relative; height: clamp(420px, 76vh, 820px); display: flex; align-items: flex-end; overflow: hidden; }
.sector img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; filter: grayscale(0.35) brightness(0.78); transition: transform 1.4s var(--ease), filter 1.4s var(--ease); }
.sector:hover img { transform: scale(1.05); filter: grayscale(0.1) brightness(0.82); }
.sector::after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, rgba(10,10,10,0.1), rgba(10,10,10,0.55)); }
.sector .sector-in { position: relative; z-index: 2; color: #fff; width: 100%; padding: clamp(36px, 6vw, 90px) clamp(24px, 5vw, 80px); max-width: var(--maxw); margin: 0 auto; display: grid; grid-template-columns: repeat(12, 1fr); gap: 24px; align-items: end; }
.sector .s-no { grid-column: 1 / 3; font-family: 'Fraunces', serif; font-size: clamp(2rem, 4vw, 3.4rem); font-weight: 600; opacity: 0.85; }
.sector .s-title { grid-column: 3 / 9; }
.sector .s-title h3 { font-family: 'Fraunces', serif; font-weight: 600; font-size: clamp(2.2rem, 5vw, 4.4rem); line-height: 0.98; letter-spacing: -0.02em; margin: 0; }
.sector .s-desc { grid-column: 9 / 13; color: rgba(255,255,255,0.82); font-size: 1.02rem; line-height: 1.5; }

/* ---------------- METRICS ---------------- */
.metrics { background: var(--ink); color: var(--paper); }
.metrics .section-head h2 { color: var(--paper); }
.metrics .section-head .kicker { color: rgba(255,255,255,0.6); }
.metrics .section-head .note { color: rgba(255,255,255,0.55); }
.metric-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(40px, 6vw, 90px); }
.metric .mv { font-family: 'Fraunces', serif; font-weight: 600; font-size: clamp(3.6rem, 9vw, 8.5rem); line-height: 0.86; letter-spacing: -0.04em; color: #fff; }
.metric .ml { margin-top: 22px; padding-top: 22px; border-top: 1px solid rgba(255,255,255,0.2); color: rgba(255,255,255,0.7); font-size: 1.02rem; max-width: 22ch; }

/* ---------------- CTA ---------------- */
.cta { text-align: center; border-top: 1px solid var(--line); }
.cta h2 { max-width: 16ch; margin: 24px auto 0; }
.cta p { max-width: 52ch; margin: 30px auto 0; color: var(--ink-2); font-size: 1.15rem; }
.cta-actions { margin-top: 46px; display: flex; justify-content: center; gap: 16px; flex-wrap: wrap; }

/* ---------------- FOOTER ---------------- */
.foot { background: var(--ink); color: rgba(255,255,255,0.62); padding: clamp(70px, 10vh, 130px) 0 40px; }
.foot-top { display: grid; grid-template-columns: 1.8fr 1fr 1fr 1.2fr; gap: 40px; padding-bottom: 60px; border-bottom: 1px solid rgba(255,255,255,0.12); }
.foot .brand { color: #fff; }
.foot .brand small { color: rgba(255,255,255,0.5); }
.foot-top > div > p { margin: 22px 0 0; max-width: 34ch; font-size: 14.5px; line-height: 1.7; }
.foot h5 { color: #fff; font-size: 11px; letter-spacing: 0.2em; text-transform: uppercase; margin: 0 0 22px; font-weight: 600; }
.foot a.fl { display: block; margin-bottom: 14px; font-size: 14.5px; transition: color 0.3s var(--ease); }
.foot a.fl:hover { color: #fff; }
.socials { display: flex; gap: 12px; margin-top: 24px; }
.social { width: 44px; height: 44px; display: grid; place-items: center; border: 1px solid rgba(255,255,255,0.2); color: #fff; transition: all 0.3s var(--ease); }
.social:hover { background: var(--accent); border-color: var(--accent); transform: translateY(-3px); }
.foot-bottom { padding-top: 30px; display: flex; justify-content: space-between; flex-wrap: wrap; gap: 14px; font-size: 13px; }
.foot-bottom a { color: var(--accent); }

/* ---------------- REVEAL ---------------- */
[data-reveal] { opacity: 0; transform: translateY(34px); transition: opacity 1s var(--ease), transform 1s var(--ease); }
[data-reveal].in { opacity: 1; transform: none; }
[data-reveal-delay="1"] { transition-delay: 0.09s; }
[data-reveal-delay="2"] { transition-delay: 0.18s; }
[data-reveal-delay="3"] { transition-delay: 0.27s; }

/* ---------------- RESPONSIVE ---------------- */
@media (max-width: 1024px) {
    .mods { grid-template-columns: repeat(2, 1fr); }
    .metric-grid { grid-template-columns: 1fr; gap: 56px; }
    .hero-stats { grid-column: 1 / 13; }
    .hero-actions { grid-column: 1 / 13; justify-content: flex-start; margin-top: 8px; }
}
@media (max-width: 760px) {
    body { font-size: 16px; }
    .nav-links { display: none; }
    .nav-toggle { display: block; }
    .nav-links.open {
        display: flex; flex-direction: column; align-items: flex-start; gap: 22px;
        position: absolute; top: 100%; left: 0; right: 0; background: var(--paper);
        padding: 28px clamp(24px,5vw,80px) 36px; border-bottom: 1px solid var(--line);
    }
    .nav-links.open a { font-size: 18px; }
    .hero-top { grid-template-columns: 1fr; align-items: start; }
    .hero-side { text-align: left; max-width: none; }
    .manifesto .wrap { grid-template-columns: 1fr; gap: 24px; }
    .manifesto .kicker, .manifesto .statement { grid-column: 1; }
    .section-head { grid-template-columns: 1fr; }
    .section-head .kicker, .section-head h2, .section-head .note { grid-column: 1; }
    .index-row { grid-template-columns: 44px 1fr; grid-template-areas: "ix title" ". desc"; gap: 8px 16px; }
    .index-row .ix { grid-area: ix; }
    .index-row h3 { grid-area: title; }
    .index-row p { grid-area: desc; }
    .index-row .go { display: none; }
    .index-row:hover { padding-left: 0; }
    .spot { grid-template-columns: 1fr; }
    .spot .spot-media, .spot .spot-body { grid-column: 1; }
    .spot:nth-child(even) .spot-media { order: 0; }
    .mods { grid-template-columns: 1fr; }
    .mods:hover .mod { opacity: 1; }
    .sector { height: 70vh; }
    .sector .sector-in { grid-template-columns: 1fr; gap: 12px; }
    .sector .s-no, .sector .s-title, .sector .s-desc { grid-column: 1; }
    .foot-top { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 480px) {
    .foot-top { grid-template-columns: 1fr; }
}
