/* ── RESET & TOKENS ─────────────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:-apple-system,BlinkMacSystemFont,'Segoe UI','Helvetica Neue',Arial,sans-serif;background:#f5f4f0;color:#1a1a1a;overflow-x:hidden;line-height:1.6}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
button{cursor:pointer;font-family:inherit}

:root{
  --bg:       #f5f4f0;
  --bg2:      #edecea;
  --bg3:      #e2e0db;
  --white:    #ffffff;
  --ink:      #111111;
  --ink2:     #3a3a3a;
  --ink3:     #767676;
  --gold:     #c8830a;
  --gold-lt:  #e8a020;
  --gold-pale:#fef3dc;
  --border:   rgba(0,0,0,0.09);
  --max:      1200px;
  --r:        12px;
  --nav-h:    76px;
}

/* ── TYPOGRAPHY ─────────────────────────────────────────────────────────── */
.t-eyebrow{
  font-size:11px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;
  color:var(--gold);display:flex;align-items:center;gap:10px;margin-bottom:12px;
}
.t-eyebrow::before{content:'';width:24px;height:2px;background:var(--gold);display:block;flex-shrink:0}
h1.display{
  font-family:'Helvetica Neue',Arial,sans-serif;font-weight:800;font-size:clamp(48px,7vw,96px);
  font-weight:800;line-height:.92;letter-spacing:-.03em;text-transform:uppercase;
}
h2.display{
  font-family:'Helvetica Neue',Arial,sans-serif;font-weight:800;font-size:clamp(34px,4.5vw,56px);
  font-weight:800;line-height:.96;letter-spacing:-.025em;text-transform:uppercase;
}
h3.display{
  font-family:'Helvetica Neue',Arial,sans-serif;font-weight:800;font-size:clamp(22px,3vw,32px);
  font-weight:800;line-height:1;letter-spacing:-.02em;text-transform:uppercase;
}
.em{color:var(--gold-lt)}
.ghost{-webkit-text-stroke:1.5px rgba(255,255,255,.3);color:transparent}
.ghost-dark{-webkit-text-stroke:1.5px rgba(0,0,0,.15);color:transparent}

/* ── LAYOUT ─────────────────────────────────────────────────────────────── */
.wrap{max-width:var(--max);margin:0 auto;padding:0 32px}
.wrap-narrow{max-width:820px;margin:0 auto;padding:0 32px}
.section{padding:100px 0}
.section-sm{padding:70px 0}

/* ── ANNOUNCE BAR ───────────────────────────────────────────────────────── */
.announce{
  background:var(--gold);padding:9px 24px;text-align:center;
  font-size:12.5px;font-weight:500;color:#fff;letter-spacing:.02em;
  position:relative;z-index:300;
}
.announce a{text-decoration:underline;margin-left:10px;opacity:.9}

/* ── NAV ────────────────────────────────────────────────────────────────── */
.nav{
  position:sticky;top:0;z-index:200;
  background:rgba(245,244,240,.95);backdrop-filter:blur(18px);
  border-bottom:1px solid var(--border);height:var(--nav-h);
}
.nav-inner{
  max-width:var(--max);margin:0 auto;padding:0 32px;
  height:100%;display:flex;align-items:center;justify-content:space-between;gap:24px;
}
.nav-logo{
  font-family:'Helvetica Neue',Arial,sans-serif;font-weight:800;font-size:21px;font-weight:800;
  text-transform:uppercase;letter-spacing:.04em;color:var(--ink);
  display:flex;flex-direction:column;line-height:1;flex-shrink:0;
}
.nav-logo .pg{color:var(--gold)}
.nav-logo-sub{font-family:-apple-system,BlinkMacSystemFont,'Segoe UI','Helvetica Neue',Arial,sans-serif;font-size:9px;font-weight:400;color:var(--ink3);letter-spacing:.14em;text-transform:uppercase;margin-top:3px}
.nav-links{list-style:none;display:flex;align-items:center;gap:2px}
.nav-links a{
  font-size:13.5px;font-weight:500;color:var(--ink2);
  padding:8px 14px;border-radius:8px;transition:all .15s;display:block;white-space:nowrap;
}
.nav-links a:hover{background:var(--bg3);color:var(--ink)}
.nav-links a.active{color:var(--gold);font-weight:600}
.nav-links .has-drop{position:relative}
.nav-links .has-drop:hover .dropdown{opacity:1;visibility:visible;transform:translateY(0)}
.dropdown{
  position:absolute;top:calc(100% + 8px);left:0;
  background:var(--white);border:1px solid var(--border);
  border-radius:var(--r);padding:8px;min-width:200px;
  box-shadow:0 8px 32px rgba(0,0,0,.1);
  opacity:0;visibility:hidden;transform:translateY(-6px);
  transition:all .2s ease;
}
.dropdown a{
  display:block;padding:9px 14px;border-radius:8px;
  font-size:13px;font-weight:500;color:var(--ink2);transition:all .12s;
}
.dropdown a:hover{background:var(--bg);color:var(--gold)}
.dropdown a.new::after{content:'NEW';font-size:9px;font-weight:700;background:var(--gold);color:#fff;padding:2px 6px;border-radius:4px;margin-left:8px;letter-spacing:.06em}
.nav-right{display:flex;align-items:center;gap:14px;flex-shrink:0}
.nav-phone{font-size:12.5px;color:var(--ink3);white-space:nowrap}
.nav-phone strong{color:var(--ink);font-weight:500}

/* ── BUTTONS ────────────────────────────────────────────────────────────── */
.btn{
  display:inline-flex;align-items:center;gap:8px;
  font-size:13.5px;font-weight:600;padding:11px 22px;
  border-radius:8px;border:none;transition:all .15s;letter-spacing:.01em;white-space:nowrap;
}
.btn-gold{background:var(--gold);color:#fff}
.btn-gold:hover{background:#b37309;transform:translateY(-1px)}
.btn-outline{background:transparent;color:var(--ink2);border:1.5px solid var(--border)}
.btn-outline:hover{border-color:var(--ink3);color:var(--ink)}
.btn-outline-white{background:transparent;color:rgba(255,255,255,.8);border:1.5px solid rgba(255,255,255,.25)}
.btn-outline-white:hover{color:#fff;border-color:rgba(255,255,255,.6)}
.btn-lg{font-size:15px;padding:14px 28px;border-radius:10px}
.btn-sm{font-size:12px;padding:8px 16px}

/* ── IMAGE SLIDER / HERO BANNER ─────────────────────────────────────────── */
.hero-slider{
  position:relative;overflow:hidden;
  height:calc(100vh - var(--nav-h) - 38px);min-height:560px;max-height:860px;
  background:#0d1117;
}
.slider-track{display:flex;height:100%;transition:transform .8s cubic-bezier(.77,0,.175,1)}
.slide{
  min-width:100%;height:100%;position:relative;overflow:hidden;flex-shrink:0;
}
.slide-bg{
  position:absolute;inset:0;background-size:cover;background-position:center;
  transform:scale(1.06);transition:transform 8s ease;
}
.slide.active .slide-bg{transform:scale(1)}
.slide-overlay{position:absolute;inset:0;background:linear-gradient(to right,rgba(10,14,20,.85) 40%,rgba(10,14,20,.3))}
.slide-content{
  position:relative;z-index:2;height:100%;display:flex;flex-direction:column;
  justify-content:center;max-width:var(--max);margin:0 auto;padding:0 32px;
}
.slide-kicker{
  font-size:11px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;
  color:var(--gold-lt);margin-bottom:18px;
  display:flex;align-items:center;gap:10px;
  opacity:0;transform:translateY(16px);transition:all .6s .2s;
}
.slide-kicker::before{content:'';width:24px;height:2px;background:var(--gold-lt)}
.slide.active .slide-kicker{opacity:1;transform:none}
.slide-title{
  font-family:'Helvetica Neue',Arial,sans-serif;font-weight:800;font-size:clamp(42px,6.5vw,86px);
  font-weight:800;line-height:.9;letter-spacing:-.03em;text-transform:uppercase;color:#fff;
  margin-bottom:22px;
  opacity:0;transform:translateY(20px);transition:all .65s .3s;
}
.slide.active .slide-title{opacity:1;transform:none}
.slide-title .gold{color:var(--gold-lt)}
.slide-title .ghost{-webkit-text-stroke:1.5px rgba(255,255,255,.28);color:transparent}
.slide-desc{
  font-size:16px;color:rgba(255,255,255,.6);line-height:1.7;max-width:480px;margin-bottom:30px;
  opacity:0;transform:translateY(16px);transition:all .6s .45s;
}
.slide.active .slide-desc{opacity:1;transform:none}
.slide-btns{
  display:flex;gap:12px;flex-wrap:wrap;
  opacity:0;transform:translateY(14px);transition:all .6s .55s;
}
.slide.active .slide-btns{opacity:1;transform:none}

/* Slider controls */
.slider-dots{
  position:absolute;bottom:28px;left:50%;transform:translateX(-50%);
  display:flex;gap:8px;z-index:10;
}
.slider-dot{
  width:28px;height:3px;border-radius:2px;background:rgba(255,255,255,.3);
  cursor:pointer;transition:all .3s;border:none;padding:0;
}
.slider-dot.active{background:var(--gold-lt);width:44px}
.slider-arrows{position:absolute;bottom:22px;right:32px;display:flex;gap:8px;z-index:10}
.slider-arrow{
  width:42px;height:42px;border-radius:50%;background:rgba(255,255,255,.1);
  border:1px solid rgba(255,255,255,.2);color:#fff;font-size:18px;
  display:flex;align-items:center;justify-content:center;cursor:pointer;
  transition:all .2s;
}
.slider-arrow:hover{background:var(--gold);border-color:var(--gold)}

/* ── PAGE HEADER (inner pages) ──────────────────────────────────────────── */
.page-header{
  background:#0d1117;padding:80px 0 70px;
  position:relative;overflow:hidden;
}
.page-header-bg{
  position:absolute;inset:0;background-size:cover;background-position:center;
  opacity:.15;
}
.page-header-content{position:relative;z-index:2}
.page-header h1{color:#fff;margin-bottom:14px}
.page-header p{font-size:16px;color:rgba(255,255,255,.5);max-width:520px;line-height:1.7}
.breadcrumb{
  display:flex;align-items:center;gap:8px;margin-bottom:20px;
  font-size:12px;color:rgba(255,255,255,.4);
}
.breadcrumb a{color:rgba(255,255,255,.4);transition:color .15s}
.breadcrumb a:hover{color:var(--gold-lt)}
.breadcrumb span{color:var(--gold-lt)}

/* ── STATS STRIP ────────────────────────────────────────────────────────── */
.stats-strip{background:var(--white);border-bottom:1px solid var(--border)}
.stats-inner{
  max-width:var(--max);margin:0 auto;padding:0 32px;
  display:grid;grid-template-columns:repeat(4,1fr);
}
.stat-cell{
  padding:28px 24px;border-right:1px solid var(--border);
  display:flex;align-items:center;gap:16px;
}
.stat-cell:last-child{border-right:none}
.stat-n{
  font-family:'Helvetica Neue',Arial,sans-serif;font-weight:800;font-size:38px;font-weight:800;
  color:var(--gold);line-height:1;white-space:nowrap;
}
.stat-n sup{font-size:16px}
.stat-lbl{font-size:14px;font-weight:500;color:var(--ink);line-height:1.3}
.stat-sub{font-size:12px;color:var(--ink3);margin-top:2px}

/* ── CARDS ──────────────────────────────────────────────────────────────── */
.card{
  background:var(--white);border:1px solid var(--border);
  border-radius:16px;overflow:hidden;
  transition:transform .2s,box-shadow .2s;
}
.card:hover{transform:translateY(-4px);box-shadow:0 12px 40px rgba(0,0,0,.09)}
.card-img{aspect-ratio:4/3;overflow:hidden;background:#0d1117;display:flex;align-items:center;justify-content:center}
.card-img img{width:100%;height:100%;object-fit:cover;opacity:.88;transition:transform .4s}
.card:hover .card-img img{transform:scale(1.04)}
.card-body{padding:24px}
.card-cat{font-size:10.5px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--gold);margin-bottom:8px}
.card-title{font-family:'Helvetica Neue',Arial,sans-serif;font-weight:800;font-size:20px;font-weight:800;text-transform:uppercase;color:var(--ink);margin-bottom:8px;line-height:1.1}
.card-desc{font-size:13.5px;color:var(--ink3);line-height:1.65;margin-bottom:16px}
.card-link{font-size:13px;font-weight:600;color:var(--gold);display:flex;align-items:center;gap:5px}
.card-link::after{content:'→';transition:transform .2s}
.card:hover .card-link::after{transform:translateX(4px)}

/* Placeholder image inside dark cards */
.img-ph{
  width:100%;height:100%;display:flex;flex-direction:column;
  align-items:center;justify-content:center;gap:10px;
  background:linear-gradient(135deg,#141a24,#1e2a3a);
  color:rgba(255,255,255,.2);font-size:11px;letter-spacing:.1em;text-transform:uppercase;font-weight:500;
}

/* ── HAMMER MODEL CARD ──────────────────────────────────────────────────── */
.hammer-card{
  background:var(--white);border:1px solid var(--border);border-radius:16px;
  overflow:hidden;cursor:pointer;transition:transform .2s,box-shadow .2s;display:flex;flex-direction:column;
}
.hammer-card:hover{transform:translateY(-5px);box-shadow:0 16px 48px rgba(0,0,0,.1)}
.hammer-card-vis{
  aspect-ratio:3/4;background:#0d1117;
  display:flex;align-items:center;justify-content:center;
  position:relative;overflow:hidden;
}
.hammer-card-vis img{width:100%;height:100%;object-fit:cover;opacity:.85;transition:transform .5s}
.hammer-card:hover .hammer-card-vis img{transform:scale(1.05)}
.hammer-card-badge{
  position:absolute;top:12px;left:12px;
  background:var(--gold);color:#fff;
  font-size:9px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;
  padding:4px 10px;border-radius:5px;
}
.hammer-card-body{padding:22px;flex:1;display:flex;flex-direction:column}
.hammer-card-name{font-family:'Helvetica Neue',Arial,sans-serif;font-weight:800;font-size:22px;font-weight:800;text-transform:uppercase;color:var(--ink);margin-bottom:4px}
.hammer-card-range{font-size:12px;font-weight:600;color:var(--gold);text-transform:uppercase;letter-spacing:.08em;margin-bottom:10px}
.hammer-card-desc{font-size:13px;color:var(--ink3);line-height:1.6;flex:1;margin-bottom:16px}
.hammer-card-specs{display:flex;flex-direction:column;gap:0;border-top:1px solid var(--border);margin-bottom:16px}
.hammer-spec-row{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px solid var(--border);font-size:12px}
.hammer-spec-key{color:var(--ink3);font-weight:500}
.hammer-spec-val{color:var(--ink);font-weight:600}

/* ── SPEC TABLE ─────────────────────────────────────────────────────────── */
.spec-table{width:100%;border-collapse:collapse;margin-top:16px}
.spec-table th{font-family:'Helvetica Neue',Arial,sans-serif;font-weight:800;font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--ink3);padding:12px 16px;background:var(--bg2);text-align:left;border-bottom:2px solid var(--border)}
.spec-table td{padding:13px 16px;border-bottom:1px solid var(--border);font-size:13.5px;color:var(--ink2)}
.spec-table tr:last-child td{border-bottom:none}
.spec-table tr:hover td{background:var(--bg)}
.spec-table td:first-child{font-weight:500;color:var(--ink3)}
.spec-table td:not(:first-child){font-weight:500;color:var(--ink)}

/* ── FEATURE STRIP ──────────────────────────────────────────────────────── */
.feature-strip{
  display:grid;grid-template-columns:repeat(3,1fr);gap:1px;
  background:var(--border);border:1px solid var(--border);
  border-radius:16px;overflow:hidden;
}
.feature-item{background:var(--white);padding:32px 28px;transition:background .15s}
.feature-item:hover{background:var(--bg)}
.feature-icon{font-size:28px;margin-bottom:14px}
.feature-title{font-family:'Helvetica Neue',Arial,sans-serif;font-weight:800;font-size:17px;font-weight:800;text-transform:uppercase;color:var(--ink);margin-bottom:8px}
.feature-desc{font-size:13.5px;color:var(--ink3);line-height:1.65}

/* ── CONTACT FORM ───────────────────────────────────────────────────────── */
.qform{background:var(--white);border:1px solid var(--border);border-top:3px solid var(--gold);border-radius:16px;padding:40px}
.qform-title{font-family:'Helvetica Neue',Arial,sans-serif;font-weight:800;font-size:26px;font-weight:800;text-transform:uppercase;color:var(--ink);margin-bottom:4px}
.qform-sub{font-size:13.5px;color:var(--ink3);margin-bottom:28px}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.fg{margin-bottom:16px}
.fl{font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--ink3);display:block;margin-bottom:7px}
.fc{width:100%;background:var(--bg);border:1.5px solid var(--border);border-radius:8px;padding:12px 16px;font-family:-apple-system,BlinkMacSystemFont,'Segoe UI','Helvetica Neue',Arial,sans-serif;font-size:14px;color:var(--ink);outline:none;transition:border-color .15s}
.fc:focus{border-color:var(--gold);background:var(--white)}
.fc option{background:var(--white)}
.fsub{width:100%;padding:14px;background:var(--gold);border:none;border-radius:8px;font-family:-apple-system,BlinkMacSystemFont,'Segoe UI','Helvetica Neue',Arial,sans-serif;font-size:14.5px;font-weight:600;color:#fff;cursor:pointer;margin-top:8px;transition:background .15s}
.fsub:hover{background:#b37309}

/* ── GALLERY GRID ───────────────────────────────────────────────────────── */
.gal-masonry{columns:3;gap:12px}
.gal-item{break-inside:avoid;margin-bottom:12px;border-radius:10px;overflow:hidden;cursor:pointer;position:relative}
.gal-item img{display:block;width:100%;transition:transform .4s}
.gal-item:hover img{transform:scale(1.03)}
.gal-item-ph{aspect-ratio:4/3;background:var(--bg3);display:flex;align-items:center;justify-content:center;font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink3);font-weight:500}
.gal-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.5),transparent);opacity:0;transition:opacity .3s;display:flex;align-items:flex-end;padding:14px}
.gal-item:hover .gal-overlay{opacity:1}
.gal-label{font-size:12px;font-weight:600;color:#fff;text-transform:uppercase;letter-spacing:.06em}

/* ── ABOUT TIMELINE ─────────────────────────────────────────────────────── */
.timeline{position:relative;padding-left:32px}
.timeline::before{content:'';position:absolute;left:8px;top:8px;bottom:8px;width:1.5px;background:var(--border)}
.tl-item{position:relative;margin-bottom:36px}
.tl-dot{position:absolute;left:-28px;top:4px;width:14px;height:14px;border-radius:50%;background:var(--bg3);border:2.5px solid var(--border)}
.tl-item.milestone .tl-dot{background:var(--gold);border-color:var(--gold)}
.tl-year{font-family:'Helvetica Neue',Arial,sans-serif;font-weight:800;font-size:13px;font-weight:800;color:var(--gold);text-transform:uppercase;letter-spacing:.08em;margin-bottom:4px}
.tl-title{font-size:15px;font-weight:600;color:var(--ink);margin-bottom:4px}
.tl-desc{font-size:13.5px;color:var(--ink3);line-height:1.6}

/* ── FOOTER ─────────────────────────────────────────────────────────────── */
footer{background:#0d1117;padding:72px 0 32px}
.foot-grid{display:grid;grid-template-columns:1.8fr 1fr 1fr 1fr;gap:48px;margin-bottom:56px}
.foot-logo{font-family:'Helvetica Neue',Arial,sans-serif;font-weight:800;font-size:26px;font-weight:800;text-transform:uppercase;color:#fff;letter-spacing:.04em;display:block;margin-bottom:16px}
.foot-logo .pg{color:var(--gold-lt)}
.foot-desc{font-size:13.5px;color:rgba(255,255,255,.38);line-height:1.75;max-width:240px;margin-bottom:18px}
.foot-cert{font-size:11px;color:rgba(255,255,255,.3);border:1px solid rgba(255,255,255,.1);padding:7px 14px;border-radius:6px;display:inline-block}
.foot-col-t{font-size:11px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.4);margin-bottom:16px}
.foot-links{list-style:none;display:flex;flex-direction:column;gap:10px}
.foot-links a{font-size:13.5px;color:rgba(255,255,255,.45);transition:color .15s}
.foot-links a:hover{color:var(--gold-lt)}
.foot-bottom{display:flex;justify-content:space-between;align-items:center;padding-top:28px;border-top:1px solid rgba(255,255,255,.07)}
.foot-copy{font-size:12px;color:rgba(255,255,255,.22)}
.foot-btm-links{display:flex;gap:22px;list-style:none}
.foot-btm-links a{font-size:12px;color:rgba(255,255,255,.22)}
.foot-btm-links a:hover{color:rgba(255,255,255,.5)}

/* ── SCROLL ANIMATIONS ──────────────────────────────────────────────────── */
.fade-up{opacity:0;transform:translateY(22px);transition:opacity .65s ease,transform .65s ease}
.fade-up.visible{opacity:1;transform:none}
.fade-up-delay-1{transition-delay:.1s}
.fade-up-delay-2{transition-delay:.2s}
.fade-up-delay-3{transition-delay:.3s}

/* ══════════════════════════════════════════════════════════════
   RESPONSIVE — Complete mobile-first overhaul
   ══════════════════════════════════════════════════════════════ */

/* ── HAMBURGER ──────────────────────────────────────────────── */
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;
  padding:6px;border:none;background:none;flex-shrink:0}
.hamburger span{display:block;width:22px;height:2px;background:var(--ink);
  border-radius:2px;transition:all .25s}
.hamburger.open span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}

/* ── MOBILE MENU ────────────────────────────────────────────── */
.mobile-menu{display:none;position:fixed;top:var(--nav-h);left:0;right:0;
  bottom:0;background:var(--white);z-index:198;overflow-y:auto;
  border-top:1px solid var(--border)}
.mobile-menu.open{display:block}
.mobile-menu a{display:block;padding:13px 20px;font-size:15px;font-weight:500;
  color:var(--ink2);border-bottom:1px solid var(--border);text-decoration:none}
.mobile-menu a:hover,.mobile-menu a.act{color:var(--gold)}
.mm-section{font-size:10px;font-weight:700;text-transform:uppercase;
  letter-spacing:.12em;color:var(--ink3);padding:16px 20px 6px;background:var(--bg2)}
.mm-sub a{padding-left:36px;font-size:14px;color:var(--ink3)}
.mobile-cta{display:flex;gap:10px;padding:14px 20px;
  border-bottom:1px solid var(--border)}
.mobile-cta a{flex:1;text-align:center;padding:11px 8px;border-radius:8px;
  font-size:13px;font-weight:600;text-decoration:none;border-bottom:none!important}
.mc-gold{background:var(--gold);color:#fff!important}
.mc-out{background:var(--bg);border:1.5px solid var(--border);color:var(--ink)!important}

/* ════════════════════════════════════════════════════════════
   TABLET  ≤ 900px
   ════════════════════════════════════════════════════════════ */
@media(max-width:900px){
  /* NAV */
  .nav-links{display:none!important}
  .nav-phone{display:none}
  .nav-right .btn,.nav-right .search-trigger{display:none}
  .hamburger{display:flex}

  /* WRAP */
  .wrap,.wrap-narrow{padding:0 20px}

  /* HERO */
  .slide-desc{display:none}
  .slide-btns .btn-lg{font-size:12px;padding:9px 14px}

  /* STATS */
  .stats-inner{grid-template-columns:1fr 1fr}
  .stat-cell:nth-child(even){border-right:none}
  .stat-sub{display:none}

  /* GRIDS */
  .grid-3,.grid-4{grid-template-columns:1fr 1fr!important;gap:14px}
  .feature-strip{grid-template-columns:1fr!important}
  .foot-grid{grid-template-columns:1fr 1fr}

  /* GALLERY */
  .gal-masonry,.gal-grid-full{columns:2}
}

/* ════════════════════════════════════════════════════════════
   MOBILE  ≤ 640px
   ════════════════════════════════════════════════════════════ */
@media(max-width:640px){
  :root{--nav-h:56px}

  /* GENERAL */
  .wrap,.wrap-narrow{padding:0 14px}
  .section{padding:48px 0}
  .section-sm{padding:32px 0}
  .btn-lg{font-size:13px;padding:10px 18px}
  h2.display,.display{font-size:clamp(26px,8vw,40px)}

  /* ANNOUNCE */
  .announce{font-size:11px;padding:6px 12px}
  .announce a{display:none}

  /* BRAND BANNER */
  .brand-banner img{height:160px!important;object-position:left center}

  /* HERO SLIDER */
  .hero-slider{min-height:180px!important;max-height:200px!important}
  .slide-content{padding:0 16px}
  .slide-title{font-size:clamp(22px,7vw,36px)!important;margin-bottom:12px}
  .slide-btns{gap:7px}
  .slide-btns .btn{font-size:11px;padding:8px 12px}
  .slide-kicker{display:none}
  .slider-arrows{bottom:8px;right:10px}
  .slider-arrow{width:28px;height:28px;font-size:13px}

  /* HOME FEATURED HAMMER — stack vertically */
  .home-feat-grid{grid-template-columns:1fr!important;min-height:auto!important}
  .home-feat-vis{padding:24px 20px!important;min-height:260px}
  .feat-main-img{max-width:160px;margin:0 auto}
  .feat-main-img img{padding:10px!important}
  .feat-thumbs{max-width:160px;margin:8px auto 0}
  .home-feat-content{padding:24px 20px!important}
  .feat-title{font-size:28px!important}
  .model-pills{gap:5px}
  .mpill{font-size:11px;padding:5px 10px}
  .spec-row{padding:8px 0}

  /* PRODUCT GRIDS — override inline styles too */
  .prod-preview .wrap>div[style*="grid"],
  div[style*="grid-template-columns:repeat(4"],
  div[style*="grid-template-columns:repeat(3"],
  div[style*="grid-template-columns:repeat(2"]{
    grid-template-columns:1fr 1fr!important;gap:12px!important
  }

  /* CARD */
  .card-img{height:180px!important}

  /* STATS */
  .stats-inner{grid-template-columns:1fr 1fr}
  .stat-n{font-size:26px}
  .stat-cell{padding:14px 10px}

  /* WHY / ABOUT / SPLITS */
  .why-grid,.about-layout,.contact-layout,
  .cat-intro,.products-split{grid-template-columns:1fr!important;gap:24px!important}
  .ps-body{padding:24px 18px!important}
  .hammer-detail-grid{grid-template-columns:1fr!important}
  .hammer-content{padding:24px 18px!important}
  .hammers-grid{grid-template-columns:1fr 1fr!important;gap:12px}
  .rig-cards{grid-template-columns:1fr!important}

  /* CONTACT */
  .qform{padding:20px 16px}
  .frow{grid-template-columns:1fr!important;gap:10px}
  .contact-methods{gap:8px}
  .cmethod{padding:14px 16px}
  .map-area{aspect-ratio:16/9}

  /* ACCORDION */
  .accordion-wrap{padding:14px 10px 60px}
  .acc-header{padding:12px 14px;gap:10px}
  .acc-icon-wrap{width:38px;height:38px;font-size:18px}
  .acc-title{font-size:15px}
  .acc-content{padding:0 12px 14px}
  .acc-cta{flex-direction:column;gap:10px}
  .search-inner{flex-direction:column;align-items:stretch}
  .search-input-wrap{max-width:100%}
  .cat-filters{padding:8px 12px 0;gap:6px}
  .cat-pill{font-size:11px;padding:5px 10px}

  /* CATEGORY PAGES */
  .cat-index-grid{grid-template-columns:1fr 1fr!important;gap:12px}
  .prod-grid{grid-template-columns:1fr 1fr!important;gap:12px}
  .enquire-banner{flex-direction:column;padding:22px 18px;gap:14px;border-radius:12px}
  .enquire-banner .btn{width:100%;text-align:center}
  .cic-img{aspect-ratio:4/3}
  .cat-intro-img{aspect-ratio:16/9}

  /* GALLERY */
  .gal-masonry,.gal-grid-full{columns:2;gap:8px}
  .gal-filter{flex-wrap:wrap;gap:5px}
  .gal-filter-btn{font-size:10px;padding:5px 9px}

  /* FOOTER */
  .foot-grid{grid-template-columns:1fr 1fr!important;gap:20px}
  .foot-bottom{flex-direction:column;text-align:center;gap:8px}
  .foot-desc{display:none}
  footer{padding:40px 0 24px}

  /* HAMMER DETAIL */
  .hammer-nav{flex-direction:column;gap:10px;text-align:center;padding:12px 14px}
  .hammer-nav-label{font-size:11px}

  /* TEAM / CLIENTS */
  .team-grid{grid-template-columns:1fr 1fr!important}
  .clients-grid{grid-template-columns:1fr 1fr!important}
  .timeline{padding-left:20px}

  /* SEARCH OVERLAY */
  .search-overlay{padding:12px;padding-top:12px}
  .search-overlay-input{font-size:15px;padding:14px 44px 14px 16px;border-radius:10px}
  .search-overlay-results{border-radius:10px;max-height:60vh}
  .search-overlay-box{padding:0}
  .search-overlay-hint{display:none}

  /* MISC */
  .acc-grid-4{grid-template-columns:1fr 1fr!important}
  .size-chart{overflow-x:auto}
  .comparison-table{min-width:600px}
  .clients-bar .clients-inner{gap:6px}
  .client-flag{font-size:11px;padding:4px 8px}
  .pull-quote{padding:12px 14px}
  .t-eyebrow{font-size:10px}
  .breadcrumb{font-size:10px}
}

/* ════════════════════════════════════════════════════════════
   EXTRA SMALL  ≤ 400px
   ════════════════════════════════════════════════════════════ */
@media(max-width:400px){
  .hammers-grid,.cat-index-grid,.prod-grid{grid-template-columns:1fr!important}
  .gal-masonry,.gal-grid-full{columns:1}
  .foot-grid{grid-template-columns:1fr!important}
  .mobile-cta{flex-direction:column}
  .stats-inner{grid-template-columns:1fr 1fr}
  .team-grid{grid-template-columns:1fr!important}
  h2.display,.display{font-size:clamp(24px,9vw,34px)}
}

/* ── RESPONSIVE GRID HELPERS ─────────────────────────────── */
.rgrid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.rgrid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.rgrid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}
@media(max-width:900px){
  .rgrid-4{grid-template-columns:repeat(2,1fr)!important}
  .rgrid-3{grid-template-columns:repeat(2,1fr)!important}
}
@media(max-width:480px){
  .rgrid-4,.rgrid-3,.rgrid-2{grid-template-columns:1fr!important}
}


/* ════════════════════════════════════════════════════════════════
   DEFINITIVE MOBILE FIX — overrides all previous rules
   ════════════════════════════════════════════════════════════════ */
html,body{max-width:100vw;overflow-x:hidden}
*{max-width:100%}
img,video,iframe{max-width:100%;height:auto}

/* Container padding scales properly */
@media(max-width:900px){
  .wrap,.wrap-narrow,.nav-inner{padding-left:16px!important;padding-right:16px!important}
}
@media(max-width:480px){
  .wrap,.wrap-narrow,.nav-inner{padding-left:12px!important;padding-right:12px!important}
}

/* ─── NAV ─────────────────────────────────────────────────────── */
.nav-inner{gap:8px!important}
.nav-right{display:flex;align-items:center;gap:8px}

@media(max-width:900px){
  .nav{height:60px!important}
  .nav-inner{height:60px!important}
  .nav-links{display:none!important}
  .nav-phone{display:none!important}
  .nav-right .btn:not(.hamburger){display:none!important}
  .nav-right .search-trigger{display:none!important}
  .nav-logo-img img{max-height:36px!important}
  .hamburger{
    display:flex!important;flex-direction:column;gap:5px;cursor:pointer;
    padding:8px;border:none;background:none;flex-shrink:0;z-index:201;position:relative
  }
  .hamburger span{display:block;width:24px;height:2.5px;background:#111;border-radius:2px;transition:.25s}
  .hamburger.open span:nth-child(1){transform:rotate(45deg) translate(6px,6px)}
  .hamburger.open span:nth-child(2){opacity:0}
  .hamburger.open span:nth-child(3){transform:rotate(-45deg) translate(6px,-6px)}
}

/* Hide hamburger on desktop */
@media(min-width:901px){
  .hamburger{display:none!important}
}

/* ─── MOBILE MENU ─────────────────────────────────────────────── */
.mobile-menu{
  display:none;position:fixed;top:60px;left:0;right:0;bottom:0;
  background:#fff;z-index:200;overflow-y:auto;
  -webkit-overflow-scrolling:touch
}
.mobile-menu.open{display:block}
.mobile-menu .mm-cta{
  display:flex;gap:10px;padding:16px;background:#f5f4f0;
  border-bottom:1px solid #e0ddd8
}
.mobile-menu .mm-cta a{
  flex:1;text-align:center;padding:12px 8px;border-radius:8px;
  font-size:14px;font-weight:600;text-decoration:none
}
.mm-cta .mc-gold{background:#c8830a;color:#fff}
.mm-cta .mc-out{background:#fff;border:1.5px solid #e0ddd8;color:#111}
.mobile-menu a.mm-link{
  display:block;padding:14px 18px;font-size:15px;color:#1a1a1a;
  border-bottom:1px solid #e0ddd8;text-decoration:none
}
.mobile-menu a.mm-link:active{background:#f5f4f0}
.mobile-menu .mm-section{
  font-size:11px;font-weight:700;text-transform:uppercase;
  letter-spacing:.12em;color:#767676;
  padding:18px 18px 8px;background:#f9f8f5
}
.mobile-menu .mm-sub a.mm-link{padding-left:32px;font-size:14px;color:#3a3a3a}
.mobile-menu .mm-info{padding:18px;font-size:13px;color:#767676;line-height:1.7}
.mobile-menu .mm-info strong{color:#111}
body.mm-open{overflow:hidden}

/* ─── HERO/SECTIONS ─────────────────────────────────────────── */
@media(max-width:900px){
  .brand-banner img{height:140px!important;object-position:center center!important}
  .hero-slider{min-height:180px!important;max-height:220px!important}
  .slide-content{padding-left:16px!important;padding-right:16px!important}
  .slide-title{font-size:clamp(22px,7vw,32px)!important}
  .slide-desc{font-size:13px!important;display:none}
  .slide-kicker{font-size:10px!important}
  .slide-btns{flex-wrap:wrap;gap:8px}
  .slide-btns .btn{font-size:12px;padding:8px 14px;flex:1;min-width:140px}
  .slider-arrows{bottom:8px;right:10px}
  .slider-arrow{width:30px;height:30px;font-size:14px}
}

/* ─── HOMEPAGE FEATURED ─────────────────────────────────────── */
@media(max-width:900px){
  .home-feat-grid{grid-template-columns:1fr!important;min-height:auto!important}
  .home-feat-vis{padding:24px 20px!important;min-height:240px!important}
  .feat-main-img{max-width:180px!important;margin:0 auto!important}
  .feat-thumbs{max-width:180px!important;margin:8px auto 0!important}
  .home-feat-content{padding:24px 20px!important}
}

/* ─── ALL GRIDS BECOME RESPONSIVE ─────────────────────────────── */
@media(max-width:900px){
  /* Generic grid override - any 4-col or 3-col grid → 2-col */
  [style*="grid-template-columns:repeat(4"],
  [style*="grid-template-columns:repeat(3"],
  [style*="grid-template-columns: repeat(4"],
  [style*="grid-template-columns: repeat(3"],
  .rgrid-4,.rgrid-3,.grid-4,.grid-3,
  .prod-grid,.cat-index-grid,.hammers-grid,.team-grid,.clients-grid{
    grid-template-columns:repeat(2,1fr)!important;gap:12px!important
  }
  /* 2-col splits become single column */
  [style*="grid-template-columns:1fr 1fr"],
  [style*="grid-template-columns: 1fr 1fr"],
  .why-grid,.about-layout,.contact-layout,.cat-intro,
  .products-split,.hammer-detail-grid,.foot-grid{
    grid-template-columns:1fr!important;gap:24px!important
  }
  /* Custom split ratios */
  [style*="grid-template-columns:30fr"],[style*="grid-template-columns:31fr"],
  [style*="grid-template-columns:35fr"],[style*="grid-template-columns:40fr"],
  [style*="grid-template-columns:45fr"],[style*="grid-template-columns:50fr"]{
    grid-template-columns:1fr!important
  }
}

@media(max-width:480px){
  [style*="grid-template-columns:repeat(4"],
  [style*="grid-template-columns:repeat(3"],
  [style*="grid-template-columns: repeat(4"],
  [style*="grid-template-columns: repeat(3"],
  .rgrid-4,.rgrid-3,.grid-4,.grid-3,
  .prod-grid,.cat-index-grid,.hammers-grid{
    grid-template-columns:1fr!important
  }
  .team-grid,.clients-grid,.foot-grid{grid-template-columns:repeat(2,1fr)!important}
  .stats-inner{grid-template-columns:repeat(2,1fr)!important}
  .stats-inner .stat-cell:nth-child(even){border-right:none!important}
}

/* ─── SECTIONS / SPACING ────────────────────────────────────── */
@media(max-width:900px){
  .section{padding:48px 0!important}
  .section-sm{padding:32px 0!important}
  h2.display,.display{font-size:clamp(26px,7vw,42px)!important}
  .feature-strip{grid-template-columns:1fr!important}
}

/* ─── ACCORDION ─────────────────────────────────────────────── */
@media(max-width:640px){
  .accordion-wrap{padding:14px 12px 60px}
  .acc-header{padding:14px;gap:10px}
  .acc-icon-wrap{width:38px;height:38px;font-size:18px;flex-shrink:0}
  .acc-title{font-size:15px}
  .acc-content{padding:0 14px 16px}
  .acc-cta{flex-direction:column;align-items:stretch;gap:10px}
  .search-inner{flex-direction:column;align-items:stretch;gap:10px}
  .search-input-wrap{max-width:100%}
  .cat-filters{padding:8px 12px 0;gap:6px;flex-wrap:wrap}
  .cat-pill{font-size:11px;padding:5px 10px}
  .acc-grid-4{grid-template-columns:1fr 1fr!important}
}

/* ─── CONTACT FORM ──────────────────────────────────────────── */
@media(max-width:640px){
  .qform{padding:20px 16px}
  .frow{grid-template-columns:1fr!important;gap:10px}
  .contact-methods{gap:8px}
  .cmethod{padding:14px 16px}
  .map-area{aspect-ratio:16/9}
}

/* ─── ENQUIRE BANNER ────────────────────────────────────────── */
@media(max-width:640px){
  .enquire-banner{flex-direction:column!important;padding:22px 18px!important;
    gap:14px!important;text-align:center}
  .enquire-banner .btn{width:100%}
}

/* ─── GALLERY ───────────────────────────────────────────────── */
@media(max-width:768px){
  .gal-grid-full,.gal-masonry{columns:2!important;gap:8px!important}
  .gal-filter{flex-wrap:wrap;gap:5px}
  .gal-filter-btn{font-size:11px;padding:5px 10px}
}
@media(max-width:480px){
  .gal-grid-full,.gal-masonry{columns:1!important}
}

/* ─── FOOTER ───────────────────────────────────────────────── */
@media(max-width:640px){
  .foot-grid{grid-template-columns:1fr 1fr!important;gap:24px!important}
  .foot-bottom{flex-direction:column;text-align:center;gap:8px}
}
@media(max-width:400px){
  .foot-grid{grid-template-columns:1fr!important}
}

/* ─── SEARCH OVERLAY ───────────────────────────────────────── */
@media(max-width:640px){
  .search-overlay-input{font-size:15px;padding:14px 44px 14px 16px}
  .search-overlay-results{max-height:60vh}
}

/* ─── HEADERS ───────────────────────────────────────────────── */
@media(max-width:640px){
  .page-header{padding:60px 0 40px}
  .page-header h1{font-size:clamp(28px,7vw,42px)}
}


/* ════════════════════════════════════════════════════════════════
   FORCE MOBILE — last resort, overrides everything above
   ════════════════════════════════════════════════════════════════ */
@media (max-width: 900px) {
  /* Everything must fit in the viewport */
  html, body { 
    width: 100% !important; 
    max-width: 100vw !important; 
    overflow-x: hidden !important;
    margin: 0 !important;
    padding: 0 !important;
  }
  
  /* No element should be wider than its parent */
  
  /* Containers reset */
  .nav, .nav-inner, .wrap, .wrap-narrow, footer, .section, 
  .brand-banner, .announce, .hero-slider, .home-feat-grid {
    width: 100% !important;
    max-width: 100vw !important;
    box-sizing: border-box !important;
  }
  
  /* NAV - Force layout */
  .nav-inner {
    padding: 0 14px !important;
    gap: 8px !important;
    height: 60px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
  }
  .nav { height: 60px !important; }
  
  /* Logo - shrink */
  .nav-logo-img { 
    flex-shrink: 1 !important; 
    min-width: 0 !important;
    overflow: hidden !important;
  }
  .nav-logo-img img { 
    max-height: 36px !important; 
    width: auto !important;
    max-width: 140px !important;
  }
  
  /* Hide nav-links */
  .nav-links, .nav-phone { display: none !important; }
  
  /* nav-right - only hamburger visible */
  .nav-right { 
    display: flex !important; 
    align-items: center !important;
    gap: 8px !important;
    flex-shrink: 0 !important;
  }
  .nav-right > * { display: none !important; }
  .nav-right .hamburger { 
    display: flex !important;
    flex-direction: column !important;
    gap: 5px !important;
    padding: 10px !important;
    background: transparent !important;
    border: none !important;
    cursor: pointer !important;
    flex-shrink: 0 !important;
    z-index: 250 !important;
  }
  .hamburger span {
    display: block !important;
    width: 24px !important;
    height: 2.5px !important;
    background: #111 !important;
    border-radius: 2px !important;
    transition: 0.25s !important;
  }
  .hamburger.open span:nth-child(1) { transform: rotate(45deg) translate(6px,6px) !important; }
  .hamburger.open span:nth-child(2) { opacity: 0 !important; }
  .hamburger.open span:nth-child(3) { transform: rotate(-45deg) translate(6px,-6px) !important; }
  
  /* MOBILE MENU */
  .mobile-menu {
    display: none !important;
    position: fixed !important;
    top: 60px !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    background: #fff !important;
    z-index: 240 !important;
    overflow-y: auto !important;
    -webkit-overflow-scrolling: touch !important;
  }
  .mobile-menu.open { display: block !important; }
  .mobile-menu .mm-cta {
    display: flex !important;
    gap: 10px !important;
    padding: 16px !important;
    background: #f5f4f0 !important;
    border-bottom: 1px solid #e0ddd8 !important;
  }
  .mobile-menu .mm-cta a {
    flex: 1 !important;
    text-align: center !important;
    padding: 12px 8px !important;
    border-radius: 8px !important;
    font-size: 14px !important;
    font-weight: 600 !important;
    text-decoration: none !important;
  }
  .mm-cta .mc-gold { background: #c8830a !important; color: #fff !important; }
  .mm-cta .mc-out { background: #fff !important; border: 1.5px solid #e0ddd8 !important; color: #111 !important; }
  .mobile-menu a.mm-link {
    display: block !important;
    padding: 14px 18px !important;
    font-size: 15px !important;
    color: #1a1a1a !important;
    border-bottom: 1px solid #e0ddd8 !important;
    text-decoration: none !important;
  }
  .mobile-menu .mm-section {
    font-size: 11px !important;
    font-weight: 700 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.12em !important;
    color: #767676 !important;
    padding: 18px 18px 8px !important;
    background: #f9f8f5 !important;
  }
  .mobile-menu .mm-sub a.mm-link {
    padding-left: 32px !important;
    font-size: 14px !important;
    color: #3a3a3a !important;
  }
  .mobile-menu .mm-info {
    padding: 18px !important;
    font-size: 13px !important;
    color: #767676 !important;
    line-height: 1.7 !important;
  }
  
  /* Banner */
  .brand-banner img {
    width: 100% !important;
    height: 140px !important;
    object-fit: cover !important;
    object-position: center !important;
  }
  
  /* Announce bar */
  .announce {
    padding: 8px 14px !important;
    font-size: 12px !important;
    line-height: 1.4 !important;
  }
  
  /* Slider */
  .hero-slider {
    min-height: 240px !important;
    max-height: 320px !important;
    width: 100% !important;
  }
  .slide-content {
    padding: 0 16px !important;
    width: 100% !important;
    max-width: 100% !important;
    box-sizing: border-box !important;
  }
  .slide-title { 
    font-size: clamp(24px, 7vw, 36px) !important;
    line-height: 1.05 !important;
  }
  .slide-desc { display: none !important; }
  .slide-btns { 
    flex-wrap: wrap !important; 
    gap: 8px !important; 
  }
  .slide-btns .btn { 
    font-size: 12px !important; 
    padding: 9px 14px !important;
  }
  
  /* Featured panel */
  .home-feat-grid {
    display: grid !important;
    grid-template-columns: 1fr !important;
    min-height: auto !important;
    width: 100% !important;
  }
  .home-feat-vis {
    padding: 24px !important;
    min-height: 240px !important;
    width: 100% !important;
    box-sizing: border-box !important;
  }
  .feat-main-img {
    max-width: 180px !important;
    margin: 0 auto !important;
  }
  
.rgrid-4, .rgrid-3, .rgrid-2,
  .grid-4, .grid-3, .grid-2,
  .prod-grid, .cat-index-grid, .hammers-grid {
    grid-template-columns: repeat(2, 1fr) !important;
    gap: 12px !important;
  }
  .foot-grid { grid-template-columns: repeat(2, 1fr) !important; }
  .stats-inner { grid-template-columns: repeat(2, 1fr) !important; }
  
  /* Section padding */
  .section { padding: 48px 0 !important; }
  .wrap, .wrap-narrow { padding: 0 14px !important; }
  
  /* Headlines */
  h1, h1.display, .display { 
    font-size: clamp(26px, 7vw, 44px) !important;
    line-height: 1.1 !important;
    word-wrap: break-word !important;
  }
  h2, h2.display { 
    font-size: clamp(22px, 6vw, 36px) !important;
    line-height: 1.15 !important;
  }
}

@media (max-width: 480px) {
  .nav-right .hamburger { padding: 8px !important; }
  .rgrid-4, .rgrid-3, .grid-4, .grid-3,
  .prod-grid, .cat-index-grid, .hammers-grid {
    grid-template-columns: 1fr !important;
  }
  .foot-grid { grid-template-columns: 1fr !important; }
  .nav-logo-img img { max-width: 110px !important; }
}


/* Fix slider on mobile - restore proper widths */
@media (max-width: 900px) {
  .slider-track { width: auto !important; max-width: none !important; }
  .slide { min-width: 100% !important; max-width: 100% !important; flex-shrink: 0 !important; }
  .slide-bg { max-width: none !important; width: 100% !important; }
}


/* CRITICAL FIX: Ensure all fade-up content is visible even if JS fails or IntersectionObserver doesn't trigger */
/* The fade-in is purely decorative - content must show without it */
@media (max-width: 900px) {
  .fade-up { opacity: 1 !important; transform: none !important; }
}
/* On desktop, also fallback: trigger visibility after 1.5s if observer hasn't fired */
@keyframes ensureVisible { to { opacity: 1; transform: none; } }
.fade-up { animation: ensureVisible 0.7s ease 1.5s forwards; }
.fade-up.visible { animation: none; opacity: 1; transform: none; }


/* ════════════════════════════════════════════════════════════
   SEARCH OVERLAY — Top-positioned modal
   ════════════════════════════════════════════════════════════ */
.search-overlay {
  display: none;
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: rgba(13, 17, 23, 0.85);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  z-index: 1000;
  padding-top: 80px;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
}
.search-overlay.open {
  display: block;
}
.search-overlay-box {
  max-width: 640px;
  margin: 0 auto;
  padding: 0 24px;
}
.search-overlay-input-wrap {
  position: relative;
  background: #fff;
  border-radius: 999px;
  box-shadow: 0 12px 48px rgba(0,0,0,.4);
  overflow: hidden;
}
.search-overlay-input {
  width: 100%;
  background: #fff;
  border: 0;
  outline: 0;
  font-size: 18px;
  font-weight: 500;
  color: #111;
  padding: 18px 56px 18px 56px;
  font-family: inherit;
  border-radius: 999px;
}
.search-overlay-input::placeholder {
  color: #999;
  font-weight: 400;
}
.search-overlay-icon {
  position: absolute;
  left: 18px;
  top: 50%;
  transform: translateY(-50%);
  font-size: 18px;
  color: #999;
  pointer-events: none;
}
.search-overlay-close {
  position: absolute;
  right: 12px;
  top: 50%;
  transform: translateY(-50%);
  width: 32px;
  height: 32px;
  background: #f5f4f0;
  color: #555;
  border: 0;
  border-radius: 50%;
  font-size: 14px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background 0.15s;
}
.search-overlay-close:hover { background: #e0ddd8; color: #111; }
.search-overlay-hint {
  font-size: 12px;
  color: rgba(255,255,255,.55);
  text-align: center;
  margin-top: 14px;
}
.search-overlay-hint kbd {
  background: rgba(255,255,255,.15);
  color: rgba(255,255,255,.85);
  padding: 2px 7px;
  border-radius: 4px;
  font-size: 11px;
  font-family: ui-monospace, Menlo, monospace;
}
.search-overlay-results {
  margin-top: 14px;
  background: #fff;
  border-radius: 14px;
  box-shadow: 0 12px 48px rgba(0,0,0,.4);
  max-height: calc(100vh - 220px);
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
}
.search-overlay-results:empty {
  display: none;
}
.search-result-item {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 14px 18px;
  border-bottom: 1px solid #f0ede8;
  text-decoration: none;
  color: #111;
  cursor: pointer;
  transition: background 0.12s;
}
.search-result-item:last-child { border-bottom: 0; }
.search-result-item:hover, .search-result-item.active {
  background: #faf9f6;
}
.search-result-icon {
  width: 38px;
  height: 38px;
  background: #f5f4f0;
  border-radius: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 16px;
  flex-shrink: 0;
}
.search-result-text {
  flex: 1;
  min-width: 0;
}
.search-result-name {
  font-size: 14px;
  font-weight: 600;
  color: #111;
  margin-bottom: 2px;
}
.search-result-cat {
  font-size: 11px;
  color: #767676;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}
.search-result-arrow {
  color: #c8830a;
  font-size: 14px;
  flex-shrink: 0;
}
.search-result-empty {
  padding: 28px 20px;
  text-align: center;
  font-size: 13px;
  color: #767676;
}

@media (max-width: 640px) {
  .search-overlay { padding-top: 60px; }
  .search-overlay-box { padding: 0 14px; }
  .search-overlay-input { font-size: 16px; padding: 16px 50px 16px 48px; }
  .search-overlay-icon { left: 14px; }
  .search-overlay-close { right: 10px; }
  .search-overlay-hint { display: none; }
  .search-overlay-results { max-height: calc(100vh - 160px); }
}


/* Search button visible on mobile (next to hamburger) */
@media (max-width: 900px) {
  .nav-right .search-trigger { 
    display: inline-flex !important; 
    align-items: center;
    justify-content: center;
    background: #f5f4f0;
    border: 1px solid #e0ddd8;
    border-radius: 999px;
    padding: 8px 12px;
    font-size: 13px;
    color: #555;
    cursor: pointer;
    gap: 4px;
  }
  .nav-right .search-trigger kbd { display: none; }
}
@media (max-width: 480px) {
  .nav-right .search-trigger {
    /* Even on small phones - icon only */
    padding: 8px 10px;
    font-size: 0;  /* hide text */
  }
  .nav-right .search-trigger::before {
    content: "🔍";
    font-size: 16px;
  }
}
