/* ===================================================================
   Box One — full rebuild
   Type: Syne (display) / Plus Jakarta Sans (body)
   Colour: copper (logo) + periwinkle (storefront) over ink + paper
=================================================================== */

:root{
  --ink:#16120D;
  --ink-2:#241E16;
  --paper:#F5F1E8;
  --paper-2:#ECE4D4;
  --copper:#B0723A;
  --copper-light:#D29A5C;
  --copper-deep:#7C4C24;
  --blue:#8FB1D4;
  --blue-deep:#5C82AB;
  --blue-tint:#E7EEF5;
  --sky:#7FB8E6;          /* client-requested sky blue, used as a light cool accent */
  --sky-soft:#E4F0FA;
  --sky-deep:#3E7DB4;
  --line:#DDD3C0;
  --muted:#6E6557;
  --white:#fff;

  --grad-copper:linear-gradient(135deg,#D7A463 0%,#B0723A 45%,#7C4C24 100%);

  --font-d:"Syne", sans-serif;
  --font-b:"Plus Jakarta Sans", sans-serif;

  --gutter:clamp(20px,4vw,52px);
  --sec:clamp(70px,9vw,150px);
  --maxw:1320px;

  --ease:cubic-bezier(.22,.61,.36,1);
  --ease-io:cubic-bezier(.7,0,.3,1);
  --t-fast:.16s; --t:.3s;
}
@media (min-width:1700px){ :root{ --maxw:1480px; } }

*,*::before,*::after{ box-sizing:border-box; }
html{ -webkit-text-size-adjust:100%; scroll-padding-top:90px; }
html,body{ overflow-x:clip; }
body{
  margin:0; background:var(--paper); color:var(--ink);
  font-family:var(--font-b); font-size:16px; line-height:1.65; font-weight:400;
  -webkit-font-smoothing:antialiased;
}
@media (hover:hover) and (pointer:fine){ html.cursor-on,html.cursor-on *{ cursor:none; } }

img{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }
ul,ol{ margin:0; padding:0; list-style:none; }
h1,h2,h3,h4{ margin:0; font-family:var(--font-d); font-weight:700; line-height:1; letter-spacing:-.02em; }
p{ margin:0; }
.container{ width:100%; max-width:var(--maxw); margin-inline:auto; padding-inline:var(--gutter); }

/* selection */
::selection{ background:var(--copper); color:var(--paper); }

/* ---------- shared type ---------- */
.h2{ font-size:clamp(2.1rem,5.4vw,4rem); letter-spacing:-.025em; }
.kicker{ display:flex; align-items:center; gap:.7rem; font-family:var(--font-b);
  font-weight:600; font-size:.74rem; letter-spacing:.18em; text-transform:uppercase;
  color:var(--copper-deep); margin-bottom:1.3rem; }
.kicker span{ font-family:var(--font-d); font-weight:700; font-size:.8rem;
  color:var(--copper); -webkit-text-stroke:0; }
.head{ margin-bottom:clamp(34px,4.5vw,64px); }
.head--row,.head--split{ display:grid; gap:1.4rem; }
.head__note{ color:var(--muted); max-width:42ch; font-size:.96rem; line-height:1.75; }

/* ---------- buttons ---------- */
.btn{ position:relative; display:inline-flex; align-items:center; justify-content:center;
  gap:.5rem; min-height:50px; padding:0 1.7rem; border-radius:50px;
  font-family:var(--font-b); font-weight:600; font-size:.86rem; letter-spacing:.01em;
  border:1.5px solid var(--ink); color:var(--ink); background:transparent;
  transition:background var(--t) var(--ease), color var(--t) var(--ease),
             transform var(--t-fast) var(--ease), border-color var(--t) var(--ease); }
.btn span{ position:relative; z-index:1; }
.btn--solid{ background:var(--ink); color:var(--paper); }
.btn--pill{ min-height:44px; padding:0 1.3rem; font-size:.8rem; }
.btn--light{ background:var(--grad-copper); border-color:transparent; color:#fff; }
.btn--text{ border:0; min-height:auto; padding:.4rem 0; border-radius:0; }
.btn--text i{ transition:transform var(--t) var(--ease); }
.btn--text-light{ color:var(--paper); }
.btn:active{ transform:scale(.96); }
@media (hover:hover) and (pointer:fine){
  .btn--solid:hover{ background:var(--copper); border-color:var(--copper); color:#fff; }
  .btn--pill:hover,.btn:not(.btn--solid):not(.btn--light):not(.btn--text):hover{
    background:var(--ink); color:var(--paper); }
  .btn--light:hover{ filter:brightness(1.06); }
  .btn--text:hover i{ transform:translateX(6px); }
}

/* ---------- loader ---------- */
.loader{ position:fixed; inset:0; z-index:200; background:var(--ink);
  display:grid; place-content:center; }
.loader__inner{ display:flex; flex-direction:column; align-items:center; gap:1.1rem; }
.loader__mark{ width:74px; height:auto; animation:floaty 2s var(--ease-io) infinite alternate; }
.loader__count{ font-family:var(--font-d); font-weight:700; font-size:1rem; letter-spacing:.3em;
  color:var(--copper-light); }
.loader.done{ transform:translateY(-100%); transition:transform .8s var(--ease-io); }
@keyframes floaty{ to{ transform:translateY(-10px); } }

/* ---------- custom cursor ---------- */
.cursor{ position:fixed; top:0; left:0; z-index:190; pointer-events:none;
  mix-blend-mode:difference; opacity:0; transition:opacity .3s; }
html.cursor-on .cursor{ opacity:1; }
.cursor__dot{ position:fixed; width:7px; height:7px; border-radius:50%; background:#fff;
  transform:translate(-50%,-50%); }
.cursor__ring{ position:fixed; width:38px; height:38px; border:1.5px solid #fff; border-radius:50%;
  transform:translate(-50%,-50%); transition:width .25s var(--ease), height .25s var(--ease),
  background .25s, opacity .25s; }
.cursor.is-hover .cursor__ring{ width:64px; height:64px; background:rgba(255,255,255,.12); }
.cursor.is-label .cursor__ring{ width:74px; height:74px; }
.cursor__label{ position:fixed; transform:translate(-50%,-50%); color:#fff;
  font-family:var(--font-b); font-weight:600; font-size:.6rem; letter-spacing:.08em;
  text-transform:uppercase; opacity:0; transition:opacity .2s; }
.cursor.is-label .cursor__label{ opacity:1; }

/* ---------- scroll progress ---------- */
.scrollbar{ position:fixed; top:0; left:0; height:3px; width:0; z-index:120;
  background:var(--grad-copper); }

/* ---------- header ---------- */
.header{ position:sticky; top:0; z-index:100;
  background:color-mix(in srgb,var(--paper) 80%,transparent);
  backdrop-filter:saturate(150%) blur(12px);
  border-bottom:1px solid transparent; transition:border-color var(--t), padding var(--t); }
.header.scrolled{ border-color:var(--line); }
.header__row{ display:flex; align-items:center; gap:1.2rem; min-height:72px; }
.brand{ display:inline-flex; align-items:center; gap:.6rem; }
.brand__icon{ height:clamp(34px,4vw,42px); width:auto; }
.brand__logo{ height:clamp(34px,5vw,54px); width:auto; display:block; }
.brand__wordmark{ height:clamp(26px,3.4vw,40px); width:auto; display:block; }
.brand__name{ font-family:var(--font-d); font-weight:700; font-size:1.1rem; line-height:1; letter-spacing:-.02em; }
.brand__name small{ display:block; font-family:var(--font-b); font-weight:600; font-size:.54rem;
  letter-spacing:.24em; text-transform:uppercase; color:var(--muted); margin-top:.3em; }
.nav{ display:none; margin-left:auto; gap:1.8rem; }
.nav a{ position:relative; font-weight:500; font-size:.9rem; color:var(--ink); padding:.3rem 0; }
.nav a::after{ content:""; position:absolute; left:0; bottom:-1px; height:1.5px; width:0;
  background:var(--copper); transition:width var(--t) var(--ease); }
@media (hover:hover){ .nav a:hover::after{ width:100%; } }
.header .btn--pill{ display:none; }

.burger{ margin-left:auto; width:46px; height:46px; display:grid; place-content:center; gap:5px;
  background:none; border:0; }
.burger span{ display:block; width:24px; height:2px; background:var(--ink);
  transition:transform var(--t) var(--ease), opacity var(--t); }
.burger[aria-expanded="true"] span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
.burger[aria-expanded="true"] span:nth-child(2){ opacity:0; }
.burger[aria-expanded="true"] span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }
.drawer{ display:grid; gap:.1rem; padding-inline:var(--gutter); overflow:hidden;
  max-height:0; background:var(--paper); transition:max-height var(--t) var(--ease-io), padding var(--t); }
.drawer.open{ max-height:420px; padding-block:1rem 1.6rem; border-bottom:1px solid var(--line); }
.drawer a{ padding:.85rem 0; font-size:1.05rem; font-weight:500; border-bottom:1px solid var(--line); }
.drawer .btn{ margin-top:1rem; }

/* ---------- hero ---------- */
.hero{ position:relative; min-height:calc(100svh - 72px); display:flex; flex-direction:column;
  padding-top:clamp(16px,2.5vw,38px); overflow:clip; }
.band--hero{ position:relative; z-index:2; }
.hero__blob{ position:absolute; top:-10%; right:-8%; width:min(56vw,720px); aspect-ratio:1;
  background:radial-gradient(circle at 40% 40%, rgba(92,130,171,.42), transparent 60%),
             radial-gradient(circle at 70% 70%, rgba(60,90,130,.34), transparent 62%);
  filter:blur(20px); z-index:0; pointer-events:none; }
.hero__grid{ position:relative; z-index:1; flex:1; display:grid; gap:clamp(28px,5vw,48px); align-items:center;
  padding-block:clamp(20px,3vw,40px); }

/* video background hero */
.hero--video{ color:var(--paper); }
.hero__video{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; z-index:0;
  background:var(--ink); }
.hero__scrim{ position:absolute; inset:0; z-index:1; pointer-events:none;
  background:
    linear-gradient(90deg, rgba(18,13,9,.88) 0%, rgba(18,13,9,.64) 46%, rgba(18,13,9,.30) 100%),
    linear-gradient(0deg, rgba(18,13,9,.62), transparent 40%),
    linear-gradient(0deg, rgba(124,76,36,.18), rgba(124,76,36,.05)); }
.hero--video .hero__grid{ position:relative; z-index:2; display:flex; flex-direction:column; justify-content:center; }
.hero--video .hero__lead{ max-width:none; }
.hero--video .hero__sub{ max-width:46ch; }
.hero--video .tagline{ color:rgba(245,241,232,.85); }
.hero--video .hero__title{ color:var(--paper); text-shadow:0 2px 30px rgba(0,0,0,.35); }
.hero--video .hero__sub{ color:rgba(245,241,232,.84); }
.tagline{ display:inline-flex; align-items:center; gap:.6rem; font-weight:600; font-size:.8rem;
  letter-spacing:.04em; color:var(--muted); margin-bottom:1.4rem; }
.tagline__dot{ width:9px; height:9px; border-radius:50%; background:var(--copper);
  box-shadow:0 0 0 4px rgba(176,114,58,.18); }
.hero__title{ font-size:clamp(2.8rem, 6.2vw, 8rem); font-weight:800; line-height:.92; letter-spacing:-.04em;
  text-transform:uppercase; }
.hero__title .kine{ display:block; overflow:hidden; padding:.08em .14em; margin:-.08em -.14em; }
.hero__title .kine>span{ display:block; }
.hero__title--accent>span{ font-style:italic; font-weight:700; padding-right:.12em;
  background:var(--grad-copper); -webkit-background-clip:text; background-clip:text; color:transparent; }
.hero__sub{ margin:clamp(.9rem,1.6vw,1.4rem) 0 0; max-width:44ch; color:var(--muted); font-size:1.02rem; line-height:1.7; }
.hero__actions{ display:flex; flex-wrap:wrap; align-items:center; gap:.9rem 1.3rem; margin-top:clamp(1.1rem,1.8vw,1.7rem); }

.hero__visual{ position:relative; width:100%; max-width:560px; margin-inline:auto; }
.hero__card{ margin:0; border-radius:14px; overflow:hidden; aspect-ratio:4/3.4;
  box-shadow:0 40px 80px rgba(22,18,13,.26); background:var(--ink-2);
  will-change:transform; animation:hfloat 6s var(--ease-io) infinite alternate; }
.hero__card img{ width:100%; height:100%; object-fit:cover; }
@keyframes hfloat{ from{ transform:translateY(-9px) rotate(-.6deg); } to{ transform:translateY(11px) rotate(.6deg); } }

/* hero bottom image feed */
.hero__feed{ position:relative; z-index:1; margin-top:auto; overflow:hidden;
  padding-block:clamp(10px,1.6vw,18px); border-top:1px solid var(--line);
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 5%,#000 95%,transparent);
          mask-image:linear-gradient(90deg,transparent,#000 5%,#000 95%,transparent); }
.hero__feed-track{ display:flex; gap:clamp(10px,1.4vw,18px); width:max-content; will-change:transform; }
.feed-img{ flex:none; width:clamp(94px,12vw,150px); aspect-ratio:1; border-radius:9px; overflow:hidden;
  background:var(--paper-2); }
.feed-img img{ width:100%; height:100%; object-fit:cover; }

/* ---------- marquee band ---------- */
.band{ background:var(--ink); color:var(--paper); overflow:hidden; white-space:nowrap;
  padding:1.1rem 0; border-block:1px solid rgba(255,255,255,.08); }
.band__track{ display:inline-flex; align-items:center; gap:1.6rem; will-change:transform; }
.band span{ font-family:var(--font-d); font-weight:700; font-size:clamp(1.1rem,2.4vw,1.7rem);
  letter-spacing:-.01em; text-transform:uppercase; }
.band b{ color:var(--copper-light); font-size:.9em; }

/* ---------- story ---------- */
.story{ padding:var(--sec) 0; }
.story__grid{ display:grid; gap:clamp(30px,4.5vw,60px); align-items:center; }
.story__media{ position:relative; }
.story__photo{ margin:0; border-radius:8px; overflow:hidden; aspect-ratio:4/3.3; }
.story__photo img{ width:100%; height:100%; object-fit:cover; filter:saturate(.9); }
/* inset matted in a cream frame so it reads as a placed photo card, not a clashing block */
.story__detail{ margin:1rem 0 0; border-radius:10px; overflow:hidden; aspect-ratio:3/2;
  border:6px solid var(--paper); box-shadow:0 16px 38px rgba(22,18,13,.20); }
.story__detail img{ width:100%; height:100%; object-fit:cover; display:block; }
.story__text{ margin-top:1.2rem; color:var(--muted); line-height:1.85; max-width:52ch; }
.story__facts{ display:flex; flex-wrap:wrap; gap:1.8rem; margin-top:2rem; padding-top:1.6rem; border-top:1px solid var(--line); }
.story__facts strong{ display:block; font-family:var(--font-d); font-weight:700; font-size:1.3rem; }
.story__facts span{ font-size:.76rem; color:var(--muted); }

/* ---------- stats ---------- */
.stats{ background:var(--ink); color:var(--paper); }
.stats__grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(26px,4vw,44px); padding-block:clamp(46px,5.5vw,72px); }
.stat{ border-left:2px solid rgba(255,255,255,.16); padding-left:1.2rem; }
.stat__n{ display:block; font-family:var(--font-d); font-weight:800; font-size:clamp(2.6rem,6vw,4.4rem);
  line-height:1; letter-spacing:-.03em; background:var(--grad-copper);
  -webkit-background-clip:text; background-clip:text; color:transparent; }
.stat__l{ display:block; margin-top:.7rem; font-size:.78rem; letter-spacing:.06em; text-transform:uppercase;
  color:rgba(245,241,232,.66); }

/* ---------- category intro (per-tab service copy) ---------- */
.catintro{ max-width:54ch; margin-bottom:clamp(22px,3.2vw,40px); }
.catintro__no{ font-family:var(--font-d); font-weight:700; font-size:.85rem; color:var(--copper); }
.catintro__title{ font-size:clamp(1.7rem,3.6vw,2.6rem); margin:.3rem 0 .6rem; }
.catintro p{ color:var(--muted); }
.catintro .btn{ margin-top:1.3rem; }
.svc__tags{ display:flex; flex-wrap:wrap; gap:.4rem .9rem; margin-top:1rem; }
.svc__tags em{ font-style:normal; font-size:.74rem; font-weight:600; letter-spacing:.03em; color:var(--copper-deep); }
.svc__tags em::before{ content:"●"; color:var(--blue-deep); margin-right:.45em; font-size:.6em; vertical-align:middle; }

/* ---------- what we make: 3D explosive boxes ---------- */
.make{ padding:var(--sec) 0; }
.make-grid{ display:grid; gap:clamp(40px,6vw,72px); }
.xbox__stage{ position:relative; height:clamp(400px,46vw,560px);
  display:flex; align-items:center; justify-content:center;
  perspective:1100px; }

/* 3D cuboid box: W=260 H=150 D=190 (half: 130/75/95), scaled by --bs.
   kept compact so the design cards fan clearly ABOVE the open lid. */
.box3d{ --bs:.58;
  position:relative; width:0; height:0; transform-style:preserve-3d;
  transform:scale(var(--bs)) rotateX(-14deg) rotateY(-26deg); transform-origin:center; }
@media (min-width:600px){ .box3d{ --bs:.72; } }
@media (min-width:1024px){ .box3d{ --bs:.84; } }
@media (min-width:1500px){ .box3d{ --bs:.94; } }
/* far layer (back, bottom, lid) sits behind the designs; near layer (front, sides) in front */
.box3d--far{ z-index:1; }
.box3d--near{ z-index:3; }
/* front 270x180 = 3:2 (matches the category image) */
.box3d__face{ position:absolute; left:50%; top:50%; box-sizing:border-box;
  background:#2E292B; border:1px solid rgba(0,0,0,.4); }
.box3d__face--front{ width:270px; height:180px; margin:-90px 0 0 -135px; transform:translateZ(85px);
  overflow:hidden; background:#262123; }
.box3d__face--front img{ width:100%; height:100%; object-fit:cover; }
.box3d__face--back{ width:270px; height:180px; margin:-90px 0 0 -135px; transform:translateZ(-85px) rotateY(180deg);
  background:#211D1F; }
.box3d__face--right{ width:170px; height:180px; margin:-90px 0 0 -85px; transform:rotateY(90deg) translateZ(135px);
  background:#241F21; }
.box3d__face--left{ width:170px; height:180px; margin:-90px 0 0 -85px; transform:rotateY(-90deg) translateZ(135px);
  background:#241F21; }
.box3d__face--bottom{ width:270px; height:170px; margin:-85px 0 0 -135px; transform:rotateX(-90deg) translateZ(90px);
  background:#1B1719; }
/* lid: hinge at back-top edge, flips open via GSAP on .box3d__lidrot */
.box3d__lidhinge{ position:absolute; left:50%; top:50%; transform:translateY(-90px) translateZ(-85px);
  transform-style:preserve-3d; }
.box3d__lidrot{ transform-style:preserve-3d; }
.box3d__lid{ position:absolute; left:0; top:0; width:270px; height:170px; margin-left:-135px;
  transform-origin:50% 0%; transform:rotateX(90deg);
  background:linear-gradient(160deg,#352F31,#2A2527); border:1px solid rgba(0,0,0,.4);
  box-shadow:0 0 0 1px rgba(255,255,255,.04) inset; }
.box3d__lid::after{ content:""; position:absolute; inset:15% 13%; border:1.5px dashed rgba(255,255,255,.13); border-radius:4px; }

.xbox__shadow{ position:absolute; left:50%; bottom:14%; width:46%; height:30px; transform:translateX(-50%);
  background:radial-gradient(closest-side, rgba(22,18,13,.38), transparent 75%); filter:blur(3px); z-index:0; }

/* box sits above the items so items are occluded until they rise out of it */
.xbox__core{ position:relative; z-index:3; }
/* product designs that erupt from inside the box */
.xbox__item{ position:absolute; left:50%; top:50%; z-index:2;
  --w:clamp(64px,16%,140px); width:var(--w); margin-left:calc(var(--w) * -0.5); margin-top:calc(var(--w) * -0.5);
  aspect-ratio:1; object-fit:cover; border-radius:10px;
  border:3px solid var(--paper); box-shadow:0 14px 30px rgba(22,18,13,.28);
  opacity:0; will-change:transform,opacity; transition:box-shadow .3s var(--ease); }
.xbox__item.is-pop{ box-shadow:0 30px 56px rgba(22,18,13,.45); }
.xbox__info{ margin-top:clamp(20px,2.5vw,30px); }
.xbox__no{ font-family:var(--font-d); font-weight:700; font-size:.82rem; color:var(--copper); }
.xbox__info h3{ font-size:clamp(1.6rem,3.6vw,2.4rem); margin:.4rem 0 .6rem; }
.xbox__info p{ color:var(--muted); max-width:46ch; margin-bottom:1.4rem; }

/* ---------- work: revolving door (3D coverflow) ---------- */
.work{ padding:var(--sec) 0 calc(var(--sec) + 10px); background:var(--ink); color:var(--paper); overflow:hidden; }
.work .kicker, .work .kicker span{ color:var(--copper-light); }
.work .h2{ color:var(--paper); }
.work .head__note{ color:rgba(245,241,232,.66); }
.door{ position:relative; margin-top:clamp(30px,4vw,56px); height:clamp(360px,46vw,560px);
  perspective:2000px; touch-action:pan-y; }
.door__stage{ position:absolute; inset:0; transform-style:preserve-3d; cursor:grab; will-change:transform; }
.door__stage.dragging{ cursor:grabbing; }
.door__card{ position:absolute; top:50%; left:50%; margin:0;
  width:clamp(200px,23vw,280px); height:clamp(270px,31vw,380px);
  margin-left:calc(clamp(200px,23vw,280px) / -2); margin-top:calc(clamp(270px,31vw,380px) / -2);
  border-radius:14px; overflow:hidden; background:var(--ink-2);
  border:1px solid rgba(255,255,255,.1); box-shadow:0 30px 60px rgba(0,0,0,.5);
  transform:rotateY(calc(var(--i) * 36deg)) translateZ(var(--door-r,640px)); }
.door__card img{ width:100%; height:100%; object-fit:cover; object-position:center; pointer-events:none; }
.door__card::after{ content:""; position:absolute; inset:0;
  background:linear-gradient(180deg, rgba(0,0,0,.25), transparent 42%, rgba(0,0,0,.22)); }
.door__nav{ position:absolute; top:50%; transform:translateY(-50%); z-index:5;
  width:54px; height:54px; border-radius:50%; border:1.5px solid transparent;
  background:var(--paper); color:var(--ink); font-size:1.2rem; cursor:pointer;
  display:grid; place-content:center; box-shadow:0 8px 20px rgba(0,0,0,.35);
  transition:background var(--t), color var(--t), transform var(--t-fast); }
.door__prev{ left:clamp(6px,3vw,40px); }
.door__next{ right:clamp(6px,3vw,40px); }
.door__nav:active{ transform:translateY(-50%) scale(.92); }
@media (hover:hover){ .door__nav:hover{ background:var(--copper); color:#fff; } }

/* ---------- why (image cards) ---------- */
.why{ padding:var(--sec) 0; }
.why__list{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(12px,2.4vw,26px); }
.why__card{ display:flex; flex-direction:column; background:var(--white); border:1px solid var(--line);
  border-radius:14px; overflow:hidden;
  transition:transform var(--t) var(--ease), box-shadow var(--t) var(--ease), border-color var(--t); }
.why__img{ margin:0; aspect-ratio:4/3; overflow:hidden; background:var(--ink-2); }
.why__img img{ width:100%; height:100%; object-fit:cover; transition:transform .6s var(--ease); }
figure.why__img.ph{ border:0; border-bottom:1.6px dashed var(--blue-deep); border-radius:0; }
.why__body{ padding:clamp(.9rem,2.6vw,1.4rem) clamp(1rem,2.6vw,1.4rem) clamp(1.1rem,2.8vw,1.6rem); }
.why__no{ font-family:var(--font-d); font-weight:700; font-size:.78rem; color:var(--copper); }
.why__body h3{ font-size:clamp(1.05rem,3.2vw,1.3rem); margin:.45rem 0 .5rem; }
.why__body p{ color:var(--muted); font-size:.92rem; }
@media (hover:hover) and (pointer:fine){
  .why__card:hover{ transform:translateY(-6px); box-shadow:0 24px 46px rgba(22,18,13,.12); border-color:transparent; }
  .why__card:hover .why__img img{ transform:scale(1.06); }
}

/* ---------- process ---------- */
.process{ padding:var(--sec) 0; background:var(--ink); color:var(--paper); }
.process .kicker{ color:var(--copper-light); }
.process .kicker span{ color:var(--copper-light); }
.process .h2{ color:var(--paper); }
.steps{ display:grid; gap:0; }
.step{ display:grid; grid-template-columns:clamp(96px,12vw,150px) 1fr; gap:clamp(1rem,2vw,2rem); align-items:start;
  padding:2.2rem 0; border-top:1px solid rgba(255,255,255,.12); }
.step:last-child{ border-bottom:1px solid rgba(255,255,255,.12); }
.step__no{ font-family:var(--font-d); font-weight:800; font-size:clamp(2.6rem,8vw,5rem); line-height:.85;
  color:transparent; -webkit-text-stroke:1.4px var(--copper-light); }
.step__b h3{ font-size:clamp(1.4rem,3.4vw,2.1rem); color:var(--paper); }
.step__b p{ margin-top:.7rem; color:rgba(245,241,232,.7); max-width:52ch; }

/* ---------- industries ---------- */
.ind{ padding:var(--sec) 0; }
.ind__grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:clamp(10px,1.5vw,16px); }
.ind__card{ position:relative; overflow:hidden; border-radius:8px; aspect-ratio:4/5; }
.ind__card:first-child{ grid-column:span 2; aspect-ratio:auto; min-height:240px; }
.ind__card img{ width:100%; height:100%; object-fit:cover; transition:transform .6s var(--ease); }
.ind__card>span:last-child{ position:absolute; inset:auto 0 0 0; padding:.9rem 1rem; color:#fff;
  font-family:var(--font-d); font-weight:600; font-size:1rem;
  background:linear-gradient(transparent, rgba(22,18,13,.82)); }
@media (hover:hover){ .ind__card:hover img{ transform:scale(1.07); } }

/* ---------- placeholders ---------- */
.ph{ display:grid; place-content:center; gap:.45rem; text-align:center; padding:1.4rem;
  border:1.6px dashed var(--blue-deep); color:var(--copper-deep);
  background:linear-gradient(135deg,var(--paper-2),#fff); border-radius:8px; }
.ph::before{ content:""; width:32px; height:26px; margin:0 auto .2rem; border:1.6px solid var(--copper-deep);
  border-radius:3px; opacity:.6;
  background:radial-gradient(circle at 70% 36%, var(--copper) 0 3px, transparent 4px); }
.ph__label{ font-size:.66rem; letter-spacing:.16em; text-transform:uppercase; font-weight:700; color:var(--copper-deep); }
.ph__hint{ font-size:.82rem; color:var(--muted); max-width:26ch; }
.ind__card--ph{ background:linear-gradient(135deg,var(--paper-2),#fff); }
.ind__card--ph>span:last-child{ background:rgba(245,241,232,.9); color:var(--copper-deep); }

/* ---------- lifestyle band ---------- */
.life{ padding:0; }
.life__ph{ position:relative; margin:0; height:clamp(260px,40vw,500px); overflow:hidden; }
.life__ph img{ width:100%; height:100%; object-fit:cover; object-position:center; display:block;
  filter:saturate(.9); }
/* even, gentle copper veil so it sits in the brand palette (no edge haze) */
.life__ph::after{ content:""; position:absolute; inset:0; pointer-events:none;
  background:rgba(124,76,36,.12); }

/* ---------- seasonal collections showcase ---------- */
.season{ padding:var(--sec) 0; }
.season__grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(12px,1.6vw,20px); margin-top:clamp(28px,3.6vw,48px); }
.season__card{ margin:0; border-radius:12px; overflow:hidden; aspect-ratio:1; background:var(--ink-2); border:1px solid var(--line); }
.season__card img{ width:100%; height:100%; object-fit:cover; display:block; transition:transform .55s var(--ease); }
@media (hover:hover) and (pointer:fine){ .season__card:hover img{ transform:scale(1.05); } }
@media (min-width:768px){ .season__grid{ grid-template-columns:repeat(4,1fr); } }

/* ---------- image lightbox (click to enlarge) ---------- */
.lightbox{ position:fixed; inset:0; z-index:300; display:flex; align-items:center; justify-content:center;
  padding:clamp(16px,4vw,52px); background:rgba(22,18,13,.86); -webkit-backdrop-filter:blur(4px); backdrop-filter:blur(4px);
  opacity:0; visibility:hidden; transition:opacity .3s var(--ease), visibility .3s; }
.lightbox.is-open{ opacity:1; visibility:visible; }
.lightbox__img{ max-width:min(1100px,100%); max-height:88vh; width:auto; height:auto; object-fit:contain;
  border-radius:10px; box-shadow:0 30px 80px rgba(0,0,0,.5); transform:scale(.95);
  transition:transform .32s var(--ease); }
.lightbox.is-open .lightbox__img{ transform:scale(1); }
.lightbox__close{ position:absolute; top:clamp(12px,2vw,24px); right:clamp(12px,2vw,24px);
  width:46px; height:46px; border:0; border-radius:50%; background:rgba(245,241,232,.14); color:var(--paper);
  font-size:1.7rem; line-height:1; cursor:pointer; display:grid; place-content:center;
  transition:background var(--t), transform var(--t-fast); }
@media (hover:hover) and (pointer:fine){ .lightbox__close:hover{ background:rgba(245,241,232,.26); } }
.lightbox__close:active{ transform:scale(.94); }
.zoomable{ cursor:zoom-in; }

/* ---------- FAQ accordion ---------- */
.faq{ padding:0 0 var(--sec); }
.faq__list{ margin-top:clamp(20px,3vw,36px); border-top:1px solid var(--line); }
.faq__item{ border-bottom:1px solid var(--line); }
.faq__item summary{ list-style:none; cursor:pointer; position:relative; color:var(--ink);
  padding:clamp(1rem,2vw,1.35rem) 2.4rem clamp(1rem,2vw,1.35rem) 0;
  font-family:var(--font-d); font-weight:600; font-size:clamp(1.05rem,2.2vw,1.25rem); transition:color var(--t); }
.faq__item summary::-webkit-details-marker{ display:none; }
.faq__item summary::after{ content:"+"; position:absolute; right:.1rem; top:50%; transform:translateY(-50%);
  font-family:var(--font-b); font-weight:400; font-size:1.5rem; line-height:1; color:var(--copper); transition:transform var(--t); }
.faq__item[open] summary::after{ transform:translateY(-50%) rotate(45deg); }
.faq__item p{ margin:0; color:var(--muted); line-height:1.7; max-width:72ch;
  padding:0 2.4rem clamp(1rem,2vw,1.3rem) 0; }
@media (hover:hover) and (pointer:fine){ .faq__item summary:hover{ color:var(--copper-deep); } }

/* ---------- services section: tighter, one-line tabs on mobile ---------- */
@media (max-width:560px){
  .tabs{ display:inline-flex; max-width:100%; gap:.2rem; }
  .tab{ white-space:nowrap; padding:.5rem .6rem; font-size:.74rem; gap:.3rem; }
  .tab i{ font-size:.58rem; padding:.1rem .38rem; }
  .cat .head__note{ display:none; }
  .catintro__count{ display:none; }
  .catintro .svc__tags{ display:none; }
  .catintro__title{ font-size:1.7rem; }
  .catintro{ margin-bottom:18px; }
}

/* ---------- cta ---------- */
.cta{ position:relative; overflow:hidden; padding:var(--sec) 0;
  background:
    linear-gradient(135deg, rgba(124,76,36,.96), rgba(176,114,58,.94)),
    url("assets/cta-bg.avif") center/cover no-repeat;
  color:var(--paper); }
.cta__hex{ position:absolute; right:-4%; top:-10%; width:min(38vw,420px); opacity:.16; z-index:0; }
.cta__hex img{ width:100%; filter:brightness(0) invert(1); }
.cta__grid{ position:relative; z-index:1; display:grid; gap:clamp(28px,4vw,48px); }
.cta__title{ font-size:clamp(2.1rem,5.6vw,3.8rem); max-width:16ch; letter-spacing:-.025em; }
.cta__aside p{ color:rgba(245,241,232,.85); max-width:42ch; line-height:1.7; }
.cta__actions{ display:flex; flex-wrap:wrap; align-items:center; gap:1rem 1.4rem; margin-top:1.9rem; }
/* CTA buttons must pop on the copper background */
.cta .btn--light{ background:var(--paper); color:var(--ink); border-color:transparent; box-shadow:0 12px 28px rgba(22,18,13,.24); }
.cta .btn--text-light{ background:rgba(245,241,232,.12); border:1.5px solid rgba(245,241,232,.5);
  border-radius:999px; min-height:auto; padding:.72rem 1.35rem; color:var(--paper); }
@media (hover:hover) and (pointer:fine){
  .cta .btn--light:hover{ background:#fff; color:var(--ink); filter:none; }
  .cta .btn--text-light:hover{ background:rgba(245,241,232,.22); color:#fff; }
}

/* ---------- footer ---------- */
.footer{ background:var(--ink); color:var(--paper); padding:clamp(50px,6vw,84px) 0 1.8rem; }
.footer__grid{ display:grid; grid-template-columns:1fr 1fr; gap:2.4rem 1.4rem; }
.footer__brand{ grid-column:1 / -1; }
.footer__logo{ height:clamp(34px,4.5vw,46px); width:auto; }
.footer__brand p{ margin-top:1.1rem; color:rgba(245,241,232,.6); max-width:34ch; font-size:.88rem; }
.footer__col h4{ font-family:var(--font-b); font-weight:700; font-size:.72rem; letter-spacing:.16em;
  text-transform:uppercase; color:var(--copper-light); margin-bottom:1rem; }
.footer__col{ display:grid; gap:.5rem; align-content:start; }
.footer__col a{ color:rgba(245,241,232,.78); font-size:.9rem; width:max-content; }
.footer__col p{ color:rgba(245,241,232,.7); font-size:.86rem; }
@media (hover:hover){ .footer__col a:hover{ color:var(--copper-light); } }
.footer__social{ display:flex; gap:.7rem; margin-top:.7rem; }
.footer__social a{ display:inline-grid; place-content:center; width:42px; height:42px; border-radius:50%;
  background:rgba(245,241,232,.08); color:rgba(245,241,232,.82);
  transition:background var(--t), color var(--t), transform var(--t-fast); }
.footer__social svg{ width:19px; height:19px; }
.footer__social a:active{ transform:scale(.94); }
@media (hover:hover) and (pointer:fine){ .footer__social a:hover{ background:rgba(245,241,232,.18); color:var(--paper); } }
.cinfo__social{ display:flex; gap:.6rem; }
.cinfo__social a{ display:inline-grid; place-content:center; width:44px; height:44px; border:0; border-radius:50%;
  background:var(--paper-2); color:var(--ink);
  transition:background var(--t), color var(--t), transform var(--t-fast); }
.cinfo__social svg{ width:20px; height:20px; }
.cinfo__social a:active{ transform:scale(.94); }
@media (hover:hover) and (pointer:fine){ .cinfo__social a:hover{ background:var(--copper); color:#fff; } }
.footer__base{ display:flex; flex-wrap:wrap; gap:.6rem 1.2rem; justify-content:space-between;
  margin-top:3rem; padding-top:1.5rem; border-top:1px solid rgba(255,255,255,.1);
  font-size:.76rem; color:rgba(245,241,232,.5); }
.footer__powered{ color:rgba(245,241,232,.55); transition:color var(--t); }
.footer__powered strong{ font-weight:700; letter-spacing:.04em; color:var(--copper-light); }
@media (hover:hover) and (pointer:fine){ .footer__powered:hover{ color:var(--paper); } }

/* ---------- reveal states ---------- */
[data-reveal]{ opacity:0; transform:translateY(24px); }
[data-reveal-lines] .ln{ display:block; overflow:hidden; }
[data-reveal-lines] .ln>span{ display:block; }
.reveal-clip{ clip-path:inset(0 0 100% 0); }

/* ---------- what we make + gallery (sticky split) ---------- */
.cat{ position:relative; padding:var(--sec) 0; }
.cat .anchor{ position:absolute; top:-84px; }

/* segmented pill tab switcher */
.tabs{ display:inline-flex; gap:.3rem; margin-bottom:clamp(26px,3.6vw,44px);
  padding:.34rem; background:var(--paper-2); border:1px solid var(--line); border-radius:999px; }
.tab{ background:none; border:0; cursor:pointer; padding:.62rem 1.1rem; font:inherit; font-weight:600;
  color:var(--muted); border-radius:999px; display:inline-flex; align-items:center; gap:.5rem;
  transition:color var(--t), background var(--t), transform var(--t-fast); }
.tab i{ font-style:normal; font-size:.66rem; background:var(--white); color:var(--copper-deep);
  padding:.12rem .5rem; border-radius:20px; transition:background var(--t), color var(--t); }
.tab.is-active{ color:var(--paper); background:var(--ink); }
.tab.is-active i{ background:rgba(245,241,232,.16); color:var(--paper); }
.tab:active{ transform:scale(.97); }
@media (hover:hover) and (pointer:fine){ .tab:not(.is-active):hover{ color:var(--ink); } }
.catpanel[hidden]{ display:none; }

/* split: intro rail (left) + full gallery (right) */
.catpanel{ display:grid; gap:clamp(26px,3vw,52px); }
.catintro{ max-width:none; margin-bottom:0; }
.catintro__no{ font-family:var(--font-d); font-weight:700; font-size:.85rem; color:var(--copper); }
.catintro__title{ font-size:clamp(2rem,4.6vw,3rem); margin:.35rem 0 .5rem; }
.catintro__count{ font-size:.74rem; font-weight:600; letter-spacing:.1em; text-transform:uppercase;
  color:var(--copper-deep); margin-bottom:1rem; }
.catintro p{ color:var(--muted); }
.catintro .btn{ margin-top:1.5rem; }

/* gallery grid — every design, framed cards with hover index */
.cat-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:clamp(10px,1.4vw,16px); counter-reset:pic; }
.cat-grid figure{ position:relative; margin:0; counter-increment:pic; overflow:hidden; border-radius:12px;
  background:var(--white); border:1px solid var(--line); aspect-ratio:1;
  transition:transform var(--t) var(--ease), box-shadow var(--t) var(--ease), border-color var(--t); }
.cat-grid img{ width:100%; height:100%; object-fit:cover; display:block; transition:transform .55s var(--ease); }
.cat-grid figure::after{ content:counter(pic,decimal-leading-zero); position:absolute; left:11px; top:9px;
  font-family:var(--font-d); font-weight:700; font-size:.72rem; letter-spacing:.03em; color:var(--copper);
  opacity:0; transform:translateY(-5px); transition:opacity var(--t), transform var(--t); pointer-events:none; }
@media (hover:hover) and (pointer:fine){
  .cat-grid figure:hover{ transform:translateY(-4px); border-color:var(--copper-light);
    box-shadow:0 18px 36px rgba(22,18,13,.16); }
  .cat-grid figure:hover img{ transform:scale(1.07); }
  .cat-grid figure:hover::after{ opacity:1; transform:none; }
}

/* ---------- nav active ---------- */
.nav a.is-active{ color:var(--copper); }
.nav a.is-active::after{ width:100%; }
.drawer a.is-active{ color:var(--copper); }

/* ---------- inner page header ---------- */
.pagehead{ position:relative; overflow:clip; padding:clamp(40px,7vw,96px) 0 clamp(28px,4vw,52px);
  background:
    linear-gradient(90deg, rgba(245,241,232,.94) 0%, rgba(245,241,232,.74) 36%, rgba(245,241,232,.30) 60%, rgba(245,241,232,0) 78%),
    url("assets/pagehead-bg.jpg") right center / cover no-repeat,
    #F5F1E8; }
.pagehead .hero__blob{ display:none; } /* glow now part of the background photo */
/* phones: products sit behind the text, so wash the image back for legibility */
@media (max-width:700px){
  .pagehead{ background:
      linear-gradient(180deg, rgba(245,241,232,.93), rgba(245,241,232,.83)),
      url("assets/pagehead-bg.jpg") center / cover no-repeat,
      #F5F1E8; }
}
.pagehead .container{ position:relative; z-index:1; }
.pagehead__crumb{ font-size:.76rem; letter-spacing:.05em; color:var(--muted); margin-bottom:1.1rem; }
.pagehead__crumb a{ color:var(--muted); }
@media (hover:hover){ .pagehead__crumb a:hover{ color:var(--copper); } }
.pagehead__crumb span{ color:var(--copper); }
.pagehead h1{ font-family:var(--font-d); font-weight:800; font-size:clamp(2.7rem,9vw,6.4rem);
  letter-spacing:-.035em; line-height:.92; text-transform:uppercase; }
.pagehead__sub{ margin-top:1.3rem; max-width:54ch; color:var(--muted); font-size:1.02rem; line-height:1.75; }

/* ---------- contact page ---------- */
.contact{ padding:var(--sec) 0; }
.contact__grid{ display:grid; gap:clamp(34px,5vw,64px); }
.contact__form{ display:grid; gap:1.3rem; }
.field{ display:grid; gap:.45rem; }
.field label{ font-size:.74rem; font-weight:700; letter-spacing:.08em; text-transform:uppercase; color:var(--muted); }
.field input, .field textarea{ width:100%; font:inherit; font-size:1rem; color:var(--ink);
  background:transparent; border:0; border-bottom:1.6px solid var(--line); padding:.7rem .1rem; border-radius:0;
  transition:border-color var(--t); }
.field textarea{ resize:vertical; min-height:120px; }
.field input:focus, .field textarea:focus{ outline:none; border-color:var(--copper); }
.field select{ width:100%; font:inherit; font-size:1rem; color:var(--ink); background:transparent;
  border:0; border-bottom:1.6px solid var(--line); padding:.7rem 1.4rem .7rem .1rem; border-radius:0;
  appearance:none; -webkit-appearance:none; cursor:pointer;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%236E6557' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
  background-repeat:no-repeat; background-position:right .15rem center; transition:border-color var(--t); }
.field select:focus{ outline:none; border-color:var(--copper); }
.form__head{ margin-bottom:.2rem; }
.form__title{ font-size:clamp(1.5rem,2.6vw,2rem); margin-bottom:.5rem; }
.form__intro{ color:var(--muted); font-size:.96rem; line-height:1.6; max-width:54ch; }
.field-row{ display:grid; gap:1.3rem; }
.field__opt{ font-weight:500; text-transform:none; letter-spacing:0; color:var(--muted); opacity:.75; }
.form__note{ font-size:.84rem; color:var(--muted); }
@media (min-width:600px){ .field-row{ grid-template-columns:1fr 1fr; gap:1.3rem 1.4rem; } }
.cinfo{ display:grid; gap:1.4rem; align-content:start; }
.cinfo__item dt{ font-size:.72rem; letter-spacing:.12em; text-transform:uppercase; color:var(--copper-deep); margin-bottom:.3rem; }
.cinfo__item dd{ margin:0; font-size:.98rem; line-height:1.6; }
.cinfo__item a{ border-bottom:1px solid var(--line); }
.contact__map{ margin-top:.6rem; border-radius:12px; overflow:hidden; aspect-ratio:16/10;
  border:1px solid var(--line); background:var(--paper-2); }
.contact__map iframe{ width:100%; height:100%; border:0; display:block; }

/* ---------- reviews (Google style) ---------- */
.reviews{ padding:var(--sec) 0; background:var(--paper-2); }
.reviews__head{ display:grid; gap:1.4rem; align-items:center; margin-bottom:clamp(28px,3.5vw,48px); }
.reviews__brand{ display:flex; align-items:center; gap:.8rem; }
.g-logo{ width:38px; height:38px; flex:none; }
.g-logo--sm{ width:20px; height:20px; }
.reviews__brandtext strong{ display:block; font-family:var(--font-d); font-weight:700; font-size:1.15rem; }
.reviews__brandtext span{ font-size:.82rem; color:var(--muted); }
.reviews__score{ display:flex; align-items:center; gap:.7rem; flex-wrap:wrap; }
.reviews__num{ font-family:var(--font-d); font-weight:800; font-size:2rem; color:var(--ink); line-height:1; }
.stars{ color:#F4B400; letter-spacing:.06em; font-size:1rem; line-height:1; }
.stars--lg{ font-size:1.3rem; }
.reviews__based{ font-size:.84rem; color:var(--muted); }
.reviews__write{ justify-self:start; }
/* full-bleed: break out of the container, span the whole viewport */
.reviews__rail{ overflow:hidden; cursor:grab; width:100vw; margin-left:calc(50% - 50vw); }
.reviews__rail.dragging{ cursor:grabbing; }
.reviews__track{ display:flex; gap:clamp(14px,1.6vw,20px); width:max-content; will-change:transform; }
.rev{ flex:none; width:clamp(280px,30vw,360px); background:var(--white); border:1px solid var(--line);
  border-radius:12px; padding:1.4rem 1.5rem; box-shadow:0 8px 22px rgba(22,18,13,.06);
  display:flex; flex-direction:column; gap:.7rem; }
.rev__top{ display:flex; align-items:center; gap:.7rem; }
.rev__av{ width:42px; height:42px; flex:none; border-radius:50%; display:grid; place-content:center;
  background:var(--c,#4285F4); color:#fff; font-family:var(--font-d); font-weight:700; font-size:1.1rem; }
.rev__who{ flex:1; min-width:0; }
.rev__who strong{ display:block; font-size:.95rem; font-weight:700; }
.rev__who span{ font-size:.74rem; color:var(--muted); }
.rev__top .g-logo--sm{ margin-left:auto; }
.rev__text{ color:var(--ink-2); font-size:.9rem; line-height:1.6; }

/* ---------- floating WhatsApp ---------- */
.wa{ position:fixed; right:clamp(16px,2.5vw,28px); bottom:clamp(16px,2.5vw,28px); z-index:130;
  width:58px; height:58px; border-radius:50%; display:grid; place-content:center;
  background:#25D366; color:#fff; box-shadow:0 12px 28px rgba(37,211,102,.42);
  transition:transform var(--t) var(--ease), box-shadow var(--t); }
.wa svg{ width:32px; height:32px; }
.wa::before{ content:""; position:absolute; inset:0; border-radius:50%; background:#25D366;
  z-index:-1; animation:wapulse 2.4s ease-out infinite; }
@keyframes wapulse{ 0%{ transform:scale(1); opacity:.5; } 70%,100%{ transform:scale(1.7); opacity:0; } }
@media (hover:hover){ .wa:hover{ transform:scale(1.08); box-shadow:0 16px 34px rgba(37,211,102,.5); } }
.wa:active{ transform:scale(.95); }

/* sky-blue accents woven in lightly */
.tagline__dot{ box-shadow:0 0 0 4px rgba(176,114,58,.2); }
.nav a::after{ background:var(--copper); }
.story__facts li:nth-child(2) strong{ color:var(--blue-deep); }

/* =================================================================
   Breakpoints
================================================================= */
@media (min-width:680px){
  .stats__grid{ grid-template-columns:repeat(4,1fr); }
  .ind__grid{ grid-template-columns:repeat(3,1fr); }
  .ind__card:first-child{ grid-column:auto; aspect-ratio:4/5; min-height:0; }
  .why__list{ grid-template-columns:1fr 1fr; }
  .head--row,.head--split{ grid-template-columns:1.3fr .7fr; align-items:end; }
  .story__facts strong{ font-size:1.4rem; }
  .reviews__head{ grid-template-columns:auto 1fr auto; }
  .reviews__score{ justify-content:center; }
  .cat-grid{ grid-template-columns:repeat(3,1fr); }
}

@media (min-width:1024px){
  body{ font-size:16.5px; }
  .nav{ display:flex; }
  .header .btn--pill{ display:inline-flex; }
  .burger{ display:none; }
  .drawer{ display:none; }
  .hero__grid{ grid-template-columns:1.08fr .92fr; gap:clamp(30px,4vw,60px); }
  .hero__visual{ max-width:none; }
  .story__grid{ grid-template-columns:1.05fr .95fr; }
  .story__media{ padding:0 56px 56px 0; }
  .story__detail{ position:absolute; right:0; bottom:0; width:62%; margin:0; box-shadow:0 26px 52px rgba(22,18,13,.22); }
  .footer__grid{ grid-template-columns:1.5fr .8fr 1.4fr; }
  .footer__brand{ grid-column:auto; }
  .cta__grid{ grid-template-columns:1.1fr .9fr; align-items:start; }
  .contact__grid{ grid-template-columns:1fr 1fr; align-items:start; }
  .why__list{ grid-template-columns:repeat(3,1fr); }
  .make-grid{ grid-template-columns:1fr 1fr; align-items:start; }
  /* sticky split: intro rail pins while the full gallery scrolls past */
  .catpanel{ grid-template-columns:minmax(250px,330px) 1fr; align-items:start; gap:clamp(34px,3.4vw,64px); }
  .catintro{ position:sticky; top:104px; }
  .cat-grid{ grid-template-columns:repeat(3,1fr); }
}

/* Genuinely short screens (small laptops): trim the hero just enough that the
   title, copy, CTAs and bottom marquee stay on one screen. Width-based sizing,
   so it stays a consistent, un-zoomed size rather than stretching to fill height. */
@media (min-width:1200px) and (max-height:820px){
  .hero__title{ font-size:clamp(2.6rem, 5.4vw, 6rem); }
  .tagline{ margin-bottom:.7rem; }
  .hero__sub{ margin-top:.85rem; line-height:1.6; }
  .hero__actions{ margin-top:1rem; }
  .hero__grid{ padding-block:clamp(8px,2vh,24px); }
}

@media (min-width:1440px){
  .cat-grid{ grid-template-columns:repeat(4,1fr); }
}

/* ---------- reduced motion ---------- */
@media (prefers-reduced-motion:reduce){
  *{ animation-duration:.001ms !important; animation-iteration-count:1 !important;
     transition-duration:.001ms !important; scroll-behavior:auto !important; }
  [data-reveal],[data-reveal-lines] .ln>span{ opacity:1 !important; transform:none !important; }
  .reveal-clip{ clip-path:none !important; }
  .loader{ display:none; }
  .hero__badge{ animation:none; }
}
