/* ===========================================================
   INVESTER OÜ — Saematerjali müük
   Design system: warm timber + Merko-clean airiness
   =========================================================== */

:root{
  /* Palette */
  --ink:        #1A1714;   /* warm near-black (logo bg) */
  --ink-soft:   #2C2722;
  --bark:       #946242;   /* brand brown (log in logo) */
  --bark-deep:  #6E4427;   /* treated-board brown */
  --bark-light: #B98A63;
  --moss:       #5C6B4A;   /* certified / natural cue */
  --sand:       #F6F1E9;   /* warm cream sections */
  --sand-deep:  #EEE6D8;
  --paper:      #FFFFFF;
  --line:       #E6DDCE;
  --line-soft:  #F0EADF;
  --text:       #221E1A;
  --text-soft:  #5E564D;
  --text-mute:  #8A8076;

  /* Type */
  --display: "Archivo", system-ui, sans-serif;
  --body: "Inter", system-ui, -apple-system, sans-serif;

  /* Radius & shadow */
  --r-sm: 10px;
  --r:    16px;
  --r-lg: 24px;
  --r-xl: 32px;
  --shadow-sm: 0 2px 8px rgba(34,30,26,.06);
  --shadow:    0 10px 30px rgba(34,30,26,.10);
  --shadow-lg: 0 24px 60px rgba(34,30,26,.16);

  --maxw: 1240px;
  --header-h: 78px;
  --ease: cubic-bezier(.4,0,.2,1);
}

*{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  font-family:var(--body);
  color:var(--text);
  background:var(--paper);
  line-height:1.6;
  font-size:16px;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; cursor:pointer; border:none; background:none; }
ul{ list-style:none; }

h1,h2,h3,h4{ font-family:var(--display); font-weight:800; line-height:1.05; letter-spacing:-.01em; color:var(--ink); }
.eyebrow{
  font-family:var(--display); font-weight:700; font-size:.78rem;
  letter-spacing:.18em; text-transform:uppercase; color:var(--bark);
  display:inline-flex; align-items:center; gap:.55rem;
}
.eyebrow::before{ content:""; width:26px; height:2px; background:var(--bark); display:inline-block; }

.container{ width:100%; max-width:var(--maxw); margin:0 auto; padding:0 24px; }
.section{ padding:96px 0; }
.section--sand{ background:var(--sand); }
.section--ink{ background:var(--ink); color:#EDE6DB; }
.section--ink h2,.section--ink h3{ color:#fff; }

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:.5rem;
  font-family:var(--display); font-weight:700; font-size:.95rem; letter-spacing:.01em;
  padding:14px 26px; border-radius:999px; transition:all .25s var(--ease);
  white-space:nowrap; cursor:pointer; line-height:1;
}
.btn svg{ width:18px; height:18px; }
.btn--primary{ background:var(--bark); color:#fff; box-shadow:0 6px 18px rgba(148,98,66,.32); }
.btn--primary:hover{ background:var(--bark-deep); transform:translateY(-2px); box-shadow:0 10px 26px rgba(148,98,66,.4); }
.btn--dark{ background:var(--ink); color:#fff; }
.btn--dark:hover{ background:var(--ink-soft); transform:translateY(-2px); }
.btn--ghost{ background:rgba(255,255,255,.12); color:#fff; border:1.5px solid rgba(255,255,255,.5); backdrop-filter:blur(6px); }
.btn--ghost:hover{ background:#fff; color:var(--ink); border-color:#fff; }
.btn--outline{ background:transparent; color:var(--ink); border:1.5px solid var(--line); }
.btn--outline:hover{ border-color:var(--bark); color:var(--bark); }
.btn--lg{ padding:17px 34px; font-size:1.02rem; }
.btn--block{ width:100%; }

/* ---------- Header ---------- */
.header{
  position:fixed; top:0; left:0; right:0; z-index:100;
  height:var(--header-h);
  transition:background .3s var(--ease), box-shadow .3s var(--ease), border-color .3s var(--ease);
  border-bottom:1px solid transparent;
}
.header__inner{ height:100%; display:flex; align-items:center; justify-content:space-between; gap:24px; }
.header__logo{ display:flex; align-items:center; gap:12px; flex-shrink:0; }
.header__logo img{ height:52px; width:auto; border-radius:9px; box-shadow:0 4px 14px rgba(0,0,0,.25); }
.header__nav{ display:flex; align-items:center; gap:4px; }
.nav-link{
  font-family:var(--display); font-weight:600; font-size:.94rem;
  padding:10px 14px; border-radius:999px; transition:all .2s var(--ease);
  position:relative; display:inline-flex; align-items:center; gap:5px; color:#fff;
}
.nav-link:hover{ background:rgba(255,255,255,.12); }
.header__actions{ display:flex; align-items:center; gap:14px; flex-shrink:0; }
.header__phone{ font-family:var(--display); font-weight:700; font-size:.96rem; color:#fff; display:flex; align-items:center; gap:7px; padding:8px 6px; }
.header__phone svg{ width:17px; height:17px; }

/* scrolled / solid state */
.header.is-solid{ background:rgba(255,255,255,.92); backdrop-filter:blur(14px); box-shadow:var(--shadow-sm); border-color:var(--line-soft); }
.header.is-solid .nav-link,
.header.is-solid .header__phone{ color:var(--ink); }
.header.is-solid .nav-link:hover{ background:var(--sand); }
.header.is-solid .header__logo img{ box-shadow:0 3px 10px rgba(0,0,0,.18); }

/* dropdown */
.has-drop{ position:relative; }
.drop{
  position:absolute; top:calc(100% + 10px); left:50%; transform:translateX(-50%) translateY(8px);
  background:#fff; border-radius:var(--r); box-shadow:var(--shadow-lg); border:1px solid var(--line-soft);
  min-width:240px; padding:10px; opacity:0; visibility:hidden; transition:all .22s var(--ease); z-index:120;
}
.has-drop:hover .drop{ opacity:1; visibility:visible; transform:translateX(-50%) translateY(0); }
.drop a{
  display:flex; align-items:center; gap:10px; padding:11px 14px; border-radius:10px;
  font-family:var(--display); font-weight:600; font-size:.9rem; color:var(--ink); transition:background .15s;
}
.drop a:hover{ background:var(--sand); color:var(--bark); }
.drop a .dot{ width:7px; height:7px; border-radius:50%; background:var(--bark-light); flex-shrink:0; }

/* burger */
.burger{ display:none; width:46px; height:46px; border-radius:12px; align-items:center; justify-content:center; flex-direction:column; gap:5px; background:rgba(255,255,255,.14); }
.header.is-solid .burger{ background:var(--sand); }
.burger span{ width:22px; height:2px; background:#fff; border-radius:2px; transition:.25s var(--ease); }
.header.is-solid .burger span{ background:var(--ink); }

/* mobile drawer */
.drawer{ position:fixed; inset:0; z-index:200; visibility:hidden; }
.drawer__scrim{ position:absolute; inset:0; background:rgba(20,17,14,.55); opacity:0; transition:.3s; backdrop-filter:blur(2px); }
.drawer__panel{
  position:absolute; top:0; right:0; bottom:0; width:min(86vw,380px); background:#fff;
  transform:translateX(100%); transition:transform .34s var(--ease); padding:22px;
  display:flex; flex-direction:column; gap:6px; overflow-y:auto;
}
.drawer.is-open{ visibility:visible; }
.drawer.is-open .drawer__scrim{ opacity:1; }
.drawer.is-open .drawer__panel{ transform:translateX(0); }
.drawer__head{ display:flex; align-items:center; justify-content:space-between; margin-bottom:14px; }
.drawer__head img{ height:46px; border-radius:8px; }
.drawer__close{ width:42px; height:42px; border-radius:11px; background:var(--sand); font-size:1.4rem; color:var(--ink); display:flex; align-items:center; justify-content:center; }
.drawer a.m-link{ font-family:var(--display); font-weight:700; font-size:1.12rem; padding:13px 12px; border-radius:12px; color:var(--ink); transition:background .15s; }
.drawer a.m-link:hover{ background:var(--sand); }
.drawer .m-sub{ font-size:.82rem; font-weight:700; letter-spacing:.1em; text-transform:uppercase; color:var(--text-mute); padding:14px 12px 4px; }
.drawer a.m-sub-link{ font-family:var(--display); font-weight:600; font-size:1rem; padding:10px 12px 10px 26px; border-radius:12px; color:var(--text-soft); }
.drawer a.m-sub-link:hover{ background:var(--sand); color:var(--bark); }
.drawer__cta{ margin-top:auto; padding-top:18px; }

/* ---------- Hero ---------- */
.hero{ position:relative; min-height:100vh; display:flex; align-items:center; color:#fff; overflow:hidden; }
.hero__bg{ position:absolute; inset:0; z-index:0; }
.hero__bg img{ width:100%; height:100%; object-fit:cover; }
.hero__bg::after{
  content:""; position:absolute; inset:0;
  background:linear-gradient(105deg, rgba(20,16,13,.82) 0%, rgba(20,16,13,.55) 42%, rgba(20,16,13,.18) 100%);
}
.hero__inner{ position:relative; z-index:2; padding:calc(var(--header-h) + 60px) 0 64px; width:100%; }
.hero__badge{
  display:inline-flex; align-items:center; gap:9px; padding:8px 16px; border-radius:999px;
  background:rgba(255,255,255,.12); border:1px solid rgba(255,255,255,.28); backdrop-filter:blur(8px);
  font-family:var(--display); font-weight:600; font-size:.84rem; letter-spacing:.02em; margin-bottom:24px;
}
.hero__badge .pefc{ width:8px; height:8px; border-radius:50%; background:#9DBE7A; box-shadow:0 0 0 4px rgba(157,190,122,.25); }
.hero h1{ font-size:clamp(2.6rem,6.4vw,5rem); color:#fff; max-width:16ch; margin-bottom:22px; }
.hero h1 em{ font-style:normal; color:var(--bark-light); }
.hero__lead{ font-size:clamp(1.05rem,1.8vw,1.32rem); max-width:48ch; color:rgba(255,255,255,.86); margin-bottom:34px; }
.hero__cta{ display:flex; flex-wrap:wrap; gap:14px; margin-bottom:46px; }
.hero__stats{ display:flex; flex-wrap:wrap; gap:34px; }
.hero__stat b{ font-family:var(--display); font-weight:800; font-size:2rem; color:#fff; display:block; line-height:1; }
.hero__stat span{ font-size:.86rem; color:rgba(255,255,255,.7); }

/* ---------- Finder widget ---------- */
.finder{ position:relative; z-index:5; margin-top:-72px; }
.finder__card{
  background:#fff; border-radius:var(--r-xl); box-shadow:var(--shadow-lg); padding:30px;
  border:1px solid var(--line-soft);
}
.finder__top{ display:flex; align-items:flex-start; gap:14px; margin-bottom:22px; flex-wrap:wrap; }
.finder__icon{ width:50px; height:50px; border-radius:14px; background:var(--sand); display:flex; align-items:center; justify-content:center; flex-shrink:0; color:var(--bark); }
.finder__icon svg{ width:26px; height:26px; }
.finder__title{ font-size:1.4rem; }
.finder__title + p{ color:var(--text-soft); font-size:.95rem; }
.finder__chips{ display:flex; flex-wrap:wrap; gap:11px; margin-bottom:24px; }
.chip{
  display:inline-flex; align-items:center; gap:9px; padding:13px 19px; border-radius:14px;
  background:var(--sand); border:1.5px solid transparent; font-family:var(--display); font-weight:600;
  font-size:.96rem; color:var(--ink); transition:all .2s var(--ease);
}
.chip svg{ width:20px; height:20px; color:var(--bark); }
.chip:hover{ background:#fff; border-color:var(--line); transform:translateY(-2px); box-shadow:var(--shadow-sm); }
.chip.is-active{ background:var(--ink); color:#fff; }
.chip.is-active svg{ color:var(--bark-light); }
.finder__result{ display:none; align-items:center; gap:16px; padding:18px 22px; background:var(--sand); border-radius:var(--r); flex-wrap:wrap; }
.finder__result.show{ display:flex; }
.finder__result p{ font-size:.96rem; color:var(--text-soft); flex:1; min-width:200px; }
.finder__result b{ color:var(--ink); }

/* ---------- Section heads ---------- */
.head{ max-width:680px; margin-bottom:54px; }
.head--center{ margin-left:auto; margin-right:auto; text-align:center; }
.head h2{ font-size:clamp(2rem,4vw,3rem); margin:16px 0 18px; }
.head p{ font-size:1.08rem; color:var(--text-soft); }

/* ---------- Product cards grid ---------- */
.prod-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:26px; }
.prod-card{
  background:#fff; border:1px solid var(--line-soft); border-radius:var(--r-lg); overflow:hidden;
  display:flex; flex-direction:column; transition:all .28s var(--ease); position:relative;
}
.prod-card:hover{ transform:translateY(-6px); box-shadow:var(--shadow-lg); border-color:transparent; }
.prod-card__media{ aspect-ratio:4/3; overflow:hidden; background:var(--sand-deep); position:relative; }
.prod-card__media img{ width:100%; height:100%; object-fit:cover; transition:transform .5s var(--ease); }
.prod-card:hover .prod-card__media img{ transform:scale(1.06); }
.prod-card__tag{ position:absolute; top:14px; left:14px; background:rgba(20,17,14,.78); color:#fff; backdrop-filter:blur(6px); font-family:var(--display); font-weight:700; font-size:.72rem; letter-spacing:.06em; text-transform:uppercase; padding:6px 12px; border-radius:999px; }
.prod-card__body{ padding:24px; display:flex; flex-direction:column; gap:10px; flex:1; }
.prod-card__body h3{ font-size:1.28rem; }
.prod-card__body p{ font-size:.94rem; color:var(--text-soft); flex:1; }
.prod-card__foot{ display:flex; align-items:center; justify-content:space-between; gap:12px; margin-top:6px; }
.prod-card__price{ font-family:var(--display); font-weight:700; font-size:.95rem; color:var(--bark); }
.prod-card__price small{ color:var(--text-mute); font-weight:500; }
.prod-card__arrow{ width:40px; height:40px; border-radius:50%; background:var(--sand); display:flex; align-items:center; justify-content:center; color:var(--ink); transition:all .2s var(--ease); flex-shrink:0; }
.prod-card:hover .prod-card__arrow{ background:var(--bark); color:#fff; transform:rotate(-45deg); }

/* ---------- Category info blocks (homepage) ---------- */
.cat{ display:grid; grid-template-columns:1fr 1fr; gap:60px; align-items:center; padding:64px 0; border-bottom:1px solid var(--line-soft); }
.cat:last-child{ border-bottom:none; }
.cat--flip .cat__media{ order:2; }
.cat__media{ border-radius:var(--r-lg); overflow:hidden; box-shadow:var(--shadow); aspect-ratio:5/4; background:var(--sand-deep); }
.cat__media img{ width:100%; height:100%; object-fit:cover; }
.cat__body h3{ font-size:clamp(1.6rem,3vw,2.3rem); margin:14px 0 16px; }
.cat__body p{ color:var(--text-soft); margin-bottom:18px; }
.cat__specs{ display:flex; flex-wrap:wrap; gap:10px; margin-bottom:24px; }
.spec{ font-family:var(--display); font-weight:600; font-size:.84rem; padding:7px 14px; border-radius:999px; background:var(--sand); color:var(--ink); border:1px solid var(--line); }
.spec b{ color:var(--bark); }

/* ---------- Price tables ---------- */
.ptable-wrap{ overflow-x:auto; border-radius:var(--r); border:1px solid var(--line); -webkit-overflow-scrolling:touch; }
table.ptable{ width:100%; border-collapse:collapse; min-width:520px; font-size:.92rem; }
.ptable thead th{ background:var(--ink); color:#fff; font-family:var(--display); font-weight:700; font-size:.78rem; letter-spacing:.04em; text-transform:uppercase; padding:14px 16px; text-align:left; white-space:nowrap; }
.ptable tbody td{ padding:12px 16px; border-bottom:1px solid var(--line-soft); font-variant-numeric:tabular-nums; }
.ptable tbody tr:nth-child(even){ background:var(--sand); }
.ptable tbody tr:hover{ background:var(--sand-deep); }
.ptable .price{ font-family:var(--display); font-weight:700; color:var(--bark-deep); }

/* ---------- Stats band ---------- */
.stats{ display:grid; grid-template-columns:repeat(4,1fr); gap:30px; }
.stat{ text-align:center; }
.stat b{ font-family:var(--display); font-weight:800; font-size:clamp(2.4rem,4vw,3.4rem); color:#fff; display:block; line-height:1; background:linear-gradient(180deg,#fff,#C9A284); -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent; }
.stat span{ font-size:.95rem; color:rgba(237,230,219,.7); margin-top:8px; display:block; }

/* ---------- CTA band ---------- */
.cta-band{ position:relative; border-radius:var(--r-xl); overflow:hidden; padding:72px 56px; color:#fff; }
.cta-band__bg{ position:absolute; inset:0; z-index:0; }
.cta-band__bg img{ width:100%; height:100%; object-fit:cover; }
.cta-band__bg::after{ content:""; position:absolute; inset:0; background:linear-gradient(100deg,rgba(110,68,39,.94),rgba(20,17,14,.8)); }
.cta-band__in{ position:relative; z-index:2; max-width:620px; }
.cta-band h2{ color:#fff; font-size:clamp(1.9rem,3.4vw,2.8rem); margin-bottom:16px; }
.cta-band p{ color:rgba(255,255,255,.86); font-size:1.1rem; margin-bottom:30px; }
.cta-band .hero__cta{ margin-bottom:0; }

/* ---------- Trust / features ---------- */
.feat-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.feat{ background:#fff; border:1px solid var(--line-soft); border-radius:var(--r-lg); padding:30px; transition:.25s var(--ease); }
.feat:hover{ box-shadow:var(--shadow); transform:translateY(-4px); }
.feat__ic{ width:54px; height:54px; border-radius:15px; background:var(--sand); display:flex; align-items:center; justify-content:center; color:var(--bark); margin-bottom:18px; }
.feat__ic svg{ width:28px; height:28px; }
.feat h3{ font-size:1.2rem; margin-bottom:8px; }
.feat p{ color:var(--text-soft); font-size:.95rem; }

/* ---------- Footer ---------- */
.footer{ background:var(--ink); color:#C8BEB1; padding:72px 0 30px; }
.footer__grid{ display:grid; grid-template-columns:1.4fr 1fr 1fr 1.2fr; gap:42px; padding-bottom:46px; border-bottom:1px solid rgba(255,255,255,.1); }
.footer__brand img{ height:60px; border-radius:10px; margin-bottom:18px; }
.footer__brand p{ font-size:.94rem; color:#9A9085; max-width:30ch; }
.footer h4{ font-family:var(--display); font-size:.82rem; letter-spacing:.12em; text-transform:uppercase; color:#fff; margin-bottom:18px; }
.footer ul li{ margin-bottom:11px; }
.footer ul a, .footer__info p{ font-size:.93rem; color:#B3A99D; transition:color .15s; }
.footer ul a:hover{ color:var(--bark-light); }
.footer__info p{ margin-bottom:10px; display:flex; gap:9px; align-items:flex-start; }
.footer__info svg{ width:17px; height:17px; color:var(--bark-light); flex-shrink:0; margin-top:3px; }
.footer__info a{ color:#B3A99D; }
.footer__info a:hover{ color:var(--bark-light); }
.footer__pefc{ display:inline-flex; align-items:center; gap:9px; margin-top:14px; padding:9px 15px; border-radius:999px; border:1px solid rgba(255,255,255,.16); font-size:.84rem; color:#C8BEB1; }
.footer__pefc .d{ width:8px; height:8px; border-radius:50%; background:#9DBE7A; }
.footer__bottom{ display:flex; justify-content:space-between; align-items:center; gap:16px; padding-top:24px; flex-wrap:wrap; font-size:.86rem; color:#8A8076; }
.footer__bottom a{ color:#8A8076; }
.footer__bottom a:hover{ color:var(--bark-light); }

/* ---------- Page hero (inner pages) ---------- */
.page-hero{ background:var(--ink); color:#fff; padding:calc(var(--header-h) + 56px) 0 64px; position:relative; overflow:hidden; }
.page-hero::after{ content:""; position:absolute; right:-10%; top:-30%; width:520px; height:520px; border-radius:50%; background:radial-gradient(circle,rgba(148,98,66,.4),transparent 65%); }
.page-hero__in{ position:relative; z-index:2; }
.page-hero .crumbs{ font-size:.86rem; color:rgba(255,255,255,.6); margin-bottom:18px; }
.page-hero .crumbs a:hover{ color:var(--bark-light); }
.page-hero h1{ color:#fff; font-size:clamp(2.2rem,4.6vw,3.6rem); max-width:18ch; }
.page-hero p{ color:rgba(255,255,255,.8); font-size:1.1rem; max-width:54ch; margin-top:16px; }

/* ---------- Forms ---------- */
.field{ margin-bottom:16px; }
.field label{ display:block; font-family:var(--display); font-weight:600; font-size:.88rem; margin-bottom:7px; color:var(--ink); }
.field input,.field select,.field textarea{
  width:100%; padding:14px 16px; border:1.5px solid var(--line); border-radius:var(--r-sm);
  font-family:var(--body); font-size:.96rem; color:var(--text); background:#fff; transition:border-color .2s;
}
.field input:focus,.field select:focus,.field textarea:focus{ outline:none; border-color:var(--bark); box-shadow:0 0 0 4px rgba(148,98,66,.12); }
.field textarea{ resize:vertical; min-height:120px; }

/* ---------- Utilities ---------- */
.reveal{ opacity:0; transform:translateY(28px); transition:opacity .7s var(--ease), transform .7s var(--ease); }
.reveal.in{ opacity:1; transform:none; }
.mt-0{ margin-top:0; }
.center{ text-align:center; }
:focus-visible{ outline:3px solid var(--bark); outline-offset:2px; border-radius:4px; }

/* ---------- Responsive ---------- */
@media (max-width:1024px){
  .prod-grid{ grid-template-columns:repeat(2,1fr); }
  .feat-grid{ grid-template-columns:1fr 1fr; }
  .footer__grid{ grid-template-columns:1fr 1fr; gap:34px; }
  .stats{ grid-template-columns:repeat(2,1fr); gap:36px; }
}
@media (max-width:860px){
  .header__nav,.header__phone{ display:none; }
  .burger{ display:flex; }
  .section{ padding:68px 0; }
  .cat{ grid-template-columns:1fr; gap:30px; padding:44px 0; }
  .cat--flip .cat__media{ order:0; }
  .cta-band{ padding:48px 28px; }
}
@media (max-width:600px){
  .container{ padding:0 18px; }
  .prod-grid{ grid-template-columns:1fr; }
  .feat-grid{ grid-template-columns:1fr; }
  .footer__grid{ grid-template-columns:1fr; }
  .stats{ grid-template-columns:1fr 1fr; gap:28px; }
  .finder__card{ padding:22px; }
  .hero__stats{ gap:22px; }
  .hero__stat b{ font-size:1.6rem; }
  .btn{ padding:13px 22px; }
  .section{ padding:56px 0; }
}
@media (prefers-reduced-motion:reduce){
  *{ animation:none!important; transition:none!important; scroll-behavior:auto!important; }
  .reveal{ opacity:1; transform:none; }
}

/* ===========================================================
   SHOP + CALCULATOR components
   =========================================================== */
.filterbar{ position:sticky; top:var(--header-h); z-index:50; background:rgba(255,255,255,.94); backdrop-filter:blur(12px); border-bottom:1px solid var(--line-soft); padding:14px 0; }
.filterbar__row{ display:flex; gap:10px; overflow-x:auto; -webkit-overflow-scrolling:touch; padding-bottom:2px; scrollbar-width:none; }
.filterbar__row::-webkit-scrollbar{ display:none; }
.fpill{ flex-shrink:0; font-family:var(--display); font-weight:600; font-size:.9rem; padding:10px 18px; border-radius:999px; background:var(--sand); color:var(--ink); border:1.5px solid transparent; transition:all .18s var(--ease); white-space:nowrap; }
.fpill:hover{ background:var(--sand-deep); }
.fpill.is-active{ background:var(--ink); color:#fff; }

.shopcat{ padding:56px 0; border-bottom:1px solid var(--line-soft); scroll-margin-top:calc(var(--header-h) + 70px); }
.shopcat__head{ display:grid; grid-template-columns:1.3fr 1fr; gap:40px; align-items:start; margin-bottom:34px; }
.shopcat__title{ font-size:clamp(1.7rem,3.2vw,2.5rem); margin:12px 0 14px; }
.shopcat__lead{ color:var(--text-soft); }
.shopcat__media{ border-radius:var(--r-lg); overflow:hidden; aspect-ratio:4/3; box-shadow:var(--shadow); background:linear-gradient(135deg,#B98A63,#6E4427); }
.shopcat__media img{ width:100%; height:100%; object-fit:cover; }
.shopcat__grid{ display:grid; grid-template-columns:1.35fr 1fr; gap:34px; align-items:start; }

/* calculator panel */
.calc{ background:var(--sand); border:1px solid var(--line); border-radius:var(--r-lg); padding:26px; position:sticky; top:calc(var(--header-h) + 80px); }
.calc h4{ font-family:var(--display); font-size:1.15rem; display:flex; align-items:center; gap:9px; margin-bottom:6px; }
.calc h4 svg{ width:22px; height:22px; color:var(--bark); }
.calc__note{ font-size:.84rem; color:var(--text-mute); margin-bottom:18px; }
.calc__out{ margin-top:18px; background:#fff; border-radius:var(--r); border:1px solid var(--line); padding:18px 20px; }
.calc__row{ display:flex; justify-content:space-between; align-items:baseline; padding:7px 0; border-bottom:1px dashed var(--line-soft); font-size:.94rem; }
.calc__row:last-child{ border-bottom:none; }
.calc__row span{ color:var(--text-soft); }
.calc__row b{ font-family:var(--display); font-variant-numeric:tabular-nums; color:var(--ink); }
.calc__total{ margin-top:10px; padding-top:14px; border-top:2px solid var(--ink); display:flex; justify-content:space-between; align-items:baseline; }
.calc__total span{ font-family:var(--display); font-weight:700; }
.calc__total b{ font-family:var(--display); font-weight:800; font-size:1.6rem; color:var(--bark-deep); }
.calc__hint{ font-size:.78rem; color:var(--text-mute); margin-top:12px; }
.calc__cta{ margin-top:16px; }

.paring-box{ background:var(--sand); border:1px dashed var(--bark-light); border-radius:var(--r-lg); padding:26px; }
.paring-box h4{ font-family:var(--display); font-size:1.15rem; margin-bottom:10px; }
.paring-box ul{ display:grid; gap:9px; margin:6px 0 18px; }
.paring-box li{ font-size:.92rem; color:var(--text-soft); display:flex; gap:9px; align-items:flex-start; }
.paring-box li::before{ content:""; width:6px; height:6px; border-radius:50%; background:var(--bark); margin-top:8px; flex-shrink:0; }

.notice{ background:var(--sand); border-left:3px solid var(--bark); border-radius:0 12px 12px 0; padding:16px 20px; font-size:.9rem; color:var(--text-soft); margin-top:26px; }

@media (max-width:900px){
  .shopcat__head{ grid-template-columns:1fr; }
  .shopcat__grid{ grid-template-columns:1fr; }
  .calc{ position:static; }
}

/* ===========================================================
   KALKULAATOR page + shared utilities
   =========================================================== */
.grid-2{ display:grid; grid-template-columns:1fr 1fr; gap:16px; }

.kalk-tabs{ display:flex; gap:10px; flex-wrap:wrap; margin-bottom:30px; }
.ktab{ font-family:var(--display); font-weight:600; font-size:.95rem; padding:12px 22px; border-radius:999px; background:var(--sand); color:var(--ink); border:1.5px solid transparent; transition:all .18s var(--ease); }
.ktab:hover{ background:var(--sand-deep); }
.ktab.is-active{ background:var(--ink); color:#fff; }

.kalk-panel{ display:none; }
.kalk-panel.is-active{ display:block; animation:kalkFade .4s var(--ease); }
@keyframes kalkFade{ from{ opacity:0; transform:translateY(12px); } to{ opacity:1; transform:none; } }

.kalk-grid{ display:grid; grid-template-columns:1.25fr 1fr; gap:36px; align-items:start; }
.kalk-form{ background:#fff; border:1px solid var(--line-soft); border-radius:var(--r-lg); padding:30px; box-shadow:var(--shadow-sm,0 2px 10px rgba(20,17,14,.05)); }
.kalk-form h3{ font-size:1.4rem; margin-bottom:6px; }
.kalk-sub{ color:var(--text-soft); font-size:.92rem; margin-bottom:22px; }
.kalk-form .calc{ position:static; }

@media (max-width:900px){
  .kalk-grid{ grid-template-columns:1fr; gap:24px; }
  .kalk-form .calc, .calc{ position:static; }
}
@media (max-width:520px){
  .grid-2{ grid-template-columns:1fr; }
  .ktab{ flex:1; text-align:center; padding:11px 14px; font-size:.88rem; }
}

/* ---------- Contact page ---------- */
.contact-grid{ display:grid; grid-template-columns:1fr 1.1fr; gap:48px; align-items:start; }
.contact-info{ display:grid; gap:22px; }
.cinfo{ display:flex; gap:16px; align-items:flex-start; }
.cinfo__ic{ width:48px; height:48px; flex-shrink:0; border-radius:14px; background:var(--sand); display:flex; align-items:center; justify-content:center; color:var(--bark); }
.cinfo__ic svg{ width:23px; height:23px; }
.cinfo h4{ font-family:var(--display); font-size:1.02rem; margin-bottom:3px; }
.cinfo p, .cinfo a{ color:var(--text-soft); font-size:.96rem; line-height:1.5; }
.cinfo a:hover{ color:var(--bark); }
.contact-card{ background:#fff; border:1px solid var(--line-soft); border-radius:var(--r-lg); padding:32px; box-shadow:var(--shadow); }
.contact-card h3{ font-size:1.45rem; margin-bottom:6px; }
.contact-card .lead{ color:var(--text-soft); margin-bottom:24px; font-size:.95rem; }
.form-note{ font-size:.82rem; color:var(--text-mute); margin-top:14px; }
.map-embed{ margin-top:8px; border-radius:var(--r-lg); overflow:hidden; border:1px solid var(--line); line-height:0; }
.map-embed iframe{ width:100%; height:380px; border:0; display:block; }
@media (max-width:860px){
  .contact-grid{ grid-template-columns:1fr; gap:34px; }
}

/* ---------- Legal / prose ---------- */
.prose{ max-width:760px; }
.prose h2{ font-size:1.5rem; margin:38px 0 12px; }
.prose h3{ font-size:1.15rem; margin:26px 0 8px; }
.prose p{ color:var(--text-soft); margin-bottom:14px; line-height:1.7; }
.prose ul{ margin:0 0 16px 0; display:grid; gap:8px; }
.prose ul li{ position:relative; padding-left:22px; color:var(--text-soft); line-height:1.6; }
.prose ul li::before{ content:""; position:absolute; left:0; top:9px; width:7px; height:7px; border-radius:50%; background:var(--bark); }
.prose a{ color:var(--bark); text-decoration:underline; }
.prose strong{ color:var(--ink); }
