/* =============================================================
   The Duch Barber — Salon & Supplies
   Premium dark editorial stylesheet
   ============================================================= */

:root{
  --ink:#0d1017;          /* near-black canvas            */
  --ink-2:#0a0c12;        /* deepest                      */
  --panel:#14181f;        /* charcoal panel               */
  --panel-2:#1a1f28;      /* raised panel                 */
  --line:rgba(255,255,255,.09);
  --line-strong:rgba(255,255,255,.16);

  --blue:#173aa8;         /* royal blue — primary accent  */
  --blue-lift:#2a55d8;    /* brighter blue for hover      */
  --gold:#d9b24c;         /* refined gold                 */
  --gold-hi:#f2d68a;      /* gold highlight               */
  --gold-lo:#a67c2e;      /* gold shadow                  */
  --red:#d1272e;          /* barber-pole red (sparing)    */

  --white:#f6f8fc;
  --text:#cdd4e0;         /* body text                    */
  --muted:#8b93a4;        /* muted / captions             */

  --gold-grad:linear-gradient(135deg,#a67c2e 0%,#f2d68a 45%,#d9b24c 60%,#8a6522 100%);
  --chrome-grad:linear-gradient(180deg,#f3f6fb 0%,#c2ccda 38%,#8b96a8 55%,#e6ebf3 78%,#9aa5b7 100%);

  --shadow-sm:0 6px 20px rgba(0,0,0,.35);
  --shadow-md:0 18px 50px rgba(0,0,0,.5);
  --shadow-lg:0 40px 90px rgba(0,0,0,.6);

  --wrap:1200px;
  --radius:6px;
  --header-h:74px;

  --ease:cubic-bezier(.22,.61,.36,1);
}

/* ---------- reset ---------- */
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  margin:0;
  font-family:"Inter",system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;
  color:var(--text);
  background:var(--ink);
  line-height:1.65;
  font-size:17px;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{
  font-family:"Oswald",Impact,sans-serif;
  font-weight:600;
  line-height:1.05;
  color:var(--white);
  margin:0 0 .5em;
  letter-spacing:.01em;
}
p{margin:0 0 1em}
::selection{background:var(--blue);color:#fff}

/* ---------- layout ---------- */
.wrap{width:min(100% - 40px,var(--wrap));margin-inline:auto}
.center{text-align:center}
section{padding:clamp(56px,9vw,120px) 0}
section.alt{background:
  radial-gradient(140% 100% at 50% 0%,rgba(23,58,168,.08),transparent 60%),
  var(--ink-2);
  border-block:1px solid var(--line);
}

/* ---------- shared accents ---------- */
.eyebrow{
  display:inline-flex;align-items:center;gap:.7em;
  font-family:"Oswald",sans-serif;font-weight:600;font-size:.8rem;
  letter-spacing:.32em;text-transform:uppercase;
  color:var(--gold);margin:0 0 1rem;
}
.eyebrow::before{
  content:"";width:34px;height:2px;
  background:var(--gold-grad);
}
.eyebrow.center-line{justify-content:center}
.eyebrow.center-line::after{
  content:"";width:34px;height:2px;background:var(--gold-grad);
}

.rule-gold{
  border:0;height:1px;margin:0;
  background:linear-gradient(90deg,transparent,rgba(217,178,76,.55),transparent);
}

.pole-stripe{
  height:5px;width:100%;
  background:repeating-linear-gradient(115deg,
    var(--red) 0 11px,#f3f4f7 11px 22px,var(--blue) 22px 33px);
  opacity:.92;
}

.section-head{max-width:720px;margin:0 0 clamp(30px,5vw,56px)}
.section-head.center{margin-inline:auto;text-align:center}
.section-head h2{font-size:clamp(2rem,4.4vw,3.15rem);text-transform:uppercase}
.section-head p{color:var(--muted);font-size:1.06rem;margin-bottom:0}

.lead{font-size:clamp(1.05rem,1.6vw,1.25rem);color:#dde3ee;max-width:56ch}

/* ---------- buttons ---------- */
.btn{
  --btn-bg:var(--blue);--btn-fg:#fff;--btn-bd:transparent;
  display:inline-flex;align-items:center;justify-content:center;gap:.55em;
  font-family:"Oswald",sans-serif;font-weight:500;font-size:.92rem;
  letter-spacing:.14em;text-transform:uppercase;
  padding:.92em 1.5em;border-radius:var(--radius);
  background:var(--btn-bg);color:var(--btn-fg);
  border:1px solid var(--btn-bd);cursor:pointer;
  transition:transform .3s var(--ease),box-shadow .3s var(--ease),
             background .3s var(--ease),border-color .3s var(--ease),color .3s var(--ease);
  will-change:transform;
}
.btn .i{width:1.1em;height:1.1em;flex:none}
.btn:hover,.btn:focus-visible{transform:translateY(-3px)}
.btn-primary{--btn-bg:var(--blue);box-shadow:0 12px 30px rgba(23,58,168,.4)}
.btn-primary:hover,.btn-primary:focus-visible{--btn-bg:var(--blue-lift);box-shadow:0 18px 40px rgba(42,85,216,.5)}
.btn-gold{--btn-fg:#1a130a;background:var(--gold-grad);box-shadow:0 12px 30px rgba(217,178,76,.28)}
.btn-gold:hover,.btn-gold:focus-visible{box-shadow:0 18px 40px rgba(217,178,76,.42)}
.btn-red{--btn-bg:var(--red);box-shadow:0 12px 30px rgba(209,39,46,.32)}
.btn-red:hover,.btn-red:focus-visible{--btn-bg:#e33a41;box-shadow:0 18px 40px rgba(209,39,46,.45)}
.btn-ghost{--btn-bg:transparent;--btn-fg:var(--white);--btn-bd:var(--line-strong);backdrop-filter:blur(4px)}
.btn-ghost:hover,.btn-ghost:focus-visible{--btn-bd:var(--gold);--btn-fg:var(--gold)}

/* focus ring */
a:focus-visible,button:focus-visible,.btn:focus-visible{
  outline:2px solid var(--gold);outline-offset:3px;
}

/* ---------- header ---------- */
.site-header{
  position:fixed;inset:0 0 auto;z-index:60;
  background:rgba(13,16,23,.5);
  backdrop-filter:saturate(150%) blur(16px);
  -webkit-backdrop-filter:saturate(150%) blur(16px);
  border-bottom:1px solid var(--line);
  transition:background .35s var(--ease),box-shadow .35s var(--ease),border-color .35s var(--ease);
}
.site-header.scrolled{
  background:rgba(9,11,17,.92);
  box-shadow:0 12px 34px rgba(0,0,0,.45);
  border-bottom-color:rgba(217,178,76,.22);
}
.header-inner{
  display:flex;align-items:center;justify-content:space-between;gap:18px;
  min-height:var(--header-h);
}

/* brand lockup */
.brand{display:inline-flex;align-items:center;gap:14px}
.brand-chip{
  --sz:46px;width:var(--sz);height:var(--sz);flex:none;
  border-radius:50%;overflow:hidden;position:relative;
  background:#fff;
  box-shadow:0 0 0 1px rgba(255,255,255,.18),0 0 0 4px rgba(217,178,76,.28),var(--shadow-sm);
}
.brand-chip img{
  position:absolute;top:50%;left:0;
  width:106.4%;              /* crops stray right ~6% strip */
  transform:translateY(-50%);
  max-width:none;
}
.brand-word{display:flex;flex-direction:column;line-height:1}
.brand-word b{
  font-family:"Oswald",sans-serif;font-weight:600;font-size:1.16rem;
  letter-spacing:.12em;text-transform:uppercase;color:var(--white);
}
.brand-word i{
  font-family:"Oswald",sans-serif;font-style:normal;font-weight:400;
  font-size:.62rem;letter-spacing:.34em;text-transform:uppercase;color:var(--gold);
  margin-top:3px;
}

/* nav */
.site-nav{display:flex;align-items:center;gap:6px}
.site-nav a{
  font-family:"Oswald",sans-serif;font-weight:400;font-size:.92rem;
  letter-spacing:.14em;text-transform:uppercase;color:var(--text);
  padding:.55em .8em;border-radius:4px;position:relative;
  transition:color .25s var(--ease);
}
.site-nav a:not(.btn)::after{
  content:"";position:absolute;left:.8em;right:.8em;bottom:.28em;height:1.5px;
  background:var(--gold-grad);transform:scaleX(0);transform-origin:left;
  transition:transform .3s var(--ease);
}
.site-nav a:not(.btn):hover,.site-nav a:not(.btn):focus-visible{color:var(--white)}
.site-nav a:not(.btn):hover::after,.site-nav a:not(.btn):focus-visible::after{transform:scaleX(1)}
.site-nav a[aria-current="page"]{color:var(--white)}
.site-nav a[aria-current="page"]::after{transform:scaleX(1)}
.site-nav .btn{margin-left:10px;padding:.62em 1.25em}

.nav-toggle{
  display:none;background:transparent;border:1px solid var(--line-strong);
  color:var(--white);width:46px;height:46px;border-radius:8px;
  font-size:1.35rem;line-height:1;cursor:pointer;transition:border-color .25s,color .25s;
}
.nav-toggle:hover{border-color:var(--gold);color:var(--gold)}

/* ---------- hero ---------- */
.hero{
  position:relative;min-height:100svh;display:flex;align-items:center;
  overflow:hidden;isolation:isolate;
  padding-top:var(--header-h);
}
.hero__img{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center;
  z-index:-2;animation:kenburns 26s ease-in-out infinite alternate;will-change:transform;
}
@keyframes kenburns{from{transform:scale(1.05)}to{transform:scale(1.18) translate(1.5%,-1%)}}
.hero__scrim{
  position:absolute;inset:0;z-index:-1;
  background:
    radial-gradient(130% 90% at 18% 26%,rgba(23,58,168,.28),transparent 55%),
    linear-gradient(180deg,rgba(8,10,16,.72) 0%,rgba(8,10,16,.42) 38%,rgba(8,10,16,.9) 100%);
}
.hero__inner{position:relative;z-index:1;padding:60px 0 90px;max-width:820px}
.hero__medallion{
  --sz:96px;display:block;width:var(--sz);height:var(--sz);border-radius:50%;overflow:hidden;
  background:#fff;position:relative;margin-bottom:26px;
  box-shadow:0 0 0 1px rgba(255,255,255,.2),0 0 0 6px rgba(217,178,76,.3),var(--shadow-md);
}
.hero__medallion img{position:absolute;top:50%;left:0;width:106.4%;transform:translateY(-50%);max-width:none}
.hero .tagline{
  font-family:"Oswald",sans-serif;font-weight:500;font-size:clamp(.85rem,2.4vw,1.05rem);
  letter-spacing:.3em;text-transform:uppercase;color:var(--gold);margin:0 0 .9rem;
}
.hero h1{
  font-size:clamp(2.7rem,7.4vw,5.6rem);text-transform:uppercase;font-weight:700;
  letter-spacing:.005em;text-shadow:0 6px 40px rgba(0,0,0,.55);margin-bottom:.35em;
}
.hero h1 .accent{color:transparent;background:var(--gold-grad);-webkit-background-clip:text;background-clip:text}
.hero .lead{color:#e6eaf2;margin-bottom:2rem;text-shadow:0 2px 20px rgba(0,0,0,.5)}
.hero-actions{display:flex;flex-wrap:wrap;gap:14px}
.hero__pole{position:absolute;left:0;right:0;bottom:0;z-index:1}
.hero__scroll{
  position:absolute;left:50%;bottom:26px;transform:translateX(-50%);z-index:1;
  display:flex;flex-direction:column;align-items:center;gap:8px;
  font-family:"Oswald",sans-serif;font-size:.66rem;letter-spacing:.3em;text-transform:uppercase;color:var(--muted);
}
.hero__scroll span{width:1px;height:38px;background:linear-gradient(var(--gold),transparent);animation:scrollcue 2.2s ease-in-out infinite}
@keyframes scrollcue{0%,100%{opacity:.3;transform:scaleY(.6)}50%{opacity:1;transform:scaleY(1)}}

/* ---------- marquee / offerings strip ---------- */
.strip{background:var(--ink-2);border-block:1px solid var(--line)}
.strip .wrap{
  display:flex;flex-wrap:wrap;justify-content:center;align-items:center;
  gap:clamp(18px,4vw,56px);padding:26px 0;
}
.strip .item{
  display:inline-flex;align-items:center;gap:.6em;
  font-family:"Oswald",sans-serif;font-weight:500;font-size:clamp(.95rem,2vw,1.15rem);
  letter-spacing:.16em;text-transform:uppercase;color:var(--white);
}
.strip .item .dot{width:7px;height:7px;border-radius:50%;background:var(--gold-grad);flex:none}

/* ---------- editorial split ---------- */
.split{
  display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(30px,5vw,70px);align-items:center;
}
.split.reverse{direction:rtl}
.split.reverse>*{direction:ltr}
.split-media{position:relative}
.split-media img{
  width:100%;height:100%;max-height:560px;object-fit:cover;border-radius:var(--radius);
  box-shadow:var(--shadow-md);
}
.split-media::before{
  content:"";position:absolute;inset:14px -14px -14px 14px;z-index:-1;
  border:1px solid rgba(217,178,76,.4);border-radius:var(--radius);
}
.split-body h2{font-size:clamp(1.9rem,4vw,2.9rem);text-transform:uppercase}
.split-body .btn{margin-top:.6rem}

/* ---------- feature cards ---------- */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.card{
  position:relative;overflow:hidden;border-radius:var(--radius);
  border:1px solid var(--line);background:var(--panel);
  box-shadow:var(--shadow-sm);isolation:isolate;
  transition:transform .4s var(--ease),box-shadow .4s var(--ease),border-color .4s var(--ease);
  min-height:340px;display:flex;flex-direction:column;justify-content:flex-end;
}
.card__img{position:absolute;inset:0;z-index:-2;width:100%;height:100%;object-fit:cover;
  transition:transform .7s var(--ease)}
.card__scrim{position:absolute;inset:0;z-index:-1;
  background:linear-gradient(180deg,rgba(13,16,23,.15) 0%,rgba(13,16,23,.55) 55%,rgba(13,16,23,.95) 100%)}
.card__body{padding:26px}
.card h3{font-size:1.5rem;text-transform:uppercase;margin-bottom:.35em}
.card p{color:var(--text);margin-bottom:1em;font-size:.98rem}
.card .more{
  font-family:"Oswald",sans-serif;font-size:.85rem;letter-spacing:.16em;text-transform:uppercase;
  color:var(--gold);display:inline-flex;align-items:center;gap:.5em;
  transition:gap .3s var(--ease),color .3s var(--ease);
}
.card:hover,.card:focus-within{transform:translateY(-8px);box-shadow:var(--shadow-lg);border-color:rgba(217,178,76,.35)}
.card:hover .card__img,.card:focus-within .card__img{transform:scale(1.07)}
.card:hover .more,.card:focus-within .more{gap:.85em;color:var(--gold-hi)}
.card__top-accent{position:absolute;top:0;left:0;right:0;height:3px;background:var(--gold-grad);
  transform:scaleX(0);transform-origin:left;transition:transform .5s var(--ease);z-index:1}
.card:hover .card__top-accent,.card:focus-within .card__top-accent{transform:scaleX(1)}

/* ---------- info / hours strip ---------- */
.info-strip{position:relative;overflow:hidden;isolation:isolate;text-align:center;
  padding:clamp(64px,10vw,120px) 0}
.info-strip__img{position:absolute;inset:0;z-index:-2;width:100%;height:100%;object-fit:cover;filter:grayscale(.2)}
.info-strip__scrim{position:absolute;inset:0;z-index:-1;
  background:linear-gradient(180deg,rgba(8,10,16,.9),rgba(8,10,16,.82)),
  radial-gradient(100% 100% at 50% 0,rgba(23,58,168,.2),transparent 60%)}
.info-strip h2{font-size:clamp(2rem,5vw,3.4rem);text-transform:uppercase}
.info-strip .hours{font-family:"Oswald",sans-serif;letter-spacing:.14em;text-transform:uppercase;
  color:var(--gold);font-size:clamp(.9rem,2vw,1.1rem);margin-bottom:1.8rem}
.info-strip .hero-actions{justify-content:center}

/* ---------- interior page banner ---------- */
.banner{
  position:relative;isolation:isolate;
  padding:calc(var(--header-h) + clamp(56px,12vw,110px)) 0 clamp(40px,7vw,72px);
  background:var(--banner-img,linear-gradient(160deg,#171c25,#0d1017)) center/cover no-repeat fixed;
}
.banner::before{content:"";position:absolute;inset:0;z-index:-1;
  background:linear-gradient(180deg,rgba(8,10,16,.72) 0%,rgba(8,10,16,.6) 40%,rgba(8,10,16,.92) 100%),
  radial-gradient(120% 90% at 15% 20%,rgba(23,58,168,.22),transparent 55%)}
.banner h1{font-size:clamp(2.4rem,6.4vw,4.4rem);text-transform:uppercase;text-shadow:0 6px 34px rgba(0,0,0,.5)}
.banner p{color:var(--gold);font-family:"Oswald",sans-serif;letter-spacing:.24em;text-transform:uppercase;
  font-size:clamp(.82rem,2vw,1rem);margin:0}
.banner .pole-stripe{position:absolute;left:0;right:0;bottom:0}

/* ---------- prose (about) ---------- */
.prose{max-width:74ch}
.prose p{color:var(--text);font-size:1.08rem}
.prose h2{font-size:clamp(1.6rem,3.4vw,2.3rem);text-transform:uppercase;margin-top:1.6em}
.prose strong{color:var(--white)}
.info-card{
  border:1px solid var(--line);border-radius:var(--radius);background:var(--panel);
  padding:28px 30px;box-shadow:var(--shadow-sm);position:relative;overflow:hidden;
}
.info-card::before{content:"";position:absolute;top:0;left:0;bottom:0;width:3px;background:var(--gold-grad)}
.info-card h3{font-size:1.3rem;text-transform:uppercase;margin-bottom:.4em}
.info-card p{margin-bottom:.5em}

/* ---------- services ---------- */
.svc-block{margin-bottom:clamp(46px,7vw,84px)}
.svc-block:last-child{margin-bottom:0}
.svc-split{display:grid;grid-template-columns:1fr .8fr;gap:clamp(28px,5vw,60px);align-items:center}
.svc-split.flip{grid-template-columns:.8fr 1fr}
.svc-title{display:flex;align-items:center;gap:.5em;font-size:clamp(1.8rem,4vw,2.7rem);text-transform:uppercase}
.svc-note{
  display:block;font-size:.94rem;color:var(--muted);
  border-left:2px solid var(--gold);padding:.15em 0 .15em .8em;margin:0 0 1.6em;font-style:italic;
}
.svc-list{list-style:none;margin:0;padding:0;
  display:grid;grid-template-columns:1fr 1fr;gap:0 2.4em}
.svc-list li{
  display:flex;align-items:center;gap:.7em;padding:.72em 0;border-bottom:1px solid var(--line);
  font-family:"Oswald",sans-serif;font-weight:400;font-size:1.04rem;letter-spacing:.05em;color:var(--white);
}
.svc-list li::before{content:"";width:8px;height:8px;flex:none;background:var(--gold-grad);
  transform:rotate(45deg)}
.svc-media img{width:100%;height:100%;max-height:520px;object-fit:cover;border-radius:var(--radius);box-shadow:var(--shadow-md)}

/* nails menu */
.menu{border:1px solid var(--line);border-radius:var(--radius);background:var(--panel);
  padding:8px 26px;box-shadow:var(--shadow-sm)}
.menu-row{display:flex;align-items:baseline;gap:12px;padding:16px 0;border-bottom:1px solid var(--line)}
.menu-row:last-child{border-bottom:0}
.menu-row .name{font-family:"Oswald",sans-serif;font-size:1.12rem;letter-spacing:.06em;
  text-transform:uppercase;color:var(--white)}
.menu-row .leader{flex:1;border-bottom:1px dotted rgba(255,255,255,.22);transform:translateY(-4px)}
.menu-row .price{font-family:"Oswald",sans-serif;font-size:1.02rem;letter-spacing:.08em;color:var(--gold);white-space:nowrap}
.menu-empty{padding:22px 0;text-align:center;color:var(--muted);font-style:italic}

/* ---------- gallery ---------- */
.gallery{display:grid;grid-template-columns:repeat(6,1fr);gap:16px;grid-auto-flow:dense}
.shot{position:relative;overflow:hidden;border-radius:var(--radius);border:1px solid var(--line);
  background:var(--panel);box-shadow:var(--shadow-sm);min-height:220px}
.shot img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease)}
.shot figcaption{
  position:absolute;left:0;right:0;bottom:0;padding:16px 18px;
  font-family:"Oswald",sans-serif;font-size:.82rem;letter-spacing:.14em;text-transform:uppercase;color:#fff;
  background:linear-gradient(0deg,rgba(8,10,16,.85),transparent);
  transform:translateY(8px);opacity:.9;transition:transform .4s var(--ease),opacity .4s var(--ease);
}
.shot::after{content:"";position:absolute;inset:0;box-shadow:inset 0 0 0 0 rgba(217,178,76,0);
  transition:box-shadow .4s var(--ease);pointer-events:none;border-radius:var(--radius)}
.shot:hover img{transform:scale(1.08)}
.shot:hover figcaption{transform:translateY(0);opacity:1}
.shot:hover::after{box-shadow:inset 0 0 0 2px rgba(217,178,76,.5)}
.shot.wide{grid-column:span 4}
.shot.mid{grid-column:span 3}
.shot.reg{grid-column:span 2}
.shot.tall{grid-row:span 2;min-height:456px}
.shot.soon{display:flex;align-items:center;justify-content:center;flex-direction:column;gap:.5em;
  border-style:dashed;border-color:var(--line-strong);color:var(--muted);text-align:center;padding:24px}
.shot.soon .k{font-family:"Oswald",sans-serif;letter-spacing:.2em;text-transform:uppercase;font-size:.8rem;color:var(--gold)}

/* ---------- supplies product grid ---------- */
.products{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.product{
  position:relative;display:flex;flex-direction:column;overflow:hidden;border-radius:var(--radius);
  border:1px solid var(--line);background:var(--panel);box-shadow:var(--shadow-sm);isolation:isolate;
  transition:transform .4s var(--ease),box-shadow .4s var(--ease),border-color .4s var(--ease);
}
.product:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg);border-color:rgba(217,178,76,.35)}
.product__top-accent{position:absolute;top:0;left:0;right:0;height:3px;background:var(--gold-grad);
  transform:scaleX(0);transform-origin:left;transition:transform .5s var(--ease);z-index:1}
.product:hover .product__top-accent{transform:scaleX(1)}
.product__media{position:relative;aspect-ratio:1/1;overflow:hidden;background:var(--ink-2)}
.product__media img{width:100%;height:100%;object-fit:cover;transition:transform .7s var(--ease)}
.product:hover .product__media img{transform:scale(1.06)}
.product__media.placeholder{display:grid;place-items:center}
.product__media.placeholder svg{width:40%;max-width:72px;height:auto;opacity:.35;color:var(--muted)}
.product__body{padding:16px 18px 18px;display:flex;flex-direction:column;gap:6px;flex:1}
.product__name{font-family:"Oswald",sans-serif;font-size:1.06rem;letter-spacing:.05em;
  text-transform:uppercase;color:var(--white);line-height:1.2}
.product__price{font-family:"Oswald",sans-serif;letter-spacing:.08em;color:var(--gold);
  font-size:1rem;margin-top:auto}
.products-note{
  display:block;font-size:.94rem;color:var(--muted);
  border-left:2px solid var(--gold);padding:.15em 0 .15em .8em;margin:0 0 clamp(28px,4vw,44px);font-style:italic;
}
.products-empty{
  border:1px dashed var(--line-strong);border-radius:var(--radius);background:var(--panel);
  padding:clamp(36px,6vw,60px);text-align:center;color:var(--muted);font-style:italic;
}
.products-empty .k{font-family:"Oswald",sans-serif;letter-spacing:.2em;text-transform:uppercase;
  font-size:.8rem;color:var(--gold);font-style:normal;display:block;margin-bottom:.5em}
@media (max-width:960px){.products{grid-template-columns:repeat(3,1fr)}}
@media (max-width:640px){.products{grid-template-columns:repeat(2,1fr);gap:16px}}

/* ---------- booth amenities ---------- */
.features{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:10px}
.feature{
  display:flex;align-items:center;gap:16px;padding:22px 24px;
  border:1px solid var(--line);border-radius:var(--radius);background:var(--panel);
  transition:transform .35s var(--ease),border-color .35s var(--ease),background .35s var(--ease);
}
.feature:hover{transform:translateY(-5px);border-color:rgba(217,178,76,.35);background:var(--panel-2)}
.feature .ring{
  width:52px;height:52px;flex:none;border-radius:50%;display:grid;place-items:center;
  background:radial-gradient(circle at 30% 25%,rgba(217,178,76,.22),rgba(23,58,168,.12));
  border:1px solid rgba(217,178,76,.4);color:var(--gold);
}
.feature .ring svg{width:24px;height:24px}
.feature h4{font-size:1.12rem;text-transform:uppercase;margin:0;letter-spacing:.06em}

.callout{
  max-width:760px;margin-inline:auto;text-align:center;
  border:1px solid rgba(217,178,76,.35);border-radius:var(--radius);
  background:linear-gradient(180deg,rgba(26,31,40,.9),rgba(13,16,23,.9));
  padding:clamp(36px,6vw,64px);box-shadow:var(--shadow-md);position:relative;overflow:hidden;
}
.callout::before{content:"";position:absolute;inset:0;top:auto;height:4px;background:var(--gold-grad)}
.callout h2{font-size:clamp(1.9rem,4.4vw,3rem);text-transform:uppercase}
.callout p{color:var(--muted);max-width:52ch;margin-inline:auto;margin-bottom:1.6rem}
.callout .hero-actions{justify-content:center}

/* ---------- contact ---------- */
.contact-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:clamp(28px,4vw,48px);align-items:stretch}
.contact-card{
  border:1px solid var(--line);border-radius:var(--radius);background:var(--panel);
  padding:clamp(26px,4vw,40px);box-shadow:var(--shadow-md);position:relative;overflow:hidden;
}
.contact-card::before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--gold-grad)}
.contact-card .row{display:flex;flex-direction:column;gap:2px;padding:16px 0;border-bottom:1px solid var(--line)}
.contact-card .row:last-of-type{border-bottom:0}
.contact-card .k{font-family:"Oswald",sans-serif;font-size:.76rem;letter-spacing:.22em;text-transform:uppercase;color:var(--gold)}
.contact-card .v{font-size:1.08rem;color:var(--white)}
.contact-card .v a{color:var(--white);border-bottom:1px solid transparent;transition:border-color .25s,color .25s}
.contact-card .v a:hover{color:var(--gold);border-bottom-color:var(--gold)}
.contact-card .btns{display:flex;flex-wrap:wrap;gap:10px;margin-top:22px}
.map-frame{border-radius:var(--radius);overflow:hidden;border:1px solid rgba(217,178,76,.3);
  box-shadow:var(--shadow-md);min-height:420px;position:relative}
.map-embed{width:100%;height:100%;min-height:420px;border:0;display:block;filter:grayscale(.35) contrast(1.05)}

/* ---------- footer ---------- */
.site-footer{background:var(--ink-2);border-top:1px solid var(--line);position:relative}
.site-footer::before{content:"";position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,rgba(217,178,76,.4),transparent)}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px;
  padding:clamp(48px,7vw,76px) 0 clamp(30px,4vw,44px)}
.footer-logo-chip{
  --sz:60px;width:var(--sz);height:var(--sz);display:block;border-radius:50%;overflow:hidden;
  position:relative;background:#fff;
  box-shadow:0 0 0 1px rgba(255,255,255,.16),0 0 0 4px rgba(217,178,76,.26),var(--shadow-sm);
}
.footer-logo-chip img{position:absolute;top:50%;left:0;width:106.4%;transform:translateY(-50%);max-width:none}
.site-footer h4{font-size:1rem;text-transform:uppercase;letter-spacing:.16em;color:var(--white);margin-bottom:.9em}
.site-footer p{color:var(--muted);font-size:.96rem;margin-bottom:.5em}
.site-footer .tag{color:var(--gold);font-family:"Oswald",sans-serif;letter-spacing:.14em;
  text-transform:uppercase;font-size:.82rem;margin-top:16px}
.site-footer nav{display:flex;flex-direction:column;gap:.55em}
.site-footer nav a,.site-footer p a{color:var(--muted);transition:color .25s}
.site-footer nav a:hover,.site-footer p a:hover{color:var(--gold)}
.footer-credit{border-top:1px solid var(--line);text-align:center;padding:22px 0;
  font-size:.86rem;color:var(--muted)}
.footer-credit a{color:var(--gold);border-bottom:1px solid transparent;transition:border-color .25s}
.footer-credit a:hover{border-bottom-color:var(--gold)}

/* ---------- scroll reveal ---------- */
.reveal{opacity:0;transform:translateY(22px);
  transition:opacity .8s var(--ease),transform .8s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.09s}
.reveal.d2{transition-delay:.18s}
.reveal.d3{transition-delay:.27s}

/* ---------- responsive ---------- */
@media (max-width:960px){
  .cards{grid-template-columns:1fr 1fr}
  .features{grid-template-columns:1fr 1fr}
  .split,.svc-split,.svc-split.flip{grid-template-columns:1fr;gap:30px}
  .split.reverse{direction:ltr}
  .split-media::before{inset:10px -10px -10px 10px}
  .contact-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
  .gallery{grid-template-columns:repeat(4,1fr)}
  .shot.wide{grid-column:span 4}
  .shot.mid{grid-column:span 2}
  .shot.reg{grid-column:span 2}
}
@media (max-width:760px){
  .nav-toggle{display:inline-flex;align-items:center;justify-content:center}
  .site-nav{
    position:absolute;top:100%;right:16px;left:16px;
    flex-direction:column;align-items:stretch;gap:4px;
    background:rgba(9,11,17,.97);backdrop-filter:blur(16px);
    border:1px solid var(--line);border-top:2px solid var(--gold);border-radius:0 0 10px 10px;
    box-shadow:var(--shadow-lg);
    max-height:0;overflow:hidden;opacity:0;pointer-events:none;padding:0 12px;
    transition:max-height .4s var(--ease),opacity .3s var(--ease),padding .3s var(--ease);
  }
  .site-nav.open{max-height:80vh;opacity:1;pointer-events:auto;padding:12px}
  .site-nav a{padding:.85em 1em;border-radius:6px}
  .site-nav a:not(.btn)::after{display:none}
  .site-nav a:not(.btn):hover{background:rgba(255,255,255,.05)}
  .site-nav .btn{margin-left:0;margin-top:6px}
  .brand-word b{font-size:1rem}
}
@media (max-width:560px){
  body{font-size:16px}
  .cards{grid-template-columns:1fr}
  .features{grid-template-columns:1fr}
  .svc-list{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .gallery{grid-template-columns:repeat(2,1fr)}
  .shot.wide,.shot.mid,.shot.reg{grid-column:span 2}
  .shot.tall{grid-row:span 1;min-height:240px}
  .brand-word i{display:none}
  .hero-actions .btn{flex:1 1 100%}
  .banner{background-attachment:scroll}
}

/* ---------- reduced motion ---------- */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;
    transition-duration:.001ms!important;scroll-behavior:auto!important}
  .hero__img{animation:none;transform:none}
  .reveal{opacity:1;transform:none}
  .banner{background-attachment:scroll}
}

/* Transparent logo — show the full mark inside the medallion (no strip-crop needed) */
.brand-chip img,.hero__medallion img,.footer-logo-chip img{
  position:static;top:auto;left:auto;width:100%;height:100%;
  object-fit:contain;transform:none;padding:12%;
}
