/* ============================================================================
   Smart Power Automation — site styles
   Design system extracted from the approved demo (steel + safety-amber).
   Vanilla CSS, no framework. Fonts can be self-hosted (see /assets/fonts).
   ============================================================================ */
:root{
  /* Steel + safety-amber industrial palette */
  --ink:#0B1220;          /* steel near-black */
  --steel:#131C2E;        /* dark surface */
  --steel-2:#1C2942;      /* raised dark surface */
  --amber:#FFB000;        /* hazard / safety amber */
  --amber-dark:#E09600;
  --paper:#F6F7F9;        /* light section bg */
  --card:#FFFFFF;
  --line:#E3E7EE;
  --muted:#5C6B82;
  --body:#27324A;
  --on-dark:#E8EDF6;
  --on-dark-mute:#9CABC4;
  /* type */
  --display:'Space Grotesk',system-ui,sans-serif;
  --text:'Inter',system-ui,-apple-system,sans-serif;
  --fs-h1:clamp(2.1rem,5.2vw,3.7rem);
  --fs-h2:clamp(1.7rem,3.4vw,2.6rem);
  --fs-h3:1.3rem;
  --maxw:1180px;
  --r:14px; --r-lg:22px;
  --t:.22s ease;
  --sh:0 10px 30px rgba(11,18,32,.10);
  --sh-lg:0 24px 60px rgba(11,18,32,.18);
  color-scheme:light;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}*{animation:none!important;transition:none!important}}
body{font-family:var(--text);color:var(--body);background:var(--card);line-height:1.6;font-size:1.02rem;-webkit-font-smoothing:antialiased}
h1,h2,h3,h4{font-family:var(--display);color:var(--ink);line-height:1.12;letter-spacing:-.01em;font-weight:700}
a{color:inherit;text-decoration:none}
img,svg{display:block;max-width:100%}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 22px}
.eyebrow{font-family:var(--display);font-weight:600;font-size:.82rem;letter-spacing:.16em;text-transform:uppercase;color:var(--amber-dark)}
.section{padding:clamp(3.4rem,7vw,6rem) 0}
:focus-visible{outline:3px solid var(--amber);outline-offset:2px;border-radius:6px}

/* hazard-stripe signature divider */
.hazard{height:10px;background:repeating-linear-gradient(135deg,var(--amber) 0 18px,var(--ink) 18px 36px)}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:.5rem;font-family:var(--display);font-weight:600;font-size:1rem;
  padding:.85rem 1.5rem;border-radius:999px;border:2px solid transparent;cursor:pointer;transition:var(--t);min-height:48px}
.btn-amber{background:var(--amber);color:var(--ink);box-shadow:0 6px 20px rgba(255,176,0,.35)}
.btn-amber:hover{background:var(--amber-dark);transform:translateY(-2px)}
.btn-ghost{background:transparent;color:var(--on-dark);border-color:rgba(255,255,255,.28)}
.btn-ghost:hover{border-color:var(--amber);color:var(--amber)}
.btn-dark{background:var(--ink);color:#fff}
.btn-dark:hover{background:var(--steel-2);transform:translateY(-2px)}

/* ---------- top utility bar ---------- */
.utility{background:var(--ink);color:var(--on-dark-mute);font-size:.86rem}
.utility .wrap{display:flex;justify-content:space-between;align-items:center;gap:1rem;padding-block:.5rem;flex-wrap:wrap}
.utility a{color:var(--on-dark-mute);transition:var(--t)}
.utility a:hover{color:var(--amber)}
.utility .tf{color:var(--on-dark);font-weight:600}
.utility .tf b{color:var(--amber)}
.usoc{display:flex;gap:.4rem}
.usoc a{width:30px;height:30px;display:grid;place-items:center;border:1px solid rgba(255,255,255,.16);border-radius:8px}
.usoc a:hover{border-color:var(--amber);background:rgba(255,176,0,.12)}

/* ---------- header ---------- */
.header{position:sticky;top:0;z-index:60;background:rgba(255,255,255,.92);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.header .wrap{display:flex;align-items:center;gap:1.2rem;padding-block:.7rem}
.brand{display:flex;align-items:center;gap:.65rem;font-family:var(--display);font-weight:700;font-size:1.22rem;color:var(--ink);letter-spacing:-.02em}
.brand .mark{width:40px;height:40px;flex:0 0 40px}
.brand span b{color:var(--amber-dark)}
.brand small{display:block;font-family:var(--text);font-weight:500;font-size:.62rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-top:1px}
.nav{margin-left:auto;display:flex;gap:1.5rem;align-items:center}
.nav a{font-weight:500;font-size:.97rem;color:var(--body);transition:var(--t)}
.nav a:hover{color:var(--amber-dark)}
.header .btn{padding:.6rem 1.15rem;min-height:42px;font-size:.93rem}
.burger{display:none;margin-left:auto;background:none;border:1px solid var(--line);border-radius:10px;width:46px;height:46px;cursor:pointer}
.burger span{display:block;width:20px;height:2px;background:var(--ink);margin:4px auto;transition:var(--t)}
@media(max-width:960px){
  .nav{position:fixed;inset:64px 0 auto 0;flex-direction:column;align-items:stretch;gap:0;background:#fff;
    border-bottom:1px solid var(--line);padding:.5rem 22px 1rem;box-shadow:var(--sh);transform:translateY(-130%);transition:transform .28s ease;margin-left:0}
  .nav.open{transform:translateY(0)}
  .nav a{padding:.85rem 0;border-bottom:1px solid var(--line)}
  .nav .btn{margin-top:.7rem;justify-content:center}
  .burger{display:block}
  .header .wrap>.btn{display:none}
}

/* ---------- hero ---------- */
.hero{position:relative;background:radial-gradient(120% 120% at 80% -10%,#1C2942 0%,var(--ink) 55%);color:var(--on-dark);overflow:hidden}
.hero::before{content:"";position:absolute;inset:0;background:
  repeating-linear-gradient(0deg,rgba(255,255,255,.03) 0 1px,transparent 1px 44px),
  repeating-linear-gradient(90deg,rgba(255,255,255,.03) 0 1px,transparent 1px 44px);
  -webkit-mask-image:radial-gradient(120% 90% at 70% 30%,#000,transparent 75%);mask-image:radial-gradient(120% 90% at 70% 30%,#000,transparent 75%)}
.hero .wrap{position:relative;display:grid;grid-template-columns:1.05fr .95fr;gap:2.4rem;align-items:center;padding-block:clamp(3rem,6vw,5rem)}
.hero h1{color:#fff;font-size:var(--fs-h1);max-width:14ch}
.hero h1 em{color:var(--amber);font-style:normal}
.hero p.lede{color:var(--on-dark-mute);font-size:1.15rem;max-width:46ch;margin:1.1rem 0 1.7rem}
.hero-cta{display:flex;gap:.8rem;flex-wrap:wrap}
.hero-trust{display:flex;gap:1.8rem;margin-top:2.2rem;flex-wrap:wrap}
.hero-trust .n{font-family:var(--display);font-weight:700;font-size:1.7rem;color:#fff;line-height:1}
.hero-trust .n b{color:var(--amber)}
.hero-trust .l{font-size:.83rem;color:var(--on-dark-mute);margin-top:.25rem}
.hero-since{display:inline-flex;align-items:center;gap:.5rem;background:rgba(255,176,0,.12);border:1px solid rgba(255,176,0,.35);
  color:var(--amber);font-family:var(--display);font-weight:600;font-size:.8rem;letter-spacing:.08em;padding:.4rem .9rem;border-radius:999px;margin-bottom:1.2rem}

/* hero motion device: a sliding gate / scanning beam */
.device{position:relative;aspect-ratio:1/1;max-width:440px;margin-inline:auto;width:100%}
.device .ring{position:absolute;inset:0;border:1px dashed rgba(255,255,255,.16);border-radius:50%}
.device .ring.r2{inset:26px}
.gatebox{position:absolute;inset:14% 12%;border:2px solid rgba(255,255,255,.14);border-radius:18px;overflow:hidden;background:rgba(13,20,35,.5)}
.rail{position:absolute;left:8%;right:8%;top:50%;height:8px;background:repeating-linear-gradient(90deg,var(--amber) 0 12px,var(--ink) 12px 24px);border-radius:4px;transform:translateY(-50%);opacity:.85}
.slider{position:absolute;top:18%;bottom:18%;left:10%;width:34%;border-radius:8px;background:linear-gradient(180deg,#33425f,#1b2740);
  border:2px solid rgba(255,255,255,.18);box-shadow:inset 0 0 0 4px rgba(255,176,0,.12);animation:slide 5s ease-in-out infinite}
.slider::after{content:"";position:absolute;inset:6px;border-radius:4px;background:repeating-linear-gradient(135deg,rgba(255,176,0,.5) 0 8px,transparent 8px 16px)}
.beam{position:absolute;left:0;right:0;top:0;height:3px;background:linear-gradient(90deg,transparent,var(--amber),transparent);
  filter:drop-shadow(0 0 8px var(--amber));animation:scan 4s linear infinite}
@keyframes slide{0%,100%{left:10%}50%{left:52%}}
@keyframes scan{0%{top:6%}50%{top:92%}100%{top:6%}}
.device .chip{position:absolute;background:#fff;color:var(--ink);font-family:var(--display);font-weight:600;font-size:.78rem;
  padding:.4rem .7rem;border-radius:10px;box-shadow:var(--sh);display:flex;align-items:center;gap:.4rem}
.device .chip.c1{top:6%;right:0;animation:float 6s ease-in-out infinite}
.device .chip.c2{bottom:8%;left:-4%;animation:float 6s ease-in-out .8s infinite}
.device .chip .dot{width:8px;height:8px;border-radius:50%;background:#1faa59}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-9px)}}
@media(max-width:860px){.hero .wrap{grid-template-columns:1fr;gap:1.6rem}.device{max-width:340px}.hero-trust{gap:1.3rem}}

/* ---------- client strip ---------- */
.clients{background:var(--steel);color:var(--on-dark-mute);padding:1.4rem 0}
.clients .wrap{display:flex;align-items:center;gap:2rem;flex-wrap:wrap;justify-content:center}
.clients .lab{font-family:var(--display);font-size:.8rem;letter-spacing:.14em;text-transform:uppercase;color:var(--on-dark-mute)}
.clients .names{display:flex;gap:1.8rem;flex-wrap:wrap;justify-content:center}
.clients .names b{font-family:var(--display);font-weight:600;font-size:1.05rem;color:#fff;opacity:.85}

/* ---------- solutions grid ---------- */
.head-center{text-align:center;max-width:62ch;margin:0 auto 2.6rem}
.head-center h2{font-size:var(--fs-h2);margin:.5rem 0 .6rem}
.head-center p{color:var(--muted)}
.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.1rem}
@media(max-width:860px){.grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.grid{grid-template-columns:1fr}}
.scard{background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);padding:1.6rem;transition:var(--t);position:relative;overflow:hidden}
.scard::before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--amber);transform:scaleY(0);transform-origin:top;transition:var(--t)}
.scard:hover{transform:translateY(-4px);box-shadow:var(--sh);border-color:transparent}
.scard:hover::before{transform:scaleY(1)}
.scard .ico{width:54px;height:54px;border-radius:14px;background:var(--paper);display:grid;place-items:center;margin-bottom:1rem;color:var(--amber-dark)}
.scard:hover .ico{background:var(--ink);color:var(--amber)}
.scard h3{font-size:var(--fs-h3);margin-bottom:.45rem}
.scard ul{list-style:none;color:var(--muted);font-size:.93rem;margin-top:.6rem}
.scard ul li{padding:.18rem 0 .18rem 1.1rem;position:relative}
.scard ul li::before{content:"";position:absolute;left:0;top:.62em;width:6px;height:6px;background:var(--amber);border-radius:2px}
.scard .more{margin-top:.9rem;font-family:var(--display);font-weight:600;font-size:.9rem;color:var(--ink);display:inline-flex;gap:.35rem;align-items:center}
.scard:hover .more{color:var(--amber-dark)}

/* ---------- why ---------- */
.why{background:var(--paper)}
.why .grid4{display:grid;grid-template-columns:repeat(4,1fr);gap:1.1rem}
@media(max-width:860px){.why .grid4{grid-template-columns:repeat(2,1fr)}}
@media(max-width:480px){.why .grid4{grid-template-columns:1fr}}
.vcard{background:#fff;border-radius:var(--r);padding:1.5rem;border:1px solid var(--line)}
.vcard .ico{width:46px;height:46px;border-radius:12px;background:rgba(255,176,0,.14);color:var(--amber-dark);display:grid;place-items:center;margin-bottom:.9rem}
.vcard h3{font-size:1.1rem;margin-bottom:.35rem}
.vcard p{font-size:.93rem;color:var(--muted)}

/* ---------- process ---------- */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:1.1rem;counter-reset:s}
@media(max-width:860px){.steps{grid-template-columns:repeat(2,1fr)}}
@media(max-width:480px){.steps{grid-template-columns:1fr}}
.step{position:relative;padding:1.6rem 1.3rem;border:1px solid var(--line);border-radius:var(--r);background:#fff}
.step .num{font-family:var(--display);font-weight:700;font-size:2.2rem;color:var(--line);line-height:1}
.step:hover .num{color:var(--amber)}
.step h3{font-size:1.08rem;margin:.4rem 0 .35rem}
.step p{font-size:.92rem;color:var(--muted)}

/* ---------- testimonials ---------- */
.tgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.1rem}
@media(max-width:860px){.tgrid{grid-template-columns:1fr}}
.tcard{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:1.6rem;display:flex;flex-direction:column;gap:.9rem}
.tcard .stars{color:var(--amber);letter-spacing:2px;font-size:.95rem}
.tcard blockquote{font-size:.98rem;color:var(--body)}
.tcard .who{display:flex;align-items:center;gap:.7rem;margin-top:auto}
.tcard .av{width:42px;height:42px;border-radius:50%;background:var(--ink);color:var(--amber);display:grid;place-items:center;font-family:var(--display);font-weight:700;font-size:.95rem;flex:0 0 42px}
.tcard .who b{display:block;font-family:var(--display);font-size:.95rem;color:var(--ink)}
.tcard .who span{font-size:.82rem;color:var(--muted)}

/* ---------- faq ---------- */
.faq{background:var(--paper)}
.faqlist{max-width:820px;margin:0 auto;display:grid;gap:.7rem}
.faqlist details{background:#fff;border:1px solid var(--line);border-radius:var(--r);overflow:hidden}
.faqlist summary{cursor:pointer;list-style:none;padding:1.05rem 1.2rem;font-family:var(--display);font-weight:600;font-size:1.02rem;color:var(--ink);
  display:flex;justify-content:space-between;align-items:center;gap:1rem}
.faqlist summary::-webkit-details-marker{display:none}
.faqlist summary::after{content:"+";font-size:1.5rem;color:var(--amber-dark);transition:var(--t);line-height:1}
.faqlist details[open] summary::after{transform:rotate(45deg)}
.faqlist .a{padding:0 1.2rem 1.1rem;color:var(--muted);font-size:.96rem}

/* ---------- CTA / contact ---------- */
.contact{background:radial-gradient(120% 120% at 10% 0%,#1C2942,var(--ink) 60%);color:var(--on-dark)}
.contact .wrap{display:grid;grid-template-columns:1fr 1fr;gap:2.4rem;align-items:start}
@media(max-width:860px){.contact .wrap{grid-template-columns:1fr;gap:1.8rem}}
.contact h2{color:#fff;font-size:var(--fs-h2);margin-bottom:.7rem}
.contact .lede{color:var(--on-dark-mute);margin-bottom:1.5rem;max-width:44ch}
.cmeta{display:grid;gap:1rem;margin-top:1.6rem}
.cmeta a,.cmeta div{display:flex;gap:.8rem;align-items:flex-start;color:var(--on-dark)}
.cmeta .ico{width:42px;height:42px;flex:0 0 42px;border-radius:11px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);display:grid;place-items:center;color:var(--amber)}
.cmeta b{font-family:var(--display);display:block}
.cmeta span{color:var(--on-dark-mute);font-size:.9rem}
.cmeta a:hover b{color:var(--amber)}

.formcard{background:#fff;border-radius:var(--r-lg);padding:1.8rem;box-shadow:var(--sh-lg);color:var(--body)}
.formcard h3{font-size:1.3rem;margin-bottom:.3rem}
.formcard p.sub{color:var(--muted);font-size:.92rem;margin-bottom:1.2rem}
.field{margin-bottom:.9rem}
.field label{display:block;font-weight:600;font-size:.86rem;margin-bottom:.35rem;color:var(--ink)}
.field input,.field select,.field textarea{width:100%;padding:.8rem .9rem;border:1.5px solid var(--line);border-radius:10px;font:inherit;font-size:.97rem;transition:var(--t);background:#fff}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--amber);outline:none}
.field.two{display:grid;grid-template-columns:1fr 1fr;gap:.7rem}
@media(max-width:480px){.field.two{grid-template-columns:1fr}}
.formcard .btn{width:100%;justify-content:center;margin-top:.4rem}
.formcard .reassure{text-align:center;font-size:.82rem;color:var(--muted);margin-top:.8rem}
.hp{position:absolute;left:-9999px}
.form-ok{background:#ecfdf3;border:1px solid #b7ecc8;color:#10663a;border-radius:12px;padding:1rem;font-size:.95rem;display:none}
.form-ok.show{display:block}

/* ---------- footer ---------- */
.footer{background:var(--ink);color:var(--on-dark-mute);padding:3rem 0 1.4rem}
.fgrid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.2fr;gap:2rem}
@media(max-width:860px){.fgrid{grid-template-columns:1fr 1fr}}
@media(max-width:480px){.fgrid{grid-template-columns:1fr}}
.footer h4{color:#fff;font-size:1rem;margin-bottom:1rem}
.footer ul{list-style:none}
.footer li{margin-bottom:.55rem}
.footer a:hover{color:var(--amber)}
.footer .fbrand{font-family:var(--display);font-weight:700;font-size:1.25rem;color:#fff;display:flex;align-items:center;gap:.6rem;margin-bottom:.8rem}
.footer .fbrand .mark{width:36px;height:36px}
.fsoc{display:flex;gap:.5rem;margin-top:1rem}
.fsoc a{width:36px;height:36px;border:1px solid rgba(255,255,255,.16);border-radius:9px;display:grid;place-items:center}
.fsoc a:hover{border-color:var(--amber);background:rgba(255,176,0,.12)}
.fbar{border-top:1px solid rgba(255,255,255,.1);margin-top:2.2rem;padding-top:1.2rem;font-size:.85rem;display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap}

/* ---------- floating + sticky mobile ---------- */
.wa-float{position:fixed;right:18px;bottom:18px;z-index:80;width:58px;height:58px;border-radius:50%;background:#25D366;
  display:grid;place-items:center;box-shadow:0 8px 24px rgba(37,211,102,.45);transition:var(--t)}
.wa-float:hover{transform:scale(1.06)}
.mbar{position:fixed;left:0;right:0;bottom:0;z-index:80;display:none;grid-template-columns:1fr 1fr;background:#fff;border-top:1px solid var(--line);box-shadow:0 -6px 20px rgba(11,18,32,.12)}
.mbar a{padding:.95rem;text-align:center;font-family:var(--display);font-weight:600;font-size:.95rem;display:flex;align-items:center;justify-content:center;gap:.4rem}
.mbar a.call{color:var(--ink)}
.mbar a.quote{background:var(--amber);color:var(--ink)}
@media(max-width:768px){
  .mbar{display:grid}
  .wa-float{bottom:74px}
  body{padding-bottom:58px}
}

/* ============================================================================
   Catalog page components (category / sub-category / product) — same tokens
   ============================================================================ */

/* breadcrumbs */
.crumbs{background:var(--paper);border-bottom:1px solid var(--line)}
.crumbs .wrap{display:flex;flex-wrap:wrap;gap:.4rem;align-items:center;padding:.7rem 22px;font-size:.88rem;color:var(--muted)}
.crumbs a{color:var(--muted)}
.crumbs a:hover{color:var(--amber-dark)}
.crumbs .sep{opacity:.5}
.crumbs [aria-current]{color:var(--ink);font-weight:600}

/* page hero (interior) */
.phero{background:var(--ink);color:var(--on-dark)}
.phero .wrap{padding:clamp(2.2rem,5vw,3.6rem) 22px;display:grid;grid-template-columns:1.3fr .7fr;gap:2rem;align-items:center}
.phero h1{color:#fff;font-size:clamp(1.8rem,4vw,2.8rem)}
.phero p{color:var(--on-dark-mute);margin-top:.7rem;max-width:60ch}
.phero .pimg{border-radius:var(--r-lg);overflow:hidden;border:1px solid rgba(255,255,255,.12);box-shadow:var(--sh-lg)}
.phero .pimg img{width:100%;height:100%;object-fit:cover;aspect-ratio:4/3}
@media(max-width:820px){.phero .wrap{grid-template-columns:1fr}.phero .pimg{display:none}}

/* answer-first AEO blocks */
.answer{background:var(--card);border:1px solid var(--line);border-left:4px solid var(--amber);
  border-radius:var(--r);padding:1.1rem 1.3rem;box-shadow:var(--sh);margin:1.4rem 0}
.answer .lab{font-family:var(--display);font-weight:600;font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;color:var(--amber-dark)}
.answer p{margin-top:.35rem;color:var(--ink);font-size:1.05rem}
.takeaways{margin:1.4rem 0;padding-left:0;list-style:none;display:grid;gap:.55rem}
.takeaways li{display:flex;gap:.6rem;align-items:flex-start}
.takeaways li::before{content:"";flex:0 0 18px;height:18px;margin-top:.2rem;border-radius:50%;
  background:var(--amber);-webkit-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%23000' d='M9 16.2 4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4z'/%3E%3C/svg%3E") center/contain no-repeat;
  mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%23000' d='M9 16.2 4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4z'/%3E%3C/svg%3E") center/contain no-repeat}
.facts{width:100%;border-collapse:collapse;margin:1rem 0;font-size:.96rem}
.facts th,.facts td{text-align:left;padding:.6rem .8rem;border-bottom:1px solid var(--line);vertical-align:top}
.facts th{width:38%;color:var(--muted);font-weight:600}

/* generic card grids */
.cardgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:1.1rem;margin-top:1.6rem}
.tile{display:flex;flex-direction:column;background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);
  overflow:hidden;box-shadow:var(--sh);transition:var(--t)}
.tile:hover{transform:translateY(-4px);box-shadow:var(--sh-lg);border-color:var(--amber)}
.tile .thumb{aspect-ratio:4/3;background:var(--paper);overflow:hidden}
.tile .thumb img{width:100%;height:100%;object-fit:cover}
.tile .body{padding:1rem 1.1rem;display:flex;flex-direction:column;gap:.4rem;flex:1}
.tile h3{font-size:1.12rem}
.tile p{color:var(--muted);font-size:.92rem}
.tile .more{margin-top:auto;font-family:var(--display);font-weight:600;color:var(--amber-dark);font-size:.9rem}

/* product layout */
.pwrap{display:grid;grid-template-columns:1fr 1fr;gap:2.2rem;align-items:start}
@media(max-width:820px){.pwrap{grid-template-columns:1fr}}
.gallery .main{border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;background:var(--paper)}
.gallery .main img{width:100%;height:100%;object-fit:contain;aspect-ratio:1/1;background:#fff}
.gallery .thumbs{display:flex;gap:.5rem;margin-top:.6rem;flex-wrap:wrap}
.gallery .thumbs button{width:64px;height:64px;border:1px solid var(--line);border-radius:10px;overflow:hidden;background:#fff;cursor:pointer;padding:0}
.gallery .thumbs button[aria-current="true"]{border-color:var(--amber);outline:2px solid var(--amber)}
.gallery .thumbs img{width:100%;height:100%;object-fit:cover}
.pinfo h1{font-size:clamp(1.5rem,3.4vw,2.2rem)}
.pinfo .sku{color:var(--muted);font-size:.85rem;margin-top:.3rem}
.prose{color:var(--body);line-height:1.7}
.prose h2,.prose h3{margin:1.4rem 0 .6rem}
.prose ul,.prose ol{margin:.6rem 0 .6rem 1.3rem}
.prose li{margin:.3rem 0}
.prose a{color:var(--amber-dark);text-decoration:underline}
.prose table{width:100%;border-collapse:collapse;margin:1rem 0}
.prose th,.prose td{border:1px solid var(--line);padding:.5rem .7rem;text-align:left}
.brochure{display:inline-flex;align-items:center;gap:.5rem;margin-top:1rem}

/* downloads / share row */
.section.tight{padding:clamp(2rem,4vw,3rem) 0}
