/* ============================================================
   TITANS FLOOR COATINGS
   Chrome + concrete premium landing page
   ============================================================ */

:root{
  --ink:#0b0c0e;
  --ink-2:#121419;
  --ink-3:#1a1d23;
  --ink-line:rgba(255,255,255,.10);
  --ink-line-2:rgba(255,255,255,.16);
  --paper:#f4f5f7;
  --paper-2:#ffffff;
  --paper-line:rgba(11,12,14,.10);
  --paper-line-2:rgba(11,12,14,.16);

  --text-dark:#e9ebee;        /* on dark */
  --text-dark-soft:#a7adb6;
  --text-light:#16181c;       /* on light */
  --text-light-soft:#565d67;

  --chrome-hi:#ffffff;
  --chrome-1:#dfe3e8;
  --chrome-2:#b9bfc7;
  --chrome-3:#8d949d;
  --chrome-4:#5d646e;

  --steel:#7f8a99;

  --r-sm:10px; --r-md:16px; --r-lg:24px; --r-xl:34px;
  --wrap:1200px;
  --pad:clamp(20px,5vw,72px);

  --shadow-1:0 2px 8px rgba(0,0,0,.18);
  --shadow-2:0 18px 50px rgba(0,0,0,.28);
  --shadow-3:0 30px 80px rgba(0,0,0,.45);

  --ease:cubic-bezier(.2,.7,.2,1);
}

*{box-sizing:border-box;margin:0;padding:0}
[hidden]{display:none !important}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;overflow-x:clip}
body{
  font-family:"Inter",system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  color:var(--text-light);
  background:var(--ink);
  line-height:1.6;
  font-size:17px;
  -webkit-font-smoothing:antialiased;
  overflow-x:clip;
}
img,svg{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
ul{list-style:none}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}

.wrap{width:100%;max-width:var(--wrap);margin-inline:auto;padding-inline:var(--pad)}

h1,h2,h3,h4{
  font-family:"Archivo",sans-serif;
  font-weight:800;
  line-height:1.04;
  letter-spacing:-.02em;
  color:var(--text-light);
}
h2{font-size:clamp(1.9rem,4.4vw,3.25rem)}
h3{font-size:1.3rem;letter-spacing:-.01em}
p{text-wrap:pretty}

/* ---------- section system ---------- */
.section{position:relative;padding-block:clamp(64px,9vw,128px);isolation:isolate}
.section-dark{background:var(--ink);color:var(--text-dark)}
.section-dark h1,.section-dark h2,.section-dark h3,.section-dark h4{color:#fff}
.section-light{background:var(--paper);color:var(--text-light)}
.section-dark::before{
  /* concrete depth */
  content:"";position:absolute;inset:0;z-index:-2;
  background:
    radial-gradient(120% 80% at 80% -10%,rgba(127,138,153,.16),transparent 60%),
    radial-gradient(80% 60% at 0% 110%,rgba(127,138,153,.10),transparent 55%),
    var(--ink);
}
.section-light::after{
  content:"";position:absolute;left:0;right:0;top:0;height:1px;z-index:1;
  background:linear-gradient(90deg,transparent,var(--paper-line),transparent);
}

/* grain overlay */
.grain{position:absolute;inset:0;z-index:-1;pointer-events:none;opacity:.5;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.45'/%3E%3C/svg%3E");
  mix-blend-mode:overlay;
}

/* ---------- eyebrows / heads ---------- */
.eyebrow{
  display:inline-flex;align-items:center;gap:9px;
  font-size:.74rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;
  color:var(--text-dark-soft);margin-bottom:18px;
}
.eyebrow-dark{color:var(--text-light-soft)}
.eyebrow .dot{width:7px;height:7px;border-radius:50%;
  background:linear-gradient(180deg,var(--chrome-hi),var(--chrome-3));
  box-shadow:0 0 0 4px rgba(127,138,153,.18)}
.section-head{max-width:760px;margin-bottom:clamp(34px,5vw,60px)}
.section-head.center{margin-inline:auto;text-align:center}
.section-head.center .eyebrow{justify-content:center}
.sec-index{
  display:block;font-family:"Archivo";font-weight:800;font-size:.8rem;
  letter-spacing:.3em;color:var(--steel);opacity:.6;margin-bottom:14px;
}
.lead{margin-top:18px;font-size:1.12rem;color:var(--text-light-soft);max-width:60ch}
.section-dark .lead{color:var(--text-dark-soft)}
.section-head.center .lead{margin-inline:auto}

.chrome-text{
  background:linear-gradient(180deg,#fff 0%,#e7eaee 40%,#9aa1aa 56%,#f3f5f7 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
  filter:drop-shadow(0 1px 0 rgba(0,0,0,.25));
}

/* ---------- buttons ---------- */
.btn{
  --bh:54px;
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  height:var(--bh);padding:0 24px;border-radius:999px;
  font-weight:700;font-size:.98rem;letter-spacing:.01em;white-space:nowrap;
  transition:transform .25s var(--ease),box-shadow .25s var(--ease),background .25s,color .25s;
  position:relative;overflow:hidden;
}
.btn .ic{width:18px;height:18px;fill:currentColor;flex:none}
.btn-lg{--bh:60px;padding:0 30px;font-size:1.02rem}
.btn-block{width:100%}

.btn-chrome{
  color:#15181d;
  background:linear-gradient(180deg,#ffffff 0%,#e4e8ec 42%,#c2c8cf 55%,#eef1f4 100%);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.9),inset 0 -2px 6px rgba(0,0,0,.18),0 10px 26px rgba(0,0,0,.32);
  font-weight:800;
}
.btn-chrome::after{
  content:"";position:absolute;inset:0;transform:translateX(-130%);
  background:linear-gradient(110deg,transparent 30%,rgba(255,255,255,.85) 50%,transparent 70%);
  transition:transform .7s var(--ease);
}
.btn-chrome:hover{transform:translateY(-2px);box-shadow:inset 0 1px 0 rgba(255,255,255,.9),0 16px 34px rgba(0,0,0,.4)}
.btn-chrome:hover::after{transform:translateX(130%)}

.btn-ink{
  color:#fff;background:linear-gradient(180deg,#23262c,#0e1014);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.08),0 10px 26px rgba(0,0,0,.28);
  border:1px solid rgba(255,255,255,.06);
}
.btn-ink:hover{transform:translateY(-2px);box-shadow:0 16px 34px rgba(0,0,0,.4)}

.btn-outline{color:#fff;border:1px solid var(--ink-line-2);background:rgba(255,255,255,.03);backdrop-filter:blur(4px)}
.btn-outline:hover{background:rgba(255,255,255,.08);transform:translateY(-2px)}
.btn-ghost{color:var(--text-dark);border:1px solid var(--ink-line)}
.btn-ghost:hover{background:rgba(255,255,255,.06)}
.btn-ghost-dark{color:var(--text-light);border:1px solid var(--paper-line-2);height:46px;padding:0 20px;border-radius:999px;font-weight:700;font-size:.9rem}
.btn-ghost-dark:hover{background:#fff;box-shadow:var(--shadow-1)}

/* ============================================================
   HEADER
   ============================================================ */
.site-header{
  position:sticky;top:0;z-index:60;
  background:rgba(11,12,14,.72);
  backdrop-filter:blur(14px) saturate(1.2);
  border-bottom:1px solid var(--ink-line);
}
.header-inner{display:flex;align-items:center;gap:22px;height:78px}
.brand-logo{height:50px;width:auto;object-fit:contain;border-radius:6px}
.primary-nav{display:flex;gap:26px;margin-left:14px}
.primary-nav a{font-size:.92rem;font-weight:600;color:var(--text-dark-soft);transition:color .2s;position:relative;padding:6px 0}
.primary-nav a:hover{color:#fff}
.primary-nav a::after{content:"";position:absolute;left:0;bottom:0;height:1px;width:0;background:linear-gradient(90deg,var(--chrome-hi),var(--chrome-3));transition:width .25s var(--ease)}
.primary-nav a:hover::after{width:100%}
.header-cta{margin-left:auto;display:flex;align-items:center;gap:12px}
.header-cta .btn-call{height:46px}
.header-cta .btn-chrome{height:46px}

.nav-toggle{display:none;width:44px;height:44px;margin-left:auto;border-radius:10px;border:1px solid var(--ink-line);flex-direction:column;align-items:center;justify-content:center;gap:5px}
.nav-toggle span{width:20px;height:2px;background:#fff;border-radius:2px;transition:.3s var(--ease)}
.nav-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.nav-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.mobile-nav{display:flex;flex-direction:column;gap:4px;padding:14px var(--pad) 26px;background:rgba(11,12,14,.96);border-bottom:1px solid var(--ink-line)}
.mobile-nav a{padding:13px 4px;font-weight:600;color:var(--text-dark);border-bottom:1px solid var(--ink-line)}
.mobile-nav a:last-child{border:none;margin-top:10px}
.mobile-nav .btn-chrome{justify-content:center}

/* ============================================================
   HERO
   ============================================================ */
.hero{position:relative;isolation:isolate;padding-top:clamp(48px,7vw,90px);padding-bottom:clamp(48px,7vw,96px);overflow:hidden}
.hero-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;filter:brightness(1.3) saturate(1.05)}
.hero-scrim{position:absolute;inset:0;z-index:1;pointer-events:none;
  background:
    linear-gradient(90deg,rgba(8,9,11,.9) 0%,rgba(8,9,11,.68) 38%,rgba(8,9,11,.36) 70%,rgba(8,9,11,.58) 100%),
    linear-gradient(180deg,rgba(8,9,11,.4),transparent 36%,rgba(8,9,11,.36));
}
.hero .grain{z-index:2}
.hero .wrap{position:relative;z-index:3}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(30px,5vw,70px);align-items:center}

/* hero quote form */
.hero-form{position:relative;overflow:hidden;
  background:linear-gradient(180deg,rgba(21,24,29,.94),rgba(11,13,16,.94));
  backdrop-filter:blur(10px);border:1px solid var(--ink-line-2);
  border-radius:var(--r-xl);padding:clamp(22px,2.6vw,32px);box-shadow:var(--shadow-3)}
.hero-form::before{content:"";position:absolute;left:0;top:0;right:0;height:3px;background:linear-gradient(90deg,var(--chrome-4),var(--chrome-hi),var(--chrome-4))}
.hero-form-head{margin-bottom:18px}
.hero-form-title{font-size:1.5rem;color:#fff;margin-bottom:5px}
.hero-form-sub{font-size:.92rem;color:var(--text-dark-soft)}
.hero-form .field{margin-bottom:12px}
.hero-form .btn-block{margin-top:4px}
.hero-form-trust{margin-top:14px;text-align:center;font-size:.82rem;color:var(--text-dark-soft)}
.hero-form-trust .stars{color:#f5c451;letter-spacing:1px;margin-right:6px}
.hero-title{font-size:clamp(2.5rem,6vw,4.6rem);font-weight:900;color:#fff;margin-bottom:22px}
.hero-sub{font-size:1.15rem;color:var(--text-dark-soft);max-width:54ch;margin-bottom:30px}
.hero-actions{display:flex;flex-wrap:wrap;gap:14px;margin-bottom:30px}
.hero-trust{display:flex;flex-wrap:wrap;gap:10px 24px;align-items:center}
.hero-trust li{font-size:.9rem;color:#ffffff;display:flex;align-items:center;gap:8px;font-weight:500}
.hero-trust li::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--steel)}
.hero-trust li strong{color:#fff;font-family:"Archivo";font-weight:800;font-size:1rem}

.hero-media{position:relative}
.hero-frame{position:relative;border-radius:var(--r-xl);overflow:hidden;
  border:1px solid var(--ink-line-2);
  box-shadow:var(--shadow-3),inset 0 1px 0 rgba(255,255,255,.1);
  aspect-ratio:4/5;background:#000;
}
.hero-frame img{width:100%;height:100%;object-fit:cover}
.hero-frame::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 55%,rgba(0,0,0,.5));pointer-events:none}
.rating-badge{
  position:absolute;left:18px;bottom:18px;z-index:2;
  display:flex;align-items:center;gap:12px;
  padding:12px 16px;border-radius:16px;
  background:rgba(15,17,21,.72);backdrop-filter:blur(10px);
  border:1px solid var(--ink-line-2);box-shadow:var(--shadow-2);
}
.rating-badge .stars{color:#f5c451;font-size:.85rem;letter-spacing:1px}
.rating-badge-text{display:flex;flex-direction:column;line-height:1.1}
.rating-badge-text strong{font-family:"Archivo";font-size:1.3rem;color:#fff}
.rating-badge-text span{font-size:.72rem;color:var(--text-dark-soft)}

/* ---------- trust marquee ---------- */
.trust-strip{padding-block:18px;border-top:1px solid var(--ink-line);border-bottom:1px solid var(--ink-line);overflow:hidden}
.marquee{display:flex;width:max-content;animation:marquee 32s linear infinite}
.marquee ul{display:flex;align-items:center;gap:0}
.marquee li{font-size:.82rem;letter-spacing:.16em;text-transform:uppercase;color:#ffffff;font-weight:600;padding:0 22px;white-space:nowrap}
.marquee li.sep{color:var(--steel);padding:0;opacity:.6}
@keyframes marquee{to{transform:translateX(-50%)}}

/* ============================================================
   SERVICES
   ============================================================ */
.service-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.service-card{
  position:relative;background:var(--paper-2);border:1px solid var(--paper-line);
  border-radius:var(--r-lg);padding:0;display:flex;flex-direction:column;transition:transform .35s var(--ease),box-shadow .35s var(--ease),border-color .35s;
  box-shadow:0 1px 2px rgba(11,12,14,.04);overflow:hidden;
}
.svc-media{aspect-ratio:4/5;overflow:hidden;background:#111}
.svc-media img{width:100%;height:100%;object-fit:cover;object-position:center;transition:transform .6s var(--ease)}
.service-card:hover .svc-media img{transform:scale(1.06)}
.svc-body{padding:26px 26px 30px;display:flex;flex-direction:column;flex:1}
.service-card::before{content:"";position:absolute;left:0;top:0;height:3px;width:0;z-index:3;background:linear-gradient(90deg,var(--chrome-3),var(--chrome-hi),var(--chrome-3));transition:width .4s var(--ease)}
.service-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-2);border-color:var(--paper-line-2)}
.service-card:hover::before{width:100%}
.service-card.feature{background:linear-gradient(180deg,#15181d,#0d0f12);border-color:rgba(255,255,255,.08)}
.service-card.feature h3{color:#fff}
.service-card.feature p{color:var(--text-dark-soft)}
.svc-emblem{display:block;width:42px;height:52px;margin-bottom:18px;
  background:url("images/emblem.svg") center/contain no-repeat;opacity:.95}
.service-card h3{margin-bottom:10px}
.service-card p{color:var(--text-light-soft);font-size:.98rem}
.svc-tag{display:inline-block;align-self:flex-start;margin-top:auto;font-size:.7rem;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:#cdd2d8;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.14);padding:5px 12px;border-radius:999px}

.section-cta{display:flex;flex-wrap:wrap;align-items:center;gap:16px 22px;margin-top:clamp(34px,5vw,56px)}
.section-head.center + .why-grid + .section-cta,.service-grid + .section-cta,.gallery + .section-cta{justify-content:flex-start}
.section .section-cta{justify-content:center}
.cta-note{color:var(--text-light-soft);font-size:.92rem}
.section-dark .cta-note{color:var(--text-dark-soft)}

/* ============================================================
   WHY
   ============================================================ */
.why-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--ink-line);border:1px solid var(--ink-line);border-radius:var(--r-lg);overflow:hidden}
.why-item{background:var(--ink);padding:34px 30px;transition:background .3s}
.why-item:hover{background:var(--ink-2)}
.why-no{display:block;font-family:"Archivo";font-weight:800;font-size:.85rem;letter-spacing:.2em;color:var(--steel);margin-bottom:18px}
.why-item h3{color:#fff;margin-bottom:10px}
.why-item p{color:var(--text-dark-soft);font-size:.97rem}

/* ============================================================
   GALLERY
   ============================================================ */
.gallery-filters{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:26px}
.chip{height:42px;padding:0 20px;border-radius:999px;border:1px solid var(--paper-line-2);font-weight:600;font-size:.9rem;color:var(--text-light-soft);transition:.25s var(--ease)}
.chip:hover{border-color:var(--text-light);color:var(--text-light)}
.chip.is-active{background:linear-gradient(180deg,#23262c,#0e1014);color:#fff;border-color:transparent;box-shadow:var(--shadow-1)}

.gallery{display:grid;grid-template-columns:repeat(3,1fr);grid-auto-rows:240px;gap:16px}
.g-item{position:relative;border-radius:var(--r-md);overflow:hidden;background:#111;box-shadow:var(--shadow-1);cursor:pointer}
.g-item.g-tall{grid-row:span 2}
.g-item img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease)}
.g-item::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 45%,rgba(0,0,0,.72));opacity:.85;transition:opacity .3s}
.g-item:hover img{transform:scale(1.07)}
.g-item figcaption{position:absolute;left:18px;bottom:16px;z-index:2;color:#fff;transform:translateY(4px);transition:transform .3s var(--ease)}
.g-item:hover figcaption{transform:translateY(0)}
.g-item figcaption span{display:block;font-family:"Archivo";font-weight:700;font-size:1.05rem}
.g-item figcaption small{color:rgba(255,255,255,.75);font-size:.82rem}
.g-item.is-hidden{display:none}

/* ============================================================
   COLOUR SLIDER
   ============================================================ */
.colours .wrap{position:relative;z-index:2}
.slider{position:relative;margin-top:8px}
.slider-track{
  display:flex;gap:18px;overflow-x:auto;scroll-snap-type:x mandatory;
  padding:24px var(--pad);scrollbar-width:none;cursor:grab;
}
.slider-track::-webkit-scrollbar{display:none}
.slider-track.dragging{cursor:grabbing;scroll-snap-type:none}
.swatch{flex:0 0 auto;width:230px;scroll-snap-align:center;
  background:var(--ink-2);border:1px solid var(--ink-line-2);border-radius:var(--r-md);
  overflow:hidden;box-shadow:var(--shadow-2);transition:transform .4s var(--ease),border-color .3s;
}
.swatch:hover{transform:translateY(-6px);border-color:rgba(255,255,255,.3)}
.swatch img{width:100%;height:200px;object-fit:cover;transform:scale(1.06);pointer-events:none}
.swatch figcaption{padding:14px 16px;font-family:"Archivo";font-weight:700;font-size:1rem;color:#fff;display:flex;align-items:center;justify-content:space-between}
.swatch figcaption::after{content:"";width:14px;height:14px;border-radius:50%;border:1px solid var(--ink-line-2);background:linear-gradient(180deg,var(--chrome-hi),var(--chrome-3));opacity:.5}
.swatch-custom{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;height:264px;
  background:repeating-linear-gradient(45deg,#15181d,#15181d 12px,#1a1e24 12px,#1a1e24 24px);}
.swatch-custom-mark{width:46px;height:56px;background:url("images/emblem.svg") center/contain no-repeat;margin-bottom:14px}
.swatch-custom figcaption{color:#fff;padding:0}.swatch-custom figcaption::after{display:none}
.swatch-custom small{color:var(--text-dark-soft);font-size:.8rem;margin-top:4px}

.slider-arrow{position:absolute;top:50%;transform:translateY(-50%);z-index:5;
  width:52px;height:52px;border-radius:50%;display:grid;place-items:center;
  background:rgba(15,17,21,.82);border:1px solid var(--ink-line-2);backdrop-filter:blur(8px);
  box-shadow:var(--shadow-2);transition:.25s var(--ease)}
.slider-arrow svg{width:22px;height:22px;fill:none;stroke:#fff;stroke-width:2.4;stroke-linecap:round;stroke-linejoin:round}
.slider-arrow:hover{background:#fff}.slider-arrow:hover svg{stroke:#15181d}
.slider-arrow.prev{left:max(12px,calc((100vw - var(--wrap))/2 + 8px))}
.slider-arrow.next{right:max(12px,calc((100vw - var(--wrap))/2 + 8px))}
.slider-progress{height:3px;border-radius:3px;background:var(--ink-line);margin-top:14px;overflow:hidden}
.slider-progress span{display:block;height:100%;width:20%;border-radius:3px;background:linear-gradient(90deg,var(--chrome-3),var(--chrome-hi))}

/* ============================================================
   OWNER
   ============================================================ */
.owner-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(30px,5vw,64px);align-items:center}
.owner-media{position:relative}
.owner-photo{position:relative;aspect-ratio:4/5;border-radius:var(--r-xl);overflow:hidden;
  background:
    radial-gradient(80% 60% at 50% 30%,#1c2026,#0d0f12),
    var(--ink-2);
  border:1px solid var(--paper-line-2);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;
  box-shadow:var(--shadow-2);
}
.owner-photo img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.owner-photo-mark{width:64px;height:78px;background:url("images/emblem.svg") center/contain no-repeat;opacity:.85}
.owner-photo-note{font-size:.82rem;letter-spacing:.14em;text-transform:uppercase;color:var(--text-dark-soft);font-weight:600}
.owner-badge{position:absolute;right:-14px;bottom:24px;display:flex;align-items:center;gap:12px;
  padding:14px 18px;border-radius:16px;background:var(--paper-2);box-shadow:var(--shadow-2);border:1px solid var(--paper-line)}
.owner-badge-emblem{width:30px;height:36px;background:url("images/emblem.svg") center/contain no-repeat;filter:contrast(1.1)}
.owner-badge strong{display:block;font-family:"Archivo";font-size:1.05rem}
.owner-badge span{font-size:.78rem;color:var(--text-light-soft)}
.owner-copy .sec-index{margin-top:0}
.owner-copy h2{margin-bottom:18px}
.owner-copy p{color:var(--text-light-soft);margin-bottom:16px;max-width:60ch}
.owner-points{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin:26px 0 28px}
.owner-points div{border-left:2px solid var(--paper-line-2);padding-left:14px}
.owner-points strong{display:block;font-family:"Archivo";font-size:.98rem}
.owner-points span{font-size:.84rem;color:var(--text-light-soft)}
.owner-actions{display:flex;flex-wrap:wrap;align-items:center;gap:18px 24px}
.signature{font-family:"Archivo";font-weight:700;font-style:italic;color:var(--text-light-soft);letter-spacing:.01em}

/* ============================================================
   VIDEO TESTIMONIALS
   ============================================================ */
.video-grid{display:flex;flex-wrap:wrap;justify-content:center;gap:28px}
.video-card{width:min(330px,80vw)}
.video-card figcaption{margin-top:14px;color:var(--text-dark-soft);font-size:.92rem;text-align:center}
.video-shell{position:relative;aspect-ratio:9/16;border-radius:var(--r-lg);overflow:hidden;
  background:#000;border:1px solid var(--ink-line-2);box-shadow:var(--shadow-3);
  transition:transform .3s var(--ease)}
.video-shell:hover{transform:translateY(-4px)}
.video-card video{width:100%;height:100%;object-fit:cover;display:block;background:#000}

/* ============================================================
   REVIEWS
   ============================================================ */
.reviews .section-head{max-width:100%;display:flex;flex-direction:column}
.google-summary{display:flex;flex-wrap:wrap;align-items:center;gap:18px 24px;margin-top:22px}
.g-logo{width:48px;height:48px;border-radius:12px;display:grid;place-items:center;background:#fff;box-shadow:var(--shadow-1);border:1px solid var(--paper-line)}
.g-rating{display:flex;align-items:center;gap:10px}
.g-rating strong{font-family:"Archivo";font-size:2rem;line-height:1}
.g-rating .stars{color:#f5b400;letter-spacing:2px;font-size:1.1rem}
.g-rating small{color:var(--text-light-soft);font-size:.82rem}

.review-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:38px}
.review-card{background:var(--paper-2);border:1px solid var(--paper-line);border-radius:var(--r-lg);padding:24px 24px 26px;box-shadow:0 1px 2px rgba(11,12,14,.04);transition:transform .3s var(--ease),box-shadow .3s}
.review-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-2)}
.r-head{display:flex;align-items:center;gap:12px;margin-bottom:14px}
.r-avatar{width:42px;height:42px;border-radius:50%;display:grid;place-items:center;font-family:"Archivo";font-weight:800;color:#fff;background:linear-gradient(180deg,#3a3f47,#1a1d22);flex:none}
.r-head strong{display:block;font-size:.96rem;font-family:"Archivo"}
.r-head small{color:var(--text-light-soft);font-size:.8rem}
.r-g{margin-left:auto;font-family:"Archivo";font-weight:800;color:#4285F4;font-size:1.05rem;align-self:flex-start}
.review-card .stars{color:#f5b400;letter-spacing:1px;font-size:.92rem;margin-bottom:10px}
.review-card p{color:var(--text-light-soft);font-size:.96rem}

/* ============================================================
   SERVICE AREA MAP
   ============================================================ */
.areas-grid{display:grid;grid-template-columns:1.3fr .85fr;gap:30px;align-items:stretch}
.map-card{display:flex;flex-direction:column;gap:14px}
.map-canvas{position:relative;z-index:0;border-radius:var(--r-lg);overflow:hidden;aspect-ratio:16/11;
  border:1px solid var(--ink-line-2);box-shadow:var(--shadow-3);background:#aadaf0}
.map-canvas .leaflet-container{width:100%;height:100%;font-family:inherit;background:#aadaf0}
.map-canvas .leaflet-control-zoom a{border-radius:8px}
.map-canvas .leaflet-popup-content{font-weight:500}
.map-svg{width:100%;height:100%}
.pin{position:absolute;transform:translate(-50%,-100%);z-index:3;display:flex;flex-direction:column;align-items:center}
.pin-dot{width:16px;height:16px;border-radius:50% 50% 50% 0;transform:rotate(-45deg);
  background:linear-gradient(180deg,#fff,#aeb4bc);border:2px solid #15181d;box-shadow:0 4px 10px rgba(0,0,0,.4)}
.pin-home .pin-dot{background:linear-gradient(180deg,#ffe08a,#f5b400)}
.pin-label{margin-top:8px;font-size:.7rem;font-weight:700;letter-spacing:.03em;color:#15181d;background:rgba(255,255,255,.94);
  padding:3px 9px;border-radius:999px;white-space:nowrap;box-shadow:var(--shadow-1)}
.map-legend{display:flex;align-items:center;gap:10px;font-size:.86rem;color:var(--text-dark-soft)}
.legend-swatch{width:26px;height:14px;border-radius:5px;background:radial-gradient(circle,rgba(207,214,223,.7),rgba(170,180,192,.25));border:1px dashed rgba(255,255,255,.4);flex:none}

.areas-list{background:var(--ink-2);border:1px solid var(--ink-line-2);border-radius:var(--r-lg);padding:30px;display:flex;flex-direction:column}
.areas-list h3{color:#fff;margin-bottom:18px}
.suburb-list{display:grid;grid-template-columns:1fr 1fr;gap:8px 16px;margin-bottom:18px}
.suburb-list li{font-size:.92rem;color:var(--text-dark-soft);display:flex;align-items:center;gap:9px}
.suburb-list li::before{content:"";width:5px;height:5px;border-radius:50%;background:var(--steel);flex:none}
.areas-note{font-size:.9rem;color:var(--text-dark-soft);margin-bottom:22px}
.areas-list .btn{margin-top:auto}

/* ============================================================
   QUOTE
   ============================================================ */
.quote-grid{display:grid;grid-template-columns:1fr 1.05fr;gap:clamp(30px,5vw,60px);align-items:start}
.quote-copy .sec-index{margin-top:0}
.quote-copy h2{margin-bottom:16px}
.quote-assurances{margin:26px 0;display:flex;flex-direction:column;gap:14px}
.quote-assurances li{display:flex;align-items:center;gap:12px;font-weight:500;color:var(--text-light)}
.tick{width:24px;height:24px;border-radius:50%;flex:none;display:grid;place-items:center;
  background:linear-gradient(180deg,#23262c,#0e1014);position:relative}
.tick::after{content:"";width:8px;height:5px;border-left:2px solid #fff;border-bottom:2px solid #fff;transform:rotate(-45deg) translate(0,-1px)}
.quote-direct{display:flex;align-items:center;gap:14px;padding:18px 22px;border-radius:var(--r-md);background:var(--paper-2);border:1px solid var(--paper-line);box-shadow:var(--shadow-1);flex-wrap:wrap}
.quote-direct span{color:var(--text-light-soft);font-size:.92rem}
.phone-big{font-family:"Archivo";font-weight:800;font-size:1.4rem;letter-spacing:-.01em}

.quote-form{background:linear-gradient(180deg,#16191e,#0d0f12);border:1px solid var(--ink-line-2);
  border-radius:var(--r-xl);padding:clamp(24px,3.4vw,40px);box-shadow:var(--shadow-3);position:relative;overflow:hidden}
.quote-form::before{content:"";position:absolute;left:0;top:0;right:0;height:3px;background:linear-gradient(90deg,var(--chrome-4),var(--chrome-hi),var(--chrome-4))}
.quote-form h3{color:#fff;margin-bottom:22px;font-size:1.4rem}
.field{margin-bottom:16px}
.field label{display:block;font-size:.84rem;font-weight:600;color:var(--text-dark);margin-bottom:7px}
.field .opt{color:var(--text-dark-soft);font-weight:400}
.field input,.field select,.field textarea{
  width:100%;height:52px;padding:0 16px;border-radius:12px;
  background:rgba(255,255,255,.04);border:1px solid var(--ink-line-2);color:#fff;font-size:1rem;font-family:inherit;
  transition:border-color .2s,background .2s,box-shadow .2s;
}
.field textarea{height:auto;padding:14px 16px;resize:vertical}
.field select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' fill='none' stroke='%23a7adb6' stroke-width='2'%3E%3Cpath d='M3 5l4 4 4-4'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 16px center;cursor:pointer}
.field input::placeholder,.field textarea::placeholder{color:#6b727c}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--chrome-2);background:rgba(255,255,255,.07);box-shadow:0 0 0 3px rgba(185,191,199,.15)}
.field.invalid input,.field.invalid select{border-color:#e0625a;box-shadow:0 0 0 3px rgba(224,98,90,.15)}
.hp{position:absolute;left:-9999px;width:1px;height:1px;opacity:0}
.form-fineprint{font-size:.78rem;color:var(--text-dark-soft);margin-top:14px;text-align:center}
.form-fineprint a{text-decoration:underline}
.quote-form .btn-block{margin-top:6px}
.form-success{text-align:center;padding:20px 10px}
.form-success-mark{width:60px;height:60px;border-radius:50%;margin:0 auto 16px;display:grid;place-items:center;background:linear-gradient(180deg,#fff,#c2c8cf);position:relative}
.form-success-mark::after{content:"";width:18px;height:10px;border-left:3px solid #15181d;border-bottom:3px solid #15181d;transform:rotate(-45deg) translate(1px,-2px)}
.form-success strong{display:block;font-family:"Archivo";font-size:1.3rem;color:#fff;margin-bottom:6px}
.form-success p{color:var(--text-dark-soft);font-size:.95rem}
.form-success a{color:#fff;text-decoration:underline}

/* ============================================================
   FAQ
   ============================================================ */
.faq-list{max-width:840px;margin-inline:auto;display:flex;flex-direction:column;gap:12px}
.faq-item{background:var(--ink-2);border:1px solid var(--ink-line-2);border-radius:var(--r-md);overflow:hidden;transition:border-color .3s}
.faq-item[open]{border-color:rgba(255,255,255,.28)}
.faq-item summary{list-style:none;cursor:pointer;padding:22px 24px;display:flex;align-items:center;justify-content:space-between;gap:16px;
  font-family:"Archivo";font-weight:700;font-size:1.08rem;color:#fff}
.faq-item summary::-webkit-details-marker{display:none}
.faq-ic{position:relative;width:18px;height:18px;flex:none}
.faq-ic::before,.faq-ic::after{content:"";position:absolute;background:var(--chrome-2);border-radius:2px;transition:.3s var(--ease)}
.faq-ic::before{left:0;top:8px;width:18px;height:2px}
.faq-ic::after{left:8px;top:0;width:2px;height:18px}
.faq-item[open] .faq-ic::after{transform:rotate(90deg);opacity:0}
.faq-a{padding:0 24px 24px;color:var(--text-dark-soft)}
.faq-a p{max-width:70ch}

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer{padding-top:clamp(56px,7vw,84px);position:relative}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.3fr;gap:40px;padding-bottom:48px}
.footer-brand img{height:54px;width:auto;margin-bottom:18px;border-radius:6px}
.footer-brand p{color:var(--text-dark-soft);font-size:.94rem;max-width:42ch;margin-bottom:20px}
.footer-social{display:flex;gap:10px}
.footer-social a{width:42px;height:42px;border-radius:11px;display:grid;place-items:center;border:1px solid var(--ink-line-2);transition:.25s var(--ease)}
.footer-social svg{width:18px;height:18px;fill:var(--text-dark-soft);transition:fill .25s}
.footer-social a:hover{background:#fff;border-color:#fff}.footer-social a:hover svg{fill:#15181d}
.footer-col h4{color:#fff;font-size:.82rem;letter-spacing:.16em;text-transform:uppercase;margin-bottom:18px}
.footer-col a{display:block;color:var(--text-dark-soft);font-size:.94rem;padding:6px 0;transition:color .2s}
.footer-col a:hover{color:#fff}
.footer-contact .footer-phone{font-family:"Archivo";font-weight:800;font-size:1.4rem;color:#fff;margin-bottom:10px}
.footer-contact p{color:var(--text-dark-soft);font-size:.92rem;margin:12px 0 18px}
.footer-contact .btn{margin-top:4px}
.footer-bar{border-top:1px solid var(--ink-line)}
.footer-bar-inner{display:flex;flex-wrap:wrap;justify-content:space-between;gap:10px;padding-block:22px;color:var(--text-dark-soft);font-size:.85rem}
.footer-links a{color:var(--text-dark);text-decoration:underline;text-underline-offset:3px}
.footer-links .divider{margin:0 10px;color:var(--steel)}

/* ============================================================
   MOBILE STICKY CTA
   ============================================================ */
.mobile-cta{display:none;gap:8px;margin-left:auto;align-items:center}
.mobile-cta .btn{flex:none;height:40px;padding:0 14px;font-size:.85rem;letter-spacing:0}
.mobile-cta .btn .ic{width:16px;height:16px}
.btn-outline-cta{color:var(--teal);border:1px solid var(--teal);background:transparent}
.btn-outline-cta:hover{background:rgba(30,200,206,.12)}
.btn-outline-cta .ic{fill:var(--teal)}
.btn-teal{color:#04211f;font-weight:800;background:linear-gradient(180deg,var(--teal-bright),var(--teal-deep));
  box-shadow:inset 0 1px 0 rgba(255,255,255,.45),0 6px 16px rgba(16,167,174,.4)}
.btn-teal:hover{transform:translateY(-2px);box-shadow:0 10px 24px rgba(16,167,174,.5)}

/* ============================================================
   REVEAL ANIMATIONS
   ============================================================ */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){
  *{animation-duration:.001ms !important;transition:none !important;scroll-behavior:auto}
  .reveal{opacity:1;transform:none}
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:1080px){
  .service-grid,.why-grid,.review-grid{grid-template-columns:repeat(2,1fr)}
  .gallery{grid-template-columns:repeat(2,1fr)}
  .primary-nav{display:none}
}
@media (max-width:860px){
  body{font-size:16px}
  .header-cta .btn-call span{display:none}
  .header-cta .btn-call{width:46px;padding:0}
  .nav-toggle{display:flex}
  .header-cta{display:none}
  .hero-grid{grid-template-columns:1fr;gap:28px}
  .hero-media{order:0;width:100%;max-width:520px;margin-inline:auto}
  .hero-scrim{background:linear-gradient(180deg,rgba(8,9,11,.78),rgba(8,9,11,.9))}
  .owner-grid,.quote-grid,.areas-grid{grid-template-columns:1fr}
  .map-canvas{aspect-ratio:auto;height:clamp(300px,70vw,380px);width:100%}
  .owner-media{width:100%;max-width:420px;margin-inline:auto}
  .owner-badge{right:8px}
  .video-grid{grid-template-columns:1fr}
  .mobile-cta{display:flex}
  .header-inner{height:64px;gap:10px}
  .nav-toggle{margin-left:4px;width:40px;height:40px}
}
@media (max-width:600px){
  .service-grid,.why-grid,.review-grid,.gallery,.footer-grid{grid-template-columns:1fr}
  .gallery{grid-auto-rows:220px}
  .g-item.g-tall{grid-row:span 1}
  .owner-points{grid-template-columns:1fr;gap:10px}
  .suburb-list{grid-template-columns:1fr 1fr}
  .why-grid{border-radius:var(--r-md)}
  .slider-arrow{display:none}
  .footer-bar-inner{flex-direction:column}
  .hero-actions .btn{width:100%}
}

/* ============================================================
   HIGH-CONTRAST TEXT ON DARK SECTIONS (readability)
   ============================================================ */
.hero .eyebrow,
.section-dark .eyebrow{color:#ffffff}
.hero-sub,
.section-dark .lead,
.why-item p,
.suburb-list li,
.areas-note,
.map-legend,
.video-card figcaption{color:#ffffff}
.primary-nav a{color:#ffffff}
.primary-nav a:hover{color:#ffffff}
.mobile-nav a{color:#ffffff}

/* ============================================================
   TEXT CONTRAST TWEAKS (round 2)
   ============================================================ */
/* Black body copy on light sections */
.owner-copy p,
#services .lead,
#work .lead,
#quote .lead,
.service-card:not(.feature) p{color:#111}

/* White footer text */
.footer-brand p,
.footer-col a,
.footer-contact p,
.footer-bar-inner,
.footer-bar-inner p{color:#ffffff}
.footer-col a:hover{color:#ffffff;text-decoration:underline;text-underline-offset:3px}

/* form error (webhook failure fallback) */
.form-error{margin-top:12px;font-size:.86rem;color:#ff9b8f;text-align:center;line-height:1.45}
.form-error a{color:#fff;text-decoration:underline;text-underline-offset:2px}

/* ============================================================
   HERO OFFER LOCKUP
   ============================================================ */
.hero-offer{
  position:relative; overflow:hidden;
  max-width:540px; margin:4px 0 30px;
  padding:18px 22px 18px;
  border-radius:20px;
  background:linear-gradient(180deg, rgba(30,34,40,.82), rgba(11,13,17,.86));
  border:1px solid rgba(255,255,255,.2);
  box-shadow:0 22px 55px rgba(0,0,0,.5), inset 0 1px 0 rgba(255,255,255,.14);
  -webkit-backdrop-filter:blur(8px); backdrop-filter:blur(8px);
}
.hero-offer::before{ /* chrome top edge */
  content:""; position:absolute; left:0; right:0; top:0; height:2px; z-index:2;
  background:linear-gradient(90deg, transparent, var(--chrome-hi), transparent);
}
.hero-offer::after{ /* shine sweep */
  content:""; position:absolute; top:0; left:-70%; width:55%; height:100%; z-index:1; pointer-events:none;
  background:linear-gradient(110deg, transparent, rgba(255,255,255,.12), transparent);
  transform:skewX(-18deg); animation:offer-shine 6.5s ease-in-out infinite;
}
@keyframes offer-shine{ 0%,55%{left:-70%} 100%{left:170%} }

.hero-offer-emblem{
  position:absolute; right:-10px; bottom:-14px; width:118px; height:140px; z-index:0; pointer-events:none;
  background:url("images/emblem.svg") center/contain no-repeat; opacity:.07;
}
.hero-offer > *{ position:relative; z-index:2; }

.hero-offer-flag{
  display:inline-flex; align-items:center; gap:7px;
  font-size:.66rem; font-weight:800; letter-spacing:.22em; text-transform:uppercase;
  color:#0e1014;
  background:linear-gradient(180deg,#ffffff,#c2c8cf);
  padding:6px 13px; border-radius:999px; margin-bottom:13px;
  box-shadow:0 3px 10px rgba(0,0,0,.35), inset 0 1px 0 rgba(255,255,255,.9);
}
.hero-offer-flag::before{ content:""; width:6px; height:6px; border-radius:50%;
  background:#0e1014; box-shadow:0 0 0 2px rgba(14,16,20,.25); }

.hero-offer-main{ display:flex; flex-direction:column; gap:3px; }
.hero-offer-amount{
  font-family:"Archivo",sans-serif; font-weight:900;
  font-size:clamp(1.55rem,3.3vw,2.15rem); line-height:1.04; letter-spacing:-.015em;
  color:#fff; text-shadow:0 2px 12px rgba(0,0,0,.4);
}
.hero-offer-amount em{
  font-style:normal; font-weight:700; font-size:.62em; color:var(--text-dark-soft);
  padding:0 .18em; text-transform:lowercase;
}
.hero-offer-note{
  font-size:.82rem; font-weight:700; letter-spacing:.06em; text-transform:uppercase;
  color:var(--chrome-2); margin-top:2px;
}
.hero-offer-bonus{
  display:flex; align-items:flex-start; gap:9px;
  margin-top:14px; padding-top:13px; border-top:1px solid rgba(255,255,255,.14);
  font-size:.92rem; line-height:1.45; color:#fff;
}
.hero-offer-bonus .plus{
  flex:none; margin-top:1px;
  font-size:.6rem; font-weight:800; letter-spacing:.16em; text-transform:uppercase;
  color:#cdd2d8; background:rgba(255,255,255,.07);
  border:1px solid rgba(255,255,255,.22); padding:4px 8px; border-radius:7px;
}
.hero-offer-bonus strong{ color:#fff; font-weight:800; white-space:nowrap;
  border-bottom:2px solid rgba(255,255,255,.5); }

@media (max-width:860px){
  .hero-offer{ max-width:520px; margin-inline:auto; }
}
@media (prefers-reduced-motion:reduce){ .hero-offer::after{ animation:none; display:none; } }

/* ---------- hero offer: phone view (boxless premium text + shine) ---------- */
@keyframes offer-text-shine{ 0%{background-position:140% 0} 100%{background-position:-40% 0} }
@media (max-width:600px){
  .hero-offer{
    background:none; border:none; box-shadow:none; padding:0;
    -webkit-backdrop-filter:none; backdrop-filter:none;
    max-width:none; margin:6px 0 26px; overflow:visible;
  }
  .hero-offer::before, .hero-offer::after{ display:none; }
  .hero-offer-emblem{ display:none; }

  .hero-offer-flag{
    background:none; box-shadow:none; padding:0; margin-bottom:9px;
    color:var(--chrome-2); letter-spacing:.24em;
  }
  .hero-offer-flag::before{ background:var(--chrome-2); box-shadow:none; }

  .hero-offer-amount{
    font-size:clamp(1.75rem,8.6vw,2.5rem);
    background:linear-gradient(110deg,#e6e9ed 16%,#ffffff 40%,#ffffff 48%,#aab0b8 62%,#e6e9ed 84%);
    background-size:240% 100%;
    -webkit-background-clip:text; background-clip:text;
    -webkit-text-fill-color:transparent; color:transparent;
    text-shadow:none;
    animation:offer-text-shine 3.6s ease-in-out infinite;
  }
  .hero-offer-amount em{
    -webkit-text-fill-color:var(--text-dark-soft); color:var(--text-dark-soft); background:none;
  }
  .hero-offer-note{ font-size:.76rem; margin-top:5px; }

  .bonus-detail{ display:none; }
  .hero-offer-bonus{
    margin-top:12px; padding-top:0; border-top:none;
    font-size:.86rem; gap:8px; align-items:center;
  }
  .hero-offer-bonus .plus{ padding:3px 7px; font-size:.56rem; }
}
@media (prefers-reduced-motion:reduce){ .hero-offer-amount{ animation:none; } }

/* ============================================================
   REVIEWS SLIDER (horizontal carousel)
   ============================================================ */
.reviews-slider{position:relative;margin-top:36px}
.review-track{
  display:flex;align-items:stretch;gap:18px;overflow-x:auto;scroll-snap-type:x mandatory;
  padding:18px 4px 24px;scrollbar-width:none;cursor:grab;-webkit-overflow-scrolling:touch;
}
.review-track::-webkit-scrollbar{display:none}
.review-track.dragging{cursor:grabbing;scroll-snap-type:none}
.review-track .review-card{
  flex:0 0 auto;width:min(340px,82vw);scroll-snap-align:start;margin:0;
}
.reviews-slider .slider-arrow.prev{left:-10px}
.reviews-slider .slider-arrow.next{right:-10px}
@media (max-width:600px){
  .reviews-slider{margin-top:26px}
  .review-track{gap:14px;padding:14px 2px 20px}
  .review-track .review-card{width:84vw}
}

/* swipe hint for reviews slider (mobile) */
.swipe-hint{
  position:absolute;top:-22px;right:6px;z-index:4;display:none;align-items:center;gap:7px;
  font-size:.68rem;font-weight:800;letter-spacing:.14em;text-transform:uppercase;color:var(--text-light-soft);
  background:rgba(11,12,14,.05);border:1px solid var(--paper-line);padding:5px 11px;border-radius:999px;
  pointer-events:none;transition:opacity .45s ease;
}
.swipe-hint .sh-arrow{width:26px;height:11px;fill:none;stroke:var(--text-light-soft);stroke-width:1.8;
  stroke-linecap:round;stroke-linejoin:round;animation:swipe-nudge 1.4s var(--ease) infinite}
@keyframes swipe-nudge{0%,100%{transform:translateX(0);opacity:.65}50%{transform:translateX(5px);opacity:1}}
.reviews-slider.scrolled .swipe-hint{opacity:0}
@media (max-width:860px){ .swipe-hint{display:inline-flex} }
@media (prefers-reduced-motion:reduce){ .swipe-hint .sh-arrow{animation:none} }

/* fix: chrome buttons must keep dark text even inside white-text contexts */
.footer-col a.btn-chrome,.mobile-nav a.btn-chrome{color:#15181d}

/* ============================================================
   QUOTE MODAL (popup form)
   ============================================================ */
body.modal-open{overflow:hidden}
.modal{position:fixed;inset:0;z-index:200;display:grid;place-items:center;padding:20px}
.modal[hidden]{display:none}
.modal-backdrop{position:absolute;inset:0;background:rgba(5,6,8,.74);-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);animation:modal-fade .25s ease}
.modal-card{position:relative;z-index:1;width:100%;max-width:460px;max-height:calc(100dvh - 40px);overflow-y:auto;animation:modal-pop .3s var(--ease);-webkit-overflow-scrolling:touch;scrollbar-width:none}
.modal-card::-webkit-scrollbar{display:none}
.modal-card .quote-form{margin:0}
.modal-sub{color:var(--text-dark-soft);font-size:.92rem;margin:-12px 0 18px}
.modal-close{position:absolute;top:14px;right:14px;z-index:3;width:40px;height:40px;border-radius:50%;
  display:grid;place-items:center;background:rgba(255,255,255,.08);border:1px solid var(--ink-line-2);transition:background .2s}
.modal-close svg{width:18px;height:18px;fill:none;stroke:#fff;stroke-width:2;stroke-linecap:round}
.modal-close:hover{background:rgba(255,255,255,.18)}
@keyframes modal-fade{from{opacity:0}to{opacity:1}}
@keyframes modal-pop{from{opacity:0;transform:translateY(14px) scale(.98)}to{opacity:1;transform:none}}
@media (prefers-reduced-motion:reduce){.modal-backdrop,.modal-card{animation:none}}

/* ============================================================
   TEAL REBRAND (new Titan branding: chrome + teal)
   ============================================================ */
:root{
  --teal:#1ec8ce;
  --teal-bright:#27dbe2;
  --teal-deep:#10a7ae;
  --teal-soft:#86dde1;
}

/* logos: transparent now, no box */
.brand-logo{height:46px;border-radius:0}
.footer-brand img{border-radius:0;height:58px}
@media (max-width:860px){ .brand-logo{height:32px} }

/* teal accents */
.eyebrow .dot{background:linear-gradient(180deg,var(--teal-bright),var(--teal-deep));box-shadow:0 0 0 4px rgba(30,200,206,.18)}
.primary-nav a::after{background:linear-gradient(90deg,var(--teal-bright),var(--teal-deep))}
.section-dark::before{
  background:
    radial-gradient(120% 80% at 82% -10%,rgba(30,200,206,.12),transparent 58%),
    radial-gradient(80% 60% at 0% 110%,rgba(30,200,206,.08),transparent 55%),
    var(--ink);
}
.service-card::before{background:linear-gradient(90deg,var(--teal-deep),var(--teal-bright),var(--teal-deep))}
.quote-form::before,.hero-form::before{background:linear-gradient(90deg,var(--teal-deep),var(--teal),var(--teal-deep))}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--teal);box-shadow:0 0 0 3px rgba(30,200,206,.18)}
.slider-progress span{background:linear-gradient(90deg,var(--teal-deep),var(--teal-bright))}
.swipe-hint .sh-arrow{stroke:var(--teal-deep)}
.why-no{color:var(--teal)}
.sec-index{color:var(--teal);opacity:.85}
.hero-trust li::before{background:var(--teal)}
.suburb-list li::before{background:var(--teal)}
.footer-social a:hover{background:var(--teal);border-color:var(--teal)}
.footer-social a:hover svg{fill:#04201f}
.signature{color:var(--teal-deep)}
.faq-item[open]{border-color:rgba(30,200,206,.45)}
.faq-ic::before,.faq-ic::after{background:var(--teal)}

/* emblem marks now use the real teal trident */
.svc-emblem,.owner-badge-emblem,.swatch-custom-mark,.hero-offer-emblem,.owner-photo-mark{
  background-image:url("images/emblem-teal.png")}

/* teal offer flag + price */
.hero-offer-flag{background:linear-gradient(180deg,var(--teal-bright),var(--teal-deep));color:#04211f;box-shadow:0 3px 10px rgba(16,167,174,.4),inset 0 1px 0 rgba(255,255,255,.5)}
.hero-offer-flag::before{background:#04211f;box-shadow:0 0 0 2px rgba(4,33,31,.25)}
.hero-offer-amount .was{text-decoration:line-through;color:var(--text-dark-soft);font-size:.56em;font-weight:700;margin-right:.18em;-webkit-text-fill-color:var(--text-dark-soft)}
.hero-offer-amount .unit{font-size:.5em;font-weight:800;color:var(--teal);-webkit-text-fill-color:var(--teal);letter-spacing:.02em}
.hero-offer-bonus strong{border-bottom-color:var(--teal)}

/* colour guide: branded tiles */
.swatch.tile{width:200px;background:#0d0f12;border:1px solid var(--ink-line-2);border-radius:var(--r-md);overflow:hidden;box-shadow:var(--shadow-2)}
.swatch.tile img{width:100%;height:auto;transform:none;display:block}
@media (max-width:600px){ .swatch.tile{width:62vw;max-width:260px} }

/* video testimonial captions: name + description */
.video-card figcaption strong{display:block;font-family:"Archivo",sans-serif;font-weight:800;font-size:1.05rem;color:#fff;margin-bottom:5px}
.video-card figcaption span{display:block;font-size:.85rem;line-height:1.55;color:var(--text-dark);font-weight:400}
