/* ==========================================================================
   TNT — Stainless Steel Kitchen Equipments
   "Hearth" design system · Warm & Premium
   Cream + espresso + terracotta. Self-hosted fonts only. No framework.
   ========================================================================== */

/* ---------------------------------------------------------------- 1. Fonts */
@font-face{font-family:"Roboto";font-style:normal;font-weight:300;font-display:swap;
  src:url("../fonts/roboto/roboto-light-webfont.woff2") format("woff2"),url("../fonts/roboto/roboto-light-webfont.woff") format("woff");}
@font-face{font-family:"Roboto";font-style:normal;font-weight:400;font-display:swap;
  src:url("../fonts/roboto/roboto-regular-webfont.woff2") format("woff2"),url("../fonts/roboto/roboto-regular-webfont.woff") format("woff");}
@font-face{font-family:"Roboto";font-style:normal;font-weight:700;font-display:swap;
  src:url("../fonts/roboto/roboto-bold-webfont.woff2") format("woff2"),url("../fonts/roboto/roboto-bold-webfont.woff") format("woff");}
@font-face{font-family:"Poppins";font-style:normal;font-weight:300;font-display:swap;
  src:url("../fonts/poppins/poppins-light-webfont.woff2") format("woff2"),url("../fonts/poppins/poppins-light-webfont.woff") format("woff");}
@font-face{font-family:"Poppins";font-style:normal;font-weight:400;font-display:swap;
  src:url("../fonts/poppins/poppins-regular-webfont.woff2") format("woff2"),url("../fonts/poppins/poppins-regular-webfont.woff") format("woff");}
@font-face{font-family:"Poppins";font-style:normal;font-weight:600;font-display:swap;
  src:url("../fonts/poppins/poppins-semibold-webfont.woff2") format("woff2"),url("../fonts/poppins/poppins-semibold-webfont.woff") format("woff");}
@font-face{font-family:"Poppins";font-style:normal;font-weight:700;font-display:swap;
  src:url("../fonts/poppins/poppins-bold-webfont.woff2") format("woff2"),url("../fonts/poppins/poppins-bold-webfont.woff") format("woff");}

/* ---------------------------------------------------------------- 2. Tokens */
:root{
  /* warm neutrals */
  --espresso:#211C19;
  --ink:#26201C;
  --cocoa:#3B322C;
  --text:#2C2520;
  --text-soft:#6E655C;
  --text-faint:#9A8E80;
  --cream:#FBF7F0;
  --cream-2:#F5EFE4;
  --sand:#EFE7D8;
  --surface:#FFFFFF;
  --line:#E9E1D2;
  --line-strong:#DBD0BC;

  /* accent — warmed logo red-orange + brass detail */
  --accent:#D1442A;
  --accent-600:#B0371F;
  --ember:#EC6A43;
  --brass:#B08A4A;
  --brass-soft:#C9A876;

  /* type */
  --font-head:"Poppins","Roboto",sans-serif;
  --font-body:"Roboto","Poppins",sans-serif;
  --fs-eyebrow:.78rem;
  --fs-body:1.0625rem;
  --fs-lead:clamp(1.125rem,.95rem + .85vw,1.4rem);
  --fs-h4:clamp(1.25rem,1.05rem + .8vw,1.6rem);
  --fs-h3:clamp(1.55rem,1.2rem + 1.4vw,2.15rem);
  --fs-h2:clamp(2rem,1.4rem + 2.6vw,3.35rem);
  --fs-h1:clamp(2.4rem,1.5rem + 4vw,4.6rem);

  /* layout / shape */
  --gutter:clamp(1.25rem,4vw,2.75rem);
  --maxw:1240px;
  --maxw-narrow:900px;
  --radius:16px;
  --radius-sm:10px;
  --radius-lg:26px;
  --section-y:clamp(4.5rem,7.5vw,8.5rem);
  --header-h:88px;

  /* motion */
  --ease:cubic-bezier(.22,.61,.36,1);
  --ease-out:cubic-bezier(.16,1,.3,1);

  /* elevation — warm tinted */
  --shadow-sm:0 1px 2px rgba(56,40,28,.06),0 4px 12px rgba(56,40,28,.05);
  --shadow:0 14px 36px -16px rgba(56,40,28,.22),0 4px 14px -8px rgba(56,40,28,.12);
  --shadow-lg:0 36px 80px -34px rgba(40,28,20,.4);
  --shadow-accent:0 18px 42px -16px rgba(209,68,42,.42);
}

/* ------------------------------------------------------------- 3. Reset/base */
*,*::before,*::after{box-sizing:border-box;}
*{margin:0;}
html{-webkit-text-size-adjust:100%;text-size-adjust:100%;scroll-behavior:smooth;}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto;}}
body{
  font-family:var(--font-body);font-size:var(--fs-body);line-height:1.72;
  color:var(--text);background:var(--cream);
  -webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img,picture,svg,video{display:block;max-width:100%;height:auto;}
a{color:inherit;text-decoration:none;}
button,input,textarea,select{font:inherit;color:inherit;}
button{background:none;border:0;cursor:pointer;}
ul,ol{list-style:none;padding:0;}
::selection{background:var(--accent);color:#fff;}
:focus-visible{outline:2.5px solid var(--accent);outline-offset:3px;border-radius:3px;}
h1,h2,h3,h4,h5,h6{font-family:var(--font-head);color:var(--ink);line-height:1.12;font-weight:700;letter-spacing:-.012em;text-wrap:balance;}
p{text-wrap:pretty;}

/* ------------------------------------------------------------ 4. a11y helpers */
.skip-link{position:fixed;top:.75rem;left:.75rem;z-index:200;background:var(--espresso);color:#fff;padding:.65rem 1.1rem;border-radius:var(--radius-sm);transform:translateY(-160%);transition:transform .25s var(--ease);font-weight:600;}
.skip-link:focus{transform:translateY(0);}
.visually-hidden{position:absolute!important;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0;}

/* --------------------------------------------------------- 5. Layout primitives */
.container{width:100%;max-width:var(--maxw);margin-inline:auto;padding-inline:var(--gutter);}
.container--narrow{max-width:var(--maxw-narrow);}
.section{padding-block:var(--section-y);position:relative;}
.section--tight{padding-block:clamp(3rem,5vw,5rem);}
.section--cream{background:var(--cream-2);}
.section--sand{background:var(--sand);}
.section--ink{background:var(--espresso);color:#F2E9DD;}
.section--ink h1,.section--ink h2,.section--ink h3,.section--ink h4,.section--ink h5,.section--ink h6{color:#fff;}

.eyebrow{display:inline-flex;align-items:center;gap:.7rem;font-family:var(--font-head);font-weight:600;font-size:var(--fs-eyebrow);letter-spacing:.2em;text-transform:uppercase;color:var(--accent);margin-bottom:1.1rem;}
.eyebrow::before{content:"";width:30px;height:2px;border-radius:2px;background:var(--accent);}
.eyebrow--center{justify-content:center;}
.eyebrow-row{display:flex;justify-content:center;}
.section--ink .eyebrow{color:var(--brass-soft);}
.section--ink .eyebrow::before{background:var(--brass-soft);}

.section-head{max-width:62ch;margin-bottom:clamp(2.2rem,4vw,3.4rem);}
.section-head--center{margin-inline:auto;text-align:center;}
.section-title{font-size:var(--fs-h2);}
.section-intro{margin-top:1.1rem;color:var(--text-soft);font-size:var(--fs-lead);max-width:60ch;}
.section--ink .section-intro{color:#D8CBBA;}
.section-head--center .section-intro{margin-inline:auto;}

/* ---------------------------------------------------------------- 6. Buttons */
.btn{
  --btn-bg:var(--accent);--btn-fg:#fff;
  position:relative;display:inline-flex;align-items:center;justify-content:center;gap:.6rem;
  font-family:var(--font-head);font-weight:600;font-size:.94rem;line-height:1;
  min-height:54px;padding:0 1.7rem;border-radius:999px;color:var(--btn-fg);background:var(--btn-bg);
  overflow:hidden;isolation:isolate;
  transition:transform .35s var(--ease),box-shadow .35s var(--ease),background .35s var(--ease),color .35s var(--ease),border-color .35s var(--ease);
}
.btn svg{width:1.05em;height:1.05em;transition:transform .35s var(--ease);}
.btn::after{content:"";position:absolute;inset:0;z-index:-1;background:var(--accent-600);opacity:0;transition:opacity .35s var(--ease);}
.btn:hover{transform:translateY(-3px);box-shadow:var(--shadow-accent);}
.btn:hover::after{opacity:1;}
.btn:hover svg{transform:translateX(3px);}
.btn:active{transform:translateY(-1px);}
.btn--ghost{--btn-bg:transparent;--btn-fg:var(--ink);box-shadow:inset 0 0 0 1.5px var(--line-strong);}
.btn--ghost::after{display:none;}
.btn--ghost:hover{--btn-fg:#fff;background:var(--ink);box-shadow:inset 0 0 0 1.5px var(--ink);}
.btn--light{--btn-bg:#fff;--btn-fg:var(--ink);}
.btn--light::after{background:var(--accent);}
.btn--light:hover{--btn-fg:#fff;}
.btn--sm{min-height:46px;padding:0 1.25rem;font-size:.88rem;}
.btn--lg{min-height:60px;padding:0 2.1rem;font-size:1rem;}
.section--ink .btn--ghost{--btn-fg:#fff;box-shadow:inset 0 0 0 1.5px rgba(255,255,255,.3);}
.section--ink .btn--ghost:hover{background:#fff;--btn-fg:var(--ink);box-shadow:inset 0 0 0 1.5px #fff;}

.tlink{display:inline-flex;align-items:center;gap:.5rem;font-family:var(--font-head);font-weight:600;color:var(--ink);font-size:.95rem;}
.tlink svg{width:1.1em;height:1.1em;transition:transform .3s var(--ease);}
.tlink span{background-image:linear-gradient(var(--accent),var(--accent));background-size:0% 2px;background-position:0 100%;background-repeat:no-repeat;transition:background-size .35s var(--ease);padding-bottom:2px;}
.tlink:hover span{background-size:100% 2px;}
.tlink:hover svg{transform:translateX(4px);}
.section--ink .tlink{color:#fff;}

/* ----------------------------------------------------------------- 7. Header */
.site-header{position:fixed;inset:0 0 auto 0;z-index:100;transition:background .4s var(--ease),box-shadow .4s var(--ease),backdrop-filter .4s var(--ease);}
.header-bar{display:flex;align-items:center;justify-content:space-between;gap:1.5rem;height:var(--header-h);transition:height .4s var(--ease);}
.brand{display:flex;align-items:center;z-index:2;}
.brand img{height:56px;width:auto;transition:height .4s var(--ease);}
.brand .logo-light{display:block;}
.brand .logo-dark{display:none;}

/* transparent over banner */
.site-header{background:linear-gradient(180deg,rgba(33,28,25,.5),rgba(33,28,25,0));}
.site-header .nav-link{color:#fff;}
.site-header .nav-toggle span{background:#fff;}

/* scrolled / solid cream */
.site-header.is-fixed{background:rgba(251,247,240,.88);backdrop-filter:saturate(140%) blur(12px);-webkit-backdrop-filter:saturate(140%) blur(12px);box-shadow:0 1px 0 var(--line),0 12px 30px -22px rgba(40,28,20,.4);}
.site-header.is-fixed .header-bar{height:72px;}
.site-header.is-fixed .brand img{height:48px;}
.site-header.is-fixed .brand .logo-light{display:none;}
.site-header.is-fixed .brand .logo-dark{display:block;}
.site-header.is-fixed .nav-link{color:var(--cocoa);}
.site-header.is-fixed .nav-toggle span{background:var(--ink);}

/* always-solid (interior pages) */
.site-header.is-solid{background:rgba(251,247,240,.94);backdrop-filter:saturate(140%) blur(12px);-webkit-backdrop-filter:saturate(140%) blur(12px);box-shadow:0 1px 0 var(--line);}
.site-header.is-solid .nav-link{color:var(--cocoa);}
.site-header.is-solid .nav-toggle span{background:var(--ink);}
.site-header.is-solid .brand .logo-light{display:none;}
.site-header.is-solid .brand .logo-dark{display:block;}

.primary-nav{display:flex;align-items:center;gap:clamp(1rem,2.4vw,2.4rem);}
.nav-list{display:flex;align-items:center;gap:clamp(.6rem,1.8vw,1.9rem);}
.nav-link{position:relative;font-family:var(--font-head);font-weight:500;font-size:.96rem;padding:.4rem 0;transition:color .3s var(--ease);}
.nav-link::after{content:"";position:absolute;left:0;bottom:-2px;height:2px;width:100%;background:var(--accent);border-radius:2px;transform:scaleX(0);transform-origin:left;transition:transform .35s var(--ease);}
.nav-link:hover{color:var(--accent);}
.nav-link:hover::after,.nav-link.is-active::after{transform:scaleX(1);}
.nav-link.is-active{color:var(--accent);}
.header-cta{display:inline-flex;}
.nav-toggle{display:none;width:46px;height:46px;border-radius:12px;position:relative;z-index:120;flex-direction:column;gap:5px;align-items:center;justify-content:center;}
.nav-toggle span{display:block;width:24px;height:2px;border-radius:2px;transition:transform .3s var(--ease),opacity .25s var(--ease),background .3s var(--ease);}
.nav-scrim{position:fixed;inset:0;z-index:90;background:rgba(33,28,25,.5);opacity:0;visibility:hidden;transition:opacity .35s var(--ease),visibility .35s;backdrop-filter:blur(2px);}

@media (max-width:960px){
  .nav-toggle{display:flex;}
  .primary-nav{position:fixed;top:0;right:0;height:100dvh;width:min(86vw,360px);z-index:110;background:var(--espresso);flex-direction:column;align-items:stretch;justify-content:flex-start;gap:0;padding:calc(var(--header-h) + 1rem) 2rem 2rem;transform:translateX(100%);transition:transform .45s var(--ease-out);box-shadow:-30px 0 80px -30px rgba(0,0,0,.6);overflow-y:auto;}
  .nav-list{flex-direction:column;align-items:stretch;gap:0;}
  .nav-link{color:#fff!important;font-size:1.25rem;padding:1.05rem 0;border-bottom:1px solid rgba(255,255,255,.08);}
  .nav-link::after{display:none;}
  .nav-link.is-active{color:var(--brass-soft)!important;}
  .header-cta{margin-top:1.6rem;}
  .header-cta .btn{width:100%;}
  body.nav-open .primary-nav{transform:translateX(0);}
  body.nav-open .nav-scrim{opacity:1;visibility:visible;}
  body.nav-open{overflow:hidden;}
  body.nav-open .nav-toggle span{background:#fff!important;}
  body.nav-open .nav-toggle span:nth-child(1){transform:translateY(7px) rotate(45deg);}
  body.nav-open .nav-toggle span:nth-child(2){opacity:0;}
  body.nav-open .nav-toggle span:nth-child(3){transform:translateY(-7px) rotate(-45deg);}
}

/* ------------------------------------------------- 8. Banner (full-width slider) */
.hero.banner{position:relative;height:100svh;min-height:560px;background:var(--espresso);overflow:hidden;}
.banner-stage{position:absolute;inset:0;}
.hero-slide{position:absolute;inset:0;opacity:0;visibility:hidden;transition:opacity 1s var(--ease);}
.hero-slide.is-active{opacity:1;visibility:visible;}
.banner-bg{position:absolute;inset:0;background-size:cover;background-position:center;transform:scale(1.06);}
.hero-slide.is-active .banner-bg{animation:kenburns 9s ease-out forwards;}
@keyframes kenburns{from{transform:scale(1.12)}to{transform:scale(1)}}
.banner-veil{position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(28,22,18,.5) 0%,rgba(28,22,18,.2) 30%,rgba(28,22,18,.55) 70%,rgba(28,22,18,.8) 100%),
            linear-gradient(90deg,rgba(28,22,18,.78) 0%,rgba(28,22,18,.35) 50%,rgba(28,22,18,.1) 100%);}
.banner-inner{position:relative;z-index:3;height:100%;display:flex;align-items:center;padding-top:var(--header-h);}
.banner-content{max-width:680px;color:#fff;}
.banner-eyebrow{color:var(--brass-soft);}
.banner-eyebrow::before{background:var(--brass-soft);}
.banner-title{font-size:var(--fs-h1);color:#fff;font-weight:700;line-height:1.04;letter-spacing:-.02em;}
.banner-title b{color:var(--ember);font-weight:700;}
.banner-text{margin-top:1.3rem;font-size:var(--fs-lead);color:rgba(255,255,255,.86);max-width:50ch;}
.banner-actions{margin-top:2.1rem;display:flex;flex-wrap:wrap;gap:1rem;}
.banner .btn--ghost{--btn-fg:#fff;box-shadow:inset 0 0 0 1.5px rgba(255,255,255,.36);}
.banner .btn--ghost:hover{background:#fff;--btn-fg:var(--ink);box-shadow:inset 0 0 0 1.5px #fff;}

/* banner controls */
.banner-ui{position:absolute;z-index:4;left:0;right:0;bottom:clamp(1.4rem,4vh,2.6rem);}
.banner-ui .container{display:flex;align-items:center;gap:1.3rem;}
.banner-dots{display:flex;gap:.55rem;}
.banner-dots button{width:30px;height:4px;border-radius:4px;background:rgba(255,255,255,.3);transition:background .3s var(--ease),width .3s var(--ease);}
.banner-dots button.is-active{background:var(--accent);width:46px;}
.hero-count{font-family:var(--font-head);font-weight:700;color:#fff;font-size:.9rem;letter-spacing:.06em;white-space:nowrap;margin-left:auto;}
.hero-count .cur{color:var(--ember);}
.hero-count i{color:rgba(255,255,255,.4);font-style:normal;margin-inline:.35rem;}
.hero-count .total{color:rgba(255,255,255,.6);}
.banner-arrows{display:flex;gap:.5rem;}
.hero-arrow{width:48px;height:48px;border-radius:50%;display:grid;place-items:center;color:#fff;border:1.5px solid rgba(255,255,255,.3);transition:background .3s var(--ease),border-color .3s var(--ease),transform .3s var(--ease);}
.hero-arrow svg{width:19px;height:19px;}
.hero-arrow:hover{background:var(--accent);border-color:var(--accent);transform:translateY(-2px);}
.hero--empty .banner-bg{background:radial-gradient(120% 120% at 75% 10%,#3a322c,#1e1a17);transform:none;animation:none;}
@media (max-width:560px){
  .banner-arrows,.hero-count{display:none;}
  .banner-eyebrow{font-size:.68rem;letter-spacing:.13em;}
  .banner-actions{width:100%;}
  .banner-actions .btn{flex:1 1 100%;}
}

/* ------------------------------------------------- 9. Vision / Mission band */
.vm-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(1.5rem,4vw,4rem);}
.vm-card{position:relative;padding-left:2rem;}
.vm-card::before{content:"";position:absolute;left:0;top:.4rem;bottom:.4rem;width:3px;border-radius:3px;background:var(--accent);}
.vm-num{font-family:var(--font-head);font-weight:700;font-size:.85rem;letter-spacing:.2em;color:var(--brass-soft);display:block;margin-bottom:.6rem;}
.vm-card h3{font-size:var(--fs-h3);margin-bottom:.9rem;}
.vm-card p{color:#D8CBBA;font-size:1.05rem;}
.vm-grid--4{grid-template-columns:repeat(4,1fr);}
@media (max-width:900px){.vm-grid--4{grid-template-columns:repeat(2,1fr);}}
@media (max-width:760px){.vm-grid{grid-template-columns:1fr;}}
@media (max-width:520px){.vm-grid--4{grid-template-columns:1fr;}}

/* ----------------------------------------------- 10. About editorial + stats */
.about-split{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(2rem,5vw,5rem);align-items:center;}
.about-figure{position:relative;}
.about-figure .plate{position:relative;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-lg);background:var(--cream-2);}
.about-figure .plate img{width:100%;aspect-ratio:4/5;object-fit:cover;}
.about-figure .badge{position:absolute;right:-1.2rem;bottom:-1.2rem;background:var(--espresso);color:#fff;border-radius:var(--radius);padding:1.2rem 1.5rem;box-shadow:var(--shadow-lg);display:grid;gap:.2rem;}
.about-figure .badge b{font-family:var(--font-head);font-size:1.9rem;color:var(--ember);line-height:1;}
.about-figure .badge span{font-size:.82rem;color:#D8CBBA;letter-spacing:.04em;}
.about-figure::before{content:"";position:absolute;inset:auto auto -1.6rem -1.6rem;width:55%;height:55%;border:1.5px solid var(--brass);border-radius:var(--radius-lg);z-index:-1;opacity:.6;}
.about-body p{color:var(--text-soft);}
.about-body p + p{margin-top:1.1rem;}
.about-lead{font-size:var(--fs-lead);color:var(--text)!important;font-weight:400;}
.about-features{margin-top:1.8rem;display:grid;gap:1rem;}
.about-features li{display:flex;gap:.85rem;align-items:flex-start;}
.about-features .tick{flex:none;width:26px;height:26px;border-radius:50%;display:grid;place-items:center;background:rgba(209,68,42,.12);color:var(--accent);margin-top:.15rem;}
.about-features .tick svg{width:14px;height:14px;}
.about-features b{font-family:var(--font-head);}
@media (max-width:860px){.about-split{grid-template-columns:1fr;}.about-figure{max-width:460px;margin-inline:auto;}.about-figure .badge{right:0;}}

.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);}
.section--ink .stats{background:rgba(255,255,255,.12);border-color:rgba(255,255,255,.14);}
.stat{background:var(--surface);padding:clamp(2rem,3.2vw,3rem) 1.1rem;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.45rem;text-align:center;transition:background .4s var(--ease);}
.stat:hover{background:var(--cream);}
.section--ink .stat{background:var(--cocoa);}
.section--ink .stat:hover{background:#473b33;}
.stat::before{content:"";width:0;height:3px;border-radius:3px;background:var(--accent);margin-bottom:.55rem;transition:width .45s var(--ease);}
.stat:hover::before{width:34px;}
.stat-num{display:inline-flex;align-items:baseline;font-family:var(--font-head);font-weight:700;line-height:1;color:var(--ink);white-space:nowrap;}
.section--ink .stat-num{color:#fff;}
.stat-val{font-size:clamp(2.4rem,1.4rem + 2.4vw,3.5rem);font-variant-numeric:tabular-nums;}
.stat-suffix{font-size:clamp(1.3rem,.9rem + 1.1vw,1.9rem);color:var(--accent);font-weight:700;margin-left:.08em;}
.stat-label{font-size:.8rem;letter-spacing:.12em;text-transform:uppercase;color:var(--text-faint);font-weight:500;}
.section--ink .stat-label{color:#C9BBA9;}
@media (max-width:760px){.stats{grid-template-columns:repeat(2,1fr);}}

/* ----------------------------------------------------- 11. Feature/cap cards */
.feat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:clamp(1rem,1.8vw,1.4rem);}
.feat-card{position:relative;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:1.9rem 1.6rem 1.7rem;overflow:hidden;transition:transform .45s var(--ease),box-shadow .45s var(--ease),border-color .45s var(--ease);}
.feat-card::before{content:"";position:absolute;left:0;top:0;height:100%;width:3px;background:var(--accent);transform:scaleY(0);transform-origin:top;transition:transform .45s var(--ease);}
.feat-card:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:transparent;}
.feat-card:hover::before{transform:scaleY(1);}
.feat-card__ic{width:56px;height:56px;border-radius:16px;display:grid;place-items:center;background:rgba(209,68,42,.1);color:var(--accent);margin-bottom:1.2rem;transition:background .4s var(--ease),color .4s var(--ease),transform .4s var(--ease);}
.feat-card__ic svg{width:27px;height:27px;}
.feat-card:hover .feat-card__ic{background:var(--accent);color:#fff;transform:rotate(-6deg);}
.feat-card h3{font-size:1.18rem;margin-bottom:.55rem;}
.feat-card p{color:var(--text-soft);font-size:.96rem;}

/* ------------------------------------------------- 12. Services image cards */
.svc-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:clamp(1.1rem,2vw,1.6rem);}
.svc-card{position:relative;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;display:flex;flex-direction:column;transition:transform .45s var(--ease),box-shadow .45s var(--ease),border-color .45s var(--ease);}
.svc-card:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:transparent;}
.svc-card__media{aspect-ratio:16/11;overflow:hidden;background:var(--cream-2);position:relative;}
.svc-card__media img{width:100%;height:100%;object-fit:cover;transition:transform .7s var(--ease);}
.svc-card:hover .svc-card__media img{transform:scale(1.07);}
.svc-card__body{padding:1.5rem 1.5rem 1.7rem;display:flex;flex-direction:column;flex:1;}
.svc-card__body h3{font-size:1.2rem;margin-bottom:.6rem;}
.svc-card__body p{color:var(--text-soft);font-size:.98rem;margin-bottom:1.1rem;}
.svc-card__more{margin-top:auto;display:inline-flex;align-items:center;gap:.5rem;color:var(--accent);font-family:var(--font-head);font-weight:600;font-size:.9rem;}
.svc-card__more svg{width:1.05em;height:1.05em;transition:transform .3s var(--ease);}
.svc-card:hover .svc-card__more svg{transform:translateX(4px);}
.svc-card__line{height:3px;width:0;background:var(--accent);transition:width .45s var(--ease);}
.svc-card:hover .svc-card__line{width:100%;}
.svc-card__num{position:absolute;top:1rem;left:1rem;z-index:2;font-family:var(--font-head);font-weight:700;font-size:.8rem;letter-spacing:.1em;color:#fff;background:rgba(33,28,25,.55);backdrop-filter:blur(4px);padding:.35rem .6rem;border-radius:8px;}

/* ------------------------------------------------- 13. Projects + lightbox */
.filter-bar{display:flex;flex-wrap:wrap;gap:.6rem;margin-bottom:2rem;}
.chip{font-family:var(--font-head);font-weight:500;font-size:.88rem;padding:.55rem 1.1rem;border-radius:999px;border:1px solid var(--line-strong);color:var(--text-soft);transition:all .3s var(--ease);}
.chip:hover{border-color:var(--ink);color:var(--ink);}
.chip.is-active{background:var(--ink);color:#fff;border-color:var(--ink);}
.gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(.8rem,1.4vw,1.2rem);}
.gallery--home{grid-template-columns:repeat(4,1fr);}
.g-item{position:relative;border-radius:var(--radius);overflow:hidden;background:var(--cream-2);aspect-ratio:4/3;cursor:pointer;border:1px solid var(--line);transition:transform .4s var(--ease),box-shadow .4s var(--ease);}
.g-item img{width:100%;height:100%;object-fit:cover;transition:transform .7s var(--ease);}
.g-item:hover{box-shadow:var(--shadow);transform:translateY(-4px);}
.g-item:hover img{transform:scale(1.08);}
.g-item__overlay{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:flex-end;padding:1.2rem;color:#fff;background:linear-gradient(180deg,rgba(28,22,18,0) 40%,rgba(28,22,18,.82) 100%);opacity:0;transform:translateY(8px);transition:opacity .4s var(--ease),transform .4s var(--ease);}
.g-item:hover .g-item__overlay{opacity:1;transform:translateY(0);}
.g-item__cat{font-family:var(--font-head);font-weight:600;font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--brass-soft);margin-bottom:.3rem;}
.g-item__title{font-family:var(--font-head);font-weight:600;font-size:1.05rem;}
.g-item__zoom{position:absolute;top:1rem;right:1rem;width:40px;height:40px;border-radius:50%;background:var(--accent);color:#fff;display:grid;place-items:center;opacity:0;transform:scale(.6);transition:opacity .4s var(--ease),transform .4s var(--ease);}
.g-item:hover .g-item__zoom{opacity:1;transform:scale(1);}
.g-item__zoom svg{width:18px;height:18px;}
.g-item.is-hidden{display:none;}
@media (max-width:900px){.gallery,.gallery--home{grid-template-columns:repeat(2,1fr);}}
@media (max-width:520px){.gallery,.gallery--home{grid-template-columns:1fr;}}

.lightbox{position:fixed;inset:0;z-index:300;display:flex;align-items:center;justify-content:center;padding:clamp(1rem,4vw,3rem);background:rgba(20,15,12,.93);backdrop-filter:blur(6px);opacity:0;visibility:hidden;transition:opacity .35s var(--ease),visibility .35s;}
.lightbox.is-open{opacity:1;visibility:visible;}
.lightbox__img{max-width:100%;max-height:82vh;border-radius:var(--radius);box-shadow:var(--shadow-lg);transform:scale(.96);transition:transform .4s var(--ease-out);}
.lightbox.is-open .lightbox__img{transform:scale(1);}
.lightbox__cap{position:absolute;left:0;right:0;bottom:clamp(1rem,3vw,2rem);text-align:center;color:#fff;font-family:var(--font-head);font-weight:500;}
.lightbox__cap em{color:var(--brass-soft);font-style:normal;display:block;font-size:.75rem;letter-spacing:.16em;text-transform:uppercase;margin-bottom:.25rem;}
.lb-btn{position:absolute;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.18);color:#fff;width:52px;height:52px;border-radius:50%;display:grid;place-items:center;transition:background .3s var(--ease),transform .3s var(--ease);}
.lb-btn:hover{background:var(--accent);transform:scale(1.06);}
.lb-btn svg{width:22px;height:22px;}
.lb-close{top:clamp(1rem,3vw,2rem);right:clamp(1rem,3vw,2rem);}
.lb-prev{left:clamp(.6rem,2vw,2rem);top:50%;transform:translateY(-50%);}
.lb-next{right:clamp(.6rem,2vw,2rem);top:50%;transform:translateY(-50%);}
.lb-prev:hover,.lb-next:hover{transform:translateY(-50%) scale(1.06);}
@media (max-width:560px){.lb-prev,.lb-next{top:auto;bottom:clamp(1rem,3vw,2rem);transform:none;}.lb-prev{left:clamp(1rem,6vw,2rem);}.lb-next{right:clamp(1rem,6vw,2rem);}.lb-prev:hover,.lb-next:hover{transform:scale(1.06);}}

/* ----------------------------------------------------------- 14. Clients */
.clients{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:clamp(2rem,5vw,4.5rem);}
.clients img{height:clamp(46px,6vw,68px);width:auto;object-fit:contain;filter:grayscale(1);opacity:.55;transition:filter .4s var(--ease),opacity .4s var(--ease),transform .4s var(--ease);}
.clients img:hover{filter:grayscale(0);opacity:1;transform:scale(1.05);}

/* ------------------------------------------------------------- 15. CTA band */
.cta{position:relative;overflow:hidden;background:var(--espresso);color:#fff;border-radius:clamp(18px,3vw,30px);padding:clamp(2.5rem,6vw,5rem);}
.cta::before{content:"";position:absolute;width:520px;height:520px;right:-120px;top:-160px;border-radius:50%;background:radial-gradient(circle,rgba(236,106,67,.5),rgba(209,68,42,0) 70%);}
.cta::after{content:"";position:absolute;inset:0;background:linear-gradient(120deg,rgba(209,68,42,.1),transparent 55%);}
.cta-inner{position:relative;z-index:2;display:flex;align-items:center;justify-content:space-between;gap:2rem;flex-wrap:wrap;}
.cta h2{font-size:var(--fs-h2);color:#fff;max-width:18ch;}
.cta p{color:#D8CBBA;margin-top:.8rem;max-width:46ch;}
.cta .btn{flex:none;}
@media (max-width:760px){.cta-inner{flex-direction:column;align-items:flex-start;}}

/* ------------------------------------------------ 16. Interior page banner */
.page-banner{position:relative;padding-top:calc(var(--header-h) + clamp(3rem,7vw,6rem));padding-bottom:clamp(3rem,7vw,6rem);background:var(--espresso);color:#fff;overflow:hidden;}
.page-banner__bg{position:absolute;inset:0;background-size:cover;background-position:center;opacity:.32;}
.page-banner::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(28,22,18,.85),rgba(28,22,18,.45));}
.page-banner__in{position:relative;z-index:2;}
.page-banner h1{font-size:var(--fs-h1);color:#fff;}
.breadcrumb{display:flex;gap:.5rem;align-items:center;color:#C9BBA9;font-size:.9rem;margin-top:1rem;}
.breadcrumb a:hover{color:#fff;}
.breadcrumb .sep{color:#8a7d6e;}
.breadcrumb .here{color:var(--brass-soft);}

/* ------------------------------------------------------------- 17. Contact */
.contact-grid{display:grid;grid-template-columns:1.2fr .8fr;gap:clamp(1.5rem,4vw,3.5rem);align-items:start;}
@media (max-width:900px){.contact-grid{grid-template-columns:1fr;}}
.form-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);padding:clamp(1.5rem,4vw,2.6rem);box-shadow:var(--shadow-sm);}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1.1rem;}
@media (max-width:540px){.form-row{grid-template-columns:1fr;}}
.field{position:relative;margin-top:1.1rem;}
.field input,.field textarea{width:100%;background:var(--cream);border:1.5px solid var(--line);border-radius:var(--radius-sm);padding:1.35rem 1rem .55rem;transition:border-color .3s var(--ease),background .3s var(--ease),box-shadow .3s var(--ease);}
.field textarea{min-height:140px;resize:vertical;padding-top:1.6rem;}
.field label{position:absolute;left:1rem;top:1rem;color:var(--text-faint);pointer-events:none;transition:transform .25s var(--ease),color .25s var(--ease),font-size .25s var(--ease);transform-origin:left;}
.field input:focus,.field textarea:focus{border-color:var(--accent);background:#fff;box-shadow:0 0 0 4px rgba(209,68,42,.1);}
.field input:focus + label,.field textarea:focus + label,
.field input:not(:placeholder-shown) + label,.field textarea:not(:placeholder-shown) + label{transform:translateY(-.75rem) scale(.78);color:var(--accent);}
.field input::placeholder,.field textarea::placeholder{color:transparent;}
.field.has-error input,.field.has-error textarea{border-color:#c5301f;background:#fdf3f1;}
.field__err{display:none;color:#b4291c;font-size:.8rem;margin-top:.35rem;}
.field.has-error .field__err{display:block;}
/* valid / success state — green */
.field.is-valid input,.field.is-valid textarea{border-color:#3f9d52;background:#fff;padding-right:2.6rem;}
.field.is-valid input:focus,.field.is-valid textarea:focus{border-color:#3f9d52;box-shadow:0 0 0 4px rgba(63,157,82,.13);}
.field.is-valid input + label,.field.is-valid textarea + label{color:#3f9d52;}
.field.is-valid::after{content:"";position:absolute;right:1rem;top:1.15rem;width:20px;height:20px;border-radius:50%;background:#3f9d52;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='3.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M5 12l5 5L20 7'/%3E%3C/svg%3E");
  background-size:13px;background-position:center;background-repeat:no-repeat;animation:pop .3s var(--ease-out);}
@keyframes pop{from{transform:scale(0);opacity:0}to{transform:scale(1);opacity:1}}
.form-foot{margin-top:1.5rem;display:flex;align-items:center;gap:1rem;flex-wrap:wrap;}
.form-note{color:var(--text-faint);font-size:.85rem;}
.form-alert{display:none;border-radius:var(--radius-sm);padding:.9rem 1.1rem;margin-bottom:1.2rem;font-size:.95rem;}
.form-alert.is-ok{display:block;background:#eef6ec;color:#2c6b30;border:1px solid #cfe6cd;}
.form-alert.is-bad{display:block;background:#fdeeec;color:#b4291c;border:1px solid #f6ccc6;}
.contact-aside{display:grid;gap:1rem;}
.contact-item{display:flex;gap:1rem;align-items:flex-start;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:1.2rem 1.3rem;transition:border-color .3s var(--ease),transform .3s var(--ease);}
.contact-item:hover{transform:translateY(-3px);border-color:var(--line-strong);}
.contact-item .ic{flex:none;width:46px;height:46px;border-radius:12px;display:grid;place-items:center;background:rgba(209,68,42,.1);color:var(--accent);}
.contact-item .ic svg{width:20px;height:20px;}
.contact-item h4{font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;color:var(--text-faint);font-weight:600;margin-bottom:.25rem;}
.contact-item p,.contact-item a{color:var(--text);font-size:1rem;line-height:1.5;}
.contact-item a:hover{color:var(--accent);}

/* -------------------------------------------------------------- 18. Footer */
.site-footer{background:var(--espresso);color:#C9BBA9;}
.footer-top{padding-block:clamp(3rem,6vw,5rem);display:grid;grid-template-columns:1.5fr 1fr 1fr 1.2fr;gap:clamp(1.8rem,4vw,3rem);}
@media (max-width:960px){.footer-top{grid-template-columns:1fr 1fr;}}
@media (max-width:540px){.footer-top{grid-template-columns:1fr;}}
.footer-brand img{height:64px;width:auto;margin-bottom:1.2rem;}
.footer-brand p{color:#A99C8C;max-width:34ch;font-size:.96rem;}
.footer-col h4{color:#fff;font-size:.8rem;letter-spacing:.14em;text-transform:uppercase;margin-bottom:1.2rem;font-weight:600;}
.footer-col ul{display:grid;gap:.7rem;}
.footer-col a{color:#C9BBA9;font-size:.96rem;transition:color .25s var(--ease);display:inline-flex;align-items:center;gap:.5rem;}
.footer-col a:hover{color:#fff;}
.footer-col a:hover .dot{background:var(--accent);}
.footer-col .dot{width:5px;height:5px;border-radius:50%;background:#6c5f50;transition:background .25s var(--ease);flex:none;}
.footer-contact li{display:flex;gap:.65rem;align-items:flex-start;color:#C9BBA9;font-size:.96rem;margin-bottom:.85rem;}
.footer-contact svg{width:17px;height:17px;color:var(--ember);flex:none;margin-top:.2rem;}
.footer-contact a:hover{color:#fff;}
.socials{display:flex;gap:.6rem;margin-top:1.4rem;}
.socials a{width:42px;height:42px;border-radius:50%;display:grid;place-items:center;border:1px solid rgba(255,255,255,.14);color:#C9BBA9;transition:all .3s var(--ease);}
.socials a:hover{background:var(--accent);border-color:var(--accent);color:#fff;transform:translateY(-3px);}
.socials svg{width:18px;height:18px;}
.footer-bottom{border-top:1px solid rgba(255,255,255,.08);padding-block:1.5rem;display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap;}
.footer-bottom p{font-size:.88rem;color:#A99C8C;}
.footer-bottom .tag{font-size:.82rem;color:#8a7d6e;letter-spacing:.04em;}
.footer-bottom .tag b{color:var(--brass-soft);font-weight:600;}

/* --------------------------------------------------------- 19. Motion/reveal */
[data-reveal]{opacity:0;transform:translateY(26px);transition:opacity .7s var(--ease-out),transform .7s var(--ease-out);will-change:opacity,transform;}
[data-reveal].is-in{opacity:1;transform:none;}
[data-reveal="left"]{transform:translateX(-30px);}
[data-reveal="right"]{transform:translateX(30px);}
[data-reveal="scale"]{transform:scale(.94);}
[data-reveal].is-in{transform:none;}
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto!important;}
  [data-reveal]{opacity:1!important;transform:none!important;}
  .banner-bg{animation:none!important;transform:none!important;}
}

/* --------------------------------------------------------- 20. Utilities */
.empty-state{text-align:center;max-width:46ch;margin-inline:auto;padding:clamp(2.5rem,6vw,4rem) 1rem;color:var(--text-faint);}
.empty-state .ic{width:60px;height:60px;border-radius:50%;background:var(--cream-2);display:grid;place-items:center;margin:0 auto 1.2rem;color:var(--text-faint);}
.empty-state h3{color:var(--cocoa);margin-bottom:.5rem;}
.center{text-align:center;}
.mt-xl{margin-top:clamp(2rem,4vw,3.2rem);}
.mt-2xl{margin-top:clamp(3rem,6vw,5rem);}
.no-scroll{overflow:hidden;}
.img-failed{background:linear-gradient(135deg,var(--cream-2),var(--sand))!important;}
.img-failed img{visibility:hidden;}
.img-failed::after{content:"TNT";position:absolute;inset:0;display:grid;place-items:center;font-family:var(--font-head);font-weight:700;letter-spacing:.28em;color:var(--text-faint);font-size:1.1rem;}
