/* Imperial Gardens & Driveways — premium dark + gold system v1 (May 2026)
   Structure ported from the MB Design and Build framework; palette + type tuned
   for a heritage / Bath positioning. Mobile-first. */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  /* core palette */
  --ink:#0a0c10;            /* near-black canvas */
  --coal:#13161c;           /* card / nav background */
  --slate:#1f242d;          /* second-tier surface */
  --line:rgba(255,255,255,.08);
  --line-strong:rgba(255,255,255,.18);
  --paper:#f5f1e8;          /* warm cream for light sections */
  --paper-2:#ece6d6;
  --white:#ffffff;

  /* gold accents (matches the heraldic logo) */
  --gold:#d4a33a;
  --gold-bright:#e8c168;
  --gold-soft:#b48928;
  --gold-glow:rgba(212,163,58,.28);

  /* text on dark */
  --text:#e9e4d6;
  --muted:#a4a08e;
  --dim:#6b6856;

  /* text on light */
  --ink-text:#1a1814;

  --max:1180px;
  --pad:20px;
  --radius:6px;
  --shadow:0 18px 42px rgba(0,0,0,.42);
}

html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:'Inter',system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  background:var(--ink);
  color:var(--text);
  line-height:1.6;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
img,svg,video{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button,input,select,textarea{font:inherit}
button{cursor:pointer;border:0;background:none;color:inherit}
:focus-visible{outline:2px solid var(--gold);outline-offset:3px}

.container{width:min(100% - (var(--pad) * 2),var(--max));margin-inline:auto}

/* ===== Type ===== */
h1,h2,h3,h4{
  font-family:'Cormorant Garamond','Playfair Display',Georgia,'Times New Roman',serif;
  font-weight:600;
  line-height:1.1;
  letter-spacing:-.01em;
  color:var(--white);
}
h1{font-size:clamp(2.4rem,6.6vw,3.6rem);max-width:22ch;font-weight:600}
h2{font-size:clamp(1.95rem,4.8vw,2.7rem);max-width:24ch;font-weight:500}
h3{font-size:1.35rem;font-weight:600;letter-spacing:-.005em}
h4{font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;font-weight:700;color:var(--gold);font-family:'Inter',sans-serif}
p{font-size:1rem;color:var(--muted);line-height:1.66}
.lead{font-size:1.1rem;line-height:1.6;color:var(--text);max-width:54ch;margin-top:18px}

.eyebrow,.kicker{
  display:inline-flex;align-items:center;gap:10px;
  font-family:'Inter',sans-serif;font-size:.74rem;font-weight:700;
  letter-spacing:.22em;text-transform:uppercase;
  color:var(--gold);margin-bottom:14px
}
.eyebrow::before,.kicker::before{content:"";width:30px;height:1px;background:currentColor}

.hl{color:var(--gold);font-weight:inherit}

/* ===== Sections ===== */
section,.section{padding:64px 0;position:relative}
.section-dark{background:var(--ink);color:var(--text)}
.section-coal{background:var(--coal);color:var(--text)}
.section-light{background:var(--paper);color:var(--ink-text)}
.section-light h1,.section-light h2,.section-light h3{color:var(--ink-text)}
.section-light p{color:#4a463b}
.section-light .eyebrow,.section-light .kicker{color:var(--gold-soft)}
.section-light .lead{color:#3a362b}

/* ===== Nav ===== */
.site-nav{
  position:fixed;top:0;left:0;right:0;z-index:50;
  min-height:74px;padding:10px var(--pad);
  display:flex;align-items:center;justify-content:space-between;
  background:rgba(10,12,16,.86);
  border-bottom:1px solid var(--line);
  backdrop-filter:blur(14px);
  -webkit-backdrop-filter:blur(14px);
  transition:background .25s ease,border-color .25s ease;
}
.site-nav.scrolled{background:rgba(10,12,16,.96);border-bottom-color:var(--line-strong)}
.brand{display:flex;align-items:center;gap:12px;color:#fff}
.brand img{width:54px;height:54px;object-fit:contain;display:block}
.brand-text{display:flex;flex-direction:column;line-height:1}
.brand-text .nm{font-family:'Cormorant Garamond',Georgia,serif;font-size:1.18rem;font-weight:600;letter-spacing:.01em;color:#fff}
.brand-text .sub{font-size:.62rem;letter-spacing:.22em;text-transform:uppercase;color:var(--gold);margin-top:3px}

.nav-links{display:none}
.menu-btn{display:grid;place-items:center;width:46px;height:46px;border:1px solid var(--line-strong);border-radius:6px;background:transparent}
.menu-btn span{display:block;width:20px;height:1.5px;background:var(--gold);margin:2px 0}

.mobile-menu{
  position:fixed;inset:0;z-index:80;display:none;
  flex-direction:column;gap:14px;padding:90px 28px 40px;
  background:var(--ink);color:#fff;
}
.mobile-menu.open{display:flex}
.mobile-menu .close{position:absolute;top:18px;right:20px;width:46px;height:46px;border:1px solid var(--line-strong);border-radius:6px;color:#fff;font-size:1.8rem}
.mobile-menu a{font-family:'Cormorant Garamond',Georgia,serif;font-size:1.9rem;line-height:1;color:#fff;font-weight:500}
.mobile-menu a:hover{color:var(--gold)}
.mobile-menu .btn{font-size:.86rem;margin-top:16px}
.mobile-menu .ph{font-family:'Inter',sans-serif;font-size:1.05rem;font-weight:600;color:var(--gold);letter-spacing:.04em;margin-top:6px}

@media (min-width:1000px){
  .menu-btn{display:none}
  .mobile-menu.open{display:none}
  .nav-links{display:flex;align-items:center;gap:28px}
  .nav-links a{font-family:'Inter',sans-serif;font-size:.82rem;font-weight:500;letter-spacing:.06em;text-transform:uppercase;color:var(--text);transition:color .2s}
  .nav-links a:hover,.nav-links a.active{color:var(--gold)}
  .nav-cta{
    padding:11px 18px;border-radius:6px;
    background:var(--gold);color:var(--ink) !important;
    font-weight:700;
    border:1px solid var(--gold);
    transition:background .2s,color .2s,border-color .2s;
  }
  .nav-cta:hover{background:var(--gold-bright);border-color:var(--gold-bright);color:var(--ink) !important}
  .site-nav{padding:8px 40px;min-height:88px}
  .brand img{width:64px;height:64px}
  .brand-text .nm{font-size:1.35rem}
}

/* ===== Buttons ===== */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  min-height:50px;padding:14px 22px;
  border-radius:6px;
  font-family:'Inter',sans-serif;font-weight:700;font-size:.84rem;
  letter-spacing:.08em;text-transform:uppercase;
  transition:transform .2s ease,background .2s ease,border-color .2s ease,color .2s ease;
}
.btn:hover{transform:translateY(-2px)}
.btn-primary{background:var(--gold);color:var(--ink);border:1px solid var(--gold)}
.btn-primary:hover{background:var(--gold-bright);border-color:var(--gold-bright);color:var(--ink)}
.btn-ghost{background:transparent;color:#fff;border:1px solid var(--line-strong)}
.btn-ghost:hover{background:rgba(255,255,255,.06);border-color:var(--gold);color:var(--gold)}
.btn-light{background:rgba(255,255,255,.94);color:var(--ink);border:1px solid #fff}
.btn-light:hover{background:var(--gold);border-color:var(--gold);color:var(--ink)}
.section-light .btn-ghost{color:var(--ink-text);border-color:rgba(0,0,0,.18)}
.section-light .btn-ghost:hover{background:var(--ink);color:#fff;border-color:var(--ink)}
.btn .arr{font-family:'Inter',sans-serif;font-weight:400;transition:transform .2s}
.btn:hover .arr,a:hover .arr{transform:translateX(4px)}

/* ===== Hero ===== */
.lead-hero{
  position:relative;
  min-height:660px;
  display:flex;align-items:flex-end;
  padding:120px 0 48px;
  background:var(--ink);
  overflow:hidden;
}
.hero-media{
  position:absolute;inset:0;
  background:
    linear-gradient(180deg,rgba(8,10,14,.55) 0%,rgba(8,10,14,.82) 60%,rgba(8,10,14,.96) 100%),
    url('../img/resin-driveway-grey.webp') center/cover no-repeat;
}
.hero-media.bg-japanese{background:linear-gradient(180deg,rgba(8,10,14,.55),rgba(8,10,14,.94)),url('../img/japanese-garden-wide.webp') center/cover no-repeat}
.hero-media.bg-patio{background:linear-gradient(180deg,rgba(8,10,14,.5),rgba(8,10,14,.92)),url('../img/grey-sandstone-patio.webp') center/cover no-repeat}
.hero-media.bg-decking{background:linear-gradient(180deg,rgba(8,10,14,.55),rgba(8,10,14,.94)),url('../img/composite-decking-pergola.webp') center/cover no-repeat}
.hero-media.bg-blockpaving{background:linear-gradient(180deg,rgba(8,10,14,.55),rgba(8,10,14,.94)),url('../img/charcoal-block-paving-driveway.webp') center/cover no-repeat}
.hero-media.bg-fence{background:linear-gradient(180deg,rgba(8,10,14,.5),rgba(8,10,14,.92)),url('../img/fence-brick-patio.webp') center/cover no-repeat}
.hero-media.bg-porcelain{background:linear-gradient(180deg,rgba(8,10,14,.5),rgba(8,10,14,.92)),url('../img/porcelain-patio-walled-garden.webp') center/cover no-repeat}
/* Artificial grass: gradient only, no photo */
.hero-media.bg-grass{background:radial-gradient(ellipse at 20% 30%,rgba(46,93,55,.4),transparent 65%),linear-gradient(180deg,#0a1410 0%,var(--ink) 100%)}
.hero-inner{position:relative;z-index:1}
.lead-hero h1{color:#fff;text-shadow:0 2px 30px rgba(0,0,0,.45)}
.lead-hero h1 .hl{color:var(--gold)}
.hero-sub{color:rgba(255,255,255,.86);font-size:1.08rem;margin-top:18px;max-width:38rem;text-shadow:0 1px 16px rgba(0,0,0,.45)}
.hero-actions{display:grid;gap:10px;margin-top:30px}
.hero-proof{display:flex;flex-wrap:wrap;gap:8px;margin-top:26px}
.hero-proof span{
  padding:8px 12px;
  border:1px solid var(--line-strong);
  border-radius:999px;
  background:rgba(255,255,255,.06);
  font-size:.72rem;font-weight:600;letter-spacing:.08em;
  color:rgba(255,255,255,.88);
  text-transform:uppercase;
}
@media (min-width:700px){
  .lead-hero{min-height:740px;padding-bottom:80px}
  .hero-actions{display:flex;flex-wrap:wrap;gap:14px}
  .hero-sub{font-size:1.18rem}
}
@media (min-width:1000px){
  .lead-hero{min-height:820px}
  .lead-hero h1{font-size:clamp(3.4rem,5.6vw,5rem);max-width:24ch}
}

/* ===== Page hero (interior pages) ===== */
.page-hero{
  position:relative;padding:128px 0 56px;
  background:var(--coal);border-bottom:1px solid var(--line);
}
.page-hero h1{font-size:clamp(2.2rem,5.4vw,3.4rem);max-width:24ch}
.crumb{display:inline-flex;flex-wrap:wrap;gap:6px;font-size:.74rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-bottom:18px}
.crumb a{color:var(--gold);transition:color .2s}
.crumb a:hover{color:var(--gold-bright)}
.crumb span.sep{color:var(--dim)}

/* ===== Service cards ===== */
.service-cards{display:grid;gap:14px;margin-top:30px}
.service-card{
  display:block;background:var(--coal);
  border:1px solid var(--line);border-radius:8px;
  padding:24px;
  transition:border-color .25s,transform .25s,background .25s;
}
.service-card .n{display:inline-block;font-family:'Cormorant Garamond',Georgia,serif;font-size:1.6rem;color:var(--gold);margin-bottom:14px;line-height:1}
.service-card h3{color:#fff;margin-bottom:8px}
.service-card p{color:var(--muted);font-size:.96rem}
.service-card em{display:inline-block;margin-top:18px;font-style:normal;font-weight:700;font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;color:var(--gold)}
.service-card:hover{border-color:var(--gold);background:#15191f;transform:translateY(-2px)}
.service-card.featured{background:linear-gradient(160deg,rgba(212,163,58,.12) 0%,var(--coal) 60%);border-color:var(--gold-soft)}
.service-card.featured .n,.service-card.featured h3{color:var(--gold-bright)}
.service-card.featured em::after{content:" \2192"}
@media (min-width:700px){.service-cards{grid-template-columns:repeat(2,1fr)}}
@media (min-width:1000px){.service-cards{grid-template-columns:repeat(3,1fr);gap:18px}}

/* ===== Split / grid ===== */
.split{display:grid;gap:32px}
.split>img,.split>.imgwrap{order:-1}
@media (min-width:900px){
  .split{grid-template-columns:1fr 1fr;align-items:center;gap:48px}
  .split>img,.split>.imgwrap{order:0}
  .split.reverse>.copy{order:1}
}
.copy-stack{display:grid;gap:14px}
.imgwrap{
  position:relative;border-radius:8px;overflow:hidden;
  background:#111;border:1px solid var(--line);aspect-ratio:4/3;
}
.imgwrap img{width:100%;height:100%;object-fit:cover}
.imgwrap.tall{aspect-ratio:3/4}

/* ===== Project grid ===== */
.proj-grid{display:grid;gap:14px;grid-template-columns:1fr;margin-top:28px}
.proj{
  position:relative;display:block;
  aspect-ratio:4/3;border-radius:8px;overflow:hidden;
  background:#111;border:1px solid var(--line);
  transition:border-color .25s,transform .25s,box-shadow .25s;
}
.proj img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0;transition:transform .8s cubic-bezier(.25,.1,.25,1)}
.proj::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 30%,rgba(0,0,0,.5) 70%,rgba(0,0,0,.92) 100%)}
.proj .caption{position:absolute;left:18px;right:18px;bottom:18px;z-index:1;display:flex;align-items:flex-end;justify-content:space-between;gap:12px}
.proj .caption .t{font-family:'Cormorant Garamond',Georgia,serif;font-size:1.25rem;font-weight:500;color:#fff;line-height:1.15}
.proj .caption .s{display:block;font-size:.7rem;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--gold);margin-bottom:4px}
.proj .tag{flex:0 0 auto;padding:5px 10px;border:1px solid var(--gold);border-radius:999px;font-size:.66rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--gold);background:rgba(212,163,58,.12)}
.proj:hover{border-color:var(--gold);transform:translateY(-3px);box-shadow:0 14px 36px rgba(0,0,0,.45)}
.proj:hover img{transform:scale(1.06)}
@media (min-width:700px){.proj-grid{grid-template-columns:repeat(2,1fr);gap:18px}}
@media (min-width:1000px){.proj-grid{grid-template-columns:repeat(3,1fr);gap:22px}.proj.wide{grid-column:span 2;aspect-ratio:16/9}}

/* ===== Stats ===== */
.stats{display:grid;gap:20px;grid-template-columns:repeat(2,1fr);margin-top:36px}
.stats div{padding:22px;border:1px solid var(--line);border-radius:8px;background:rgba(255,255,255,.02)}
.stats .n{display:block;font-family:'Cormorant Garamond',Georgia,serif;font-size:2.4rem;color:var(--gold);line-height:1;font-weight:600}
.stats .l{display:block;margin-top:8px;font-size:.74rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}
@media (min-width:700px){.stats{grid-template-columns:repeat(4,1fr)}}

/* ===== Process steps ===== */
.steps{display:grid;gap:16px;margin-top:36px}
.step{padding:24px;border:1px solid var(--line);border-radius:8px;background:var(--coal)}
.step .n{display:block;font-family:'Cormorant Garamond',Georgia,serif;font-size:1.5rem;color:var(--gold);line-height:1;margin-bottom:10px}
.step h3{margin-bottom:8px;color:#fff}
@media (min-width:700px){.steps{grid-template-columns:repeat(2,1fr)}}
@media (min-width:1000px){.steps{grid-template-columns:repeat(4,1fr)}}

/* ===== Checklist ===== */
.checklist{list-style:none;display:grid;gap:12px;margin-top:18px}
.checklist li{display:flex;gap:12px;font-size:.98rem;color:var(--text)}
.checklist li::before{content:"";flex:0 0 auto;width:18px;height:18px;border:1px solid var(--gold);border-radius:50%;background:radial-gradient(circle at 35% 35%,var(--gold),var(--gold-soft));margin-top:5px;box-shadow:0 0 0 3px rgba(212,163,58,.08)}
.section-light .checklist li{color:var(--ink-text)}

/* ===== FAQ ===== */
.faq-list{display:grid;gap:10px;margin-top:24px}
.faq-item{border:1px solid var(--line);border-radius:8px;background:var(--coal);overflow:hidden}
.section-light .faq-item{background:#fff;border-color:rgba(0,0,0,.08)}
.faq-q{width:100%;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:18px;text-align:left;font-family:'Cormorant Garamond',Georgia,serif;font-size:1.18rem;color:#fff;font-weight:500}
.section-light .faq-q{color:var(--ink-text)}
.faq-q .plus{display:grid;place-items:center;width:30px;height:30px;border:1px solid var(--gold);border-radius:6px;color:var(--gold);transition:transform .2s,background .2s;flex:0 0 auto;font-size:1.1rem;line-height:1}
.faq-a{max-height:0;overflow:hidden;transition:max-height .3s ease}
.faq-a div,.faq-a p{padding:0 18px 18px;color:var(--muted)}
.section-light .faq-a div,.section-light .faq-a p{color:#4a463b}
.faq-item.open .faq-a{max-height:520px}
.faq-item.open .faq-q .plus{transform:rotate(45deg);background:var(--gold);color:var(--ink)}

/* ===== Area list ===== */
.area-list{display:flex;flex-wrap:wrap;gap:8px;margin-top:18px}
.area-list span{padding:8px 14px;border:1px solid var(--line);border-radius:999px;font-size:.84rem;font-weight:500;color:var(--text);background:rgba(255,255,255,.03)}
.section-light .area-list span{background:#fff;border-color:rgba(0,0,0,.1);color:var(--ink-text)}

/* ===== Quote / contact form ===== */
.quote{display:grid;gap:14px;background:var(--coal);border:1px solid var(--line);border-radius:10px;padding:26px}
.section-light .quote{background:#fff;border-color:rgba(0,0,0,.08)}
.quote h3{font-size:1.55rem}
.quote label{display:grid;gap:6px;font-size:.74rem;font-weight:700;letter-spacing:.08em;color:var(--muted);text-transform:uppercase}
.section-light .quote label{color:#4a463b}
.quote input,.quote select,.quote textarea{
  width:100%;
  border:1px solid var(--line);
  border-radius:6px;
  background:rgba(255,255,255,.03);
  padding:14px;
  color:var(--text);
  font-size:1rem;
}
.section-light .quote input,.section-light .quote select,.section-light .quote textarea{background:var(--paper);border-color:rgba(0,0,0,.1);color:var(--ink-text)}
.quote textarea{min-height:120px;resize:vertical}
.quote input:focus,.quote select:focus,.quote textarea:focus{outline:0;border-color:var(--gold);background:rgba(212,163,58,.06);box-shadow:0 0 0 3px var(--gold-glow)}
.quote .row2{display:grid;gap:12px}
@media (min-width:600px){.quote .row2{grid-template-columns:1fr 1fr}}
.quote .note{font-size:.84rem;color:var(--muted)}
.quote .note a{color:var(--gold);font-weight:700}

/* ===== CTA banner ===== */
.cta-banner{
  position:relative;
  background:
    linear-gradient(135deg,rgba(212,163,58,.10) 0%,transparent 60%),
    var(--ink);
  border-top:1px solid var(--line);
  padding:78px 0;text-align:center;
}
.cta-banner h2{color:#fff;margin-inline:auto}
.cta-banner p{margin:14px auto 0;max-width:52ch}
.cta-banner .actions{justify-content:center;display:flex;flex-wrap:wrap;gap:12px;margin-top:32px}
.actions{display:flex;flex-wrap:wrap;gap:12px;margin-top:30px}

/* ===== Trust strip ===== */
.trust{background:var(--coal);border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:22px 0}
.trust-row{display:flex;flex-wrap:wrap;gap:8px;justify-content:center}
.trust-row span{padding:8px 14px;border:1px solid var(--line);border-radius:999px;background:rgba(212,163,58,.05);color:var(--text);font-size:.78rem;font-weight:600;letter-spacing:.06em}
.trust-row span::before{content:"✦";color:var(--gold);margin-right:8px}

/* ===== Footer ===== */
footer{background:#070809;color:rgba(255,255,255,.6);padding:56px 0 30px;border-top:1px solid var(--line)}
.footer-grid{display:grid;gap:30px}
.footer-brand{display:flex;align-items:center;gap:14px;margin-bottom:8px}
.footer-brand img{width:54px;height:54px}
.footer-brand .nm{font-family:'Cormorant Garamond',Georgia,serif;color:#fff;font-size:1.2rem;font-weight:600}
.footer-brand .sub{display:block;font-size:.62rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);margin-top:3px}
.footer-grid h4{color:var(--gold);font-size:.74rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;margin-bottom:14px}
.footer-grid a,.footer-grid span{display:block;color:rgba(255,255,255,.65);padding:4px 0;font-size:.94rem;transition:color .2s}
.footer-grid a:hover{color:var(--gold)}
.footer-grid p{color:rgba(255,255,255,.55);margin-top:12px;font-size:.92rem}
.footer-bottom{display:grid;gap:8px;margin-top:34px;padding-top:20px;border-top:1px solid var(--line);font-size:.78rem;color:rgba(255,255,255,.42)}
@media (min-width:700px){.footer-grid{grid-template-columns:1.4fr 1fr 1fr 1fr;gap:48px}.footer-bottom{grid-template-columns:1fr 1fr}.footer-bottom .right{text-align:right}}

/* ===== WhatsApp / phone floating button ===== */
.wa-fab{position:fixed;right:18px;bottom:18px;z-index:90;width:58px;height:58px;border-radius:50%;display:grid;place-items:center;background:#25D366;box-shadow:0 10px 26px rgba(37,211,102,.45),0 2px 6px rgba(0,0,0,.25);transition:transform .2s,box-shadow .2s}
.wa-fab svg{width:30px;height:30px;display:block}
.wa-fab:hover{transform:translateY(-2px);box-shadow:0 14px 32px rgba(37,211,102,.55)}
@media (min-width:700px){.wa-fab{width:66px;height:66px;right:28px;bottom:28px}.wa-fab svg{width:34px;height:34px}}

/* ===== Service-detail content typography ===== */
main h2{margin-top:32px}
main h3{margin-top:24px;margin-bottom:10px}
main p+p{margin-top:14px}
.lead-copy{font-size:1.05rem;line-height:1.7;color:var(--text)}
.section-light .lead-copy{color:var(--ink-text)}

/* ===== Conversion strip (hidden on mobile, shows on tablet+) ===== */
.conversion-strip{display:none;background:var(--slate);padding:18px 0;border-bottom:1px solid var(--line)}
.strip-grid{display:grid;gap:10px;grid-template-columns:1fr}
.strip-grid a{display:block;padding:16px 18px;border:1px solid var(--line);border-radius:8px;background:rgba(255,255,255,.03);transition:border-color .2s,background .2s}
.strip-grid a:hover{border-color:var(--gold);background:rgba(212,163,58,.06)}
.strip-grid strong{display:block;font-family:'Cormorant Garamond',Georgia,serif;font-size:1.15rem;color:#fff;font-weight:500}
.strip-grid span{display:block;color:var(--muted);font-size:.86rem;margin-top:3px}
@media (min-width:700px){.conversion-strip{display:block}.strip-grid{grid-template-columns:repeat(3,1fr);gap:14px}}

/* ===== Testimonial cards ===== */
.t-grid{display:grid;gap:18px;margin-top:30px}
@media (min-width:700px){.t-grid{grid-template-columns:repeat(2,1fr)}}
@media (min-width:1000px){.t-grid{grid-template-columns:repeat(3,1fr)}}
.t-card{padding:26px;border:1px solid var(--line);border-radius:8px;background:var(--coal);position:relative}
.section-light .t-card{background:#fff;border-color:rgba(0,0,0,.08)}
.t-card .stars{color:var(--gold);letter-spacing:.1em;font-size:1rem;margin-bottom:14px}
.t-card .body{font-size:1rem;line-height:1.6;color:var(--text);margin-bottom:18px}
.section-light .t-card .body{color:var(--ink-text)}
.t-card .who{font-family:'Inter',sans-serif;font-weight:700;font-size:.84rem;color:#fff;letter-spacing:.04em}
.section-light .t-card .who{color:var(--ink-text)}
.t-card .who span{display:block;font-weight:500;font-size:.78rem;color:var(--muted);margin-top:3px;letter-spacing:.06em;text-transform:uppercase}

/* ===== Blog ===== */
.blog-grid{display:grid;gap:22px;margin-top:32px}
@media (min-width:700px){.blog-grid{grid-template-columns:repeat(2,1fr)}}
@media (min-width:1000px){.blog-grid{grid-template-columns:repeat(3,1fr)}}
.blog-card{display:block;background:var(--coal);border:1px solid var(--line);border-radius:10px;overflow:hidden;transition:border-color .25s,transform .25s}
.blog-card:hover{border-color:var(--gold);transform:translateY(-2px)}
.blog-card .ph{aspect-ratio:16/9;background:#111;background-size:cover;background-position:center}
.blog-card .body{padding:22px}
.blog-card .meta{font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;color:var(--gold);font-weight:600;margin-bottom:10px}
.blog-card h3{color:#fff;font-size:1.25rem;margin-bottom:10px}
.blog-card p{font-size:.94rem}

.post-body{max-width:42rem;margin-inline:auto;font-size:1.04rem;line-height:1.78;color:var(--text)}
.post-body h2{font-size:clamp(1.55rem,3.4vw,2rem);margin-top:42px;margin-bottom:14px}
.post-body h3{font-size:1.22rem;margin-top:28px;margin-bottom:8px}
.post-body p{color:var(--text)}
.post-body ul,.post-body ol{margin:14px 0 14px 20px}
.post-body li{margin-bottom:8px;color:var(--text)}
.post-body blockquote{border-left:3px solid var(--gold);padding:6px 0 6px 22px;margin:24px 0;font-family:'Cormorant Garamond',Georgia,serif;font-size:1.2rem;color:#fff;line-height:1.5}

/* ===== Legal pages ===== */
.legal-body{max-width:44rem;margin-inline:auto}
.legal-body h2{margin-top:34px;margin-bottom:10px;font-size:1.5rem}
.legal-body h3{margin-top:22px;margin-bottom:8px;font-size:1.15rem}
.legal-body p,.legal-body li{font-size:.96rem;line-height:1.65}
.legal-body ul,.legal-body ol{margin:10px 0 14px 22px}

/* ===== Reveal animation ===== */
.reveal{opacity:1;transform:none}
@media (min-width:700px){
  .reveal{opacity:0;transform:translateY(16px);transition:opacity .6s ease,transform .6s ease}
  .reveal.in{opacity:1;transform:none}
}

/* ===== Helpers ===== */
.text-center{text-align:center}
.mt-0{margin-top:0}.mt-8{margin-top:8px}.mt-16{margin-top:16px}.mt-24{margin-top:24px}.mt-32{margin-top:32px}
.muted{color:var(--muted)}
.gold{color:var(--gold)}

/* ===== Tables (legal) ===== */
table{width:100%;border-collapse:collapse;font-size:.92rem;margin:14px 0 22px;display:block;overflow-x:auto}
table thead th{background:var(--slate);text-align:left;padding:12px 14px;font-size:.74rem;letter-spacing:.08em;text-transform:uppercase;color:var(--gold);border-bottom:1px solid var(--line)}
table tbody td{padding:12px 14px;border-bottom:1px solid var(--line);color:var(--text);vertical-align:top}

/* ===== Reduced motion ===== */
@media (prefers-reduced-motion:reduce){*,*::before,*::after{scroll-behavior:auto!important;transition:none!important;animation:none!important}.reveal{opacity:1;transform:none}}

/* ===== Print ===== */
@media print{.site-nav,.mobile-menu,.wa-fab,.cta-banner,footer{display:none!important}body{background:#fff;color:#000}h1,h2,h3,h4{color:#000}}
