/* =========================================================================
   Proficient Roofing & Restoration LLC  —  Pine Point Digital build
   Brand: pulled from the client logo (vivid lime green + silver/graphite on
   black). Direction:
     - LIGHT, clean, predominantly white/neutral (NOT a dark site)
     - Brand green is the signature: lime #43cf17 for pops/fills-on-dark,
       deep green #1f7a0e for readable text/icons/buttons on light
     - ONE dark moment only: the footer (graphite, matches the logo's bg
       where the green emblem pops)
     - Fonts: Archivo (strong grotesque headings, echoes the bold logo) + Inter
     - 4px radius everywhere, 1px hairlines
   Deliberately distinct from Legacy Roofing (dark #0D0F14 + red + Playfair).
   ========================================================================= */

:root{
  --bg:        #f6f7f4;   /* clean light neutral canvas */
  --bg-panel:  #eef1ea;   /* faint green-grey alternating panel */
  --bg-tint:   #e8f5df;   /* light green tint (restoration section) */
  --bg-deep:   #14181a;   /* graphite near-black — footer only, matches logo */
  --paper:     #ffffff;   /* cards */
  --green:     #43cf17;   /* BRAND lime — solid pops & on-dark contexts */
  --green-d:   #36a811;   /* darker lime for hover on bright fills */
  --green-ink: #1f7a0e;   /* deep readable green — text, icons, buttons on light */
  --green-ink-d:#176009;  /* darker still for button hover */
  --green-soft:#e6f6db;   /* tinted square behind service icons */
  --ink:       #15191c;   /* primary text, near-black */
  --ink-soft:  #353b3f;   /* body text */
  --muted:     #6b7176;   /* captions, footnotes */
  --line:      #e1e4dc;   /* hairline borders */
}

/* ---------- reset / base ---------- */
*,*::before,*::after{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  background:var(--bg);
  color:var(--ink-soft);
  font-family:'Inter',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  font-size:16px;
  line-height:1.62;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
h1,h2,h3,h4{
  font-family:'Archivo','Inter',system-ui,sans-serif;
  color:var(--ink);
  font-weight:700;
  letter-spacing:-0.018em;
  line-height:1.08;
}
:focus-visible{ outline:2px solid var(--green-ink); outline-offset:3px; border-radius:2px; }

/* ---------- layout helpers ---------- */
.container{ max-width:1180px; margin:0 auto; padding:0 24px; }
.section{ padding:64px 0; }
.section--panel{ background:var(--bg-panel); }
.eyebrow{
  display:inline-flex; align-items:center; gap:8px;
  font-family:'Inter',sans-serif;
  font-size:12px; font-weight:700;
  letter-spacing:0.2em; text-transform:uppercase;
  color:var(--green-ink);
  margin-bottom:14px;
}
.eyebrow::before{ content:""; width:9px; height:9px; background:var(--green); transform:rotate(45deg); display:inline-block; } /* diamond nod to the logo */
.section-head{ max-width:660px; margin:0 auto 40px; text-align:center; }
.section-head .eyebrow{ justify-content:center; }
.section-head h2{ font-size:clamp(30px,4.6vw,48px); }
.section-head p{ margin-top:16px; color:var(--ink-soft); font-size:17px; }
.accent-rule{ width:54px; height:3px; background:var(--green); border:0; }

/* ---------- buttons ---------- */
.btn{
  display:inline-flex; align-items:center; gap:8px;
  font-family:'Inter',sans-serif;
  font-size:15px; font-weight:600; letter-spacing:0.01em;
  padding:14px 22px; border-radius:4px;
  border:1px solid transparent; cursor:pointer;
  transition:background .18s ease,color .18s ease,border-color .18s ease,transform .18s ease;
}
.btn svg{ width:16px; height:16px; }
.btn-primary{ background:var(--green-ink); color:#fff; }
.btn-primary:hover{ background:var(--green-ink-d); }
.btn-outline{ background:transparent; color:var(--ink); border-color:var(--line); }
.btn-outline:hover{ border-color:var(--green-ink); color:var(--green-ink); }
/* bright lime button for dark contexts (footer) */
.btn-lime{ background:var(--green); color:#10240a; }
.btn-lime:hover{ background:var(--green-d); }

/* ---------- announce bar (bright, on-brand, NOT dark) ---------- */
.announce{
  background:var(--green); color:#10240a;
  font-size:12px; font-weight:700; letter-spacing:0.1em; text-transform:uppercase;
  text-align:center; padding:8px 16px;
}
.announce .dot{ opacity:.45; margin:0 8px; }
.announce a{ color:#10240a; font-weight:800; text-decoration:underline; text-underline-offset:2px; }

/* ---------- nav ---------- */
.nav{
  position:sticky; top:0; z-index:50;
  background:rgba(246,247,244,.93);
  backdrop-filter:blur(10px); -webkit-backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line);
}
.nav-inner{ display:flex; align-items:center; justify-content:space-between; height:70px; }
/* logo image (preferred once provided) */
.nav-logo{ display:flex; align-items:center; }
.nav-logo img{ height:46px; width:auto; display:block; }
/* temporary text wordmark — REMOVE once images/logo.png is in place */
.brand{ display:flex; flex-direction:column; line-height:1; }
.brand .name{ font-family:'Archivo',sans-serif; font-weight:800; font-size:21px; color:var(--ink); letter-spacing:-0.01em; text-transform:uppercase; }
.brand .name b{ color:var(--green-ink); }
.brand .sub{ font-family:'Inter',sans-serif; font-size:9px; font-weight:700; letter-spacing:0.22em; text-transform:uppercase; color:var(--muted); margin-top:3px; }
.nav-links{ display:none; align-items:center; gap:28px; }
.nav-links a{ font-size:14px; font-weight:500; color:var(--ink-soft); transition:color .18s ease; }
.nav-links a:hover{ color:var(--green-ink); }
.nav-actions{ display:flex; align-items:center; gap:14px; }
.nav-cta{
  display:inline-flex; align-items:center; gap:6px;
  background:var(--green-ink); color:#fff;
  font-size:14px; font-weight:600;
  padding:10px 16px; border-radius:4px;
  transition:background .18s ease;
}
.nav-cta:hover{ background:var(--green-ink-d); }
.nav-cta svg{ width:14px; height:14px; }

/* ---------- hero ---------- */
.hero{ padding:52px 0 60px; }
.hero-grid{ display:grid; grid-template-columns:1fr; gap:36px; align-items:center; }
.hero-copy{ text-align:center; }
.hero h1{
  font-size:clamp(38px,6.4vw,66px); line-height:1.02; font-weight:800;
  letter-spacing:-0.025em; color:var(--ink);
}
.hero h1 em{ font-style:normal; color:var(--green-ink); position:relative; white-space:nowrap; }
.hero h1 em::after{ content:""; position:absolute; left:0; right:0; bottom:0.06em; height:0.14em; background:var(--green); opacity:.45; border-radius:2px; z-index:-1; }
.hero-lead{
  margin:22px auto 0; max-width:520px;
  font-size:clamp(16px,1.5vw,18px); line-height:1.6; color:var(--ink-soft);
}
.hero-cta{ display:flex; flex-wrap:wrap; gap:14px; justify-content:center; margin-top:30px; }
.hero-fineprint{ margin-top:18px; font-size:13px; color:var(--muted); }
.hero-media{
  position:relative; aspect-ratio:4/5; border-radius:4px; overflow:hidden;
  border:1px solid var(--line);
}
.hero-media img{ width:100%; height:100%; object-fit:cover; }
.hero-media::after{ content:""; position:absolute; inset:0; box-shadow:inset 0 0 0 1px rgba(0,0,0,.06); border-radius:4px; }
.hero-badge{
  position:absolute; left:16px; bottom:16px;
  background:rgba(20,24,26,.88); color:#fff; backdrop-filter:blur(4px);
  border-left:3px solid var(--green);
  border-radius:4px; padding:10px 14px; font-size:12.5px; line-height:1.35; max-width:240px;
}
.hero-badge strong{ display:block; font-weight:700; color:#fff; }

/* ---------- trust bar ---------- */
.trust{ border-top:1px solid var(--line); border-bottom:1px solid var(--line); background:var(--paper); }
.trust-inner{
  display:flex; flex-wrap:wrap; justify-content:center; gap:10px 0;
  padding:16px 0; font-size:13px; font-weight:600; letter-spacing:0.04em;
  text-transform:uppercase; color:var(--ink-soft); text-align:center;
}
.trust-inner span{ padding:0 18px; position:relative; }
.trust-inner span + span::before{
  content:""; position:absolute; left:-3px; top:50%; width:6px; height:6px;
  background:var(--green); border-radius:1px; transform:translateY(-50%) rotate(45deg);
}

/* ---------- services ---------- */
.svc-grid{ display:grid; grid-template-columns:1fr; gap:16px; }
.svc-card{
  background:var(--paper); border:1px solid var(--line); border-radius:4px;
  padding:28px 26px; transition:transform .2s ease,border-color .2s ease,box-shadow .2s ease;
}
.svc-card:hover{ transform:translateY(-2px); border-color:var(--green-ink); box-shadow:0 14px 26px -18px rgba(31,122,14,.45); }
.svc-icon{
  width:46px; height:46px; border-radius:4px; background:var(--green-soft);
  display:flex; align-items:center; justify-content:center; margin-bottom:18px;
}
.svc-icon svg{ width:26px; height:26px; stroke:var(--green-ink); stroke-width:1.7; fill:none; stroke-linecap:round; stroke-linejoin:round; }
.svc-card h3{ font-size:21px; line-height:1.15; margin-bottom:8px; }
.svc-card p{ font-size:15px; line-height:1.6; color:var(--ink-soft); }
.svc-coda{ text-align:center; margin-top:26px; color:var(--muted); font-size:15px; }

/* ---------- restoration section (LIGHT, green-tinted) ---------- */
.band{ background:var(--bg-tint); }
.band .container{ padding-top:64px; padding-bottom:64px; }
.band-grid{ display:grid; grid-template-columns:1fr; gap:30px; align-items:center; }
.band h2{ font-size:clamp(28px,4.2vw,42px); }
.band p{ color:var(--ink-soft); font-size:16px; margin-top:14px; }
.band-points{ list-style:none; margin-top:22px; display:grid; gap:12px; }
.band-points li{ display:flex; gap:10px; font-size:15px; color:var(--ink-soft); }
.band-points svg{ width:20px; height:20px; stroke:var(--green-ink); stroke-width:2.2; fill:none; flex-shrink:0; margin-top:2px; }
.band-cta{ margin-top:26px; }
.band-cards{ display:grid; gap:14px; }
.band-cardlet{ background:var(--paper); border:1px solid var(--line); border-radius:4px; padding:20px 22px; }
.band-cardlet .t{ display:flex; align-items:center; gap:10px; font-family:'Archivo',sans-serif; font-weight:700; color:var(--ink); font-size:17px; margin-bottom:6px; }
.band-cardlet .t svg{ width:20px; height:20px; stroke:var(--green-ink); stroke-width:2; fill:none; }
.band-cardlet p{ margin-top:0; font-size:14.5px; color:var(--ink-soft); line-height:1.6; }

/* ---------- about / why ---------- */
.about-grid{ display:grid; grid-template-columns:1fr; gap:36px; align-items:center; }
.about-media{ position:relative; border-radius:4px; overflow:hidden; border:1px solid var(--line); aspect-ratio:4/3; }
.about-media img{ width:100%; height:100%; object-fit:cover; }
.about-copy h2{ font-size:clamp(28px,4vw,42px); line-height:1.08; margin-bottom:6px; }
.about-copy p{ margin-top:16px; font-size:16px; line-height:1.7; color:var(--ink-soft); }
.about-copy .accent-rule{ margin:20px 0 4px; }

/* ---------- process ---------- */
.steps{ display:grid; grid-template-columns:1fr; gap:16px; }
.step{ background:var(--paper); border:1px solid var(--line); border-radius:4px; padding:24px 22px; position:relative; }
.step::before{ content:""; position:absolute; top:0; left:0; width:34px; height:3px; background:var(--green); border-radius:0 0 2px 0; }
.step-num{
  font-family:'Archivo',sans-serif; font-size:13px; font-weight:800; color:var(--green-ink);
  letter-spacing:0.08em; text-transform:uppercase; display:block; margin-bottom:8px;
}
.step h3{ font-size:18px; margin-bottom:6px; }
.step p{ font-size:14.5px; color:var(--ink-soft); line-height:1.6; }

/* ---------- service area ---------- */
.area-grid{ display:grid; grid-template-columns:1fr; gap:30px; align-items:center; }
.area-list{ display:flex; flex-wrap:wrap; gap:8px; margin-top:20px; }
.area-list span{
  font-size:13px; font-weight:600; color:var(--ink-soft);
  background:var(--paper); border:1px solid var(--line); border-radius:4px; padding:7px 12px;
}
.area-note{ margin-top:18px; font-size:14px; color:var(--muted); }

/* ---------- contact (LIGHT card) ---------- */
.contact-grid{ display:grid; grid-template-columns:1fr; gap:24px; }
.contact-info h2{ font-size:clamp(28px,4vw,42px); margin-bottom:6px; }
.contact-info > p{ margin-top:14px; font-size:16px; color:var(--ink-soft); max-width:420px; }
.detail-rows{ margin-top:26px; }
.detail-row{ display:flex; gap:14px; align-items:flex-start; padding:16px 0; border-bottom:1px solid var(--line); }
.detail-row:last-child{ border-bottom:0; }
.detail-row svg{ width:20px; height:20px; stroke:var(--green-ink); stroke-width:1.7; fill:none; flex-shrink:0; margin-top:3px; }
.detail-row .label{ font-size:11px; font-weight:700; letter-spacing:0.16em; text-transform:uppercase; color:var(--muted); }
.detail-row .value{ font-size:16px; color:var(--ink); font-weight:500; }
.detail-row a.value:hover{ color:var(--green-ink); }

.quote-card{ background:var(--paper); color:var(--ink); border:1px solid var(--line); border-radius:4px; padding:30px 26px; box-shadow:0 18px 40px -28px rgba(20,40,15,.35); }
.quote-card h3{ font-size:22px; margin-bottom:6px; }
.quote-card .sub{ color:var(--muted); font-size:14px; margin-bottom:20px; }
.field{ margin-bottom:14px; }
.field label{ display:block; font-size:11px; font-weight:700; letter-spacing:0.16em; text-transform:uppercase; color:var(--green-ink); margin-bottom:6px; }
.field input,.field textarea,.field select{
  width:100%; font-family:'Inter',sans-serif; font-size:15px; color:var(--ink);
  background:var(--bg); border:1px solid var(--line);
  border-radius:4px; padding:11px 13px; transition:border-color .18s ease,box-shadow .18s ease;
}
.field input::placeholder,.field textarea::placeholder{ color:var(--muted); }
.field input:focus,.field textarea:focus,.field select:focus{ outline:none; border-color:var(--green-ink); box-shadow:0 0 0 3px rgba(31,122,14,.12); }
.field textarea{ resize:vertical; min-height:96px; }
.quote-card .btn-primary{ width:100%; justify-content:center; margin-top:4px; }
.quote-or{ text-align:center; margin-top:16px; font-size:14px; color:var(--muted); }
.quote-or a{ color:var(--green-ink); font-weight:700; }

/* ---------- footer (the ONE dark moment — matches logo bg) ---------- */
.footer{ background:var(--bg-deep); color:rgba(255,255,255,.72); padding:46px 0 30px; }
.footer-top{ display:grid; grid-template-columns:1fr; gap:24px; }
.footer-logo img{ height:60px; width:auto; margin-bottom:16px; }
.footer .name{ font-family:'Archivo',sans-serif; font-size:22px; font-weight:800; color:#fff; text-transform:uppercase; letter-spacing:-0.01em; }
.footer .name b{ color:var(--green); }
.footer .sub{ font-size:11px; font-weight:700; letter-spacing:0.2em; text-transform:uppercase; color:var(--green); margin-top:4px; }
.footer p{ font-size:14px; line-height:1.7; margin-top:14px; max-width:340px; }
.footer a:hover{ color:#fff; }
.footer-col h4{ color:#fff; font-family:'Inter',sans-serif; font-size:12px; font-weight:700; letter-spacing:0.16em; text-transform:uppercase; margin-bottom:14px; }
.footer-col a,.footer-col span{ display:block; font-size:14px; margin-bottom:9px; color:rgba(255,255,255,.72); }
.footer-bottom{
  margin-top:36px; padding-top:22px; border-top:1px solid rgba(255,255,255,.12);
  display:flex; flex-direction:column; gap:10px; align-items:center; text-align:center;
  font-size:12.5px; color:rgba(255,255,255,.55);
}
.footer-bottom .credit{ color:rgba(255,255,255,.65); }
.footer-bottom .credit a{ color:var(--green); }

/* =========================================================================
   Responsive
   ========================================================================= */
@media (min-width:720px){
  .section{ padding:84px 0; }
  .hero{ padding:72px 0 84px; }
  .hero-grid{ grid-template-columns:1.05fr 1fr; gap:54px; }
  .hero-copy{ text-align:left; }
  .hero-lead{ margin-left:0; }
  .hero-cta{ justify-content:flex-start; }
  .hero-media{ aspect-ratio:5/6; }
  .nav-links{ display:flex; }
  .svc-grid{ grid-template-columns:1fr 1fr; }
  .band-grid{ grid-template-columns:1.25fr 1fr; gap:48px; }
  .about-grid{ grid-template-columns:1fr 1.25fr; gap:48px; }
  .steps{ grid-template-columns:1fr 1fr; }
  .area-grid{ grid-template-columns:1.1fr 1fr; gap:48px; }
  .contact-grid{ grid-template-columns:1fr 1.05fr; gap:40px; }
  .footer-top{ grid-template-columns:1.6fr 1fr 1fr; gap:40px; }
  .footer-bottom{ flex-direction:row; justify-content:space-between; text-align:left; }
}
@media (min-width:1024px){
  .hero{ padding:84px 0 100px; }
  .svc-grid{ grid-template-columns:repeat(3,1fr); }
  .steps{ grid-template-columns:repeat(4,1fr); }
}
@media (prefers-reduced-motion:reduce){
  *{ scroll-behavior:auto !important; transition:none !important; }
}
