/* =====================================================================
   THE MAILER BOXES — "Die-Line Standard" Design System
   Industrial / technical / premium B2B packaging aesthetic
   Brand: ink-navy + kraft + signal-yellow
   ===================================================================== */

@import url('https://fonts.googleapis.com/css2?family=Archivo:wght@400;500;600;700;800;900&family=IBM+Plex+Mono:wght@400;500;600&family=IBM+Plex+Sans:wght@400;500;600;700&display=swap');

:root{
  /* ---- Brand palette ---- */
  --ink:        #15182f;   /* deep navy ink (primary) */
  --ink-2:      #0c0e1f;   /* near-black */
  --ink-soft:   #2c3050;
  --paper:      #f5f1e8;   /* warm paper */
  --paper-2:    #ece4d4;   /* kraft tint */
  --paper-3:    #fbf9f3;   /* lightest */
  --kraft:      #c08a4e;   /* kraft brown */
  --kraft-deep: #82542b;   /* deep kraft */
  --yellow:     #ffd400;   /* signal yellow (brand) */
  --yellow-deep:#e3b500;
  --white:      #ffffff;

  --ink-rgb: 21,24,47;

  /* ---- Functional ---- */
  --line:       rgba(21,24,47,.14);
  --line-strong:rgba(21,24,47,.28);
  --line-light: rgba(255,255,255,.16);
  --muted:      #6b6f86;
  --muted-paper:rgba(245,241,232,.62);

  /* ---- Type ---- */
  --display: 'Archivo', sans-serif;
  --body:    'IBM Plex Sans', sans-serif;
  --mono:    'IBM Plex Mono', monospace;

  /* ---- Layout ---- */
  --wrap: 1280px;
  --wrap-wide: 1440px;
  --gut: clamp(20px, 5vw, 64px);
  --radius: 4px;

  --shadow-card: 0 1px 0 var(--line), 0 18px 40px -28px rgba(21,24,47,.4);
  --header-h: 116px;
}

*{ box-sizing:border-box; }
html{ -webkit-text-size-adjust:100%; scroll-behavior:smooth; }
body{
  margin:0;
  font-family:var(--body);
  color:var(--ink);
  background:var(--paper);
  font-size:17px;
  line-height:1.62;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; cursor:pointer; }
::selection{ background:var(--yellow); color:var(--ink); }

/* ===================== Typography ===================== */
h1,h2,h3,h4,h5{ font-family:var(--display); font-weight:800; line-height:1.04; margin:0; letter-spacing:-.022em; color:var(--ink); }
.h-display{ font-size:clamp(2.9rem,1.2rem+6.6vw,6.2rem); font-weight:900; letter-spacing:-.035em; line-height:.96; }
h1{ font-size:clamp(2.4rem,1.2rem+4.6vw,4.4rem); font-weight:900; letter-spacing:-.03em; }
h2{ font-size:clamp(2rem,1.2rem+2.7vw,3.4rem); }
h3{ font-size:clamp(1.4rem,1.05rem+1.3vw,2.1rem); }
h4{ font-size:clamp(1.15rem,1rem+.6vw,1.45rem); }
p{ margin:0 0 1.1em; }
strong{ font-weight:700; color:var(--ink); }

/* Technical mono kicker label */
.kicker{
  font-family:var(--mono);
  font-size:13px;
  font-weight:500;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--kraft-deep);
  display:inline-flex;
  align-items:center;
  gap:10px;
}
.kicker::before{
  content:attr(data-num);
  color:var(--ink);
  background:var(--yellow);
  padding:2px 8px;
  border-radius:2px;
  font-weight:600;
  letter-spacing:.08em;
}
.kicker.on-dark{ color:var(--yellow); }
.kicker.on-dark::before{ background:rgba(255,255,255,.1); color:var(--paper); }
.kicker.plain::before{ display:none; }

.lead{ font-size:clamp(1.05rem,1rem+.4vw,1.3rem); color:var(--ink-soft); line-height:1.6; }
.muted{ color:var(--muted); }

/* ===================== Layout ===================== */
.wrap{ width:100%; max-width:var(--wrap); margin:0 auto; padding-inline:var(--gut); }
.wrap-wide{ max-width:var(--wrap-wide); }
.section{ padding-block:clamp(64px,7vw,120px); position:relative; }
.section-sm{ padding-block:clamp(48px,5vw,80px); }
.center{ text-align:center; }
.eyebrow-row{ display:flex; align-items:center; gap:18px; flex-wrap:wrap; margin-bottom:22px; }

/* Surfaces */
.bg-ink{ background:var(--ink); color:var(--paper); }
.bg-ink h1,.bg-ink h2,.bg-ink h3,.bg-ink h4{ color:var(--white); }
.bg-paper2{ background:var(--paper-2); }
.bg-kraft{ background:var(--kraft); color:#fff; }
.bg-white{ background:var(--white); }

/* ===================== Die-line decorations ===================== */
/* Blueprint grid */
.grid-bg{ position:relative; }
.grid-bg::before{
  content:""; position:absolute; inset:0; pointer-events:none; z-index:0;
  background-image:
    linear-gradient(var(--line) 1px, transparent 1px),
    linear-gradient(90deg, var(--line) 1px, transparent 1px);
  background-size:64px 64px;
  -webkit-mask-image:radial-gradient(ellipse 80% 70% at 50% 40%, #000 40%, transparent 100%);
          mask-image:radial-gradient(ellipse 80% 70% at 50% 40%, #000 40%, transparent 100%);
  opacity:.6;
}
.grid-bg.on-dark::before{
  background-image:
    linear-gradient(rgba(255,255,255,.07) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.07) 1px, transparent 1px);
}
.grid-bg > *{ position:relative; z-index:1; }

/* Corner crop marks */
.crop{ position:relative; }
.crop::before,.crop::after{
  content:""; position:absolute; width:14px; height:14px; pointer-events:none;
  border-color:var(--line-strong); border-style:solid; border-width:0;
}
.crop::before{ top:10px; left:10px; border-top-width:2px; border-left-width:2px; }
.crop::after{ bottom:10px; right:10px; border-bottom-width:2px; border-right-width:2px; }

/* Dotted fold-line divider */
.fold{ height:0; border:0; border-top:2px dashed var(--line-strong); margin:0; }

/* Dimension tag */
.dim-tag{
  font-family:var(--mono); font-size:12px; letter-spacing:.05em; color:var(--muted);
  display:inline-flex; align-items:center; gap:8px;
}
.dim-tag::before{ content:"↔"; color:var(--kraft); font-size:14px; }

/* ===================== Buttons ===================== */
.btn{
  display:inline-flex; align-items:center; gap:10px;
  font-family:var(--display); font-weight:700; font-size:15px;
  letter-spacing:-.01em; padding:15px 26px; border-radius:var(--radius);
  border:2px solid var(--ink); background:var(--ink); color:var(--white);
  transition:transform .15s ease, background .2s ease, color .2s ease, box-shadow .2s ease;
  line-height:1; cursor:pointer; white-space:nowrap;
}
.btn .ico{ font-size:18px; display:flex; }
.btn:hover{ transform:translateY(-2px); box-shadow:0 12px 24px -12px rgba(21,24,47,.5); }
.btn-yellow{ background:var(--yellow); border-color:var(--yellow); color:var(--ink); }
.btn-yellow:hover{ background:var(--yellow-deep); border-color:var(--yellow-deep); }
.btn-outline{ background:transparent; color:var(--ink); }
.btn-outline:hover{ background:var(--ink); color:var(--white); }
.btn-ghost-light{ background:transparent; border-color:var(--line-light); color:var(--paper); }
.btn-ghost-light:hover{ background:var(--white); color:var(--ink); border-color:var(--white); }
.btn-lg{ padding:18px 32px; font-size:16px; }
.btn-sm{ padding:11px 18px; font-size:13px; }
.link-arrow{ font-family:var(--mono); font-size:13px; font-weight:500; letter-spacing:.08em; text-transform:uppercase; display:inline-flex; align-items:center; gap:8px; border-bottom:2px solid var(--yellow); padding-bottom:3px; transition:gap .2s ease; }
.link-arrow:hover{ gap:14px; }

/* ===================== Header ===================== */
.site-header{ position:sticky; top:0; z-index:90; background:var(--paper); border-bottom:1px solid var(--line); }
.topbar{ background:var(--ink); color:var(--muted-paper); font-family:var(--mono); font-size:12.5px; letter-spacing:.03em; }
.topbar .wrap{ display:flex; align-items:center; justify-content:space-between; min-height:38px; padding-block:7px; gap:16px; }
.topbar a{ color:var(--paper); }
.topbar a:hover{ color:var(--yellow); }
.topbar .tb-left{ display:flex; gap:22px; align-items:center; flex-wrap:wrap; }
.topbar .tb-right{ display:flex; gap:18px; align-items:center; }
.topbar .pill{ color:var(--yellow); }

.headbar{ display:flex; align-items:center; gap:28px; min-height:78px; }
.logo{ display:flex; align-items:center; gap:12px; flex-shrink:0; }
.logo .mark{ width:42px; height:42px; background:var(--ink); color:var(--yellow); border-radius:5px; display:grid; place-items:center; font-family:var(--display); font-weight:900; font-size:22px; position:relative; }
.logo .mark::after{ content:""; position:absolute; inset:6px; border:1.5px dashed rgba(255,212,0,.5); border-radius:2px; }
.logo .lg-txt{ font-family:var(--display); font-weight:900; line-height:.92; letter-spacing:-.03em; font-size:20px; color:var(--ink); }
.logo .lg-txt span{ display:block; font-family:var(--mono); font-weight:500; font-size:10.5px; letter-spacing:.34em; color:var(--kraft-deep); margin-top:3px; }

.mainnav{ display:flex; align-items:center; gap:26px; margin-left:6px; }
.mainnav a{ font-weight:600; font-size:15.5px; color:var(--ink); position:relative; padding-block:6px; }
.mainnav a::after{ content:""; position:absolute; left:0; bottom:0; width:0; height:2px; background:var(--yellow); transition:width .22s ease; }
.mainnav a:hover::after,.mainnav a.active::after{ width:100%; }
.head-actions{ margin-left:auto; display:flex; align-items:center; gap:14px; }
.icon-btn{ width:44px; height:44px; border:1px solid var(--line); border-radius:var(--radius); background:var(--white); display:grid; place-items:center; font-size:19px; color:var(--ink); transition:.2s; }
.icon-btn:hover{ border-color:var(--ink); }
.phone-chip{ display:inline-flex; align-items:center; gap:9px; background:var(--ink); color:var(--white); padding:11px 16px; border-radius:var(--radius); font-family:var(--mono); font-weight:500; font-size:14px; white-space:nowrap; }
.phone-chip .ph{ color:var(--yellow); font-size:17px; }
.burger{ display:none; }

/* Mobile drawer */
.drawer-backdrop{ position:fixed; inset:0; background:rgba(12,14,31,.5); opacity:0; visibility:hidden; transition:.25s; z-index:95; }
.drawer-backdrop.open{ opacity:1; visibility:visible; }
.drawer{ position:fixed; top:0; right:0; height:100%; width:min(86vw,360px); background:var(--paper); z-index:96; transform:translateX(100%); transition:transform .3s cubic-bezier(.4,0,.1,1); display:flex; flex-direction:column; padding:22px; overflow-y:auto; }
.drawer.open{ transform:translateX(0); }
.drawer-head{ display:flex; justify-content:space-between; align-items:center; margin-bottom:22px; }
.drawer nav a{ display:block; font-family:var(--display); font-weight:700; font-size:21px; padding:15px 0; border-bottom:1px solid var(--line); color:var(--ink); }
.drawer .drawer-cta{ margin-top:auto; padding-top:20px; display:grid; gap:10px; }

/* ===================== Footer ===================== */
.site-footer{ background:var(--ink-2); color:var(--muted-paper); padding-top:clamp(56px,6vw,88px); }
.footer-top{ display:grid; grid-template-columns:1.6fr 1fr 1fr 1.3fr; gap:40px; padding-bottom:48px; border-bottom:1px solid rgba(255,255,255,.1); }
.footer-col h5{ font-family:var(--mono); font-weight:500; font-size:12px; letter-spacing:.16em; text-transform:uppercase; color:var(--yellow); margin-bottom:20px; }
.footer-col ul{ list-style:none; margin:0; padding:0; display:grid; gap:11px; }
.footer-col a{ color:var(--muted-paper); font-size:15px; }
.footer-col a:hover{ color:var(--white); }
.footer-brand .logo .lg-txt{ color:var(--white); }
.footer-brand p{ font-size:14.5px; margin-top:18px; max-width:34ch; line-height:1.6; }
.foot-contact li{ display:flex; gap:11px; align-items:flex-start; font-size:14.5px; }
.foot-contact .ph{ color:var(--yellow); font-size:17px; margin-top:1px; }
.footer-bottom{ display:flex; justify-content:space-between; align-items:center; gap:18px; flex-wrap:wrap; padding-block:24px; font-family:var(--mono); font-size:12.5px; letter-spacing:.03em; }
.social-row{ display:flex; gap:10px; margin-top:22px; }
.social-row a{ width:40px; height:40px; border:1px solid rgba(255,255,255,.16); border-radius:var(--radius); display:grid; place-items:center; font-size:17px; color:var(--paper); transition:.2s; }
.social-row a:hover{ background:var(--yellow); color:var(--ink); border-color:var(--yellow); }

/* ===================== Product card ===================== */
.prod-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:20px; }
.prod-card{ background:var(--white); border:1px solid var(--line); border-radius:var(--radius); overflow:hidden; display:flex; flex-direction:column; transition:transform .2s ease, box-shadow .2s ease, border-color .2s ease; position:relative; }
.prod-card:hover{ transform:translateY(-4px); box-shadow:var(--shadow-card); border-color:var(--line-strong); }
.prod-card .pc-thumb{ aspect-ratio:1/1; background:var(--paper-3); position:relative; overflow:hidden; }
.prod-card .pc-thumb img{ width:100%; height:100%; object-fit:cover; transition:transform .4s ease; }
.prod-card:hover .pc-thumb img{ transform:scale(1.05); }
.pc-tag{ position:absolute; top:12px; left:12px; font-family:var(--mono); font-size:10.5px; font-weight:600; letter-spacing:.08em; text-transform:uppercase; background:var(--ink); color:var(--yellow); padding:5px 9px; border-radius:2px; z-index:2; }
.pc-sale{ position:absolute; top:12px; right:12px; font-family:var(--mono); font-size:10.5px; font-weight:600; background:var(--yellow); color:var(--ink); padding:5px 9px; border-radius:2px; z-index:2; }
.pc-body{ padding:18px 18px 20px; display:flex; flex-direction:column; gap:6px; flex:1; }
.pc-cat{ font-family:var(--mono); font-size:11px; letter-spacing:.08em; text-transform:uppercase; color:var(--kraft-deep); }
.pc-title{ font-family:var(--display); font-weight:700; font-size:17px; line-height:1.15; letter-spacing:-.01em; }
.pc-meta{ display:flex; align-items:center; justify-content:space-between; gap:10px; margin-top:auto; padding-top:14px; }
.pc-price{ font-family:var(--mono); font-weight:600; font-size:15px; color:var(--ink); }
.pc-price s{ color:var(--muted); font-weight:400; font-size:13px; margin-left:4px; }
.pc-price .q{ color:var(--muted); font-weight:400; font-size:12px; }
.pc-cta{ width:40px; height:40px; border-radius:var(--radius); background:var(--paper-2); border:1px solid var(--line); display:grid; place-items:center; font-size:17px; color:var(--ink); transition:.2s; flex-shrink:0; }
.prod-card:hover .pc-cta{ background:var(--yellow); border-color:var(--yellow); }

/* Image fallback placeholder (when remote photo blocked) */
.img-fallback{ position:absolute; inset:0; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:10px; background:
  repeating-linear-gradient(45deg, var(--paper-2), var(--paper-2) 14px, var(--paper-3) 14px, var(--paper-3) 28px); color:var(--kraft-deep); text-align:center; padding:18px; }
.img-fallback svg{ width:46px; height:46px; opacity:.8; }
.img-fallback span{ font-family:var(--mono); font-size:11px; letter-spacing:.06em; text-transform:uppercase; max-width:22ch; line-height:1.4; }

/* ===================== Forms ===================== */
.field{ display:flex; flex-direction:column; gap:7px; }
.field label{ font-family:var(--mono); font-size:11.5px; letter-spacing:.08em; text-transform:uppercase; color:var(--ink-soft); }
.field input,.field select,.field textarea{
  font-family:var(--body); font-size:15px; color:var(--ink); background:var(--white);
  border:1px solid var(--line-strong); border-radius:var(--radius); padding:13px 14px; width:100%;
  transition:border-color .2s, box-shadow .2s;
}
.field input:focus,.field select:focus,.field textarea:focus{ outline:none; border-color:var(--ink); box-shadow:0 0 0 3px rgba(255,212,0,.35); }
.field textarea{ resize:vertical; min-height:96px; }
.form-grid{ display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.form-grid .full{ grid-column:1/-1; }
.quote-card{ background:var(--white); border:1px solid var(--line); border-radius:var(--radius); padding:clamp(24px,3vw,36px); position:relative; }
.field input.err,.field select.err,.field textarea.err{ border-color:#d23b3b; box-shadow:0 0 0 3px rgba(210,59,59,.16); }
.file-drop{ display:flex; align-items:center; gap:10px; justify-content:center; border:1.5px dashed var(--line-strong); border-radius:var(--radius); padding:18px; color:var(--ink-soft); font-size:14.5px; cursor:pointer; background:var(--paper-3); transition:.18s; }
.file-drop:hover{ border-color:var(--ink); }
.file-drop i{ font-size:20px; color:var(--kraft-deep); }
.file-drop [data-file-name]{ color:var(--ink-soft); }
.form-note{ font-family:var(--mono); font-size:11.5px; color:var(--muted); margin:14px 0 0; text-align:center; }

/* ===================== Accordion ===================== */
.acc-item{ border-bottom:1px solid var(--line); }
.acc-q{ width:100%; background:none; border:0; text-align:left; display:flex; align-items:center; justify-content:space-between; gap:20px; padding:22px 4px; font-family:var(--display); font-weight:700; font-size:clamp(1rem,.95rem+.3vw,1.2rem); color:var(--ink); }
.acc-q .pm{ flex-shrink:0; width:30px; height:30px; border:1.5px solid var(--line-strong); border-radius:50%; display:grid; place-items:center; font-size:18px; transition:.25s; font-family:var(--body); }
.acc-q[aria-expanded="true"] .pm{ background:var(--yellow); border-color:var(--yellow); transform:rotate(180deg); }
.acc-a{ max-height:0; overflow:hidden; transition:max-height .3s ease; }
.acc-a-inner{ padding:0 4px 24px; color:var(--ink-soft); max-width:64ch; }

/* ===================== Misc utilities ===================== */
.tag{ display:inline-flex; align-items:center; gap:7px; font-family:var(--mono); font-size:12px; letter-spacing:.05em; padding:6px 12px; border:1px solid var(--line-strong); border-radius:100px; color:var(--ink-soft); }
.tag.solid{ background:var(--ink); color:var(--paper); border-color:var(--ink); }
.divider-line{ height:1px; background:var(--line); border:0; }
.reveal{ opacity:0; transform:translateY(24px); transition:opacity .7s ease, transform .7s ease; }
.reveal.in{ opacity:1; transform:none; }
.mono{ font-family:var(--mono); }
.nowrap{ white-space:nowrap; }
.stack-sm{ display:grid; gap:10px; }

/* breadcrumb */
.breadcrumb{ font-family:var(--mono); font-size:12.5px; letter-spacing:.04em; color:var(--muted); display:flex; gap:10px; align-items:center; flex-wrap:wrap; }
.breadcrumb a:hover{ color:var(--ink); }
.breadcrumb .sep{ color:var(--kraft); }

/* page hero band */
.page-hero{ background:var(--ink); color:var(--paper); padding-block:clamp(48px,6vw,84px); position:relative; overflow:hidden; }
.page-hero h1,.page-hero h2,.page-hero h3{ color:#fff; }
.page-hero .breadcrumb{ color:var(--muted-paper); }
.page-hero .breadcrumb a{ color:var(--paper); }

/* ===================== Responsive ===================== */
@media (max-width:1080px){
  .prod-grid{ grid-template-columns:repeat(3,1fr); }
  .footer-top{ grid-template-columns:1fr 1fr; gap:32px; }
}
@media (max-width:1160px){
  .mainnav{ gap:18px; }
  .phone-chip{ display:none; }
}
@media (max-width:860px){
  :root{ --header-h:64px; }
  .mainnav, .topbar .tb-left .hide-sm{ display:none; }
  .burger{ display:grid; }
  .headbar{ min-height:64px; gap:14px; }
  .form-grid{ grid-template-columns:1fr; }
  .prod-grid{ grid-template-columns:repeat(2,1fr); gap:14px; }
}
@media (max-width:560px){
  body{ font-size:16px; }
  .topbar .tb-left a:not(.show-xs){ display:none; }
  .prod-grid{ grid-template-columns:repeat(2,1fr); gap:12px; }
  .footer-top{ grid-template-columns:1fr; gap:30px; }
  .pc-body{ padding:14px; }
  .btn{ padding:14px 22px; }
}


/* =====================================================================
   PAGE & TEMPLATE LAYOUTS (consolidated from approved HTML pages)
   ===================================================================== */

/* ---------- index.html ---------- */
/* ---- Page-specific layout (homepage) ---- */
.hero-grid{ display:grid; grid-template-columns:1.15fr .85fr; gap:clamp(32px,5vw,72px); align-items:center; }
.underline-swish{ position:absolute; left:-2%; bottom:-.28em; width:104%; height:.4em; }
.hero-cta{ display:flex; gap:14px; flex-wrap:wrap; margin-top:32px; }
.hero-specs{ display:flex; gap:clamp(20px,3vw,44px); margin-top:40px; padding-top:28px; border-top:1px solid var(--line); }
.hspec b{ font-family:var(--display); font-weight:900; font-size:clamp(1.8rem,1.2rem+1.6vw,2.6rem); letter-spacing:-.03em; display:block; line-height:1; }
.hspec b i{ font-style:normal; color:var(--kraft); }
.hspec span{ font-family:var(--mono); font-size:11.5px; letter-spacing:.04em; color:var(--muted); display:block; margin-top:8px; max-width:14ch; }
.qf-head h3{ font-size:1.5rem; }
.qf-note{ font-family:var(--mono); font-size:11.5px; color:var(--muted); margin:14px 0 0; text-align:center; }

.trust-strip{ padding-block:30px; }
.trust-grid{ display:flex; align-items:center; justify-content:space-between; gap:24px; flex-wrap:wrap; }
.tstat b{ font-family:var(--display); font-weight:900; font-size:clamp(1.6rem,1rem+1.6vw,2.4rem); color:#fff; letter-spacing:-.03em; line-height:1; }
.tstat b i{ font-style:normal; color:var(--yellow); }
.tstat span{ display:block; font-family:var(--mono); font-size:11.5px; letter-spacing:.06em; color:var(--muted-paper); margin-top:7px; text-transform:uppercase; }
.tstat-note .kicker{ text-transform:none; }

.sec-head{ display:grid; grid-template-columns:1fr 1fr; gap:32px; align-items:end; margin-bottom:48px; }
.sec-head h2{ margin-top:6px; }

.bento{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
.bento-card{ background:var(--white); border:1px solid var(--line); border-radius:var(--radius); padding:32px 26px; transition:.2s; }
.bento-card:hover{ border-color:var(--line-strong); transform:translateY(-3px); }
.bento-card i{ font-size:38px; color:var(--kraft-deep); }
.bento-card h4{ margin:18px 0 10px; }
.bento-card p{ color:var(--ink-soft); font-size:15.5px; margin:0; }

.steps{ display:grid; grid-template-columns:repeat(4,1fr); gap:0; margin-top:48px; }
.step{ padding:0 28px; border-left:1px solid var(--line); position:relative; }
.step:first-child{ border-left:0; padding-left:0; }
.step-num{ font-family:var(--mono); font-weight:600; font-size:13px; color:var(--ink); background:var(--yellow); padding:5px 10px; border-radius:2px; display:inline-block; margin-bottom:18px; }
.step h4{ margin:0 0 10px; }
.step p{ color:var(--ink-soft); font-size:15.5px; margin:0; }

.spec-cols{ display:grid; grid-template-columns:repeat(4,1fr); gap:18px; margin-top:46px; }
.spec-block{ border:1px solid var(--line-light); border-radius:var(--radius); padding:24px; background:rgba(255,255,255,.03); }
.spec-block h5{ font-family:var(--mono); font-weight:500; font-size:12px; letter-spacing:.14em; text-transform:uppercase; color:var(--yellow); margin:0 0 16px; }
.spec-list{ list-style:none; margin:0; padding:0; display:grid; gap:0; }
.spec-list li{ display:flex; justify-content:space-between; align-items:center; gap:12px; padding:12px 0; border-bottom:1px dashed rgba(255,255,255,.12); }
.spec-list li:last-child{ border-bottom:0; }
.spec-list span{ color:#fff; font-weight:500; font-size:15px; }
.spec-list i{ font-family:var(--mono); font-style:normal; font-size:11.5px; color:var(--muted-paper); letter-spacing:.03em; }

.sustain{ display:grid; grid-template-columns:.9fr 1.1fr; gap:clamp(32px,5vw,68px); align-items:center; }
.sustain-visual{ background:var(--paper-2); border:1px solid var(--line); border-radius:var(--radius); padding:38px; }
.sv-badge{ width:62px; height:62px; border-radius:50%; background:var(--kraft-deep); color:#fff; display:grid; place-items:center; font-size:30px; margin-bottom:24px; }
.sv-stat{ display:flex; align-items:baseline; gap:16px; }
.sv-stat b{ font-family:var(--display); font-weight:900; font-size:clamp(2.6rem,1.6rem+3vw,4rem); letter-spacing:-.03em; line-height:.9; color:var(--kraft-deep); }
.sv-stat span{ font-size:15px; color:var(--ink-soft); max-width:18ch; }
.sv-row{ display:flex; align-items:center; gap:12px; padding:10px 0; font-weight:500; }
.sv-row i{ color:var(--kraft-deep); font-size:22px; }
.check-list{ list-style:none; margin:26px 0 30px; padding:0; display:grid; gap:12px; }
.check-list li{ display:flex; gap:12px; align-items:center; font-weight:500; }
.check-list i{ color:var(--ink); background:var(--yellow); border-radius:50%; width:24px; height:24px; display:grid; place-items:center; font-size:13px; flex-shrink:0; }

.seo-block{ display:grid; grid-template-columns:.8fr 2fr; gap:clamp(32px,5vw,64px); align-items:start; }
.seo-toc{ position:sticky; top:130px; }
.seo-toc h3{ margin:6px 0 18px; }
.seo-toc ul{ list-style:none; margin:0; padding:0; display:grid; gap:2px; }
.seo-toc a{ display:block; padding:11px 14px; border-left:2px solid var(--line); color:var(--ink-soft); font-size:14.5px; transition:.2s; }
.seo-toc a:hover{ border-color:var(--yellow); color:var(--ink); background:var(--white); }
.seo-body h2{ margin-bottom:18px; }
.seo-body h3{ margin:38px 0 14px; }
.seo-body p{ color:var(--ink-soft); max-width:68ch; }
.seo-chips{ display:flex; flex-wrap:wrap; gap:10px; margin-top:22px; }

.faq-wrap{ display:grid; grid-template-columns:.85fr 1.15fr; gap:clamp(32px,5vw,64px); align-items:start; }
.faq-head{ position:sticky; top:130px; }
.faq-head h2{ margin:6px 0 16px; }

.blog-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.blog-card{ background:var(--white); border:1px solid var(--line); border-radius:var(--radius); overflow:hidden; display:flex; flex-direction:column; transition:.2s; }
.blog-card:hover{ transform:translateY(-4px); box-shadow:var(--shadow-card); }
.bc-thumb{ aspect-ratio:16/10; position:relative; display:flex; align-items:flex-end; padding:16px; }
.bc-kicker{ font-family:var(--mono); font-size:11px; letter-spacing:.1em; text-transform:uppercase; background:rgba(255,255,255,.92); color:var(--ink); padding:5px 10px; border-radius:2px; font-weight:600; }
.bc-body{ padding:22px; }
.bc-date{ font-family:var(--mono); font-size:11.5px; letter-spacing:.04em; color:var(--muted); }
.bc-body h4{ margin:10px 0 10px; line-height:1.2; }
.bc-body p{ color:var(--ink-soft); font-size:15px; margin:0; }

.cta-band{ background:var(--ink); color:#fff; padding-block:clamp(56px,7vw,104px); }
.cta-inner{ display:grid; grid-template-columns:1.2fr .8fr; gap:clamp(32px,5vw,64px); align-items:center; }
.cta-actions{ display:flex; flex-direction:column; gap:14px; align-items:flex-start; }
.cta-actions .btn{ width:100%; justify-content:center; }
.cta-mini{ font-size:11.5px; color:var(--muted-paper); letter-spacing:.04em; margin-top:8px; }

@media (max-width:980px){
  .hero-grid{ grid-template-columns:1fr; }
  .hero-form{ max-width:520px; }
  .bento{ grid-template-columns:repeat(2,1fr); }
  .steps{ grid-template-columns:repeat(2,1fr); gap:32px 0; }
  .step:nth-child(3){ border-left:0; padding-left:0; }
  .spec-cols{ grid-template-columns:repeat(2,1fr); }
  .sustain{ grid-template-columns:1fr; }
  .seo-block{ grid-template-columns:1fr; }
  .seo-toc{ position:static; }
  .faq-wrap{ grid-template-columns:1fr; }
  .faq-head{ position:static; }
  .blog-grid{ grid-template-columns:1fr; }
  .cta-inner{ grid-template-columns:1fr; }
  .sec-head{ grid-template-columns:1fr; gap:16px; margin-bottom:36px; }
}
@media (max-width:600px){
  .bento{ grid-template-columns:1fr; }
  .steps{ grid-template-columns:1fr; }
  .step{ border-left:0; padding-left:0; padding-bottom:6px; }
  .spec-cols{ grid-template-columns:1fr; }
  .hero-specs{ gap:18px; flex-wrap:wrap; }
}

/* ---------- shop.html ---------- */
.shop-hero-grid{ display:grid; grid-template-columns:1.4fr .9fr; gap:40px; align-items:end; }
.shop-hero-stats{ display:flex; gap:30px; justify-content:flex-end; }
.shop-hero-stats b{ font-family:var(--display); font-weight:900; font-size:clamp(1.8rem,1.2rem+1.6vw,2.6rem); color:#fff; letter-spacing:-.03em; line-height:1; }
.shop-hero-stats b i{ font-style:normal; color:var(--yellow); }
.shop-hero-stats span{ display:block; font-family:var(--mono); font-size:11px; letter-spacing:.05em; text-transform:uppercase; color:var(--muted-paper); margin-top:7px; }
.shop-toolbar{ display:flex; justify-content:space-between; align-items:center; gap:20px; flex-wrap:wrap; margin-bottom:26px; padding-bottom:22px; border-bottom:1px solid var(--line); }
.filter-chips{ display:flex; gap:9px; flex-wrap:wrap; }
.chip{ font-family:var(--mono); font-size:12.5px; letter-spacing:.03em; padding:9px 16px; border:1px solid var(--line-strong); border-radius:100px; background:transparent; color:var(--ink-soft); transition:.18s; }
.chip:hover{ border-color:var(--ink); color:var(--ink); }
.chip.on{ background:var(--ink); color:var(--white); border-color:var(--ink); }
.shop-count{ font-family:var(--mono); font-size:13px; color:var(--muted); white-space:nowrap; }
@media (max-width:860px){ .shop-hero-grid{ grid-template-columns:1fr; gap:28px; } .shop-hero-stats{ justify-content:flex-start; gap:24px; } }

/* ---------- product.html ---------- */
.crumb-bar{ background:var(--yellow); padding-block:13px; }
.crumb-bar .breadcrumb{ color:var(--ink); } .crumb-bar .breadcrumb a:hover{ color:var(--kraft-deep); } .crumb-bar .sep{ color:var(--kraft-deep); }

.pdp{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(28px,4vw,56px); align-items:start; }
.pdp-main{ aspect-ratio:1/1; background:var(--paper-3); border:1px solid var(--line); border-radius:var(--radius); overflow:hidden; position:relative; }
.pdp-main img{ width:100%; height:100%; object-fit:cover; }
.pdp-thumbs{ display:grid; grid-template-columns:repeat(4,1fr); gap:10px; margin-top:12px; }
.pthumb{ aspect-ratio:1/1; border:1px solid var(--line); border-radius:var(--radius); background:var(--paper-3); overflow:hidden; padding:0; position:relative; cursor:pointer; }
.pthumb.on{ border-color:var(--ink); } .pthumb img{ width:100%; height:100%; object-fit:cover; } .pthumb .img-fallback span{ font-size:8px; }
.pay-row{ display:flex; align-items:center; gap:12px; margin-top:18px; font-size:12px; color:var(--muted); flex-wrap:wrap; }
.pay-row i{ font-size:24px; color:var(--ink-soft); }
.badge-guar{ margin-left:auto; display:inline-flex; align-items:center; gap:6px; font-family:var(--mono); font-size:11px; color:var(--kraft-deep); } .badge-guar i{ font-size:16px; }

.pdp-info h1{ font-size:clamp(1.9rem,1.3rem+2vw,2.9rem); margin-top:6px; }
.pdp-meta-row{ display:flex; align-items:center; gap:18px; flex-wrap:wrap; margin:16px 0; font-size:13px; }
.stock{ display:inline-flex; align-items:center; gap:6px; background:#e9f6ee; color:#1f7a45; padding:5px 11px; border-radius:100px; font-family:var(--mono); font-size:12px; } .stock i{ font-size:15px; }
.rating{ display:inline-flex; align-items:center; gap:2px; color:var(--yellow-deep); font-size:14px; } .rating .muted{ margin-left:6px; }
.pdp-price{ font-family:var(--display); font-weight:900; font-size:2.2rem; letter-spacing:-.03em; color:var(--ink); margin:8px 0 16px; }
.pdp-price s{ color:var(--muted); font-weight:400; font-size:1.3rem; margin-left:8px; }
.pdp-price .q{ font-family:var(--mono); font-size:.8rem; color:var(--muted); font-weight:400; letter-spacing:.02em; display:block; margin-top:4px; }
.pdp-lead{ color:var(--ink-soft); max-width:54ch; }
.pdp-quote-btn{ margin:22px 0 16px; }
.pdp-cart-row{ display:flex; align-items:center; gap:12px; flex-wrap:wrap; padding:14px 0; border-top:1px dashed var(--line); border-bottom:1px dashed var(--line); }
.qty{ display:flex; align-items:center; border:1px solid var(--line-strong); border-radius:var(--radius); overflow:hidden; }
.qty button{ width:38px; height:42px; background:var(--paper-2); border:0; font-size:18px; color:var(--ink); }
.qty input{ width:54px; height:42px; border:0; text-align:center; font-family:var(--mono); font-size:15px; border-inline:1px solid var(--line); }
.btn-cart-mini{ display:inline-flex; align-items:center; gap:8px; background:transparent; border:1px solid var(--line-strong); color:var(--ink-soft); border-radius:var(--radius); padding:11px 16px; font-size:13.5px; font-weight:600; transition:.18s; }
.btn-cart-mini:hover{ border-color:var(--ink); color:var(--ink); }
.cart-hint{ font-family:var(--mono); font-size:11px; color:var(--muted); flex:1; min-width:140px; }
.pdp-assure{ list-style:none; margin:22px 0 0; padding:22px 0 0; border-top:1px solid var(--line); display:grid; grid-template-columns:1fr 1fr; gap:18px; }
.pdp-assure li{ display:flex; gap:12px; align-items:flex-start; } .pdp-assure i{ font-size:28px; color:var(--kraft-deep); }
.pdp-assure b{ display:block; font-size:14.5px; } .pdp-assure span{ font-size:13px; color:var(--muted); }

.quote-band{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(28px,4vw,56px); align-items:center; }
.quote-band-copy h2{ font-size:clamp(1.9rem,1.3rem+2vw,3rem); }
.quote-points{ list-style:none; margin:22px 0 0; padding:0; display:grid; gap:11px; }
.quote-points li{ display:flex; gap:11px; align-items:center; font-weight:500; color:var(--paper); }
.quote-points i{ color:var(--ink); background:var(--yellow); border-radius:50%; width:22px; height:22px; display:grid; place-items:center; font-size:12px; flex-shrink:0; }
#quote .quote-card{ background:var(--white); }

.tabs{ display:flex; gap:8px; flex-wrap:wrap; }
.tab{ font-family:var(--display); font-weight:700; font-size:14.5px; padding:13px 22px; border:1px solid var(--line); border-bottom:0; border-radius:var(--radius) var(--radius) 0 0; background:transparent; color:var(--ink-soft); }
.tab.on{ background:var(--white); color:var(--ink); }
.tab-panel{ display:none; background:var(--white); border:1px solid var(--line); border-radius:0 var(--radius) var(--radius) var(--radius); padding:clamp(20px,3vw,36px); }
.tab-panel.on{ display:block; }
.spec-table{ width:100%; border-collapse:collapse; }
.spec-table th,.spec-table td{ text-align:left; padding:14px 16px; border-bottom:1px solid var(--line); vertical-align:top; font-size:15px; }
.spec-table th{ font-family:var(--mono); font-weight:500; font-size:12.5px; letter-spacing:.03em; text-transform:uppercase; color:var(--ink); width:32%; background:var(--paper-3); }
.spec-table tr:last-child th,.spec-table tr:last-child td{ border-bottom:0; }
.rich h3{ margin:24px 0 10px; } .rich h3:first-child{ margin-top:0; } .rich p{ color:var(--ink-soft); max-width:72ch; }

.feat-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
.feat{ background:var(--white); border:1px solid var(--line); border-radius:var(--radius); padding:28px 24px; }
.feat i{ font-size:34px; color:var(--kraft-deep); } .feat h4{ margin:16px 0 9px; } .feat p{ color:var(--ink-soft); font-size:15px; margin:0; }

.custom-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:20px; }
.custom-col h5{ font-family:var(--mono); font-weight:500; font-size:12px; letter-spacing:.12em; text-transform:uppercase; color:var(--kraft-deep); margin:0 0 16px; padding-bottom:12px; border-bottom:1px solid var(--line); }
.opt-chips{ display:flex; flex-wrap:wrap; gap:8px; }
.opt-chips span{ font-family:var(--mono); font-size:12px; padding:7px 12px; border:1px solid var(--line-strong); border-radius:100px; color:var(--ink-soft); }

.usecases{ display:grid; grid-template-columns:repeat(4,1fr); gap:14px; }
.uc{ display:flex; align-items:center; gap:12px; background:var(--white); border:1px solid var(--line); border-radius:var(--radius); padding:18px 20px; font-weight:600; font-size:15px; }
.uc i{ font-size:26px; color:var(--kraft-deep); }

.rev-summary{ display:flex; align-items:center; gap:12px; justify-self:end; }
.rev-score{ font-family:var(--display); font-weight:900; font-size:2.4rem; letter-spacing:-.03em; line-height:1; }
.rev-stars{ color:var(--yellow-deep); font-size:15px; }
.reviews{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
.review{ background:var(--white); border:1px solid var(--line); border-radius:var(--radius); padding:28px; margin:0; }
.r-stars{ color:var(--yellow-deep); font-size:15px; margin-bottom:14px; }
.review blockquote{ margin:0 0 18px; font-size:16px; line-height:1.5; color:var(--ink); border:0; padding:0; font-family:var(--body); font-weight:500; }
.review figcaption b{ display:block; } .review figcaption span{ font-size:13px; color:var(--muted); font-family:var(--mono); }

.faq-wrap-product{ display:grid; grid-template-columns:.7fr 1.3fr; gap:clamp(28px,5vw,56px); align-items:start; }

.benefits-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:22px; }
.bf{ display:flex; gap:14px; align-items:center; } .bf i{ font-size:34px; color:var(--yellow); }
.bf b{ display:block; color:#fff; font-family:var(--display); font-size:16px; } .bf span{ font-size:13px; color:var(--muted-paper); font-family:var(--mono); }

@media (max-width:980px){
  .feat-grid{ grid-template-columns:repeat(2,1fr); }
  .custom-grid{ grid-template-columns:repeat(2,1fr); }
  .usecases{ grid-template-columns:repeat(2,1fr); }
  .reviews{ grid-template-columns:1fr; }
  .faq-wrap-product{ grid-template-columns:1fr; }
}
@media (max-width:860px){
  .pdp{ grid-template-columns:1fr; }
  .pdp-assure{ grid-template-columns:1fr; }
  .quote-band{ grid-template-columns:1fr; }
  .benefits-grid{ grid-template-columns:1fr 1fr; gap:18px; }
  .sec-head{ grid-template-columns:1fr; }
  .rev-summary{ justify-self:start; }
}
@media (max-width:560px){
  .feat-grid,.custom-grid,.usecases,.benefits-grid{ grid-template-columns:1fr; }
}

/* ---------- about.html ---------- */
.about-hero{ display:grid; grid-template-columns:1.5fr 1fr; gap:40px; align-items:end; }
.story{ display:grid; grid-template-columns:1fr 1.1fr; gap:clamp(28px,5vw,64px); align-items:center; }
.story-media{ background:linear-gradient(150deg,var(--kraft-deep),var(--kraft)); border-radius:var(--radius); min-height:380px; display:flex; align-items:center; padding:clamp(28px,4vw,52px); }
.story-quote i{ font-size:46px; color:rgba(255,255,255,.55); }
.story-quote p{ font-family:var(--display); font-weight:800; font-size:clamp(1.3rem,1rem+1.2vw,1.9rem); line-height:1.25; color:#fff; letter-spacing:-.02em; margin:16px 0 18px; }
.story-quote span{ color:rgba(255,255,255,.8); font-size:13px; }
.story-copy p{ color:var(--ink-soft); max-width:60ch; }
.values{ display:grid; grid-template-columns:repeat(2,1fr); gap:1px; background:var(--line); border:1px solid var(--line); }
.value{ background:var(--paper-2); padding:34px; }
.v-num{ font-family:var(--mono); font-weight:600; color:var(--kraft-deep); font-size:14px; }
.value h4{ margin:14px 0 10px; }
.value p{ color:var(--ink-soft); font-size:15.5px; margin:0; }
@media (max-width:860px){
  .about-hero{ grid-template-columns:1fr; gap:24px; }
  .story{ grid-template-columns:1fr; }
  .values{ grid-template-columns:1fr; }
}

/* ---------- contact.html ---------- */
.contact-grid{ display:grid; grid-template-columns:1.4fr .85fr; gap:clamp(28px,4vw,48px); align-items:start; }
.contact-side{ display:grid; gap:18px; position:sticky; top:130px; }
.ci-card{ background:var(--ink); color:var(--paper); border-radius:var(--radius); padding:30px; }
.ci-card h3{ color:#fff; margin-bottom:20px; }
.ci-list{ list-style:none; margin:0; padding:0; display:grid; gap:18px; }
.ci-list li{ display:flex; gap:14px; align-items:flex-start; }
.ci-list i{ font-size:26px; color:var(--yellow); margin-top:2px; }
.ci-list span{ display:block; font-family:var(--mono); font-size:11px; letter-spacing:.08em; text-transform:uppercase; color:var(--muted-paper); margin-bottom:3px; }
.ci-list a,.ci-list address{ color:#fff; font-style:normal; font-size:15.5px; font-weight:500; }
.ci-list a:hover{ color:var(--yellow); }
.map-card{ position:relative; height:200px; border-radius:var(--radius); overflow:hidden; border:1px solid var(--line); background:var(--paper-2); display:flex; align-items:center; justify-content:center; }
.map-grid{ position:absolute; inset:0; background-image:linear-gradient(var(--line) 1px,transparent 1px),linear-gradient(90deg,var(--line) 1px,transparent 1px); background-size:28px 28px; }
.map-pin{ position:relative; width:54px; height:54px; border-radius:50%; background:var(--yellow); display:grid; place-items:center; font-size:26px; color:var(--ink); box-shadow:0 10px 24px -8px rgba(21,24,47,.4); }
.map-label{ position:absolute; bottom:12px; left:12px; background:var(--ink); color:var(--paper); font-size:11px; padding:6px 11px; border-radius:3px; }
.benefits-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:22px; }
.bf{ display:flex; gap:14px; align-items:center; }
.bf i{ font-size:34px; color:var(--yellow); }
.bf b{ display:block; color:#fff; font-family:var(--display); font-size:16px; }
.bf span{ font-size:13px; color:var(--muted-paper); font-family:var(--mono); }
@media (max-width:860px){
  .contact-grid{ grid-template-columns:1fr; }
  .contact-side{ position:static; }
  .benefits-grid{ grid-template-columns:1fr 1fr; gap:18px; }
}
@media (max-width:560px){ .benefits-grid{ grid-template-columns:1fr; } }

/* ---------- blog.html ---------- */
.article-head{ max-width:880px; }
.art-tag{ display:inline-block; background:var(--yellow); color:var(--ink); font-size:11px; letter-spacing:.1em; text-transform:uppercase; padding:6px 12px; border-radius:3px; margin:18px 0 16px; font-weight:600; }
.article-head h1{ font-size:clamp(2rem,1.3rem+2.6vw,3.4rem); max-width:18ch; }
.art-meta{ display:flex; align-items:center; gap:22px; margin-top:22px; flex-wrap:wrap; font-size:14px; }
.am-author{ display:inline-flex; align-items:center; gap:10px; color:#fff; font-weight:600; }
.am-avatar{ width:34px; height:34px; border-radius:50%; background:var(--ink); border:1.5px solid var(--yellow); color:var(--yellow); display:grid; place-items:center; font-family:var(--display); font-weight:900; font-size:13px; }
.art-meta .muted{ color:var(--muted-paper); }
.art-feature{ margin-top:-44px; margin-bottom:8px; aspect-ratio:21/8; border-radius:var(--radius); position:relative; display:flex; align-items:flex-end; padding:18px; border:1px solid var(--line); }
.af-cap{ background:rgba(255,255,255,.9); color:var(--ink); font-size:11px; padding:6px 11px; border-radius:3px; display:inline-flex; align-items:center; gap:7px; }

.art-layout{ display:grid; grid-template-columns:230px 1fr; gap:clamp(28px,5vw,64px); align-items:start; padding-block:clamp(40px,5vw,72px); }
.art-toc{ position:sticky; top:130px; }
.toc-label{ font-size:11px; letter-spacing:.12em; text-transform:uppercase; color:var(--muted); display:block; margin-bottom:14px; }
.art-toc ul{ list-style:none; margin:0 0 28px; padding:0; display:grid; gap:2px; }
.art-toc a{ display:block; padding:9px 14px; border-left:2px solid var(--line); color:var(--ink-soft); font-size:14px; transition:.2s; }
.art-toc a:hover{ border-color:var(--yellow); color:var(--ink); }
.share-row{ display:flex; gap:8px; }
.share-row a{ width:38px; height:38px; border:1px solid var(--line-strong); border-radius:var(--radius); display:grid; place-items:center; font-size:16px; transition:.2s; }
.share-row a:hover{ background:var(--ink); color:#fff; border-color:var(--ink); }

.art-body{ max-width:72ch; }
.art-lead{ font-size:clamp(1.15rem,1rem+.5vw,1.4rem); line-height:1.55; color:var(--ink); font-weight:500; }
.art-body h2{ font-size:clamp(1.5rem,1.1rem+1.4vw,2.1rem); margin:42px 0 14px; }
.art-body p{ color:var(--ink-soft); }
.art-body ul{ margin:0 0 1.2em; padding-left:0; list-style:none; display:grid; gap:11px; }
.art-body ul li{ position:relative; padding-left:30px; color:var(--ink-soft); }
.art-body ul li::before{ content:""; position:absolute; left:0; top:11px; width:14px; height:2px; background:var(--yellow); }
blockquote{ margin:32px 0; padding:6px 0 6px 28px; border-left:4px solid var(--yellow); font-family:var(--display); font-weight:700; font-size:clamp(1.25rem,1rem+1vw,1.6rem); line-height:1.3; color:var(--ink); letter-spacing:-.01em; }
.art-cta{ margin-top:44px; background:var(--paper-2); border:1px solid var(--line); border-radius:var(--radius); padding:30px; display:flex; align-items:center; justify-content:space-between; gap:24px; flex-wrap:wrap; }
.art-cta h3{ margin-bottom:6px; } .art-cta p{ margin:0; color:var(--ink-soft); font-size:15px; }

@media (max-width:860px){
  .art-layout{ grid-template-columns:1fr; }
  .art-toc{ position:static; display:none; }
  .art-feature{ margin-top:-28px; aspect-ratio:16/9; }
}

/* ---------- thank-you.html ---------- */
.ty{ padding-block:clamp(64px,8vw,120px); text-align:center; }
.ty-inner{ max-width:760px; display:flex; flex-direction:column; align-items:center; }
.ty-check{ width:86px; height:86px; border-radius:50%; background:var(--yellow); color:var(--ink); display:grid; place-items:center; font-size:42px; margin-bottom:26px; }
.ty-steps{ display:grid; grid-template-columns:repeat(3,1fr); gap:0; margin:48px 0; width:100%; text-align:left; }
.ty-step{ padding:0 26px; border-left:1px solid var(--line); } .ty-step:first-child{ border-left:0; padding-left:0; }
.ty-step .step-num{ font-family:var(--mono); font-weight:600; font-size:13px; color:var(--ink); background:var(--yellow); padding:5px 10px; border-radius:2px; display:inline-block; margin-bottom:14px; }
.ty-step h4{ margin:0 0 8px; } .ty-step p{ color:var(--ink-soft); font-size:14.5px; margin:0; }
.ty-cta{ display:flex; gap:14px; flex-wrap:wrap; justify-content:center; }
.ty-contact{ display:flex; gap:22px; align-items:center; flex-wrap:wrap; justify-content:center; margin-top:34px; font-size:14.5px; }
.ty-contact .mono{ font-size:12px; color:var(--muted); letter-spacing:.05em; text-transform:uppercase; }
.ty-contact a{ display:inline-flex; align-items:center; gap:8px; font-weight:600; }
.ty-contact a:hover{ color:var(--kraft-deep); }
@media (max-width:680px){
  .ty-steps{ grid-template-columns:1fr; gap:24px; }
  .ty-step{ border-left:0; padding-left:0; }
}


/* ---------- WordPress nav-menu compatibility ---------- */
.mainnav ul, .drawer nav ul { list-style:none; margin:0; padding:0; display:contents; }
.mainnav li { list-style:none; }
.mainnav li > a { font-weight:600; font-size:15.5px; color:var(--ink); position:relative; padding-block:6px; }
.mainnav li > a::after { content:""; position:absolute; left:0; bottom:0; width:0; height:2px; background:var(--yellow); transition:width .22s ease; }
.mainnav li:hover > a::after, .mainnav li.current-menu-item > a::after, .mainnav li.current_page_item > a::after { width:100%; }
.drawer nav li { list-style:none; }
.drawer nav li > a { display:block; font-family:var(--display); font-weight:700; font-size:21px; padding:15px 0; border-bottom:1px solid var(--line); color:var(--ink); }
.page-content > * { max-width:none; }
.page-content h2 { margin:28px 0 12px; }
.page-content h3 { margin:24px 0 10px; }
.page-content p, .page-content li { color:var(--ink-soft); }
.page-content ul, .page-content ol { padding-left:20px; margin:0 0 1.2em; }
