:root{--ink:#1a1a19;--cream:#faf6f1;--sand:#e8cba9;--sand-light:#f1dfc6;--sage:#8fb09a;--sage-light:#cfdcd2;--deep:#0a1628;--mist:#c8c0e0;--ember:#c45d3e;--ember-light:#e8c9bd;--line:rgba(26,26,25,.14);--line-strong:rgba(26,26,25,.28);--muted:rgba(26,26,25,.68);--serif:'Fraunces',Georgia,serif;--sans:'Be Vietnam Pro',-apple-system,system-ui,sans-serif;--mono:'Inconsolata',ui-monospace,monospace;--container:1440px;--gutter:clamp(24px,4vw,56px)}
*{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}
*:focus{outline:none}
*:focus-visible{outline:2px solid var(--ember);outline-offset:3px;border-radius:2px}
.btn:focus-visible,a.btn:focus-visible{outline-offset:4px}
body{background:var(--cream);color:var(--ink);font-family:var(--sans);font-weight:400;font-size:17px;line-height:1.5;-webkit-font-smoothing:antialiased}
img,svg{display:block;max-width:100%}a{color:inherit;text-decoration:none}button{font:inherit;cursor:pointer;border:none;background:none;color:inherit}
.container{max-width:var(--container);margin:0 auto;padding:0 var(--gutter)}
.kicker{font-family:var(--mono);font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);display:inline-flex;align-items:center;gap:10px}
.kicker::before{content:'';width:22px;height:1px;background:currentColor;opacity:.5}
.kicker.no-dash::before{display:none}.kicker.ember{color:var(--ember)}.kicker.sage{color:#3d6b4e}.kicker.sand{color:#a87944}
.display-xl{font-family:var(--serif);font-weight:300;font-size:clamp(48px,6.5vw,96px);line-height:.98;letter-spacing:-0.02em}
.display-l{font-family:var(--serif);font-weight:300;font-size:clamp(40px,4.5vw,68px);line-height:1.02;letter-spacing:-0.015em}
.display-m{font-family:var(--serif);font-weight:300;font-size:clamp(30px,3vw,44px);line-height:1.08;letter-spacing:-0.01em}
em,.italic{font-style:italic;font-weight:300}
h2.upper{font-family:var(--sans);font-weight:500;font-size:clamp(28px,3vw,44px);letter-spacing:-0.01em;text-transform:uppercase;line-height:1.05}
.lead{font-family:var(--serif);font-weight:300;font-size:clamp(20px,1.6vw,26px);line-height:1.35}
.muted{color:var(--muted)}.mono{font-family:var(--mono);font-size:12px;letter-spacing:.08em;text-transform:uppercase}
.hairline{height:1px;background:var(--line);width:100%}
/* CTA + newsletter still mounted via JS (variant-driven); reserve space to prevent CLS. */
#cta-mount{display:block;min-height:380px}
#newsletter-mount{display:block;min-height:520px;background:var(--sand)}
@media(max-width:900px){
  #cta-mount{min-height:480px}
  #newsletter-mount{min-height:780px}
}
/* Ticker/header/footer are now pre-rendered at build time → 0 CLS (see .claude/prerender.py) */
/* Ticker */
.ticker{background:var(--ink);color:var(--cream);font-family:var(--mono);font-size:13px;letter-spacing:.14em;text-transform:uppercase;overflow:hidden;position:relative;height:52px;display:flex;align-items:center}
.ticker:hover .ticker-track{animation-play-state:paused}
.ticker-track{display:inline-flex;white-space:nowrap;gap:60px;animation:tk 42s linear infinite;padding-left:100%}
.ticker a{display:inline-flex;align-items:center;gap:14px}.ticker .dot{width:6px;height:6px;background:var(--ember);border-radius:50%;display:inline-block}
.ticker .arrow{color:var(--ember)}@keyframes tk{from{transform:translateX(0)}to{transform:translateX(-100%)}}
/* Header */
.hdr{position:sticky;top:0;z-index:60;background:rgba(250,246,241,.88);backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);border-bottom:1px solid var(--line)}
.hdr-inner{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:32px;padding:18px var(--gutter);max-width:var(--container);margin:0 auto}
.hdr-logo{display:flex;align-items:center;gap:10px}.hdr-logo img{height:28px}
.hdr-nav{display:flex;justify-content:center;gap:clamp(14px,2vw,30px)}
.hdr-nav a{font-size:14px;opacity:.78;transition:opacity .2s;position:relative;padding:6px 0}.hdr-nav a:hover,.hdr-nav a.active{opacity:1}
.hdr-nav a.active::after{content:'';position:absolute;left:0;right:0;bottom:-2px;height:1px;background:var(--ember)}
.hdr-social{display:flex;gap:10px}.hdr-social a{width:34px;height:34px;border:1px solid var(--line);border-radius:50%;display:grid;place-items:center;transition:all .2s}
.hdr-social a:hover{background:var(--ink);color:var(--cream);border-color:var(--ink)}
@media(max-width:900px){.hdr-nav{display:none}.hdr-inner{grid-template-columns:auto 1fr}}
/* Buttons */
.btn{display:inline-flex;align-items:center;gap:10px;padding:16px 22px;font-family:var(--sans);font-size:14px;font-weight:500;border-radius:999px;transition:all .2s;border:1px solid transparent}
.btn:hover{transform:translateY(-1px)}.btn-primary{background:var(--ember);color:var(--cream)}.btn-primary:hover{background:#a84b30}
.btn-dark{background:var(--ink);color:var(--cream)}.btn-outline{background:transparent;border-color:var(--ink)}.btn-outline:hover{background:var(--ink);color:var(--cream)}
.btn .arr{transition:transform .3s}.btn:hover .arr{transform:translateX(4px)}
.chips{display:flex;flex-wrap:wrap;gap:12px;align-items:center}
.chip{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}
.chip-sep{width:1px;height:12px;background:var(--line-strong);display:inline-block}
/* Sections */
section{padding:clamp(80px,10vw,140px) 0;position:relative}
.bg-cream{background:var(--cream)}.bg-ink{background:var(--ink);color:var(--cream)}.bg-deep{background:var(--deep);color:var(--cream)}
.bg-sage-light{background:var(--sage-light)}.bg-sand-light{background:var(--sand-light)}.bg-mist{background:var(--mist)}.bg-ember-light{background:var(--ember-light)}.bg-white{background:#fff}
.bg-deep .kicker,.bg-ink .kicker{color:rgba(250,246,241,.55)}
.grid{display:grid;gap:32px}.g-12{grid-template-columns:repeat(12,1fr)}
.col-5{grid-column:span 5}.col-7{grid-column:span 7}
@media(max-width:900px){.g-12{grid-template-columns:1fr}.col-5,.col-7{grid-column:span 1}}
/* Footer */
.ftr{background:var(--deep);color:var(--cream);padding:100px 0 32px}
.ftr-top{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:60px;padding-bottom:60px;border-bottom:1px solid rgba(250,246,241,.14)}
.ftr-brand img{height:32px;margin-bottom:22px;filter:invert(1) brightness(1.4)}
.ftr-brand p{color:rgba(250,246,241,.6);max-width:32ch;font-size:14px;line-height:1.5;margin-bottom:22px}
.ftr h4{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:rgba(250,246,241,.5);margin-bottom:18px}
.ftr ul{list-style:none;display:flex;flex-direction:column;gap:12px}
.ftr ul a{color:rgba(250,246,241,.85);font-size:14px}.ftr ul a:hover{color:var(--ember)}
.ftr-social{display:flex;gap:8px}.ftr-social a{width:36px;height:36px;border:1px solid rgba(250,246,241,.2);border-radius:50%;display:grid;place-items:center}
.ftr-social a:hover{background:var(--ember);border-color:var(--ember)}
.ftr-bottom{display:flex;justify-content:space-between;padding-top:28px;color:rgba(250,246,241,.4);font-size:12px;font-family:var(--mono);letter-spacing:.08em;text-transform:uppercase}
.ftr-bottom a{color:rgba(250,246,241,.6)}.ftr-bottom a:hover{color:var(--ember)}
@media(max-width:900px){.ftr-top{grid-template-columns:1fr 1fr;gap:40px}}
/* CTA */
.cta-block{padding:clamp(80px,10vw,140px) 0}
.cta-block.ember{background:var(--ember);color:var(--cream)}.cta-block.cream{background:var(--cream)}.cta-block.dark{background:var(--ink);color:var(--cream)}.cta-block.deep{background:var(--deep);color:var(--cream)}
.cta-wrap{max-width:var(--container);margin:0 auto;padding:0 var(--gutter)}
.cta-wrap h2{font-family:var(--serif);font-weight:300;font-size:clamp(36px,4vw,60px);line-height:1.05;letter-spacing:-0.015em;max-width:18ch;margin:18px 0 40px}
.cta-block.ember .btn-primary{background:var(--cream);color:var(--ember)}.cta-block.ember .btn-primary:hover{background:var(--ink);color:var(--cream)}
.cta-block.ember .btn-outline{border-color:rgba(250,246,241,.55);color:var(--cream)}.cta-block.ember .btn-outline:hover{background:var(--cream);color:var(--ember);border-color:var(--cream)}
.cta-actions{display:grid;grid-template-columns:repeat(2,max-content);gap:16px 40px;align-items:center;margin-top:8px}
.cta-note{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;opacity:.7;line-height:1.5;max-width:28ch}
.cta-notes{display:flex;flex-wrap:wrap;gap:30px;margin-top:30px;font-family:var(--mono);font-size:12px;letter-spacing:.1em;text-transform:uppercase;opacity:.75}
/* Newsletter */
.news{padding:clamp(80px,10vw,120px) 0;background:var(--sand)}.news.deep{background:var(--deep);color:var(--cream)}
.news-wrap{max-width:var(--container);margin:0 auto;padding:0 var(--gutter);display:grid;grid-template-columns:1fr 1.3fr;gap:60px;align-items:start}
.news-logo{font-family:var(--serif);font-size:48px;font-style:italic;font-weight:300;letter-spacing:-0.02em;line-height:1}
.news.deep .news-logo img{filter:invert(1) brightness(1.15)}
.news-logo span{font-style:normal;font-family:var(--sans);font-weight:400;font-size:28px;vertical-align:6px}
.news h3{font-family:var(--serif);font-weight:300;font-size:clamp(22px,2.2vw,34px);line-height:1.2;margin-bottom:30px}
.news-lead{padding-right:20px}
.news-lead .kicker{margin-bottom:18px}
.news-h{font-family:var(--serif);font-weight:300;font-size:clamp(28px,3vw,44px);line-height:1.1;letter-spacing:-0.015em;margin-bottom:20px}
.news-h em{font-style:italic;color:var(--ember);font-weight:300}
.news-sub{font-family:var(--serif);font-weight:300;font-size:clamp(16px,1.5vw,20px);line-height:1.5;color:var(--muted);margin-bottom:20px;max-width:42ch}
.news.deep .news-sub{color:rgba(250,246,241,.78)}
.news-meta{display:flex;flex-wrap:wrap;gap:14px;font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}
.news.deep .news-meta{color:rgba(250,246,241,.5)}
.news-form{display:grid;grid-template-columns:1fr 1fr;gap:18px}.news-form .full{grid-column:span 2}
.news-field label{display:block;font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-bottom:6px}
.news.deep .news-field label{color:rgba(250,246,241,.6)}
.news-field input{width:100%;background:transparent;border:none;border-bottom:1px solid var(--line-strong);padding:10px 0;font:inherit;color:inherit}
.news.deep .news-field input{border-bottom-color:rgba(250,246,241,.3)}
.news-field input:focus{outline:none;border-bottom-color:var(--ember)}
.rodo{font-size:12px;line-height:1.5;color:var(--muted);margin:20px 0;display:flex;gap:10px;align-items:flex-start}
.news.deep .rodo{color:rgba(250,246,241,.65)}.rodo input{margin-top:4px;flex-shrink:0}
@media(max-width:900px){.news-wrap,.news-form{grid-template-columns:1fr}.news-form .full{grid-column:span 1}}
.scroll-hint{position:absolute;left:var(--gutter);bottom:30px;display:flex;flex-direction:column;align-items:center;gap:4px;animation:bnc 2s infinite}
@keyframes bnc{0%,100%{transform:translateY(0)}50%{transform:translateY(6px)}}
.portrait-bw{filter:grayscale(100%) contrast(1.02);transition:filter .5s}

/* ═══════ Subtle animations ═══════ */
/* Scroll reveal — only applies AFTER .js-ready class on <html> (set by shared.js).
   Without JS, content stays fully visible (no FOUC, no blank text on slow connections). */
.js-ready [data-reveal]{opacity:0;transform:translateY(48px);transition:opacity 1.1s cubic-bezier(.2,.7,.2,1),transform 1.1s cubic-bezier(.2,.7,.2,1);transition-delay:var(--rd,0ms);will-change:opacity,transform}
.js-ready [data-reveal].in{opacity:1;transform:none}
/* Above-fold safety: never hide elements inside the hero (.hh) — they ARE the LCP */
.js-ready .hh [data-reveal]{opacity:1;transform:none;transition:none}
.js-ready [data-reveal="clip"]{opacity:1;transform:none;clip-path:inset(0 100% 0 0);transition:clip-path 1.6s cubic-bezier(.76,0,.24,1);transition-delay:var(--rd,0ms)}
.js-ready [data-reveal="clip"].in{clip-path:inset(0 0 0 0)}
.js-ready [data-reveal="scale-img"]{overflow:hidden}
.js-ready [data-reveal="scale-img"] img{transform:scale(1.14);opacity:0;transition:transform 2s cubic-bezier(.2,.7,.2,1),opacity 1.2s ease}
.js-ready [data-reveal="scale-img"].in img{transform:scale(1);opacity:1}
@media (prefers-reduced-motion:reduce){.js-ready [data-reveal]{opacity:1;transform:none;clip-path:none;transition:none}.js-ready [data-reveal="scale-img"] img{transform:none;transition:none}}

/* Nav link underline */
.hdr-nav a{position:relative}
.hdr-nav a::after{content:'';position:absolute;left:0;right:0;bottom:-6px;height:1px;background:var(--ink);transform:scaleX(0);transform-origin:right;transition:transform .35s cubic-bezier(.6,.1,.2,1)}
.hdr-nav a:hover::after,.hdr-nav a.active::after{transform:scaleX(1);transform-origin:left}

/* Kicker dot pulse */
.kicker{position:relative}
.kicker.ember::before,.kicker.sage::before{animation:kickerPulse 3.2s ease-in-out infinite}
@keyframes kickerPulse{0%,100%{opacity:1}50%{opacity:.35}}

/* Buttons — arrow slide */
.btn .arr{display:inline-block;transition:transform .4s cubic-bezier(.4,0,.2,1)}
.btn:hover .arr{transform:translateX(10px)}
.btn{transition:background .3s,color .3s,border-color .3s,transform .4s cubic-bezier(.2,.7,.2,1)}
.btn:hover{transform:translateY(-2px)}

/* Card lift — services, curators, posts */
.svc-row,.cur-c,.sp-c,.pc,.partner-card,.fi{transition:transform .5s cubic-bezier(.2,.7,.2,1),box-shadow .5s,background-color .4s}
.svc-row:hover,.pc:hover{transform:translateY(-6px)}
.mem,.ch,.cc{transition:transform .5s cubic-bezier(.2,.7,.2,1)}
.mem:hover,.ch:hover,.cc:hover{transform:translateY(-4px)}

/* Image zoom in cards */
.partner-photo,.mp,.cur-a,.pc-i,.lm{overflow:hidden}
.partner-photo img,.mp img,.cur-a img,.pc-i img,.lm img{transition:transform 1s cubic-bezier(.2,.7,.2,1)}
.partner-card:hover .partner-photo img,.mem:hover .mp img,.cur-c:hover .cur-a img,.pc:hover .pc-i img,.lm:hover img{transform:scale(1.08)}

/* Portrait section parallax hint */
.portrait-section img{transition:transform 1.4s cubic-bezier(.2,.7,.2,1)}
.portrait-section.in img{transform:scale(1.03)}

/* Statement — italic emphasis subtle underline draw */
.statement em{background-image:linear-gradient(var(--ember),var(--ember));background-repeat:no-repeat;background-size:0% 1px;background-position:0 100%;transition:background-size 1.6s cubic-bezier(.76,0,.24,1) .4s}
.statement.in em{background-size:100% 1px}
.misja .statement em{background-image:linear-gradient(var(--ember),var(--ember))}

/* Accordion smooth glyph rotation (already exists, adding color shift) */
.ai2:hover .ab-t{color:var(--ember);transition:color .3s}
.ab-t{transition:color .3s}

/* Video frame subtle glow */
.vf{transition:box-shadow .5s}
.vf:hover{box-shadow:0 20px 60px -20px rgba(10,22,40,.35)}

/* Form inputs */
.news-field input{transition:border-bottom-color .3s,padding-left .3s}
.news-field input:focus{padding-left:4px}

/* FAQ chevron */
.fi .ft{transition:transform .4s cubic-bezier(.6,.1,.2,1),color .3s}
.fi:hover .ft{color:var(--ember)}

/* Partners track pause feel */
.partner-card{transition:transform .45s}
.partner-card:hover{transform:translateY(-4px)}

/* Skip link (a11y) */
.skip-link{position:absolute;left:-9999px;top:0;z-index:100;background:var(--ink);color:var(--cream);padding:12px 18px;font-family:var(--mono);font-size:12px;letter-spacing:.12em;text-transform:uppercase}
.skip-link:focus{left:12px;top:12px;outline:2px solid var(--ember);outline-offset:2px}

/* Mobile hamburger */
.hdr-burger{display:none;width:40px;height:40px;border:1px solid var(--line-strong);border-radius:50%;align-items:center;justify-content:center;flex-direction:column;gap:4px;background:transparent}
.hdr-burger span{display:block;width:16px;height:1.5px;background:var(--ink);transition:transform .3s,opacity .25s}
.hdr-burger.open span:nth-child(1){transform:translateY(5.5px) rotate(45deg)}
.hdr-burger.open span:nth-child(2){opacity:0}
.hdr-burger.open span:nth-child(3){transform:translateY(-5.5px) rotate(-45deg)}
.hdr-mobile{position:fixed;top:0;left:0;right:0;background:var(--cream);padding:80px var(--gutter) 48px;border-bottom:1px solid var(--line);z-index:55;transform:translateY(-100%);opacity:0;transition:transform .35s cubic-bezier(.2,.7,.2,1),opacity .25s ease}
.hdr-mobile.open{transform:translateY(0);opacity:1}
.hdr-mobile nav{display:flex;flex-direction:column;gap:18px;padding:24px 0}
.hdr-mobile nav a{font-family:var(--serif);font-weight:300;font-size:28px;line-height:1.1;letter-spacing:-.01em}
.hdr-mobile nav a[aria-current="page"]{color:var(--ember)}
.hdr-mobile-social{display:flex;gap:10px;padding-top:24px;border-top:1px solid var(--line)}
.hdr-mobile-social a{width:36px;height:36px;border:1px solid var(--line);border-radius:50%;display:grid;place-items:center}
@media(max-width:900px){.hdr-burger{display:inline-flex}.hdr-social{display:none}.hdr-inner{grid-template-columns:auto 1fr auto}}
@media (prefers-reduced-motion:reduce){.hdr-mobile{transition:none}.ticker-track{animation:none !important}}

/* Cookie banner (RODO-compliant: equal visual weight on both buttons) */
.ck-banner{position:fixed;left:16px;right:16px;bottom:16px;z-index:90;background:var(--ink);color:var(--cream);box-shadow:0 20px 50px -10px rgba(0,0,0,.35);border:1px solid rgba(250,246,241,.08);padding:20px 22px;animation:ckIn .35s cubic-bezier(.2,.7,.2,1);max-width:1140px;margin:0 auto}
.ck-banner .ck-inner{display:grid;grid-template-columns:1fr auto;gap:24px;align-items:center}
.ck-banner .ck-text strong{display:block;font-family:var(--serif);font-weight:400;font-size:15px;margin-bottom:6px;color:var(--cream)}
.ck-banner p{font-size:13px;line-height:1.55;color:rgba(250,246,241,.78);margin:0;max-width:62ch}
.ck-banner p a{color:var(--ember-light);text-decoration:underline;text-underline-offset:3px}
.ck-banner .ck-acts{display:flex;gap:8px;flex-shrink:0}
/* Both buttons share the same visual weight — RODO Art.4(11)/EDPB Guidelines 03/2022 */
.ck-banner button{font:500 13px/1 var(--sans);padding:12px 20px;border-radius:999px;cursor:pointer;border:1px solid rgba(250,246,241,.4);background:transparent;color:var(--cream);transition:background .2s,border-color .2s}
.ck-banner button:hover{background:rgba(250,246,241,.08);border-color:rgba(250,246,241,.7)}
.ck-banner button:focus-visible{outline:2px solid var(--ember-light);outline-offset:3px}
@media(max-width:700px){.ck-banner .ck-inner{grid-template-columns:1fr;gap:16px}.ck-banner .ck-acts{display:grid;grid-template-columns:1fr 1fr;width:100%}.ck-banner button{width:100%}}
@keyframes ckIn{from{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}
@media (prefers-reduced-motion:reduce){.ck-banner{animation:none}}
