/* TCP — Toowoomba Commercial Plastering. Corporate-trade, dual-arm (green contracting / red supplies). */
:root{
  --ink:#0c0d0f;
  --base:#101215;
  --surface:#15181c;
  --surface-2:#1c2026;
  --line:#262b32;
  --text:#e9ecef;
  --muted:#9aa3ad;
  --white:#ffffff;
  --green:#63aa30;
  --green-bright:#74c43a;
  --red:#d11f26;
  --red-bright:#e8323a;
  --accent:var(--green);
  --accent-bright:var(--green-bright);
  --maxw:1180px;
  --r:10px;
  --ff:'Inter',system-ui,-apple-system,'Segoe UI',Roboto,sans-serif;
  --fd:'Archivo',var(--ff);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--ff);
  background:var(--ink);
  color:var(--text);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
body.supplies{--accent:var(--red);--accent-bright:var(--red-bright)}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 22px}
section{position:relative}
h1,h2,h3,h4{font-family:var(--fd);font-weight:800;line-height:1.05;letter-spacing:-.01em}

/* ---------- demo banner ---------- */
.demo-banner{
  background:var(--accent);color:#0a0c0e;font-size:.8rem;font-weight:600;
  text-align:center;padding:9px 16px;letter-spacing:.01em;
}
.demo-banner b{font-weight:800}

/* ---------- nav ---------- */
.nav{
  position:sticky;top:0;z-index:60;
  background:rgba(12,13,15,.86);backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line);
}
.nav-inner{display:flex;align-items:center;gap:22px;height:70px}
.brand{display:flex;align-items:center;gap:11px;flex-shrink:0}
.brand img{height:40px;width:auto}
.brand .bt{font-family:var(--fd);font-weight:800;font-size:1.02rem;letter-spacing:.02em;line-height:1.05}
.brand .bt span{color:var(--accent)}
.brand .bs{display:block;font-family:var(--ff);font-weight:500;font-size:.62rem;letter-spacing:.18em;color:var(--muted);text-transform:uppercase}
.nav-links{display:flex;gap:5px;margin-left:auto;align-items:center}
.nav-links a{
  font-size:.83rem;font-weight:600;color:var(--muted);padding:9px 13px;border-radius:7px;
  transition:color .2s,background .2s;
}
.nav-links a:hover,.nav-links a.active{color:var(--white);background:var(--surface-2)}
.nav-call{
  display:inline-flex;align-items:center;gap:7px;
  background:var(--accent);color:#0a0c0e;font-weight:800;font-size:.83rem;
  padding:10px 16px;border-radius:8px;margin-left:8px;
  transition:transform .15s,background .2s;
}
.nav-call:hover{transform:translateY(-1px);background:var(--accent-bright)}
.nav-call svg{width:15px;height:15px}
.burger{display:none;margin-left:auto;background:none;border:0;color:var(--text);cursor:pointer;padding:8px}
.burger svg{width:26px;height:26px}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:9px;
  font-family:var(--ff);font-weight:700;font-size:.9rem;
  padding:13px 22px;border-radius:9px;cursor:pointer;border:0;
  transition:transform .15s,background .2s,border-color .2s;
}
.btn svg{width:16px;height:16px}
.btn-primary{background:var(--accent);color:#0a0c0e}
.btn-primary:hover{transform:translateY(-2px);background:var(--accent-bright)}
.btn-ghost{background:transparent;color:var(--text);border:1.5px solid var(--line)}
.btn-ghost:hover{border-color:var(--accent);color:var(--white)}

/* ---------- hero (photo-split, pattern B) ---------- */
.hero{
  background:
    radial-gradient(900px 480px at 88% -10%,rgba(99,170,48,.14),transparent 60%),
    var(--ink);
  border-bottom:1px solid var(--line);
  overflow:hidden;
}
body.supplies .hero{background:radial-gradient(900px 480px at 88% -10%,rgba(209,31,38,.16),transparent 60%),var(--ink)}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:center;padding:64px 0 70px}
.eyebrow{
  display:inline-flex;align-items:center;gap:9px;
  font-size:.72rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;
  color:var(--accent);margin-bottom:20px;
}
.eyebrow::before{content:"";width:26px;height:2px;background:var(--accent)}
.hero h1{font-size:clamp(2rem,4.6vw,3.5rem);margin-bottom:18px}
.hero h1 em{font-style:normal;color:var(--accent)}
.hero p.lead{font-size:1.08rem;color:var(--muted);max-width:30em;margin-bottom:18px}
.tagband{
  display:inline-block;font-family:var(--fd);font-weight:800;font-style:italic;
  color:var(--white);font-size:1.05rem;margin-bottom:26px;
  border-left:3px solid var(--accent);padding-left:12px;
}
.hero-cta{display:flex;gap:13px;flex-wrap:wrap;margin-bottom:26px}
.hero-trust{display:flex;gap:26px;flex-wrap:wrap;padding-top:22px;border-top:1px solid var(--line)}
.hero-trust .t{display:flex;flex-direction:column}
.hero-trust .t b{font-family:var(--fd);font-size:1.45rem;color:var(--white);line-height:1}
.hero-trust .t span{font-size:.74rem;color:var(--muted);margin-top:5px;letter-spacing:.04em}
.hero-media{position:relative}
.hero-media .frame{
  position:relative;border-radius:14px;overflow:hidden;border:1px solid var(--line);
  box-shadow:0 30px 70px rgba(0,0,0,.5);
}
.hero-media img{width:100%;height:auto;display:block;transform:scale(1.04);will-change:transform}
.hero-media .cap{
  position:absolute;left:14px;bottom:14px;right:14px;
  display:flex;align-items:center;gap:9px;
  background:rgba(12,13,15,.78);backdrop-filter:blur(6px);
  border:1px solid var(--line);border-radius:9px;padding:9px 13px;font-size:.78rem;color:var(--muted);
}
.hero-media .cap b{color:var(--white);font-weight:700}
.hero-media .dot{width:8px;height:8px;border-radius:50%;background:var(--accent);flex-shrink:0;box-shadow:0 0 0 4px rgba(99,170,48,.2)}

/* ---------- marquee ---------- */
.marquee{border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:var(--base);overflow:hidden;padding:16px 0}
.marquee-track{display:flex;gap:46px;white-space:nowrap;width:max-content;animation:scroll 34s linear infinite}
.marquee:hover .marquee-track{animation-play-state:paused}
.marquee span{
  font-family:var(--fd);font-weight:800;font-size:1.55rem;letter-spacing:.01em;
  -webkit-text-stroke:1px var(--line);color:transparent;text-transform:uppercase;
}
.marquee span.on{-webkit-text-stroke:1px var(--accent);color:transparent}
@keyframes scroll{to{transform:translateX(-50%)}}

/* ---------- dual-arm split ---------- */
.split{padding:74px 0}
.split-head{text-align:center;max-width:640px;margin:0 auto 44px}
.split-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.arm{
  position:relative;border-radius:16px;overflow:hidden;border:1px solid var(--line);
  background:var(--surface);padding:38px 34px;min-height:300px;
  display:flex;flex-direction:column;
  transition:transform .25s,border-color .25s;
}
.arm:hover{transform:translateY(-4px)}
.arm.green{border-top:3px solid var(--green)}
.arm.green:hover{border-color:var(--green)}
.arm.red{border-top:3px solid var(--red)}
.arm.red:hover{border-color:var(--red)}
.arm .tag{font-size:.7rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;margin-bottom:14px}
.arm.green .tag{color:var(--green)}
.arm.red .tag{color:var(--red)}
.arm h3{font-size:1.6rem;margin-bottom:12px;color:var(--white)}
.arm p{color:var(--muted);font-size:.96rem;margin-bottom:22px;flex:1}
.arm .arm-link{display:inline-flex;align-items:center;gap:8px;font-weight:700;font-size:.9rem}
.arm.green .arm-link{color:var(--green-bright)}
.arm.red .arm-link{color:var(--red-bright)}
.arm-link svg{width:16px;height:16px;flex-shrink:0;transition:transform .2s}
.arm:hover .arm-link svg{transform:translateX(4px)}

/* ---------- section heads ---------- */
.sec{padding:74px 0}
.sec.alt{background:var(--base)}
.shead{max-width:680px;margin-bottom:46px}
.shead.center{margin-left:auto;margin-right:auto;text-align:center}
.shead .kick{font-size:.72rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--accent);margin-bottom:14px;display:block}
.shead h2{font-size:clamp(1.7rem,3.4vw,2.5rem);margin-bottom:14px;color:var(--white)}
.shead p{color:var(--muted);font-size:1.02rem}

/* ---------- service cards ---------- */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.svc{
  background:var(--surface);border:1px solid var(--line);border-radius:13px;padding:28px 24px;
  transition:transform .22s,border-color .22s;
}
.svc:hover{transform:translateY(-4px);border-color:var(--accent)}
.svc .ico{
  width:46px;height:46px;border-radius:10px;background:var(--surface-2);
  display:flex;align-items:center;justify-content:center;margin-bottom:18px;border:1px solid var(--line);
}
.svc .ico svg{width:23px;height:23px;stroke:var(--accent);fill:none;stroke-width:1.7}
.svc h3{font-size:1.12rem;color:var(--white);margin-bottom:9px}
.svc p{color:var(--muted);font-size:.9rem}

/* ---------- projects strip ---------- */
.proj-strip{display:grid;grid-template-columns:1.4fr 1fr;gap:22px;align-items:stretch}
.proj-main{position:relative;border-radius:14px;overflow:hidden;border:1px solid var(--line)}
.proj-main img{width:100%;height:100%;object-fit:cover;min-height:340px}
.proj-main .meta{
  position:absolute;left:0;right:0;bottom:0;padding:22px;
  background:linear-gradient(transparent,rgba(8,9,11,.92));
}
.proj-main .meta b{font-family:var(--fd);font-size:1.25rem;color:var(--white);display:block}
.proj-main .meta span{color:var(--muted);font-size:.85rem}
.proj-side{display:flex;flex-direction:column;gap:22px}
.proj-note{
  background:var(--surface);border:1px solid var(--line);border-radius:14px;padding:26px;flex:1;
  display:flex;flex-direction:column;justify-content:center;
}
.proj-note h3{font-size:1.2rem;color:var(--white);margin-bottom:10px}
.proj-note p{color:var(--muted);font-size:.92rem;margin-bottom:16px}

/* ---------- supplier brands ---------- */
.brands{display:flex;flex-wrap:wrap;gap:12px;justify-content:center}
.brands .b{
  border:1px solid var(--line);border-radius:9px;padding:13px 20px;background:var(--surface);
  font-family:var(--fd);font-weight:800;font-size:.98rem;color:var(--text);letter-spacing:.01em;
}
body.supplies .brands .b:hover{border-color:var(--red)}

/* ---------- info / why list ---------- */
.why-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.why{background:var(--surface);border:1px solid var(--line);border-radius:13px;padding:26px}
.why .n{font-family:var(--fd);font-size:1.7rem;color:var(--accent);margin-bottom:10px}
.why h3{font-size:1.06rem;color:var(--white);margin-bottom:8px}
.why p{color:var(--muted);font-size:.9rem}

/* ---------- CTA band ---------- */
.cta-band{
  background:linear-gradient(120deg,var(--accent),var(--accent-bright));
  border-radius:18px;padding:46px;text-align:center;color:#0a0c0e;
}
.cta-band h2{font-size:clamp(1.6rem,3.2vw,2.3rem);margin-bottom:12px;color:#0a0c0e}
.cta-band p{font-size:1.04rem;margin-bottom:26px;opacity:.86;max-width:34em;margin-left:auto;margin-right:auto}
.cta-band .btn-dark{background:#0c0d0f;color:#fff}
.cta-band .btn-dark:hover{background:#000}

/* ---------- contact ---------- */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:46px}
.cinfo .row{display:flex;gap:15px;padding:18px 0;border-bottom:1px solid var(--line)}
.cinfo .row:first-child{padding-top:0}
.cinfo .ci{
  width:42px;height:42px;border-radius:10px;background:var(--surface-2);flex-shrink:0;
  display:flex;align-items:center;justify-content:center;border:1px solid var(--line);
}
.cinfo .ci svg{width:20px;height:20px;stroke:var(--accent);fill:none;stroke-width:1.7}
.cinfo .row b{display:block;font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-bottom:4px;font-weight:700}
.cinfo .row a,.cinfo .row span{font-size:1.02rem;color:var(--text);font-weight:500}
.form{background:var(--surface);border:1px solid var(--line);border-radius:16px;padding:30px}
.form h3{color:var(--white);font-size:1.3rem;margin-bottom:6px}
.form .sub{color:var(--muted);font-size:.88rem;margin-bottom:22px}
.field{margin-bottom:16px}
.field label{display:block;font-size:.78rem;font-weight:600;color:var(--muted);margin-bottom:7px;letter-spacing:.03em}
.field input,.field textarea,.field select{
  width:100%;background:var(--ink);border:1px solid var(--line);border-radius:9px;
  padding:12px 14px;color:var(--text);font-family:var(--ff);font-size:.94rem;transition:border-color .2s;
}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--accent)}
.field textarea{resize:vertical;min-height:120px}
.form .btn{width:100%;justify-content:center;margin-top:4px}
.hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}
.form-note{font-size:.74rem;color:var(--muted);margin-top:14px;text-align:center}

/* ---------- footer ---------- */
.footer{background:var(--base);border-top:1px solid var(--line);padding:54px 0 30px}
.foot-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:36px;margin-bottom:38px}
.foot-brand img{height:42px;margin-bottom:16px}
.foot-brand p{color:var(--muted);font-size:.9rem;max-width:30em}
.foot-col h4{font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-bottom:16px;font-weight:700;font-family:var(--ff)}
.foot-col a{display:block;color:var(--text);font-size:.92rem;padding:6px 0;transition:color .2s}
.foot-col a:hover{color:var(--accent)}
.foot-bottom{border-top:1px solid var(--line);padding-top:24px;display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;align-items:center}
.foot-bottom p{color:var(--muted);font-size:.82rem}
.foot-bottom .credit{color:var(--muted);font-size:.82rem}
.foot-bottom .credit a{color:var(--accent);font-weight:600}

/* ---------- reveal ---------- */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s ease,transform .7s ease}
.reveal.in{opacity:1;transform:none}

/* ---------- responsive ---------- */
@media(max-width:900px){
  .hero-grid{grid-template-columns:1fr;gap:34px;padding:44px 0 50px}
  .hero-media{order:-1}
  .split-grid,.contact-grid,.proj-strip{grid-template-columns:1fr}
  .svc-grid,.why-grid{grid-template-columns:1fr 1fr}
  .foot-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:640px){
  .nav-links{
    display:none;position:absolute;top:70px;left:0;right:0;flex-direction:column;gap:0;
    background:var(--ink);border-bottom:1px solid var(--line);padding:10px 16px 16px;
  }
  .nav-links.open{display:flex}
  .nav-links a{width:100%;padding:13px 12px}
  .nav-call{margin:8px 0 0;width:100%;justify-content:center}
  .burger{display:block}
  .hero h1{font-size:clamp(1.8rem,7.4vw,2.3rem)}
  .svc-grid,.why-grid,.foot-grid{grid-template-columns:1fr}
  .cta-band,.form{padding:30px 22px}
  .hero-trust{gap:18px}
}
@media(prefers-reduced-motion:reduce){
  .marquee-track{animation:none}
  .reveal{opacity:1;transform:none;transition:none}
  *{scroll-behavior:auto}
}
