/* ============================================================
   SAVE IT SEALCOATING — shared stylesheet
   Visual DNA: black + gold + chrome, bold condensed italic type,
   but lightened for easy reading.
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Barlow:ital,wght@0,400;0,500;0,600;0,700;1,500&family=Barlow+Condensed:ital,wght@0,500;0,600;0,700;0,800;1,700;1,800&display=swap');

:root {
  --ink:        #131316;
  --ink-2:      #1d1d22;
  --ink-3:      #2a2a30;
  --gold:       #f5b400;
  --gold-lite:  #ffd24d;
  --gold-deep:  #b9851a;
  --chrome:     #dfe3e8;
  --chrome-2:   #aab0b8;
  --paper:      #f4f4f1;
  --white:      #ffffff;
  --line:       #e5e4df;
  --ink-text:   #1b1b1f;
  --muted:      #62636a;
  --shadow-sm:  0 2px 10px rgba(0,0,0,.07);
  --shadow-md:  0 14px 40px rgba(0,0,0,.12);
  --gold-grad:  linear-gradient(170deg, #ffe07a 0%, #f5b400 42%, #c8881a 100%);
  --chrome-grad:linear-gradient(180deg, #ffffff 0%, #d4d8dd 48%, #9aa0a8 52%, #e9ecef 100%);
  --maxw: 1200px;
}

* { box-sizing: border-box; }

html { scroll-behavior: smooth; }

body {
  margin: 0;
  font-family: "Barlow", system-ui, sans-serif;
  color: var(--ink-text);
  background: var(--paper);
  font-size: 18px;
  line-height: 1.65;
  -webkit-font-smoothing: antialiased;
}

h1, h2, h3, h4 {
  font-family: "Barlow Condensed", "Barlow", sans-serif;
  font-weight: 800;
  line-height: 1.02;
  margin: 0;
  letter-spacing: .005em;
}

a { color: inherit; text-decoration: none; }

p { margin: 0 0 1em; }
img { max-width: 100%; display: block; }

.wrap { width: 100%; max-width: var(--maxw); margin: 0 auto; padding: 0 28px; }

/* ---- carbon texture ---- */
.carbon {
  background-color: #0e0e11;
  background-image:
    linear-gradient(27deg, #15151a 5px, transparent 5px),
    linear-gradient(207deg, #15151a 5px, transparent 5px),
    linear-gradient(27deg, #0c0c0f 5px, transparent 5px),
    linear-gradient(207deg, #0c0c0f 5px, transparent 5px),
    linear-gradient(90deg, #121217 10px, transparent 10px),
    linear-gradient(#16161b 25%, #0e0e11 25%, #0e0e11 50%, transparent 50%, transparent 75%, #0e0e11 75%);
  background-size: 20px 20px;
}

/* ============================================================
   LOGO WORDMARK (CSS recreation of the card badge)
   ============================================================ */
.logo { display: inline-flex; flex-direction: column; line-height: .82; gap: 2px; }
.logo .l-1 {
  font-family: "Barlow Condensed", sans-serif;
  font-style: italic;
  font-weight: 800;
  font-size: 1.55rem;
  letter-spacing: .02em;
  background: var(--gold-grad);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  filter: drop-shadow(0 1px 0 rgba(0,0,0,.4));
}
.logo .l-2 {
  font-family: "Barlow Condensed", sans-serif;
  font-style: italic;
  font-weight: 800;
  font-size: 1.18rem;
  letter-spacing: .04em;
  background: var(--chrome-grad);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  filter: drop-shadow(0 1px 0 rgba(0,0,0,.5));
}
/* large logo variant for footer / hero */
.logo.lg .l-1 { font-size: 2.6rem; }
.logo.lg .l-2 { font-size: 1.95rem; }

/* ============================================================
   TOP BAR
   ============================================================ */
.topbar {
  background: var(--ink);
  color: #cfcfd4;
  font-size: .82rem;
  letter-spacing: .03em;
  border-bottom: 1px solid rgba(245,180,0,.25);
}
.topbar .wrap { display: flex; align-items: center; justify-content: space-between; height: 40px; }
.topbar .badges { display: flex; gap: 22px; align-items: center; text-transform: uppercase; font-weight: 600; }
.topbar .badges span { display: inline-flex; align-items: center; gap: 7px; }
.topbar .badges svg { width: 14px; height: 14px; color: var(--gold); }
.topbar a.tb-phone { color: var(--gold-lite); font-weight: 700; letter-spacing: .04em; }

/* ============================================================
   HEADER / NAV
   ============================================================ */
.site-head {
  position: sticky; top: 0; z-index: 50;
  background: rgba(19,19,22,.97);
  backdrop-filter: blur(8px);
  border-bottom: 2px solid var(--gold);
  box-shadow: 0 6px 24px rgba(0,0,0,.28);
}
.site-head .wrap { display: flex; align-items: center; justify-content: space-between; height: 78px; gap: 18px; }
.nav { display: flex; align-items: center; gap: 6px; }
.nav a {
  color: #d9dade;
  font-family: "Barlow Condensed", sans-serif;
  font-weight: 700; font-size: 1.05rem;
  text-transform: uppercase; letter-spacing: .06em;
  padding: 8px 16px; border-radius: 7px;
  transition: color .15s, background .15s;
}
.nav a:hover { color: #fff; background: rgba(255,255,255,.06); }
.nav a.active { color: var(--gold); }
.head-cta { display: flex; align-items: center; gap: 14px; }

/* ---- buttons ---- */
.btn {
  display: inline-flex; align-items: center; gap: 10px;
  font-family: "Barlow Condensed", sans-serif;
  font-weight: 800; text-transform: uppercase; letter-spacing: .05em;
  font-size: 1.08rem;
  padding: 13px 24px; border-radius: 10px;
  border: none; cursor: pointer;
  transition: transform .12s ease, box-shadow .12s ease, filter .15s;
  white-space: nowrap;
}
.btn svg { width: 19px; height: 19px; }
.btn-gold {
  background: var(--gold-grad);
  color: #211800;
  box-shadow: 0 6px 18px rgba(245,180,0,.38), inset 0 1px 0 rgba(255,255,255,.55);
}
.btn-gold:hover { transform: translateY(-2px); box-shadow: 0 10px 26px rgba(245,180,0,.5), inset 0 1px 0 rgba(255,255,255,.55); }
.btn-ghost {
  background: transparent; color: #fff;
  border: 2px solid rgba(255,255,255,.35);
}
.btn-ghost:hover { border-color: var(--gold); color: var(--gold); }
.btn-dark {
  background: var(--ink); color: #fff;
  box-shadow: var(--shadow-sm);
}
.btn-dark:hover { transform: translateY(-2px); background: var(--ink-2); }
.btn-lg { font-size: 1.28rem; padding: 17px 32px; }

/* ============================================================
   HERO
   ============================================================ */
.hero { position: relative; color: #fff; overflow: hidden; }
.hero::after {
  content:""; position:absolute; inset:0;
  background:
    radial-gradient(900px 380px at 18% 0%, rgba(245,180,0,.16), transparent 60%),
    linear-gradient(90deg, rgba(14,14,17,.96) 0%, rgba(14,14,17,.82) 48%, rgba(14,14,17,.35) 100%);
  pointer-events: none;
}
.hero .wrap { position: relative; z-index: 2; padding-top: 76px; padding-bottom: 84px; }
.hero-grid { display: grid; grid-template-columns: 1.15fr .85fr; gap: 48px; align-items: center; }
.eyebrow {
  display: inline-flex; align-items: center; gap: 10px;
  font-family: "Barlow Condensed", sans-serif; font-weight: 700;
  text-transform: uppercase; letter-spacing: .18em; font-size: .95rem;
  color: var(--gold-lite); margin-bottom: 18px;
}
.eyebrow::before { content:""; width: 34px; height: 2px; background: var(--gold); }
.hero h1 {
  font-size: clamp(3rem, 6.2vw, 5.4rem);
  font-style: italic;
  text-transform: uppercase;
  text-shadow: 0 3px 0 rgba(0,0,0,.35);
}
.hero h1 .accent {
  background: var(--gold-grad); -webkit-background-clip: text; background-clip: text; color: transparent;
}
.hero .lede { font-size: 1.2rem; color: #d6d7db; max-width: 46ch; margin: 22px 0 30px; }
.hero-cta { display: flex; flex-wrap: wrap; gap: 14px; align-items: center; }
.hero-chips { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 34px; }
.chip {
  display: inline-flex; align-items: center; gap: 9px;
  background: rgba(255,255,255,.06); border: 1px solid rgba(255,255,255,.14);
  color: #e8e8ec; padding: 9px 16px; border-radius: 999px;
  font-family: "Barlow Condensed", sans-serif; font-weight: 700;
  text-transform: uppercase; letter-spacing: .05em; font-size: .92rem;
}
.chip svg { width: 16px; height: 16px; color: var(--gold); }

/* ============================================================
   PLACEHOLDER IMAGE BLOCKS
   ============================================================ */
.ph {
  position: relative; border-radius: 16px; overflow: hidden;
  background:
    repeating-linear-gradient(135deg, #1b1b20 0 14px, #16161b 14px 28px);
  border: 1px solid rgba(255,255,255,.1);
  display: flex; align-items: center; justify-content: center;
  color: #7d7e87; min-height: 320px;
}
.ph .ph-label {
  display: flex; flex-direction: column; align-items: center; gap: 12px;
  font-family: "Barlow Condensed", sans-serif; font-weight: 700;
  text-transform: uppercase; letter-spacing: .12em; font-size: .85rem; text-align: center;
}
.ph .ph-label svg { width: 46px; height: 46px; color: #4f5059; }
.ph.gold-edge { border-color: rgba(245,180,0,.45); box-shadow: 0 0 0 1px rgba(245,180,0,.25), var(--shadow-md); }
.ph.light { background: repeating-linear-gradient(135deg,#ececea 0 14px,#e3e3df 14px 28px); color:#a6a69e; }
.ph.light .ph-label svg { color:#bcbcb4; }

/* real photo frames (stock placeholders — swap for client job photos) */
.photo { position: relative; border-radius: 16px; overflow: hidden; box-shadow: var(--shadow-md); border: 1px solid rgba(255,255,255,.1); background:#1b1b20; }
.photo img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; display: block; }
.photo.gold-edge { border-color: rgba(245,180,0,.5); box-shadow: 0 0 0 1px rgba(245,180,0,.3), var(--shadow-md); }
.photo::after { content:""; position:absolute; inset:0; background: linear-gradient(180deg, transparent 55%, rgba(0,0,0,.35)); pointer-events:none; }

/* corner tag on hero image */
.img-tag {
  position: absolute; left: 16px; bottom: 16px; z-index: 3;
  background: var(--gold-grad); color: #211800;
  font-family: "Barlow Condensed", sans-serif; font-weight: 800;
  text-transform: uppercase; letter-spacing: .05em; font-size: .9rem;
  padding: 7px 14px; border-radius: 8px; box-shadow: var(--shadow-sm);
}

/* ============================================================
   SECTIONS
   ============================================================ */
section { position: relative; }
.sec { padding: 84px 0; }
.sec-head { max-width: 760px; margin-bottom: 50px; }
.sec-head.center { margin-left: auto; margin-right: auto; text-align: center; }
.kicker {
  font-family: "Barlow Condensed", sans-serif; font-weight: 700;
  text-transform: uppercase; letter-spacing: .16em; font-size: .92rem;
  color: var(--gold-deep); margin-bottom: 12px; display: block;
}
.sec h2 {
  font-size: clamp(2.2rem, 4vw, 3.2rem);
  font-style: italic; text-transform: uppercase; color: var(--ink);
}
.sec .sub { color: var(--muted); font-size: 1.12rem; margin-top: 14px; }
.bg-dark { background: var(--ink); color: #ececed; }
.bg-dark h2 { color: #fff; }
.bg-dark .sub { color: #b7b8bf; }
.bg-paper { background: var(--paper); }
.bg-white { background: var(--white); }

/* gold rule */
.rule { width: 64px; height: 4px; background: var(--gold-grad); border-radius: 3px; }
.sec-head.center .rule { margin: 18px auto 0; }

/* ============================================================
   SERVICE CARDS
   ============================================================ */
.cards { display: grid; grid-template-columns: repeat(4, 1fr); gap: 22px; }
.card {
  background: var(--white); border: 1px solid var(--line); border-radius: 16px;
  padding: 30px 26px 28px; box-shadow: var(--shadow-sm);
  transition: transform .16s ease, box-shadow .16s ease, border-color .16s;
  position: relative; overflow: hidden;
}
.card::before {
  content:""; position:absolute; left:0; top:0; height:4px; width:100%;
  background: var(--gold-grad); transform: scaleX(0); transform-origin: left;
  transition: transform .25s ease;
}
.card:hover { transform: translateY(-6px); box-shadow: var(--shadow-md); border-color: rgba(245,180,0,.5); }
.card:hover::before { transform: scaleX(1); }
.card .ic {
  width: 60px; height: 60px; border-radius: 14px;
  display: flex; align-items: center; justify-content: center;
  background: linear-gradient(170deg, #26262c, #131316);
  border: 1px solid rgba(245,180,0,.35);
  margin-bottom: 20px;
}
.card .ic svg { width: 30px; height: 30px; color: var(--gold); }
.card h3 { font-size: 1.5rem; text-transform: uppercase; font-style: italic; color: var(--ink); }
.card p { color: var(--muted); font-size: .98rem; margin: 10px 0 0; line-height: 1.55; }
.card .more {
  margin-top: 18px; display: inline-flex; align-items: center; gap: 6px;
  font-family: "Barlow Condensed", sans-serif; font-weight: 700; text-transform: uppercase;
  letter-spacing: .05em; color: var(--gold-deep); font-size: .92rem;
}

/* ============================================================
   FEATURE / WHY ROW
   ============================================================ */
.feat { display: grid; grid-template-columns: repeat(4,1fr); gap: 26px; }
.feat .f { text-align: left; }
.feat .f .fic {
  width: 52px; height: 52px; border-radius: 12px; margin-bottom: 16px;
  display:flex; align-items:center; justify-content:center;
  background: rgba(245,180,0,.12); border: 1px solid rgba(245,180,0,.4);
}
.feat .f .fic svg { width: 26px; height: 26px; color: var(--gold-deep); }
.bg-dark .feat .f .fic { background: rgba(245,180,0,.14); }
.feat .f h3 { font-size: 1.3rem; text-transform: uppercase; font-style: italic; }
.feat .f p { font-size: .98rem; color: var(--muted); margin-top: 6px; }
.bg-dark .feat .f p { color: #b7b8bf; }

/* stat band */
.stats { display: grid; grid-template-columns: repeat(4,1fr); gap: 20px; text-align: center; }
.stat .n {
  font-family: "Barlow Condensed", sans-serif; font-weight: 800; font-style: italic;
  font-size: 3.2rem; line-height: 1;
  background: var(--gold-grad); -webkit-background-clip: text; background-clip: text; color: transparent;
}
.stat .l { text-transform: uppercase; letter-spacing: .08em; font-weight: 600; font-size: .9rem; color: #b7b8bf; margin-top: 8px; }

/* ============================================================
   SPLIT / CTA BANDS
   ============================================================ */
.split { display: grid; grid-template-columns: 1fr 1fr; gap: 56px; align-items: center; }
.split.narrow { gap: 44px; }

.cta-band { text-align: center; }
.cta-band h2 { font-size: clamp(2.2rem, 4.4vw, 3.4rem); }
.cta-band .phone-big {
  display: inline-flex; align-items: center; justify-content: center; gap: 14px; margin-top: 8px;
  white-space: nowrap; max-width: 100%;
  font-family: "Barlow Condensed", sans-serif; font-weight: 800; font-style: italic;
  font-size: clamp(2.1rem, 5.2vw, 3.9rem);
  background: var(--gold-grad); -webkit-background-clip: text; background-clip: text; color: transparent;
}
.cta-band .phone-big svg { color: var(--gold); stroke: var(--gold); }
.cta-band .cta-actions { display:flex; gap:16px; justify-content:center; flex-wrap:wrap; margin-top: 28px; }

/* check list */
.checks { list-style: none; padding: 0; margin: 22px 0 0; display: grid; gap: 14px; }
.checks li { display: flex; gap: 13px; align-items: flex-start; font-size: 1.05rem; }
.checks li svg { width: 24px; height: 24px; flex: 0 0 auto; color: var(--gold-deep); margin-top: 2px; }
.bg-dark .checks li svg { color: var(--gold); }

/* ============================================================
   FOOTER
   ============================================================ */
.site-foot { background: #0c0c0f; color: #aeaeb6; padding: 64px 0 30px; border-top: 3px solid var(--gold); }
.foot-grid { display: grid; grid-template-columns: 1.4fr 1fr 1fr 1.2fr; gap: 40px; }
.site-foot h4 {
  font-family: "Barlow Condensed", sans-serif; text-transform: uppercase; letter-spacing: .08em;
  color: #fff; font-size: 1.1rem; margin-bottom: 16px; font-style: italic;
}
.site-foot ul { list-style: none; padding: 0; margin: 0; display: grid; gap: 9px; }
.site-foot a:hover { color: var(--gold); }
.site-foot .f-phone { color: var(--gold-lite); font-weight: 700; font-size: 1.25rem; font-family: "Barlow Condensed", sans-serif; letter-spacing: .02em; }
.foot-bottom {
  margin-top: 46px; padding-top: 22px; border-top: 1px solid rgba(255,255,255,.1);
  display: flex; justify-content: space-between; gap: 16px; flex-wrap: wrap;
  font-size: .85rem; color: #76767e;
}
.foot-note { display:flex; gap:8px; align-items:center; }

/* ============================================================
   CONTACT
   ============================================================ */
.contact-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 48px; align-items: start; }
.contact-card {
  background: var(--white); border: 1px solid var(--line); border-radius: 18px;
  padding: 14px; box-shadow: var(--shadow-md); display: grid; gap: 12px;
}
.contact-row {
  display: flex; gap: 18px; align-items: center;
  padding: 22px; border-radius: 12px; background: var(--paper);
  transition: background .15s;
}
.contact-row:hover { background: #efefe9; }
.contact-row .cic {
  width: 54px; height: 54px; border-radius: 12px; flex: 0 0 auto;
  display:flex; align-items:center; justify-content:center;
  background: linear-gradient(170deg,#26262c,#131316); border: 1px solid rgba(245,180,0,.4);
}
.contact-row .cic svg { width: 26px; height: 26px; color: var(--gold); }
.contact-row .ct-k { font-family:"Barlow Condensed",sans-serif; font-weight:700; text-transform:uppercase; letter-spacing:.08em; font-size:.82rem; color: var(--muted); }
.contact-row .ct-v { font-size: 1.45rem; font-weight: 700; font-family:"Barlow Condensed",sans-serif; color: var(--ink); }
.hours-list { list-style:none; margin:0; padding:0; display:grid; gap:0; }
.hours-list li { display:flex; justify-content:space-between; padding: 11px 0; border-bottom: 1px solid var(--line); }
.hours-list li:last-child { border-bottom: none; }
.hours-list .d { font-weight: 600; }
.hours-list .h { color: var(--muted); }

/* ============================================================
   MAP EMBED
   ============================================================ */
.map-frame {
  position: relative; border-radius: 16px; overflow: hidden;
  border: 1px solid rgba(245,180,0,.5);
  box-shadow: 0 0 0 1px rgba(245,180,0,.25), var(--shadow-md);
  background: #e8e8e4;
}
.map-frame iframe { display: block; width: 100%; border: 0; filter: grayscale(.12) contrast(1.02); }
.map-band .map-frame iframe { height: 480px; }
@media (max-width: 760px) { .map-band .map-frame iframe { height: 360px; } }

/* page hero (interior) */
.page-hero { color: #fff; padding: 70px 0 64px; position: relative; overflow: hidden; }
.page-hero::after {
  content:""; position:absolute; inset:0;
  background: radial-gradient(800px 320px at 80% -10%, rgba(245,180,0,.16), transparent 60%);
}
.page-hero .wrap { position: relative; z-index: 2; }
.page-hero h1 { font-size: clamp(2.6rem,5.5vw,4.4rem); font-style: italic; text-transform: uppercase; }
.page-hero h1 .accent { background: var(--gold-grad); -webkit-background-clip:text; background-clip:text; color:transparent; }
.page-hero p { color:#cfd0d6; font-size:1.18rem; max-width: 54ch; margin-top: 14px; }
.crumbs { font-family:"Barlow Condensed",sans-serif; text-transform:uppercase; letter-spacing:.1em; font-size:.85rem; color:#9a9ba2; margin-bottom: 16px; }
.crumbs a:hover { color: var(--gold); }
.crumbs span { color: var(--gold); }

/* service detail rows */
.svc-detail { display: grid; grid-template-columns: 1fr 1fr; gap: 50px; align-items: center; padding: 56px 0; border-bottom: 1px solid var(--line); }
.svc-detail:last-child { border-bottom: none; }
.svc-detail.flip .svc-text { order: 2; }
.svc-detail .svc-ic {
  width: 64px; height: 64px; border-radius: 14px; margin-bottom: 22px;
  display:flex; align-items:center; justify-content:center;
  background: linear-gradient(170deg,#26262c,#131316); border:1px solid rgba(245,180,0,.4);
}
.svc-detail .svc-ic svg { width: 32px; height: 32px; color: var(--gold); }
.svc-detail h3 { font-size: 2rem; text-transform: uppercase; font-style: italic; color: var(--ink); }
.svc-detail .num { font-family:"Barlow Condensed",sans-serif; font-style:italic; font-weight:800; font-size:1rem; color: var(--gold-deep); letter-spacing:.1em; }

/* mobile nav toggle */
.nav-toggle { display: none; background: none; border: none; color: #fff; cursor: pointer; padding: 8px; }
.nav-toggle svg { width: 30px; height: 30px; }

/* ============================================================
   RESPONSIVE
   ============================================================ */
/* collapse nav + compact call button on tablet so the header never overflows */
@media (max-width: 1080px) {
  .nav { display: none; }
  .nav.open {
    display: flex; flex-direction: column; align-items: stretch;
    position: absolute; top: 78px; left: 0; right: 0;
    background: var(--ink-2); padding: 14px; gap: 4px;
    border-bottom: 2px solid var(--gold);
    box-shadow: 0 18px 30px rgba(0,0,0,.35);
  }
  .nav.open a { padding: 13px 16px; }
  .nav.open a.active { background: rgba(245,180,0,.12); }
  .nav-toggle { display: block; }
  .head-cta .btn-label { display: none; }
  .head-cta .btn { padding: 12px 16px; }
}
@media (max-width: 980px) {
  .hero-grid { grid-template-columns: 1fr; }
  .hero-grid .hero-art { display: none; }
  .cards { grid-template-columns: repeat(2,1fr); }
  .feat { grid-template-columns: repeat(2,1fr); }
  .stats { grid-template-columns: repeat(2,1fr); gap: 30px 20px; }
  .foot-grid { grid-template-columns: 1fr 1fr; gap: 32px; }
  .split, .contact-grid, .svc-detail { grid-template-columns: 1fr; gap: 32px; }
  .svc-detail.flip .svc-text { order: 0; }
  .svc-detail .svc-art { display:none; }
}
@media (max-width: 760px) {
  body { font-size: 17px; }
  .topbar .badges { display: none; }
  .topbar .wrap { justify-content: center; }
  .cards { grid-template-columns: 1fr; }
  .feat { grid-template-columns: 1fr; }
  .sec { padding: 60px 0; }
  .foot-grid { grid-template-columns: 1fr; }
}
