/* KEY-CRON Hugo Theme — style.css
   Art direction: B2B Manufacturing / Services → professional, direct, trustworthy
   Palette: warm neutral surfaces + orange #ff4f00 accent (Zapier-style)
   Typography: Clash Display (headings) + Inter (body)
   ─────────────────────────────────────────────── */

:root {
  /* Brand */
  --orange:        #ff4f00;
  --orange-h:      #e64500;
  --orange-a:      #c43900;
  --orange-light:  oklch(97% .015 50);
  --orange-border: oklch(88% .04 50);

  /* Surfaces */
  --bg:            #fffefb;
  --surface:       #faf9f6;
  --surface-2:     #f4f2ee;
  --border:        #c5c0b1;
  --border-light:  rgba(197,192,177,.45);
  --divider:       #e2dfda;

  /* Text */
  --text:          #201515;
  --text-muted:    #6e6860;
  --text-faint:    #9e9990;
  --text-inv:      #f5f3ef;

  /* Dark section */
  --dark:          #201515;
  --dark-2:        #2e2020;
  --dark-text:     #f0ede8;
  --dark-muted:    rgba(240,237,232,.65);

  /* Radius */
  --radius-sm: .375rem;
  --radius-md: .5rem;
  --r-lg:      .75rem;
  --r-xl:      1rem;
  --r-2xl:     1.25rem;
  --r-full:    9999px;

  /* Fluid type */
  --text-xs:   clamp(.75rem,.7rem + .25vw,.875rem);
  --text-sm:   clamp(.875rem,.8rem + .35vw,1rem);
  --text-base: clamp(1rem,.95rem + .25vw,1.125rem);
  --text-lg:   clamp(1.125rem,1rem + .75vw,1.5rem);
  --text-xl:   clamp(1.5rem,1.2rem + 1.25vw,2.25rem);
  --text-2xl:  clamp(2rem,1.2rem + 2.5vw,3.5rem);
  --text-3xl:  clamp(2.5rem,1rem + 4vw,5rem);
  --text-hero: clamp(3rem,.5rem + 7vw,8rem);

  /* Spacing */
  --sp1:.25rem;--sp2:.5rem;--sp3:.75rem;--sp4:1rem;--sp5:1.25rem;--sp6:1.5rem;
  --sp8:2rem;--sp10:2.5rem;--sp12:3rem;--sp16:4rem;--sp20:5rem;--sp24:6rem;

  /* Shadows */
  --shadow-sm: 0 1px 2px oklch(.2 .01 50/.06);
  --shadow-md: 0 4px 12px oklch(.2 .01 50/.08);
  --shadow-lg: 0 12px 32px oklch(.2 .01 50/.12);

  /* Layout */
  --nav-h:            64px;
  --content-narrow:   640px;
  --content-default:  960px;
  --content-wide:     1200px;

  /* Fonts */
  --font-display: 'Clash Display','Georgia',serif;
  --font-body:    'Inter','Helvetica Neue',sans-serif;

  /* Motion */
  --ease: cubic-bezier(.16,1,.3,1);
  --tr:   180ms var(--ease);
}

/* Dark mode */
[data-theme="dark"] {
  --bg:#171210;--surface:#1c1916;--surface-2:#22201d;
  --border:#3a3530;--border-light:rgba(58,53,48,.6);--divider:#2e2b27;
  --text:#e8e5df;--text-muted:#8a8580;--text-faint:#5e5a55;--text-inv:#201515;
  --orange:#ff6b25;--orange-h:#ff4f00;--orange-a:#e64500;
  --orange-light:rgba(255,111,37,.08);--orange-border:rgba(255,111,37,.25);
  --shadow-sm:0 1px 2px oklch(0 0 0/.25);--shadow-md:0 4px 12px oklch(0 0 0/.35);--shadow-lg:0 12px 32px oklch(0 0 0/.45);
}
@media(prefers-color-scheme:dark){:root:not([data-theme]){
  --bg:#171210;--surface:#1c1916;--surface-2:#22201d;
  --border:#3a3530;--border-light:rgba(58,53,48,.6);--divider:#2e2b27;
  --text:#e8e5df;--text-muted:#8a8580;--text-faint:#5e5a55;--text-inv:#201515;
  --orange:#ff6b25;--orange-h:#ff4f00;--orange-a:#e64500;
  --orange-light:rgba(255,111,37,.08);--orange-border:rgba(255,111,37,.25);
  --shadow-sm:0 1px 2px oklch(0 0 0/.25);--shadow-md:0 4px 12px oklch(0 0 0/.35);--shadow-lg:0 12px 32px oklch(0 0 0/.45);
}}

/* ── Reset ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility;scroll-behavior:smooth;scroll-padding-top:var(--nav-h)}
body{min-height:100dvh;line-height:1.6;font-family:var(--font-body);font-size:var(--text-base);color:var(--text);background:var(--bg);transition:background var(--tr),color var(--tr)}
img,picture,video,canvas,svg{display:block;max-width:100%;height:auto}
input,button,textarea,select{font:inherit;color:inherit}
h1,h2,h3,h4,h5,h6{text-wrap:balance;line-height:1.12;font-family:var(--font-display)}
p,li,figcaption{text-wrap:pretty;max-width:72ch}
::selection{background:oklch(from var(--orange) l c h/.18)}
:focus-visible{outline:2px solid var(--orange);outline-offset:3px;border-radius:var(--radius-sm)}
@media(prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important}}
button{cursor:pointer;background:none;border:none}
a,button,[role="button"],input,textarea,select{transition:color var(--tr),background var(--tr),border-color var(--tr),box-shadow var(--tr),opacity var(--tr)}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}
.skip-link{position:fixed;top:var(--sp4);left:var(--sp4);z-index:999;padding:var(--sp2) var(--sp4);background:var(--orange);color:#fff;border-radius:var(--radius-md);font-weight:600}

/* ── Containers ── */
.c{max-width:var(--content-wide);margin-inline:auto;padding-inline:var(--sp6)}
.c--md{max-width:var(--content-default)}
.c--sm{max-width:var(--content-narrow)}
.sec{padding-block:clamp(var(--sp12),6vw,var(--sp24))}
.sec-border{border-top:1px solid var(--divider)}

/* ── Buttons ── */
.btn{display:inline-flex;align-items:center;gap:var(--sp2);font-family:var(--font-body);font-weight:600;border-radius:var(--radius-md);border:1px solid transparent;cursor:pointer;text-decoration:none;white-space:nowrap}
.btn-sm{font-size:var(--text-xs);padding:.375rem .875rem}
.btn-md{font-size:var(--text-sm);padding:.5rem 1.125rem}
.btn-lg{font-size:var(--text-sm);padding:.75rem 1.5rem}
.btn-xl{font-size:var(--text-sm);padding:.875rem 1.75rem}
.btn-orange{background:var(--orange);color:#fff;border-color:var(--orange)}
.btn-orange:hover{background:var(--orange-h);border-color:var(--orange-h)}
.btn-orange:active{background:var(--orange-a)}
.btn-ghost{background:transparent;color:var(--text-muted);border-color:var(--border)}
.btn-ghost:hover{background:var(--surface-2);color:var(--text)}
.btn-dark{background:var(--dark);color:var(--dark-text);border-color:var(--dark)}
.btn-dark:hover{background:var(--dark-2)}

/* ── Nav ── */
.nav{position:sticky;top:0;z-index:100;height:var(--nav-h);background:var(--bg);border-bottom:1px solid var(--divider);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}
.nav-in{max-width:var(--content-wide);margin-inline:auto;padding-inline:var(--sp6);height:100%;display:flex;align-items:center;gap:var(--sp8)}
.nav-logo{display:flex;align-items:center;gap:var(--sp2);font-family:var(--font-display);font-weight:700;font-size:var(--text-base);color:var(--text);text-decoration:none;letter-spacing:-.01em}
.nav-links{display:flex;align-items:center;gap:var(--sp1);margin-inline-start:auto}
.nav-link{font-size:var(--text-sm);color:var(--text-muted);text-decoration:none;padding:.375rem .75rem;border-radius:var(--radius-sm)}
.nav-link:hover{color:var(--text);background:var(--surface-2)}
.nav-right{display:flex;align-items:center;gap:var(--sp3);margin-inline-start:var(--sp4)}
.theme-toggle{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:var(--radius-md);color:var(--text-muted);border:1px solid var(--border)}
.theme-toggle:hover{background:var(--surface-2);color:var(--text)}
.lang-badge{font-size:var(--text-xs);font-weight:600;color:var(--text-muted);border:1px solid var(--border);border-radius:var(--r-full);padding:.25rem .625rem;text-decoration:none}
.lang-badge:hover{background:var(--surface-2);color:var(--text)}
@media(max-width:900px){.nav-links{display:none}}
@media(max-width:640px){.lang-badge{display:none}}

/* ── Hero ── */
.hero{padding-block:clamp(var(--sp12),7vw,var(--sp24))}
.hero-grid{max-width:var(--content-wide);margin-inline:auto;padding-inline:var(--sp6);display:grid;grid-template-columns:1fr 1fr;gap:var(--sp16);align-items:center}
.hero-eye{display:inline-flex;align-items:center;gap:var(--sp2);font-size:var(--text-xs);font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);margin-bottom:var(--sp5)}
.hero-dot{width:8px;height:8px;border-radius:50%;background:var(--orange);flex-shrink:0;animation:pulse 2s ease-in-out infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}
.hero-h1{font-family:var(--font-display);font-size:var(--text-3xl);font-weight:700;line-height:1;letter-spacing:-.03em;color:var(--text);margin-bottom:var(--sp6)}
.hero-h1 em{font-style:normal;color:var(--orange)}
.hero-sub{font-size:var(--text-base);color:var(--text-muted);margin-bottom:var(--sp8);max-width:48ch}
.hero-cta{display:flex;gap:var(--sp3);flex-wrap:wrap;margin-bottom:var(--sp6)}
.hero-badges{display:flex;flex-wrap:wrap;gap:var(--sp3);align-items:center;font-size:var(--text-xs);color:var(--text-muted)}
.hero-sep{width:1px;height:12px;background:var(--border)}
.hero-img-wrap{position:relative}
.hero-img{border-radius:var(--r-xl);object-fit:cover;aspect-ratio:4/3;width:100%;border:1px solid var(--border-light)}
.hero-pill{position:absolute;bottom:-1rem;left:-1.5rem;background:var(--bg);border:1px solid var(--border);border-radius:var(--r-xl);padding:var(--sp3) var(--sp4);display:flex;align-items:center;gap:var(--sp3);box-shadow:var(--shadow-lg)}
.hero-pill-icon{width:32px;height:32px;border-radius:var(--r-full);background:var(--orange-light);border:1px solid var(--orange-border);display:flex;align-items:center;justify-content:center;color:var(--orange);flex-shrink:0}
.hero-pill-lbl{font-size:var(--text-xs);color:var(--text-muted)}
.hero-pill-val{font-size:var(--text-xs);font-weight:700;color:var(--text)}
@media(max-width:768px){.hero-grid{grid-template-columns:1fr}.hero-img-wrap{display:none}}

/* ── Trust Bar ── */
.trust{border-top:1px solid var(--divider);border-bottom:1px solid var(--divider);padding-block:var(--sp4);background:var(--surface)}
.trust-in{max-width:var(--content-wide);margin-inline:auto;padding-inline:var(--sp6);display:flex;align-items:center;gap:var(--sp6);flex-wrap:wrap}
.trust-lbl{font-size:var(--text-xs);font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--text-faint);flex-shrink:0}
.trust-logos{display:flex;align-items:center;gap:var(--sp2);flex-wrap:wrap}
.trust-logo{font-size:var(--text-xs);font-weight:600;color:var(--text-muted);padding:.25rem .625rem;border:1px solid var(--border-light);border-radius:var(--r-full);background:var(--bg)}

/* ── Stats ── */
.stats{border-bottom:1px solid var(--divider);background:var(--surface)}
.stats-grid{max-width:var(--content-wide);margin-inline:auto;padding-inline:var(--sp6);display:grid;grid-template-columns:repeat(4,1fr)}
.stat{padding:var(--sp10) var(--sp6);border-right:1px solid var(--divider)}
.stat:last-child{border-right:none}
.stat-num{font-family:var(--font-display);font-size:var(--text-2xl);font-weight:700;letter-spacing:-.03em;line-height:1;margin-bottom:var(--sp2)}
.stat-num em{font-style:normal;color:var(--orange)}
.stat-lbl{font-size:var(--text-xs);color:var(--text-muted);max-width:22ch}
@media(max-width:768px){.stats-grid{grid-template-columns:1fr 1fr}.stat{border-right:none;border-bottom:1px solid var(--divider)}}

/* ── Section headers ── */
.sec-eye{font-size:var(--text-xs);font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--text-faint);margin-bottom:var(--sp3)}
.sec-title{font-family:var(--font-display);font-size:var(--text-2xl);font-weight:700;letter-spacing:-.03em;line-height:1.05;color:var(--text);margin-bottom:var(--sp5)}
.sec-sub{font-size:var(--text-base);color:var(--text-muted);max-width:52ch}

/* ── About ── */
.about-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--sp6)}
.about-card{padding:var(--sp8);border:1px solid var(--border);border-radius:var(--r-xl);transition:box-shadow var(--tr)}
.about-card:hover{box-shadow:var(--shadow-md)}
.about-num{font-family:var(--font-display);font-size:var(--text-xl);font-weight:700;color:var(--orange);opacity:.35;margin-bottom:var(--sp4)}
.about-title{font-family:var(--font-display);font-size:var(--text-lg);font-weight:700;margin-bottom:var(--sp3)}
.about-desc{font-size:var(--text-sm);color:var(--text-muted);line-height:1.7}
@media(max-width:768px){.about-grid{grid-template-columns:1fr}}

/* ── Services ── */
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;border:1px solid var(--border);border-radius:var(--r-xl);overflow:hidden;background:var(--border)}
.svc-card{padding:var(--sp8);background:var(--bg);display:flex;flex-direction:column;transition:background var(--tr)}
.svc-card:hover{background:var(--surface)}
.svc-card--featured{background:var(--dark);color:var(--dark-text)}
.svc-card--featured:hover{background:var(--dark-2)}
.svc-idx{font-size:var(--text-xs);font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--text-faint);margin-bottom:var(--sp4)}
.svc-card--featured .svc-idx{color:var(--dark-muted)}
.svc-title{font-family:var(--font-display);font-size:var(--text-lg);font-weight:700;margin-bottom:var(--sp3);line-height:1.2}
.svc-card--featured .svc-title{color:var(--dark-text)}
.svc-desc{font-size:var(--text-sm);color:var(--text-muted);line-height:1.7;flex:1}
.svc-card--featured .svc-desc{color:var(--dark-muted)}
.svc-more{margin-top:var(--sp5);font-size:var(--text-sm);font-weight:600;color:var(--text-muted);text-decoration:none;align-self:flex-start}
.svc-more:hover{color:var(--text)}
.svc-card--featured .svc-more{color:var(--orange);background:rgba(255,111,37,.12);padding:.375rem .875rem;border-radius:var(--r-full)}
.svc-card--featured .svc-more:hover{background:rgba(255,111,37,.2)}
@media(max-width:900px){.services-grid{grid-template-columns:1fr 1fr}}
@media(max-width:600px){.services-grid{grid-template-columns:1fr}}

/* ── CTA Strip ── */
.cta-strip{border-top:1px solid var(--divider);border-bottom:1px solid var(--divider);padding-block:var(--sp12)}
.cta-strip-in{max-width:var(--content-wide);margin-inline:auto;padding-inline:var(--sp6);display:flex;align-items:center;justify-content:space-between;gap:var(--sp12);flex-wrap:wrap}
.cta-strip-eye{font-size:var(--text-xs);font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--text-faint);margin-bottom:var(--sp2)}
.cta-strip-title{font-family:var(--font-display);font-size:var(--text-xl);font-weight:700;letter-spacing:-.03em;line-height:1.1;margin-bottom:var(--sp3)}
.cta-strip-sub{font-size:var(--text-sm);color:var(--text-muted);max-width:44ch}

/* ── Products / Tabs ── */
.tab-nav{display:flex;gap:var(--sp1);margin-bottom:var(--sp8);border-bottom:1px solid var(--divider);overflow-x:auto;-webkit-overflow-scrolling:touch}
.tab-btn{font-size:var(--text-sm);font-weight:600;color:var(--text-muted);background:transparent;border:none;padding:.625rem 1rem;cursor:pointer;position:relative;white-space:nowrap;transition:color var(--tr)}
.tab-btn::after{content:'';position:absolute;bottom:-1px;left:0;right:0;height:2px;background:var(--orange);transform:scaleX(0);transition:transform var(--tr)}
.tab-btn.active{color:var(--text)}
.tab-btn.active::after,.tab-btn:hover::after{transform:scaleX(1)}
.tab-panel{display:none}
.tab-panel.active{display:block}
.prod-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(240px,100%),1fr));gap:var(--sp4)}
.prod-card{border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden;background:var(--bg);transition:box-shadow var(--tr)}
.prod-card:hover{box-shadow:var(--shadow-md)}
.prod-img{width:100%;aspect-ratio:4/3;object-fit:contain;background:#ffffff;padding:1rem;box-sizing:border-box;}
.prod-body{padding:var(--sp4) var(--sp5);background:var(--surface-2);}
.prod-cat{font-size:var(--text-xs);font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--orange);margin-bottom:var(--sp1)}
.prod-name{font-size:var(--text-sm);font-weight:600;line-height:1.4}
.prod-spec{font-size:var(--text-xs);color:var(--text-muted);margin-top:var(--sp1)}

/* ── Split layout ── */
.split{display:grid;grid-template-columns:1fr 1fr;gap:var(--sp16);align-items:center}
.split-eye{font-size:var(--text-xs);font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--text-faint);margin-bottom:var(--sp3)}
.split-title{font-family:var(--font-display);font-size:var(--text-2xl);font-weight:700;letter-spacing:-.03em;line-height:1.05;margin-bottom:var(--sp5)}
.split-text{font-size:var(--text-base);color:var(--text-muted);margin-bottom:var(--sp6);max-width:44ch}
.split-img{border-radius:var(--r-xl);object-fit:cover;aspect-ratio:4/3;width:100%;border:1px solid var(--border-light)}
.checks{list-style:none;display:flex;flex-direction:column;gap:var(--sp3);margin-bottom:var(--sp8)}
.check{display:flex;align-items:flex-start;gap:var(--sp3);font-size:var(--text-sm);color:var(--text-muted)}
.check-icon{width:18px;height:18px;border-radius:var(--r-full);background:var(--orange-light);border:1px solid var(--orange-border);display:flex;align-items:center;justify-content:center;color:var(--orange);flex-shrink:0;margin-top:2px}
@media(max-width:768px){.split{grid-template-columns:1fr}}

/* ── Dark Banner ── */
.dark-banner{background:var(--dark);padding-block:clamp(var(--sp12),7vw,var(--sp24))}
.dark-banner-in{max-width:var(--content-wide);margin-inline:auto;padding-inline:var(--sp6);display:grid;grid-template-columns:1fr 1fr;gap:var(--sp16);align-items:center}
.dark-eye{font-size:var(--text-xs);font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:rgba(240,237,232,.35);margin-bottom:var(--sp3)}
.dark-title{font-family:var(--font-display);font-size:var(--text-2xl);font-weight:700;letter-spacing:-.03em;line-height:1.05;color:var(--dark-text);margin-bottom:var(--sp5)}
.dark-text{font-size:var(--text-base);color:rgba(240,237,232,.65);margin-bottom:var(--sp6);max-width:44ch}
.dark-checks .check{color:rgba(240,237,232,.7)}
.dark-img{border-radius:var(--r-xl);object-fit:cover;aspect-ratio:4/3;width:100%;border:1px solid rgba(255,255,255,.08)}
@media(max-width:768px){.dark-banner-in{grid-template-columns:1fr}}

/* ── Testimonial ── */
.testi-wrap{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-2xl);padding:clamp(var(--sp8),5vw,var(--sp16));position:relative}
.testi-quote{font-family:var(--font-display);font-size:5rem;line-height:1;color:var(--orange);opacity:.15;position:absolute;top:var(--sp4);left:var(--sp8);pointer-events:none}
.testi-text{font-family:var(--font-display);font-size:var(--text-xl);font-weight:500;line-height:1.4;margin-bottom:var(--sp8);letter-spacing:-.01em}
.testi-author{display:flex;align-items:center;gap:var(--sp4)}
.testi-avatar{width:40px;height:40px;border-radius:var(--r-full);background:var(--orange-light);border:1px solid var(--orange-border);display:flex;align-items:center;justify-content:center;font-size:var(--text-xs);font-weight:700;color:var(--orange)}
.testi-name{font-size:var(--text-sm);font-weight:600}
.testi-role{font-size:var(--text-xs);color:var(--text-muted)}

/* ── Blog ── */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--sp6)}
.blog-card{text-decoration:none;border:1px solid var(--border);border-radius:var(--r-xl);overflow:hidden;background:var(--bg);display:flex;flex-direction:column;transition:box-shadow var(--tr)}
.blog-card:hover{box-shadow:var(--shadow-md)}
.blog-img{width:100%;aspect-ratio:16/9;object-fit:cover;background:var(--surface-2)}
.blog-body{padding:var(--sp5) var(--sp6);display:flex;flex-direction:column;gap:var(--sp2);flex:1}
.blog-tag{font-size:var(--text-xs);font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--orange)}
.blog-title{font-size:var(--text-base);font-weight:600;line-height:1.35;color:var(--text)}
.blog-card:hover .blog-title{color:var(--orange)}
.blog-date{font-size:var(--text-xs);color:var(--text-faint);margin-top:auto}
@media(max-width:900px){.blog-grid{grid-template-columns:1fr 1fr}}
@media(max-width:600px){.blog-grid{grid-template-columns:1fr}}

/* ── Contact ── */
.contact-grid{display:grid;grid-template-columns:1fr 2fr;gap:var(--sp12);align-items:start}
.contact-detail{display:flex;align-items:flex-start;gap:var(--sp4);margin-bottom:var(--sp6)}
.contact-icon{width:36px;height:36px;border-radius:var(--radius-md);background:var(--surface-2);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;color:var(--text-muted);flex-shrink:0}
.contact-lbl{font-size:var(--text-xs);font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--text-faint);margin-bottom:var(--sp1)}
.contact-val{font-size:var(--text-sm)}
.contact-val a{color:var(--text);text-decoration:none}
.contact-val a:hover{color:var(--orange)}
.form{display:flex;flex-direction:column;gap:var(--sp5)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--sp5)}
.field{display:flex;flex-direction:column;gap:var(--sp2)}
.field label{font-size:var(--text-xs);font-weight:600;text-transform:uppercase;letter-spacing:.06em}
.field input,.field select,.field textarea{padding:.625rem .875rem;border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg);font-size:var(--text-sm);transition:border-color var(--tr),box-shadow var(--tr)}
.field textarea{min-height:120px;resize:vertical}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--orange);box-shadow:0 0 0 3px oklch(from var(--orange) l c h/.12);outline:none}
@media(max-width:900px){.contact-grid{grid-template-columns:1fr}}
@media(max-width:600px){.form-row{grid-template-columns:1fr}}

/* ── Newsletter ── */
.newsletter{background:var(--surface-2);border-top:1px solid var(--divider);padding-block:var(--sp12)}
.newsletter-in{max-width:var(--content-wide);margin-inline:auto;padding-inline:var(--sp6);display:flex;align-items:center;justify-content:space-between;gap:var(--sp12);flex-wrap:wrap}
.nl-title{font-family:var(--font-display);font-size:var(--text-xl);font-weight:700;letter-spacing:-.02em}
.nl-sub{font-size:var(--text-sm);color:var(--text-muted);max-width:44ch}
.nl-form{display:flex;gap:var(--sp2);flex-wrap:wrap}
.nl-input{flex:1;min-width:240px;padding:.625rem 1rem;border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg);font-size:var(--text-sm)}
.nl-input:focus{border-color:var(--orange);box-shadow:0 0 0 3px oklch(from var(--orange) l c h/.1);outline:none}

/* ── Footer ── */
.footer{background:var(--dark);color:var(--dark-text);padding-top:var(--sp16);padding-bottom:var(--sp8)}
.footer-in{max-width:var(--content-wide);margin-inline:auto;padding-inline:var(--sp6);display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:var(--sp10);padding-bottom:var(--sp12);border-bottom:1px solid rgba(255,255,255,.07)}
.footer-logo{display:flex;align-items:center;gap:var(--sp2);font-family:var(--font-display);font-weight:700;font-size:var(--text-base);color:var(--dark-text);margin-bottom:var(--sp4)}
.footer-tag{font-size:var(--text-sm);color:rgba(240,237,232,.5);margin-bottom:var(--sp6);max-width:32ch;line-height:1.7}
.footer-social{display:flex;gap:var(--sp2)}
.footer-soc{width:32px;height:32px;border-radius:var(--radius-md);border:1px solid rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center;color:rgba(240,237,232,.5);text-decoration:none;font-size:var(--text-xs);font-weight:600}
.footer-soc:hover{border-color:rgba(255,255,255,.25);color:var(--dark-text)}
.footer-col-title{font-size:var(--text-xs);font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:rgba(240,237,232,.35);margin-bottom:var(--sp5)}
.footer-links{list-style:none;display:flex;flex-direction:column;gap:var(--sp3)}
.footer-link{font-size:var(--text-sm);color:rgba(240,237,232,.5);text-decoration:none}
.footer-link:hover{color:var(--dark-text)}
.footer-bottom{max-width:var(--content-wide);margin-inline:auto;padding-inline:var(--sp6);padding-top:var(--sp6);display:flex;align-items:center;justify-content:space-between;gap:var(--sp6);flex-wrap:wrap}
.footer-copy,.footer-loc{font-size:var(--text-xs);color:rgba(240,237,232,.3)}
.footer-loc{display:flex;align-items:center;gap:var(--sp2)}
@media(max-width:900px){.footer-in{grid-template-columns:1fr 1fr}}
@media(max-width:600px){.footer-in{grid-template-columns:1fr}}

/* ── Prose ── */
.prose h1,.prose h2,.prose h3,.prose h4{font-family:var(--font-display);letter-spacing:-.02em;margin-top:var(--sp10);margin-bottom:var(--sp4)}
.prose p{font-size:var(--text-base);color:var(--text-muted);line-height:1.8;margin-bottom:var(--sp5)}
.prose ul,.prose ol{padding-inline-start:var(--sp6);margin-bottom:var(--sp5)}
.prose li{font-size:var(--text-base);color:var(--text-muted);line-height:1.8;margin-bottom:var(--sp2)}
.prose a{color:var(--orange);text-decoration:underline;text-underline-offset:3px}
.prose a:hover{opacity:.8}

/* ── Scroll reveal ── */
[data-reveal]{opacity:0;transform:translateY(20px);transition:opacity .6s var(--ease),transform .6s var(--ease)}
[data-reveal].visible{opacity:1;transform:none}
