/* layout.css — nav, hero (base + Noir cinematic hero), sections, footer, media queries, prefers-reduced-motion (verbatim) */

nav{position:sticky;top:0;z-index:50;background:rgba(245,241,233,.86);backdrop-filter:blur(14px);border-bottom:1px solid var(--line)}
nav .wrap{display:flex;align-items:center;gap:18px;height:68px}
.brand{font-family:var(--serif);font-size:25px;font-weight:700;letter-spacing:-.01em;display:flex;align-items:center;gap:9px}
.brand .mk{width:34px;height:34px;border-radius:11px;background:var(--grad);display:flex;align-items:center;justify-content:center;color:#fff;font-size:17px;box-shadow:var(--shadow-sm)}
.brand span{color:var(--moss)}
.nav-links{display:flex;gap:26px;margin-left:auto}
.nav-links a{font-size:13.5px;font-weight:600;color:var(--ink);transition:.2s}.nav-links a:hover{color:var(--moss)}
.lang{display:flex;gap:2px;border:1px solid var(--line);border-radius:30px;padding:3px;background:var(--white)}
.lang button{border:none;background:none;font-family:var(--sans);font-size:11.5px;font-weight:700;padding:5px 9px;border-radius:20px;cursor:pointer;color:var(--muted)}
.lang button.on{background:var(--grad);color:#fff}

.hero{position:relative;overflow:hidden}
.hero::before{content:"";position:absolute;width:620px;height:620px;right:-120px;top:-160px;border-radius:50%;background:radial-gradient(circle,rgba(134,156,120,.28),transparent 68%);pointer-events:none}
.hero::after{content:"";position:absolute;width:380px;height:380px;left:-130px;bottom:-150px;border-radius:50%;background:radial-gradient(circle,rgba(191,125,79,.18),transparent 68%);pointer-events:none}
.hero .wrap{display:grid;grid-template-columns:1.05fr .95fr;gap:50px;align-items:center;padding:72px 24px 88px;position:relative}
.hero .eyebrow{display:block;margin-bottom:18px}
.hero h1{font-size:clamp(44px,7.2vw,82px);letter-spacing:-.015em}
.hero h1 em{font-style:italic;color:var(--moss)}
.hero .lead{font-size:19px;font-weight:400;color:var(--muted);margin:20px 0 16px;max-width:480px}
.hero .meta{display:flex;gap:18px;flex-wrap:wrap;font-size:13px;color:var(--muted);margin-bottom:28px}
.hero .meta b{color:var(--ink);font-weight:700}
.hero-actions{display:flex;gap:13px;flex-wrap:wrap}
.hero-visual{position:relative;aspect-ratio:1;border-radius:46% 54% 56% 44%/54% 44% 56% 46%;background:radial-gradient(circle at 42% 30%,#aec19f,#516b46);box-shadow:var(--shadow);display:flex;align-items:center;justify-content:center;animation:morph 16s ease-in-out infinite}
@keyframes morph{0%,100%{border-radius:46% 54% 56% 44%/54% 44% 56% 46%}50%{border-radius:56% 44% 44% 56%/44% 56% 44% 56%}}
.hero-visual .icon{font-size:80px;filter:drop-shadow(0 10px 22px rgba(0,0,0,.22));animation:float 6s ease-in-out infinite}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-14px)}}
.fbadge{position:absolute;background:var(--white);border-radius:16px;padding:12px 15px;box-shadow:var(--shadow);font-size:12.5px;font-weight:700;display:flex;align-items:center;gap:9px}
.fbadge .em{font-size:18px}
.fbadge.f1{top:24px;right:-14px;animation:float 7s ease-in-out infinite}
.fbadge.f2{bottom:60px;left:-22px;animation:float 8s ease-in-out .5s infinite}
.fbadge .dot{width:9px;height:9px;border-radius:50%;background:var(--sage);box-shadow:0 0 0 4px rgba(134,156,120,.25)}
.fbadge small{display:block;font-weight:500;color:var(--muted);font-size:11px}

section{padding:84px 0}
.alt{background:var(--cream)}
.sec-head{text-align:center;max-width:640px;margin:0 auto 48px}
.sec-head h2{font-size:clamp(30px,4.6vw,48px);margin-top:12px}
.sec-head p{color:var(--muted);font-size:16.5px;margin-top:12px}

footer{background:#273221;color:#cdd6c4;padding:54px 0 28px}
footer .cols{display:flex;justify-content:space-between;gap:30px;flex-wrap:wrap;margin-bottom:28px}
footer .brand{color:#fff}footer .brand span{color:#aec19f}footer .brand .mk{background:rgba(255,255,255,.12)}
footer p{font-size:13.5px;color:#9caf92;margin-top:10px;max-width:320px}footer a:hover{color:#fff}
.fcredit{border-top:1px solid rgba(255,255,255,.12);padding-top:18px;font-size:12px;color:#8a9b80;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px}
.fcredit b{color:#d9b878}
.fcredit .made-by a{color:#d9b878;font-weight:700;text-decoration:underline;text-underline-offset:2px}
.fcredit .made-by a:hover{color:#fff}
::selection{background:rgba(134,156,120,.35)}

/* NOTE: the responsive (≤900 / ≤760) + prefers-reduced-motion media queries were moved
   to the END of components.css. They override base grids (.cards/.feats/…)
   that live in components.css, which is loaded AFTER this file — so kept here they lost
   the cascade by source order and the layout never collapsed on mobile. The Noir hero
   ≤860 query below stays here (it only targets hero rules defined in this same file). */

/* ===== Noir cinematic hero ===== */
.hero{position:relative;min-height:100vh;display:flex;flex-direction:column;justify-content:space-between;overflow:hidden;background:#0a0a0c;padding:0}
.hero::before,.hero::after{display:none}
.hero-media{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:1}
.hero-bgfx{position:absolute;inset:-5%;z-index:0;background:radial-gradient(120% 90% at 72% 18%,#3a1512,#0a0a0c 58%),linear-gradient(180deg,#15100f,#08080a);animation:kb 24s ease-in-out infinite alternate}
@keyframes kb{from{transform:scale(1) translate(0,0)}to{transform:scale(1.1) translate(-2%,-1%)}}
.hero-overlay{position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(8,8,10,.5),rgba(8,8,10,.3) 38%,rgba(8,8,10,.9))}
.hero-ticks{position:absolute;left:20px;top:0;bottom:0;z-index:3;display:flex;flex-direction:column;justify-content:center;gap:11px}
.hero-ticks span{width:20px;height:2px;background:rgba(255,255,255,.4);transform-origin:left}
.hero-ticks span:nth-child(3){width:36px;background:var(--moss)}
.hero-top{position:relative;z-index:3;display:flex;align-items:center;justify-content:space-between;padding:22px 40px}
.hero-top .brand{color:#fff;font-family:var(--serif);font-size:19px;font-weight:600;letter-spacing:.22em;text-transform:uppercase;display:block}
.hero-top .brand b{color:var(--moss);font-weight:700}
.hero-top-right{display:flex;align-items:center;gap:16px}
.socials{display:flex;gap:10px}.socials a{color:rgba(255,255,255,.7);font-size:17px}.socials a:hover{color:var(--moss)}
.hero .lang{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.18)}
.hero .lang button{color:rgba(255,255,255,.7)}.hero .lang button.on{color:#fff}
.burger{width:44px;height:44px;border:1px solid rgba(255,255,255,.2);background:rgba(255,255,255,.06);color:#fff;border-radius:10px;font-size:20px;line-height:1;cursor:pointer}
.hero-center{position:relative;z-index:3;max-width:1180px;width:100%;margin:0 auto;padding:30px 40px}
.tag{display:inline-block;background:#fff;color:#0a0a0c;font-family:var(--serif);font-weight:600;text-transform:uppercase;letter-spacing:.14em;font-size:clamp(15px,1.6vw,20px);padding:7px 18px}
.hero-title{color:#fff;font-family:var(--serif);font-weight:700;text-transform:uppercase;font-size:clamp(46px,8.6vw,106px);line-height:.92;letter-spacing:.01em;margin-top:14px;max-width:12ch}
.hero-sub{color:rgba(255,255,255,.82);font-size:clamp(15px,1.6vw,18.5px);max-width:470px;margin-top:20px;font-weight:400}
.hero-cols{position:relative;z-index:3;max-width:1180px;width:100%;margin:0 auto;display:grid;grid-template-columns:repeat(2,1fr);gap:26px;padding:0 40px 48px}
.hcol{border-top:2px solid rgba(255,255,255,.2);padding-top:15px}
.hc-n{font-family:var(--serif);color:var(--moss);font-size:13px;font-weight:600;letter-spacing:.14em;margin-bottom:9px}
.hcol h3{color:#fff;font-family:var(--serif);text-transform:uppercase;font-size:21px;font-weight:600;letter-spacing:.05em;margin-bottom:7px}
.hcol p{color:rgba(255,255,255,.62);font-size:13px;margin-bottom:15px;line-height:1.5}
.rbtn{display:inline-flex;align-items:center;gap:8px;background:var(--grad);color:#fff;font-family:var(--sans);font-weight:700;font-size:12px;letter-spacing:.05em;text-transform:uppercase;padding:11px 20px;border-radius:5px;transition:.22s}
.rbtn::after{content:"→"}.rbtn:hover{filter:brightness(1.12);transform:translateX(4px)}
@media(max-width:860px){.hero-top{padding:18px 22px}.hero-top-right .socials{display:none}.hero-center{padding:90px 22px 20px}.hero-cols{grid-template-columns:1fr;gap:0;padding:0 22px 32px}.hcol{padding:14px 0;border-top:1px solid rgba(255,255,255,.14)}}
