/* ============================================================
   Thames Audio Systems — Main Stylesheet
   Theme: Warm cream / parchment with gold accents
   ============================================================ */

/* ── RESET & ROOT ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
  /* Gold palette */
  --gold:#B8832A;
  --gold-lt:#D4A855;
  --gold-dk:#7A5818;
  --gold-pale:rgba(184,131,42,0.1);

  /* Warm cream backgrounds */
  --bg-page:#F5F0E8;        /* main page bg — warm parchment */
  --bg-section:#EDE8DF;     /* alternate sections — slightly deeper */
  --bg-card:#FFFFFF;        /* cards — clean white */
  --bg-card-hover:#FAF7F2;  /* card hover */
  --bg-dark:#2A2420;        /* dark contrast sections */
  --bg-nav:#1E1C18;         /* nav */

  /* Text */
  --text-primary:#1E1C18;   /* headings — near black warm */
  --text-body:#3D3830;      /* body text */
  --text-muted:#7A7268;     /* muted/labels */

  /* Borders */
  --border:#D8D0C4;
  --border-gold:rgba(184,131,42,0.3);

  /* Typography */
  --font-display:'Cormorant Garamond',Georgia,serif;
  --font-body:'Barlow',sans-serif;
  --font-cond:'Barlow Condensed',sans-serif;
}

html{scroll-behavior:smooth}
body{
  background:var(--bg-page);
  color:var(--text-body);
  font-family:var(--font-body);
  overflow-x:hidden;
  line-height:1.6;
}

/* ── TYPOGRAPHY ── */
h1,h2,h3{font-family:var(--font-display);font-weight:300;color:var(--text-primary);line-height:1.1}
.section-dark h1,.section-dark h2,.section-dark h3,.heritage h1,.heritage h2,.heritage h3,.page-hero h1,.page-hero h2{color:#F5F0E8}.section-dark em,.heritage em,.page-hero em{font-style:italic}
em{font-style:italic;color:var(--gold)}
p{color:var(--text-body)}

/* ── SHARED COMPONENTS ── */
.eyebrow{
  font-family:var(--font-cond);font-size:0.7rem;letter-spacing:0.22em;
  text-transform:uppercase;color:var(--gold);
  margin-bottom:0.75rem;display:flex;align-items:center;gap:0.75rem;
}
.eyebrow::before{content:'';display:block;width:2rem;height:1px;background:var(--gold)}
.eyebrow-center{justify-content:center}

.section-title{font-size:clamp(2rem,4vw,3.2rem);margin-bottom:1rem}
.section-title-sm{font-size:clamp(1.6rem,3vw,2.4rem);margin-bottom:1rem}

/* Buttons */
.btn-primary{
  font-family:var(--font-cond);font-size:0.8rem;font-weight:600;
  letter-spacing:0.14em;text-transform:uppercase;
  color:#fff;background:var(--gold);
  padding:0.85rem 2.2rem;text-decoration:none;
  display:inline-block;border:none;cursor:pointer;
  transition:background 0.25s,transform 0.2s;
}
.btn-primary:hover{background:var(--gold-lt);transform:translateY(-1px)}

.btn-ghost{
  font-family:var(--font-cond);font-size:0.8rem;font-weight:500;
  letter-spacing:0.14em;text-transform:uppercase;
  color:var(--text-primary);text-decoration:none;
  display:inline-flex;align-items:center;gap:0.6rem;
  background:none;border:none;cursor:pointer;transition:color 0.25s;
}
.btn-ghost:hover{color:var(--gold)}
.btn-ghost svg{transition:transform 0.25s}
.btn-ghost:hover svg{transform:translateX(4px)}

.btn-outline{
  font-family:var(--font-cond);font-size:0.8rem;font-weight:500;
  letter-spacing:0.14em;text-transform:uppercase;
  color:var(--text-primary);text-decoration:none;
  display:inline-flex;align-items:center;gap:0.6rem;
  border:1px solid var(--border);padding:0.85rem 2rem;
  transition:border-color 0.25s,color 0.25s;
}
.btn-outline:hover{border-color:var(--gold);color:var(--gold)}

.btn-dark{
  font-family:var(--font-cond);font-size:0.8rem;font-weight:600;
  letter-spacing:0.14em;text-transform:uppercase;
  color:#fff;background:var(--bg-dark);
  padding:0.85rem 2rem;text-decoration:none;
  display:inline-flex;align-items:center;gap:0.6rem;
  transition:background 0.25s;white-space:nowrap;
  border:none;cursor:pointer;
}
.btn-dark:hover{background:var(--bg-nav)}

/* ── NAV ── */
nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  padding:1.1rem 3rem;
  display:flex;align-items:center;justify-content:space-between;
  background:var(--bg-nav);
  border-bottom:1px solid rgba(255,255,255,0.06);
}
.nav-logo{
  font-family:var(--font-cond);font-size:1.05rem;font-weight:600;
  letter-spacing:0.18em;text-transform:uppercase;
  color:#F5F0E8;text-decoration:none;
}
.nav-logo span{color:var(--gold)}
.nav-links{display:flex;gap:2rem;list-style:none}
.nav-links a{
  font-family:var(--font-cond);font-size:0.75rem;font-weight:500;
  letter-spacing:0.12em;text-transform:uppercase;
  color:rgba(245,240,232,0.55);text-decoration:none;transition:color 0.25s;
}
.nav-links a:hover,.nav-links a.active{color:#F5F0E8}
.nav-cta{
  font-family:var(--font-cond);font-size:0.72rem;font-weight:600;
  letter-spacing:0.14em;text-transform:uppercase;
  color:#fff;background:var(--gold);
  padding:0.5rem 1.3rem;text-decoration:none;transition:background 0.25s;
}
.nav-cta:hover{background:var(--gold-lt)}
.nav-hamburger{
  display:none;flex-direction:column;gap:5px;
  cursor:pointer;padding:4px;background:none;border:none;
}
.nav-hamburger span{display:block;width:22px;height:1.5px;background:#F5F0E8}

/* ── MOBILE MENU ── */
.mobile-menu{
  display:none;position:fixed;top:0;left:0;right:0;bottom:0;
  background:rgba(30,28,24,0.98);z-index:99;
  flex-direction:column;align-items:center;justify-content:center;gap:2rem;
}
.mobile-menu.open{display:flex}
.mobile-menu a{
  font-family:var(--font-cond);font-size:1.5rem;font-weight:500;
  letter-spacing:0.12em;text-transform:uppercase;
  color:#F5F0E8;text-decoration:none;transition:color 0.25s;
}
.mobile-menu a:hover{color:var(--gold)}
.mobile-close{
  position:absolute;top:1.5rem;right:1.5rem;
  background:none;border:none;color:rgba(245,240,232,0.5);font-size:1.5rem;cursor:pointer;
}

/* ── PAGE HERO (inner pages) ── */
.page-hero{
  padding:9rem 3rem 5rem;
  position:relative;overflow:hidden;
  background:var(--bg-dark);
}
.page-hero-bg{
  position:absolute;inset:0;
  background-size:cover;background-position:center;
  filter:brightness(0.2) saturate(0.4);
}
.page-hero-overlay{
  position:absolute;inset:0;
  background:linear-gradient(to right,rgba(30,28,24,0.97) 50%,rgba(30,28,24,0.7) 100%);
}
.page-hero-content{position:relative;z-index:1}
.page-title{font-size:clamp(2.5rem,6vw,4.5rem);margin-bottom:1.25rem;color:#F5F0E8}
.page-sub{
  font-size:0.95rem;font-weight:300;color:rgba(245,240,232,0.6);
  max-width:520px;line-height:1.7;
}
.page-eyebrow{color:var(--gold-lt)}
.page-eyebrow::before{background:var(--gold-lt)}

/* ── GOLD STRIP ── */
.strip{
  background:var(--gold);padding:0.9rem 3rem;
  display:flex;align-items:center;justify-content:space-between;
  gap:2rem;overflow-x:auto;
}
.strip-text{
  font-family:var(--font-cond);font-size:0.72rem;font-weight:500;
  letter-spacing:0.16em;text-transform:uppercase;
  color:#fff;white-space:nowrap;
}
.strip-divider{width:1px;height:1.1rem;background:rgba(255,255,255,0.3);flex-shrink:0}

/* ── SECTIONS ── */
.section{padding:5rem 3rem}
.section-alt{background:var(--bg-section)}
.section-dark{background:var(--bg-dark)}
.section-header{margin-bottom:3rem}

/* ── CARDS ── */
.card-grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.card-grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem}
.card-grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem}

.card{
  background:var(--bg-card);
  border:1px solid var(--border);
  display:flex;flex-direction:column;
  transition:box-shadow 0.3s,transform 0.3s;
}
.card:hover{box-shadow:0 8px 32px rgba(0,0,0,0.1);transform:translateY(-2px)}
.card-img{width:100%;aspect-ratio:3/2;overflow:hidden;flex-shrink:0}
.card-img img{
  width:100%;height:100%;object-fit:cover;
  filter:brightness(0.9) saturate(0.85);
  transition:transform 0.5s,filter 0.3s;
}
.card:hover .card-img img{transform:scale(1.03);filter:brightness(1) saturate(0.9)}
.card-body{padding:1.5rem;flex:1;display:flex;flex-direction:column}
.card-num{
  font-family:var(--font-display);font-size:2.2rem;font-weight:300;
  color:rgba(184,131,42,0.2);line-height:1;margin-bottom:0.5rem;
}
.card-name{
  font-family:var(--font-cond);font-size:0.95rem;font-weight:600;
  letter-spacing:0.06em;text-transform:uppercase;
  color:var(--text-primary);margin-bottom:0.6rem;
}
.card-desc{font-size:0.85rem;font-weight:300;color:var(--text-muted);line-height:1.7;flex:1}
.card-tag{
  display:inline-block;margin-top:0.75rem;
  font-family:var(--font-cond);font-size:0.6rem;letter-spacing:0.14em;
  text-transform:uppercase;color:var(--gold-dk);
  border:1px solid var(--border-gold);padding:0.2rem 0.55rem;
}
.card-arrow{
  display:flex;align-items:center;gap:0.5rem;margin-top:1rem;
  font-family:var(--font-cond);font-size:0.68rem;letter-spacing:0.12em;
  text-transform:uppercase;color:var(--text-muted);
  text-decoration:none;transition:color 0.25s,gap 0.25s;
}
.card:hover .card-arrow{color:var(--gold);gap:0.75rem}

/* ── SPLIT LAYOUT ── */
.split{display:grid;grid-template-columns:1fr 1fr;align-items:center}
.split-img{overflow:hidden;min-height:420px}
.split-img img{width:100%;height:100%;object-fit:cover;filter:brightness(0.92) saturate(0.85)}
.split-content{padding:4rem 3rem}

/* ── FEATURE LIST ── */
.feat-list{display:flex;flex-direction:column;gap:1.25rem;margin-top:1.5rem}
.feat-item{
  display:flex;gap:1rem;align-items:flex-start;
  padding-bottom:1.25rem;border-bottom:1px solid var(--border);
}
.feat-item:last-child{border-bottom:none}
.feat-dot{width:6px;height:6px;background:var(--gold);flex-shrink:0;margin-top:0.55rem}
.feat-name{
  font-family:var(--font-cond);font-size:0.82rem;font-weight:600;
  letter-spacing:0.08em;text-transform:uppercase;
  color:var(--text-primary);margin-bottom:0.2rem;
}
.feat-desc{font-size:0.82rem;font-weight:300;color:var(--text-muted)}

/* ── SECTOR CARDS ── */
.sector{
  position:relative;aspect-ratio:3/4;
  display:flex;flex-direction:column;justify-content:flex-end;
  padding:1.5rem;overflow:hidden;
}
.sector-bg{position:absolute;inset:0;transition:transform 0.5s}
.sector-bg img{
  width:100%;height:100%;object-fit:cover;
  filter:brightness(0.55) saturate(0.7);transition:filter 0.5s;
}
.sector:hover .sector-bg{transform:scale(1.04)}
.sector:hover .sector-bg img{filter:brightness(0.65) saturate(0.8)}
.sector-overlay{
  position:absolute;inset:0;
  background:linear-gradient(to top,rgba(30,28,24,0.92) 0%,rgba(30,28,24,0.2) 60%,transparent 100%);
}
.sector-content{position:relative;z-index:1}
.sector-tag{
  font-family:var(--font-cond);font-size:0.62rem;letter-spacing:0.2em;
  text-transform:uppercase;color:var(--gold-lt);margin-bottom:0.35rem;
}
.sector-name{
  font-family:var(--font-display);font-size:1.4rem;font-weight:300;
  color:#F5F0E8;line-height:1.1;
}

/* ── HERITAGE / QUOTE ── */
.heritage{
  padding:5rem 3rem;background:var(--bg-dark);
  text-align:center;position:relative;overflow:hidden;
}
.heritage-watermark{
  font-family:var(--font-display);
  font-size:clamp(6rem,15vw,13rem);
  font-weight:300;color:rgba(245,240,232,0.04);
  position:absolute;top:50%;left:50%;
  transform:translate(-50%,-50%);
  white-space:nowrap;pointer-events:none;user-select:none;
}
.heritage-content{position:relative;z-index:1;max-width:640px;margin:0 auto}
.heritage-quote{
  font-family:var(--font-display);
  font-size:clamp(1.3rem,2.5vw,2rem);
  font-weight:300;font-style:italic;line-height:1.4;
  color:#F5F0E8;margin-bottom:1.25rem;
}
.heritage-body{font-size:0.88rem;font-weight:300;color:rgba(245,240,232,0.5);max-width:480px;margin:0 auto}

/* ── ENQUIRE STRIP ── */
.enquire-strip{
  background:var(--bg-dark);padding:2.5rem 3rem;
  display:flex;align-items:center;justify-content:space-between;
  gap:2rem;flex-wrap:wrap;
  border-top:1px solid rgba(255,255,255,0.06);
}
.enquire-strip-title{
  font-family:var(--font-display);font-size:1.8rem;font-weight:300;
  color:#F5F0E8;line-height:1.1;
}
.enquire-strip-sub{font-size:0.85rem;font-weight:300;color:rgba(245,240,232,0.45);margin-top:0.25rem}

/* ── CONTACT ── */
.contact-left{background:var(--bg-section);padding:4rem 3rem;border-right:1px solid var(--border)}
.contact-right{background:var(--bg-card);padding:4rem 3rem}
.contact-block-label{
  font-family:var(--font-cond);font-size:0.65rem;letter-spacing:0.2em;
  text-transform:uppercase;color:var(--gold);margin-bottom:1rem;
  display:flex;align-items:center;gap:0.6rem;
}
.contact-block-label::before{content:'';display:block;width:1.5rem;height:1px;background:var(--gold)}
.contact-item-key{
  font-family:var(--font-cond);font-size:0.6rem;letter-spacing:0.16em;
  text-transform:uppercase;color:var(--text-muted);margin-bottom:0.15rem;
}
.contact-item-val{
  font-size:0.92rem;font-weight:300;color:var(--text-primary);
  text-decoration:none;transition:color 0.2s;line-height:1.4;
}
a.contact-item-val:hover{color:var(--gold)}
.contact-divider{width:100%;height:1px;background:var(--border);margin:1.5rem 0}
.hours-grid{display:grid;grid-template-columns:1fr 1fr;gap:0.4rem 2rem}
.hours-day{font-family:var(--font-cond);font-size:0.72rem;letter-spacing:0.08em;text-transform:uppercase;color:var(--text-muted)}
.hours-time{font-size:0.82rem;font-weight:300;color:var(--text-primary)}
.social-links{display:flex;gap:0.75rem;flex-wrap:wrap;margin-top:0.5rem}
.social-link{
  font-family:var(--font-cond);font-size:0.66rem;letter-spacing:0.12em;
  text-transform:uppercase;color:var(--text-muted);text-decoration:none;
  border:1px solid var(--border);padding:0.4rem 0.8rem;
  transition:color 0.2s,border-color 0.2s;
}
.social-link:hover{color:var(--gold);border-color:var(--border-gold)}

/* ── FORM ── */
.form-heading{font-size:clamp(1.6rem,2.5vw,2.4rem);margin-bottom:0.4rem}
.form-sub{font-size:0.85rem;font-weight:300;color:var(--text-muted);margin-bottom:2rem;line-height:1.6}
.contact-form{display:flex;flex-direction:column;gap:1rem}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.form-field{display:flex;flex-direction:column;gap:0.35rem}
.form-label{
  font-family:var(--font-cond);font-size:0.62rem;letter-spacing:0.16em;
  text-transform:uppercase;color:var(--text-muted);
}
.form-input{
  background:#fff;border:1px solid var(--border);
  color:var(--text-primary);padding:0.75rem 0.9rem;
  font-family:var(--font-body);font-size:0.85rem;font-weight:300;
  outline:none;transition:border-color 0.25s;resize:vertical;
  -webkit-appearance:none;width:100%;
}
.form-input::placeholder{color:rgba(122,114,104,0.4)}
.form-input:focus{border-color:var(--gold)}
select.form-input{cursor:pointer}
.banner-success{
  display:none;background:rgba(184,131,42,0.08);
  border-left:3px solid var(--gold);padding:0.9rem 1.1rem;
  margin-bottom:1rem;font-family:var(--font-cond);font-size:0.75rem;
  letter-spacing:0.1em;text-transform:uppercase;color:var(--gold-dk);
}
.banner-error{
  display:none;background:rgba(180,60,60,0.08);
  border-left:3px solid #B43C3C;padding:0.9rem 1.1rem;
  margin-bottom:1rem;font-family:var(--font-cond);font-size:0.75rem;
  letter-spacing:0.1em;text-transform:uppercase;color:#B43C3C;
}

/* ── MAP ── */
.map-frame{width:100%;aspect-ratio:16/9;overflow:hidden;border:1px solid var(--border)}
.map-frame iframe{width:100%;height:100%;border:0;filter:grayscale(0.3) brightness(0.95)}

/* ── STAT BADGE ── */
.est-badge{
  position:absolute;bottom:-0.75rem;right:-1.25rem;
  background:var(--gold);padding:1.1rem 1.5rem;z-index:1;
}
.est-year{font-family:var(--font-display);font-size:2rem;font-weight:300;color:#fff;line-height:1}
.est-label{font-family:var(--font-cond);font-size:0.6rem;letter-spacing:0.18em;text-transform:uppercase;color:rgba(255,255,255,0.6);margin-top:0.15rem}

/* ── PROCESS STEPS ── */
.process-steps{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;margin-top:3rem}
.process-step{background:var(--bg-card);border:1px solid var(--border);padding:2rem 1.75rem}
.step-num{font-family:var(--font-display);font-size:2.8rem;font-weight:300;color:rgba(184,131,42,0.2);line-height:1;margin-bottom:0.6rem}
.step-name{font-family:var(--font-cond);font-size:0.85rem;font-weight:600;letter-spacing:0.08em;text-transform:uppercase;color:var(--text-primary);margin-bottom:0.4rem}
.step-desc{font-size:0.8rem;font-weight:300;color:var(--text-muted);line-height:1.6}

/* ── HIRE PAGE ── */
.cat-nav{
  position:sticky;top:60px;z-index:50;
  background:#fff;border-bottom:1px solid var(--border);
  padding:0 3rem;display:flex;gap:0;overflow-x:auto;
  box-shadow:0 2px 12px rgba(0,0,0,0.06);
}
.cat-nav a{
  font-family:var(--font-cond);font-size:0.7rem;font-weight:500;
  letter-spacing:0.1em;text-transform:uppercase;color:var(--text-muted);
  text-decoration:none;padding:0.9rem 1.25rem;
  border-bottom:2px solid transparent;white-space:nowrap;
  transition:color 0.2s,border-color 0.2s;
}
.cat-nav a:hover,.cat-nav a.active{color:var(--gold);border-bottom-color:var(--gold)}
.hire-note{
  background:#FFF8EE;border-left:3px solid var(--gold);
  padding:1.1rem 1.5rem;margin:2.5rem 3rem 0;
  display:flex;gap:0.75rem;align-items:flex-start;
}
.hire-note p{font-size:0.83rem;font-weight:300;color:var(--text-body);line-height:1.6}
.hire-note p strong{color:var(--text-primary);font-weight:500}
.cat-section{padding:3.5rem 3rem;border-bottom:1px solid var(--border)}
.cat-section:last-of-type{border-bottom:none}
.cat-header{
  display:flex;align-items:flex-end;justify-content:space-between;
  margin-bottom:2rem;padding-bottom:1rem;border-bottom:1px solid var(--border);
}
.cat-eyebrow{font-family:var(--font-cond);font-size:0.62rem;letter-spacing:0.2em;text-transform:uppercase;color:var(--gold);margin-bottom:0.3rem}
.cat-title{font-family:var(--font-display);font-size:clamp(1.5rem,3vw,2.2rem);font-weight:300;color:var(--text-primary)}
.cat-count{font-family:var(--font-display);font-size:3rem;font-weight:300;color:rgba(184,131,42,0.1);line-height:1}
.product-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.product-grid-2{grid-template-columns:repeat(2,1fr)}
.product-card{
  background:var(--bg-card);border:1px solid var(--border);
  display:flex;flex-direction:column;overflow:hidden;
  transition:box-shadow 0.3s,transform 0.3s;
}
.product-card:hover{box-shadow:0 6px 24px rgba(0,0,0,0.08);transform:translateY(-2px)}
.product-img{width:100%;aspect-ratio:4/3;overflow:hidden;flex-shrink:0}
.product-img img{width:100%;height:100%;object-fit:cover;filter:brightness(0.9) saturate(0.8);transition:transform 0.5s,filter 0.3s}
.product-card:hover .product-img img{transform:scale(1.03);filter:brightness(0.95) saturate(0.85)}
.product-body{padding:1.5rem;flex:1;display:flex;flex-direction:column}
.product-name{font-family:var(--font-cond);font-size:0.95rem;font-weight:600;letter-spacing:0.06em;text-transform:uppercase;color:var(--text-primary);margin-bottom:0.5rem}
.product-items{list-style:none;display:flex;flex-direction:column;gap:0.28rem;flex:1}
.product-items li{font-size:0.8rem;font-weight:300;color:var(--text-muted);display:flex;align-items:baseline;gap:0.4rem;line-height:1.4}
.product-items li::before{content:'—';color:rgba(184,131,42,0.4);flex-shrink:0;font-size:0.68rem}
.product-tag{display:inline-block;margin-top:0.75rem;font-family:var(--font-cond);font-size:0.6rem;letter-spacing:0.12em;text-transform:uppercase;color:var(--gold-dk);border:1px solid var(--border-gold);padding:0.2rem 0.5rem}

/* ── EBAY LISTINGS ── */
.listings-loading{text-align:center;padding:4rem 2rem;color:var(--text-muted)}
.loading-spinner{width:28px;height:28px;border:2px solid rgba(184,131,42,0.2);border-top-color:var(--gold);border-radius:50%;animation:spin 0.8s linear infinite;margin:0 auto 1rem}
@keyframes spin{to{transform:rotate(360deg)}}
.loading-text{font-family:var(--font-cond);font-size:0.72rem;letter-spacing:0.14em;text-transform:uppercase;color:var(--text-muted)}
.listing-card{
  background:var(--bg-card);border:1px solid var(--border);
  display:flex;flex-direction:column;
  transition:box-shadow 0.3s,transform 0.3s;
  text-decoration:none;color:inherit;
}
.listing-card:hover{box-shadow:0 6px 24px rgba(0,0,0,0.08);transform:translateY(-2px)}
.listing-img{width:100%;aspect-ratio:1;overflow:hidden;background:var(--bg-section);flex-shrink:0}
.listing-img img{width:100%;height:100%;object-fit:cover;transition:transform 0.5s}
.listing-card:hover .listing-img img{transform:scale(1.04)}
.listing-body{padding:1.1rem;flex:1;display:flex;flex-direction:column}
.listing-title{font-size:0.82rem;font-weight:400;color:var(--text-primary);line-height:1.4;margin-bottom:0.6rem;flex:1;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.listing-footer{display:flex;align-items:center;justify-content:space-between;margin-top:auto;padding-top:0.6rem;border-top:1px solid var(--border)}
.listing-price{font-family:var(--font-display);font-size:1.3rem;font-weight:300;color:var(--gold);line-height:1}
.listing-condition{font-family:var(--font-cond);font-size:0.58rem;letter-spacing:0.12em;text-transform:uppercase;color:var(--text-muted);border:1px solid var(--border);padding:0.18rem 0.45rem}
.listing-cta{display:block;text-align:center;font-family:var(--font-cond);font-size:0.65rem;font-weight:600;letter-spacing:0.1em;text-transform:uppercase;color:#fff;background:var(--gold);padding:0.55rem;margin:0 1.1rem 1.1rem;transition:background 0.25s;text-decoration:none}
.listing-card:hover .listing-cta{background:var(--gold-lt)}
.listings-meta{font-family:var(--font-cond);font-size:0.66rem;letter-spacing:0.12em;text-transform:uppercase;color:var(--text-muted)}
.listings-meta span{color:var(--gold)}

/* ── FOOTER ── */
footer{
  background:var(--bg-nav);
  border-top:1px solid rgba(255,255,255,0.06);
  padding:2rem 3rem;
  display:flex;align-items:center;justify-content:space-between;
  flex-wrap:wrap;gap:1.5rem;
}
.footer-logo{font-family:var(--font-cond);font-size:0.85rem;font-weight:600;letter-spacing:0.18em;text-transform:uppercase;color:rgba(245,240,232,0.45)}
.footer-logo span{color:var(--gold)}
.footer-copy{font-size:0.72rem;font-weight:300;color:rgba(245,240,232,0.25);text-align:center}
.footer-social{display:flex;gap:1.25rem;flex-wrap:wrap}
.footer-social a{font-family:var(--font-cond);font-size:0.62rem;letter-spacing:0.12em;text-transform:uppercase;color:rgba(245,240,232,0.4);text-decoration:none;transition:color 0.25s}
.footer-social a:hover{color:var(--gold)}

/* ── SCROLL REVEAL ── */
.reveal{opacity:0;transform:translateY(20px);transition:opacity 0.6s ease,transform 0.6s ease}
.reveal.visible{opacity:1;transform:none}

/* ── SCROLL HINT ── */
.scroll-hint{position:absolute;bottom:2rem;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:0.4rem;z-index:1}
.scroll-hint span{font-family:var(--font-cond);font-size:0.58rem;letter-spacing:0.18em;text-transform:uppercase;color:rgba(245,240,232,0.4)}
.scroll-line{width:1px;height:36px;background:linear-gradient(to bottom,rgba(184,131,42,0.5),transparent);animation:scrollAnim 2s ease-in-out infinite}
@keyframes scrollAnim{0%,100%{opacity:1}50%{opacity:0.3}}

/* ── RESPONSIVE ── */
@media(max-width:900px){
  nav{padding:1rem 1.5rem}
  .nav-links,.nav-cta{display:none}
  .nav-hamburger{display:flex}
  .section,.section-alt,.section-dark{padding:3.5rem 1.5rem}
  .page-hero{padding:7rem 1.5rem 4rem}
  .strip{padding:0.9rem 1.5rem;gap:1.25rem}
  .card-grid-3,.card-grid-4{grid-template-columns:1fr 1fr}
  .split{grid-template-columns:1fr}
  .split-img{min-height:260px}
  .split-content{padding:2.5rem 1.5rem}
  .contact-left,.contact-right{padding:3rem 1.5rem}
  .contact-left{border-right:none;border-bottom:1px solid var(--border)}
  .form-row{grid-template-columns:1fr}
  .cat-nav{padding:0 1.5rem}
  .hire-note{margin:2rem 1.5rem 0}
  .cat-section{padding:2.5rem 1.5rem}
  .product-grid{grid-template-columns:1fr 1fr}
  .process-steps{grid-template-columns:1fr 1fr}
  .enquire-strip{padding:2rem 1.5rem}
  footer{padding:1.75rem 1.5rem;flex-direction:column;text-align:center}
}
@media(max-width:600px){
  .card-grid-2,.card-grid-3,.card-grid-4{grid-template-columns:1fr}
  .product-grid,.product-grid-2{grid-template-columns:1fr}
  .process-steps{grid-template-columns:1fr}
}
