/* ============================================================
   BEATUS OFFICE — base.css  (shared structure, both directions)
   ============================================================ */

:root{
  /* color tokens — warm neutral base, clay accent (overridden per direction / via Tweaks) */
  --bg:        #fbfaf7;
  --bg-alt:    #f3f0e9;
  --ink:       #1f1c18;
  --ink-soft:  #5a554c;
  --ink-faint: #948d80;
  --line:      #e8e2d6;
  --line-strong:#d4ccbc;
  --accent:    oklch(0.55 0.14 42);    /* clay / terracotta */
  --accent-2:  oklch(0.62 0.07 155);   /* muted sage */
  --accent-ink:#ffffff;
  --card:      #ffffff;

  --ff-sans: "Hanken Grotesk", "Helvetica Neue", Helvetica, Arial, sans-serif;
  --ff-serif: "Newsreader", Georgia, "Times New Roman", serif;
  --ff-mono: "IBM Plex Mono", ui-monospace, "SF Mono", Menlo, monospace;

  --maxw: 1200px;
  --gutter: clamp(20px, 5vw, 64px);
  --radius: 12px;
  --radius-sm: 8px;
  --sec-pad: clamp(56px, 8vw, 120px);

  --ease: cubic-bezier(.22,.61,.36,1);
}

*{ box-sizing: border-box; }
html{ scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body{
  margin:0;
  font-family: var(--ff-sans);
  background: var(--bg);
  color: var(--ink);
  font-size: 17px;
  line-height: 1.62;
  font-weight: 400;
  letter-spacing: -0.003em;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
img{ max-width:100%; display:block; }
a{ color: inherit; text-decoration: none; }
h1,h2,h3{ margin:0; font-weight:700; letter-spacing:-0.02em; line-height:1.08; text-wrap:balance; }
h1,h2{ font-family: var(--ff-serif); font-weight:500; letter-spacing:-0.018em; line-height:1.06; }
p{ margin:0; text-wrap:pretty; }
ul,ol{ margin:0; padding:0; list-style:none; }
button{ font:inherit; cursor:pointer; }
input,select,textarea{ font:inherit; color:inherit; }
::selection{ background: var(--accent); color: var(--accent-ink); }

.wrap{ width:100%; max-width: var(--maxw); margin:0 auto; padding:0 var(--gutter); }

/* ---------- type helpers ---------- */
h1{ font-size: clamp(36px, 5.2vw, 64px); }
h2{ font-size: clamp(28px, 3.5vw, 44px); }
h3{ font-size: clamp(19px, 1.5vw, 22px); }
.eyebrow{
  font-family: var(--ff-mono);
  font-size: 12.5px;
  font-weight: 500;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--accent);
}
.lead{ font-size: clamp(18px, 1.6vw, 21px); color: var(--ink-soft); line-height:1.58; }
.sec-intro{ font-size: clamp(17px, 1.4vw, 19px); color: var(--ink-soft); max-width: 64ch; margin-top: 14px; }

/* ---------- section heading ---------- */
.sec-head{ display:flex; align-items:center; gap:14px; margin-bottom: 22px; }
.sec-num{
  font-family: var(--ff-mono); font-size:12.5px; font-weight:500;
  color: var(--ink-faint); letter-spacing:.1em;
  padding-right:14px; border-right:1px solid var(--line-strong);
}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
  padding: 13px 22px; border-radius: var(--radius-sm);
  font-weight:600; font-size:15px; letter-spacing:-0.01em;
  border:1px solid transparent; transition: all .18s var(--ease);
  white-space:nowrap;
}
.btn-sm{ padding:9px 16px; font-size:14px; }
.btn-lg{ padding:16px 30px; font-size:16px; }
.btn-block{ width:100%; }
.btn-primary{ background: var(--accent); color: var(--accent-ink); }
.btn-primary:hover{ filter:brightness(1.07); transform: translateY(-1px); }
.btn-ghost{ background:transparent; color: var(--ink); border-color: var(--line-strong); }
.btn-ghost:hover{ border-color: var(--ink); background: var(--ink); color: var(--bg); }

/* ---------- header / nav ---------- */
.site-header{
  position: sticky; top:0; z-index:50;
  background: color-mix(in oklab, var(--bg) 88%, transparent);
  backdrop-filter: blur(12px);
  border-bottom:1px solid var(--line);
  transition: box-shadow .2s var(--ease);
}
.site-header.is-scrolled{ box-shadow: 0 1px 0 var(--line), 0 8px 24px -18px rgba(0,0,0,.3); }
.header-inner{ display:flex; align-items:center; gap:24px; height:68px; }
.brand{ display:flex; align-items:center; gap:11px; font-weight:800; font-size:19px; letter-spacing:-0.02em; }
.brand-logo{ height:30px; width:auto; display:block; }
.brand-mark{
  width:34px; height:34px; border-radius:8px; flex:none;
  background: var(--accent); color: var(--accent-ink);
  display:grid; place-items:center; font-weight:800; font-size:19px;
}
.brand-thin{ color: var(--ink-faint); font-weight:600; }
.main-nav{ display:flex; gap:26px; margin-left:8px; }
.main-nav a{ font-size:15px; font-weight:500; color: var(--ink-soft); position:relative; padding:4px 0; }
.main-nav a:hover{ color: var(--ink); }
.main-nav a::after{ content:""; position:absolute; left:0; right:100%; bottom:-2px; height:2px; background:var(--accent); transition:right .22s var(--ease); }
.main-nav a:hover::after{ right:0; }
.header-tools{ display:flex; align-items:center; gap:12px; margin-left:auto; }

/* segmented control */
.seg{ display:inline-flex; align-items:center; gap:2px; padding:3px; border:1px solid var(--line); border-radius:8px; background: var(--bg-alt); }
.seg-label{ font-family:var(--ff-mono); font-size:10.5px; text-transform:uppercase; letter-spacing:.1em; color:var(--ink-faint); padding:0 6px 0 4px; }
.seg-btn{ border:none; background:transparent; color: var(--ink-soft); font-size:13px; font-weight:600; padding:5px 11px; border-radius:6px; transition: all .15s var(--ease); }
.seg-btn.is-active{ background: var(--ink); color: var(--bg); }
.seg-dir .seg-btn.is-active{ background: var(--accent); color: var(--accent-ink); }

/* ---------- USP strip ---------- */
.usp{ border-bottom:1px solid var(--line); background: var(--bg-alt); padding: clamp(40px,5vw,64px) 0; }
.usp-grid{ display:grid; grid-template-columns: repeat(3,1fr); gap: 16px; }
.usp-item{
  background: var(--card);
  border:1px solid var(--line);
  border-radius: var(--radius);
  padding: 26px 26px 28px;
  display:flex; flex-direction:column; align-items:stretch;
  transition: transform .2s var(--ease), box-shadow .2s var(--ease), border-color .2s var(--ease);
}
.usp-item:hover{ transform: translateY(-3px); box-shadow:0 24px 46px -32px rgba(31,28,24,.42); border-color: var(--line-strong); }
.usp-tick{ width:28px; height:3px; border-radius:3px; background: var(--accent); margin-bottom:18px; }
.usp-key{
  font-family: var(--ff-mono); font-weight:500;
  font-size: 11.5px; line-height:1.3;
  letter-spacing:.09em; text-transform:uppercase; color: var(--accent);
}
.usp-item h3{
  font-family: var(--ff-serif); font-size:22px; font-weight:500;
  letter-spacing:-0.015em; line-height:1.1; color: var(--ink);
  margin:9px 0 11px;
}
.usp-item p{ font-size:14px; color: var(--ink-soft); line-height:1.55; margin:0; }

/* ---------- hero ---------- */
.hero{ padding: clamp(48px,7vw,96px) 0 var(--sec-pad); }
.hero-inner{ display:grid; grid-template-columns: 1.08fr .92fr; gap: clamp(36px,5vw,64px); align-items:stretch; }
.hero-text{ display:flex; flex-direction:column; align-self:center; }
.hero-text .eyebrow{ margin-bottom:20px; }
.hero-eyebrow{ display:inline-flex; align-items:center; gap:9px; align-self:flex-start; }
.hero-eyebrow::before{ content:""; width:7px; height:7px; border-radius:50%; background: var(--accent); flex:none; }
.hero-text h1{ margin-bottom:24px; }
.hero-text .lead{ margin-bottom:18px; }
.hero-sub{ font-size:16px; color: var(--ink-soft); max-width: 56ch; }
.hero-actions{ display:flex; gap:14px; margin:30px 0 26px; flex-wrap:wrap; }
.hero-trust{ font-family:var(--ff-mono); font-size:12.5px; color: var(--ink-faint); padding-top:20px; border-top:1px solid var(--line); letter-spacing:.01em; }
.hero-visual{ display:flex; }

/* ---------- placeholders ---------- */
.ph{
  position:relative; border-radius: var(--radius); overflow:hidden;
  background:
    repeating-linear-gradient(135deg, var(--line) 0 1px, transparent 1px 11px),
    var(--bg-alt);
  border:1px solid var(--line);
}
.ph::after{
  content: attr(data-ph);
  position:absolute; inset:0; display:grid; place-items:center; text-align:center; padding:18px;
  font-family: var(--ff-mono); font-size:12px; letter-spacing:.04em; color: var(--ink-faint);
}
.ph-hero{ aspect-ratio: 4/3.4; }
.hero-media{ position:relative; width:100%; height:100%; min-height:360px; border-radius: var(--radius); overflow:hidden; border:1px solid var(--line); margin:0; }
.hero-img{ width:100%; height:100%; object-fit:cover; display:block; }
.hero-chip{
  position:absolute; left:18px; bottom:18px; display:flex; flex-direction:column;
  background: var(--accent); color: var(--accent-ink);
  border-radius: var(--radius-sm); padding:14px 18px;
  box-shadow: 0 18px 40px -22px rgba(0,0,0,.6);
}
.hero-chip-num{ font-size:36px; font-weight:800; line-height:1; letter-spacing:-0.03em; }
.hero-chip-num span{ font-size:19px; }
.hero-chip-lbl{ font-family:var(--ff-mono); font-size:10.5px; text-transform:uppercase; letter-spacing:.12em; opacity:.92; margin-top:7px; }

/* ---------- about ---------- */
.about{ padding: var(--sec-pad) 0; border-top:1px solid var(--line); }
.about-grid{ display:grid; grid-template-columns: 1.1fr .9fr; gap: clamp(36px,5vw,68px); align-items:start; margin-top:8px; }
.about-lead h2{ margin-bottom:22px; }
.about-lead p{ color: var(--ink-soft); margin-bottom:16px; font-size:16.5px; }
.about-points{ display:flex; flex-direction:column; }
.about-points li{ display:flex; flex-direction:column; gap:4px; padding:18px 0; border-top:1px solid var(--line); }
.about-points li:first-child{ border-top:none; padding-top:0; }
.point-k{ font-weight:700; font-size:16.5px; }
.point-d{ color: var(--ink-soft); font-size:15px; }

/* logo wall */
.logo-wall{ margin-top: clamp(40px,5vw,64px); padding-top:32px; border-top:1px solid var(--line); }
.logo-wall-label{ font-family:var(--ff-mono); font-size:12px; text-transform:uppercase; letter-spacing:.12em; color: var(--ink-faint); }
.logo-row{ display:grid; grid-template-columns: repeat(3,1fr); gap: clamp(24px,4vw,56px); margin-top:26px; align-items:center; justify-items:center; }
.logo-slot{
  width:100%; min-height:96px; border:none; background:none; padding:0;
  display:grid; place-items:center;
}
.logo-slot img{ max-height:92px; max-width:100%; width:auto; object-fit:contain; filter:none; opacity:1; transition:transform .25s var(--ease); }
.logo-slot:hover img{ transform:scale(1.05); }

/* ---------- sortiment / finder ---------- */
.sortiment{ padding: var(--sec-pad) 0; background: var(--bg-alt); border-top:1px solid var(--line); }
.finder{
  display:grid; grid-template-columns: .85fr 1.15fr; gap: clamp(24px,3vw,40px);
  margin-top: clamp(28px,4vw,44px); background: var(--card);
  border:1px solid var(--line); border-radius: var(--radius); padding: clamp(22px,3vw,34px);
}
.finder-control label{ display:block; font-weight:700; font-size:16px; margin-bottom:10px; }
.finder-select{
  width:100%; padding:14px 16px; border:1px solid var(--line-strong); border-radius: var(--radius-sm);
  background: var(--bg); font-size:16px; font-weight:500; appearance:none;
  background-image: linear-gradient(45deg, transparent 50%, var(--ink-soft) 50%), linear-gradient(135deg, var(--ink-soft) 50%, transparent 50%);
  background-position: calc(100% - 20px) center, calc(100% - 14px) center;
  background-size: 6px 6px, 6px 6px; background-repeat:no-repeat; cursor:pointer;
}
.finder-select:focus{ outline:none; border-color: var(--accent); box-shadow:0 0 0 3px color-mix(in oklab, var(--accent) 22%, transparent); }
.finder-hint{ font-size:13.5px; color: var(--ink-faint); margin-top:12px; }
.finder-result{ border-left:1px solid var(--line); padding-left: clamp(24px,3vw,40px); min-height:160px; display:flex; align-items:center; }
.finder-empty{ font-family:var(--ff-mono); font-size:13px; color: var(--ink-faint); line-height:1.6; }
.finder-cards{ display:flex; gap:16px; width:100%; flex-wrap:wrap; animation: rise .35s var(--ease); }
.fcard{ flex:1 1 150px; background: var(--bg-alt); border:1px solid var(--line); border-radius: var(--radius-sm); padding:18px; }
.fcard-type{ font-family:var(--ff-mono); font-size:11px; text-transform:uppercase; letter-spacing:.1em; color: var(--ink-faint); }
.fcard-code{ font-size:24px; font-weight:800; letter-spacing:-0.02em; margin:8px 0 4px; }
.fcard-yield{ font-size:13px; color: var(--ink-soft); }
.finder-cta{ flex-basis:100%; margin-top:4px; }
.prod-other{ margin-top:24px; font-size:15px; color: var(--ink-soft); }
.prod-other a{ color: var(--accent); font-weight:600; border-bottom:1px solid currentColor; }

@keyframes rise{ from{ opacity:0; transform: translateY(8px);} to{ opacity:1; transform:none;} }

/* ---------- quality ---------- */
.quality{ padding: var(--sec-pad) 0; border-top:1px solid var(--line); }
.qual-grid{ display:grid; grid-template-columns: repeat(3,1fr); gap:20px; margin-top: clamp(28px,4vw,44px); }
.qual-card{ background: var(--card); border:1px solid var(--line); border-radius: var(--radius); padding: clamp(24px,3vw,32px); }
.qual-tag{
  display:inline-grid; place-items:center; min-width:48px; height:48px; padding:0 12px;
  border-radius:10px; background: color-mix(in oklab, var(--accent) 12%, var(--bg));
  color: var(--accent); font-family:var(--ff-mono); font-weight:500; font-size:16px;
}
.qual-card h3{ margin:20px 0 10px; }
.qual-card p{ color: var(--ink-soft); font-size:15px; }

/* ---------- order ---------- */
.order{ padding: var(--sec-pad) 0; background: var(--bg-alt); border-top:1px solid var(--line); }
.order-grid{ display:grid; grid-template-columns: 1fr 1fr; gap: clamp(36px,5vw,68px); align-items:start; }
.order-lead h2{ margin-bottom:16px; }
.order-lead > p{ color: var(--ink-soft); margin-bottom:24px; }
.channels{ display:flex; flex-direction:column; gap:12px; }
.channel{
  display:grid; grid-template-columns: 44px 1fr; grid-template-rows:auto auto; column-gap:14px;
  align-items:center; background: var(--card); border:1px solid var(--line); border-radius: var(--radius-sm);
  padding:14px 18px; transition: all .16s var(--ease);
}
.channel:hover{ border-color: var(--accent); transform: translateX(3px); }
.channel-ic{ grid-row:1/3; width:44px; height:44px; border-radius:10px; display:grid; place-items:center; font-size:20px; background: color-mix(in oklab, var(--accent) 12%, var(--bg)); color: var(--accent); }
.channel-k{ font-family:var(--ff-mono); font-size:11px; text-transform:uppercase; letter-spacing:.1em; color: var(--ink-faint); }
.channel-v{ font-weight:700; font-size:16px; }
.order-info{ background: var(--card); border:1px solid var(--line); border-radius: var(--radius); padding: clamp(26px,3vw,38px); }
.order-info h3{ margin-bottom:16px; }
.order-needs{ counter-reset: step; display:flex; flex-direction:column; gap:14px; }
.order-needs li{ position:relative; padding-left:40px; font-size:15.5px; color: var(--ink-soft); }
.order-needs li::before{ counter-increment: step; content: counter(step,decimal-leading-zero); position:absolute; left:0; top:0; font-family:var(--ff-mono); font-size:12px; font-weight:500; color: var(--accent); border:1px solid var(--line-strong); border-radius:6px; width:26px; height:26px; display:grid; place-items:center; }
.order-hours{ display:flex; flex-direction:column; gap:2px; margin:26px 0 14px; padding-top:20px; border-top:1px solid var(--line); }
.order-hours span{ font-family:var(--ff-mono); font-size:11px; text-transform:uppercase; letter-spacing:.1em; color: var(--ink-faint); }
.order-hours strong{ font-size:18px; }
.order-eta{ font-size:14.5px; color: var(--ink-soft); }

/* ---------- franchise ---------- */
.franchise{ padding: var(--sec-pad) 0; background: var(--ink); color: var(--bg); }
.franchise .eyebrow{ color: var(--accent-2); }
.sec-head-inv .sec-num{ color: color-mix(in oklab, var(--bg) 55%, transparent); border-right-color: color-mix(in oklab, var(--bg) 30%, transparent); }
.franchise-grid{ display:grid; grid-template-columns: 1fr 1fr; gap: clamp(36px,5vw,72px); align-items:center; }
.franchise-lead h2{ margin-bottom:18px; }
.franchise-lead > p{ color: color-mix(in oklab, var(--bg) 72%, transparent); margin-bottom:28px; }
.franchise-list{ display:flex; flex-direction:column; }
.franchise-list li{ padding:18px 0 18px 34px; border-top:1px solid color-mix(in oklab, var(--bg) 18%, transparent); font-size:17px; position:relative; }
.franchise-list li:first-child{ border-top:none; }
.franchise-list li::before{ content:"→"; position:absolute; left:0; color: var(--accent-2); font-weight:700; }

/* ---------- shipping ---------- */
.shipping{ padding: var(--sec-pad) 0; border-top:1px solid var(--line); }
.shipping-inner{ display:grid; grid-template-columns: 1.3fr .7fr; gap: clamp(36px,5vw,72px); align-items:center; }
.shipping-text h2{ margin-bottom:18px; }
.shipping-text p{ color: var(--ink-soft); margin-bottom:14px; font-size:16.5px; }
.shipping-stat{ text-align:center; border-left:1px solid var(--line); padding-left: clamp(24px,3vw,48px); }
.stat-num{ display:block; font-size: clamp(56px,8vw,92px); font-weight:800; letter-spacing:-0.04em; line-height:.9; color: var(--accent); }
.stat-unit{ font-size:.45em; }
.stat-lbl{ font-family:var(--ff-mono); font-size:12.5px; color: var(--ink-soft); display:block; margin-top:14px; }

/* ---------- pricing ---------- */
.pricing{ padding: var(--sec-pad) 0; background: var(--bg-alt); border-top:1px solid var(--line); }
.price-table-wrap{ margin-top: clamp(26px,4vw,40px); overflow-x:auto; border:1px solid var(--line); border-radius: var(--radius); background: var(--card); }
.price-table{ width:100%; border-collapse:collapse; min-width:680px; }
.price-table th, .price-table td{ text-align:left; padding:16px 20px; border-bottom:1px solid var(--line); }
.price-table th{ font-family:var(--ff-mono); font-size:11.5px; text-transform:uppercase; letter-spacing:.08em; color: var(--ink-faint); font-weight:500; }
.price-table tbody tr:last-child td{ border-bottom:none; }
.price-table tbody tr:hover{ background: var(--bg-alt); }
.price-table .pt-model{ font-weight:700; }
.price-table .pt-code{ font-family:var(--ff-mono); font-size:14px; }
.price-table .pt-ask{ font-family:var(--ff-mono); font-size:13px; color: var(--accent); }
.price-note{ font-size:13.5px; color: var(--ink-faint); margin-top:16px; }
.price-note a{ color: var(--accent); font-weight:600; white-space:nowrap; }

/* calculator */
.calc{ margin-top: clamp(40px,5vw,64px); background: var(--card); border:1px solid var(--line); border-radius: var(--radius); overflow:hidden; }
.calc-head{ padding: clamp(24px,3vw,32px) clamp(24px,3vw,36px); border-bottom:1px solid var(--line); }
.calc-head .eyebrow{ display:block; margin-bottom:8px; }
.calc-body{ display:grid; grid-template-columns: 1.1fr .9fr; }
.calc-inputs{ padding: clamp(24px,3vw,36px); display:flex; flex-direction:column; gap:22px; border-right:1px solid var(--line); }
.calc-field label{ display:flex; justify-content:space-between; align-items:center; font-weight:600; font-size:15px; margin-bottom:9px; }
.calc-field input[type=number]{ width:100%; padding:13px 15px; border:1px solid var(--line-strong); border-radius: var(--radius-sm); background: var(--bg); font-size:17px; font-weight:600; }
.calc-field input[type=number]:focus{ outline:none; border-color: var(--accent); box-shadow:0 0 0 3px color-mix(in oklab, var(--accent) 20%, transparent); }
.calc-field output{ font-family:var(--ff-mono); font-size:15px; color: var(--accent); font-weight:500; }
input[type=range]{ -webkit-appearance:none; appearance:none; width:100%; height:6px; border-radius:99px; background: var(--line-strong); }
input[type=range]::-webkit-slider-thumb{ -webkit-appearance:none; width:22px; height:22px; border-radius:50%; background: var(--accent); border:3px solid var(--card); box-shadow:0 1px 6px rgba(0,0,0,.3); cursor:pointer; }
input[type=range]::-moz-range-thumb{ width:22px; height:22px; border-radius:50%; background: var(--accent); border:3px solid var(--card); cursor:pointer; }
.calc-output{ padding: clamp(24px,3vw,36px); display:flex; flex-direction:column; gap:16px; background: color-mix(in oklab, var(--accent) 5%, var(--card)); }
.calc-result{ display:flex; justify-content:space-between; align-items:baseline; }
.calc-result-lbl{ font-size:14px; color: var(--ink-soft); }
.calc-result-val{ font-size:24px; font-weight:800; letter-spacing:-0.02em; }
.calc-result-big{ border-top:1px solid var(--line); padding-top:16px; }
.calc-result-big .calc-result-val{ font-size:40px; color: var(--accent); }
.calc-output .btn{ margin-top:6px; }
.calc-disclaimer{ font-size:12px; color: var(--ink-faint); line-height:1.5; }

/* ---------- contact ---------- */
.contact{ padding: var(--sec-pad) 0; background: var(--ink); color: var(--bg); }
.contact .eyebrow{ color: var(--accent-2); }
.contact-inner{ display:grid; grid-template-columns: .82fr 1.18fr; gap: clamp(40px,5vw,80px); align-items:start; }
.contact-intro h2{ margin-bottom:16px; }
.contact-intro > p{ color: color-mix(in oklab, var(--bg) 72%, transparent); margin-bottom:28px; }
.contact-direct{ display:flex; flex-direction:column; }
.contact-direct li{ display:flex; flex-direction:column; gap:2px; padding:14px 0; border-top:1px solid color-mix(in oklab, var(--bg) 16%, transparent); }
.contact-direct li span{ font-family:var(--ff-mono); font-size:11px; text-transform:uppercase; letter-spacing:.1em; color: color-mix(in oklab, var(--bg) 55%, transparent); }
.contact-direct li a, .contact-direct li strong{ font-size:17px; font-weight:700; }
.contact-direct li a:hover{ color: var(--accent-2); }

.contact-form{ background: var(--card); color: var(--ink); border-radius: var(--radius); padding: clamp(26px,3.2vw,40px); }
.form-row{ display:grid; grid-template-columns:1fr 1fr; gap:18px; }
.form-row-item{ grid-template-columns: 1fr; }
.field{ display:flex; flex-direction:column; margin-bottom:18px; }
.field label{ font-size:13.5px; font-weight:600; margin-bottom:7px; color: var(--ink-soft); }
.field input, .field textarea{
  padding:13px 15px; border:1px solid var(--line-strong); border-radius: var(--radius-sm);
  background: var(--bg); font-size:16px; transition: border-color .15s, box-shadow .15s;
}
.field textarea{ resize:vertical; }
.field input:focus, .field textarea:focus{ outline:none; border-color: var(--accent); box-shadow:0 0 0 3px color-mix(in oklab, var(--accent) 18%, transparent); }
.field.invalid input{ border-color: oklch(0.58 0.2 25); box-shadow:0 0 0 3px oklch(0.58 0.2 25 / .15); }
@media(min-width:560px){ .form-row-item{ grid-template-columns: 1fr 120px; } }
.field-qty input{ text-align:center; }
.form-foot{ display:flex; align-items:center; gap:20px; flex-wrap:wrap; margin-top:6px; }
.form-note{ font-size:12px; color: var(--ink-faint); max-width:42ch; line-height:1.5; }
.form-success[hidden]{ display:none; }
.form-success{ display:flex; gap:16px; align-items:flex-start; background: color-mix(in oklab, var(--accent-2) 12%, var(--card)); border:1px solid color-mix(in oklab, var(--accent-2) 35%, transparent); border-radius: var(--radius); padding:22px; margin-top:4px; animation: rise .4s var(--ease); }
.form-success-ic{ flex:none; width:38px; height:38px; border-radius:50%; background: var(--accent-2); color:#fff; display:grid; place-items:center; font-size:20px; font-weight:700; }
.form-success strong{ font-size:17px; display:block; margin-bottom:6px; }
.form-success p{ font-size:14.5px; color: var(--ink-soft); margin-bottom:14px; }
.form-success-actions{ display:flex; gap:10px; flex-wrap:wrap; }

/* error + loading states */
.form-error{
  margin-top:14px; padding:13px 16px; border-radius: var(--radius-sm);
  background: color-mix(in oklab, #d9483b 10%, var(--card));
  border:1px solid color-mix(in oklab, #d9483b 38%, transparent);
  color: color-mix(in oklab, #d9483b 72%, var(--ink));
  font-size:14px; line-height:1.5;
}
.btn[data-loading]{ position:relative; opacity:.72; cursor:progress; pointer-events:none; }

/* ---------- footer ---------- */
.site-footer{ background: var(--bg); border-top:1px solid var(--line); padding: 44px 0; }
.footer-inner{ display:flex; align-items:center; justify-content:space-between; gap:28px; flex-wrap:wrap; }
.footer-brand{ display:flex; flex-direction:column; align-items:flex-start; gap:10px; }
.footer-logo{ height:30px; width:auto; display:block; }
.footer-tag{ font-size:13px; color: var(--ink-faint); }
.footer-contact{ display:flex; flex-direction:column; gap:3px; font-size:14px; }
.footer-contact a:hover{ color: var(--accent); }
.footer-legal{ display:flex; align-items:center; gap:18px; font-size:13px; color: var(--ink-faint); }
.footer-legal a:hover{ color: var(--ink); }

/* ---------- scroll reveal ---------- */
.reveal{ opacity:0; transform: translateY(22px); transition: opacity .6s var(--ease), transform .6s var(--ease); }
.reveal.in{ opacity:1; transform:none; }

/* ---------- responsive ---------- */
@media(max-width:1024px){
  .usp-grid{ grid-template-columns: repeat(2,1fr); }
  .hero-inner{ grid-template-columns:1fr; }
  .hero-text{ align-self:auto; }
  .hero-media{ min-height:320px; max-height:440px; }
}
@media(max-width:860px){
  .main-nav{ display:none; }
  .about-grid, .order-grid, .franchise-grid, .shipping-inner, .finder, .calc-body, .contact-inner, .qual-grid{ grid-template-columns:1fr; }
  .finder-result{ border-left:none; border-top:1px solid var(--line); padding-left:0; padding-top:20px; }
  .calc-inputs{ border-right:none; border-bottom:1px solid var(--line); }
  .shipping-stat{ border-left:none; border-top:1px solid var(--line); padding-left:0; padding-top:24px; text-align:left; }
  .logo-row{ grid-template-columns: repeat(3,1fr); }
}
@media(max-width:560px){
  body{ font-size:16px; }
  .usp-grid{ grid-template-columns: 1fr; }
  .form-row{ grid-template-columns:1fr; }
  .seg-dir{ display:none; }
  .header-tools .btn{ display:none; }
  .footer-inner{ flex-direction:column; align-items:flex-start; }
  .logo-row{ grid-template-columns: 1fr; gap:28px; }
  .logo-slot img{ max-height:80px; }
}
