/* Great Choice Construction — shared styles
   Construction orange accent on clean white/black */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}

:root{
  --black:#0e0e0e;
  --ink:#1a1a1a;
  --ink-2:#2a2a2a;
  --muted:#525252;
  --muted-2:#737373;
  --line:#e6e6e6;
  --line-2:#f0f0f0;
  --bg:#ffffff;
  --bg-soft:#f7f7f5;
  --bg-card:#fafaf9;
  --orange:#15803D;          /* construction orange */
  --orange-deep:#14532D;
  --orange-soft:#FEF9C3;
  --orange-tint:#FDE68A;
  --shadow-sm:0 1px 2px rgba(15,15,15,.04), 0 1px 1px rgba(15,15,15,.03);
  --shadow:0 4px 14px rgba(15,15,15,.06), 0 1px 3px rgba(15,15,15,.04);
  --shadow-lg:0 20px 50px -20px rgba(15,15,15,.18), 0 8px 20px -10px rgba(15,15,15,.08);
  --r-sm:6px;
  --r:10px;
  --r-lg:16px;
  --r-xl:24px;
  --t:.25s cubic-bezier(.2,.7,.2,1);
  --max:1200px;
  --max-narrow:920px;
}

html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:'Inter','Helvetica Neue',Helvetica,Arial,system-ui,sans-serif;
  color:var(--ink);
  background:var(--bg);
  line-height:1.6;
  font-size:16px;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}

img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}

/* ---------- Typography ---------- */
h1,h2,h3,h4{
  font-family:'Inter','Helvetica Neue',Helvetica,Arial,sans-serif;
  font-weight:700;
  letter-spacing:-.02em;
  color:var(--ink);
  text-wrap:balance;
}
h1{font-size:clamp(2.1rem,4.5vw,3.4rem);line-height:1.05;letter-spacing:-.03em}
h2{font-size:clamp(1.7rem,3vw,2.4rem);line-height:1.15;margin-bottom:.6em}
h3{font-size:clamp(1.2rem,1.8vw,1.45rem);line-height:1.3;margin-bottom:.4em}
h4{font-size:1.05rem;line-height:1.35;margin-bottom:.3em}
p{margin-bottom:1em;color:var(--muted);max-width:70ch;text-wrap:pretty}
.lead{font-size:1.1rem;color:var(--muted);max-width:62ch}

ul,ol{margin:0 0 1.2em 1.2em}
li{margin-bottom:.45em;color:var(--muted);line-height:1.65}
li strong{color:var(--ink)}

strong{color:var(--ink);font-weight:600}

/* Section wrappers */
.section{padding:88px 24px}
.section--soft{background:var(--bg-soft)}
.section--ink{background:var(--ink);color:#e9e9e9}
.section--ink h2,.section--ink h3,.section--ink h4{color:#fff}
.section--ink p{color:#bdbdbd}
.section--ink li{color:#bdbdbd}
.section--ink li strong{color:#fff}
.wrap{max-width:var(--max);margin:0 auto}
.wrap--narrow{max-width:var(--max-narrow);margin:0 auto}

.eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  font-size:.72rem;font-weight:600;letter-spacing:.16em;text-transform:uppercase;
  color:var(--orange);
  margin-bottom:18px;
}
.eyebrow::before{
  content:"";width:22px;height:1.5px;background:var(--orange);display:inline-block;
}

/* ---------- Top utility bar (allowed — not nav/header) ---------- */
.utility{
  background:var(--ink);
  color:#cfcfcf;
  font-size:.82rem;
  padding:9px 24px;
  display:flex;justify-content:space-between;align-items:center;gap:16px;
  flex-wrap:wrap;
}
.utility a{color:#fff;font-weight:500;display:inline-flex;align-items:center;gap:6px}
.utility a:hover{color:var(--orange)}
.utility .u-left,.utility .u-right{display:flex;gap:18px;flex-wrap:wrap}
.utility .dot{width:6px;height:6px;background:#22c55e;border-radius:50%;display:inline-block;box-shadow:0 0 0 3px rgba(34,197,94,.18)}

/* ---------- Breadcrumb ---------- */
.crumb{
  max-width:var(--max);margin:0 auto;
  padding:20px 24px 0;
  font-size:.86rem;color:var(--muted-2);
}
.crumb a{color:var(--ink);font-weight:500}
.crumb a:hover{color:var(--orange)}
.crumb .sep{margin:0 8px;color:var(--line)}

/* ---------- Hero ---------- */
.hero{
  position:relative;
  padding:84px 24px 88px;
  background:var(--bg);
  overflow:hidden;
}
.hero--dark{
  background:linear-gradient(180deg,#101010 0%, #1a1a1a 100%);
  color:#f5f5f5;
}
.hero--dark h1{color:#fff}
.hero--dark .lead{color:#bdbdbd}
.hero-inner{max-width:var(--max);margin:0 auto;display:grid;grid-template-columns:1.15fr .85fr;gap:64px;align-items:center}
.hero h1{margin-bottom:18px}
.hero-meta{display:flex;flex-wrap:wrap;gap:22px;margin-top:28px;font-size:.92rem;color:var(--muted-2)}
.hero--dark .hero-meta{color:#a3a3a3}
.hero-meta span{display:inline-flex;align-items:center;gap:8px}
.hero-meta svg{width:16px;height:16px;color:var(--orange);flex-shrink:0}
.hero-ctas{display:flex;flex-wrap:wrap;gap:12px;margin-top:32px}

.hero-visual{
  aspect-ratio:5/4;
  border-radius:var(--r-lg);
  background:
    repeating-linear-gradient(135deg, #f4f4f2 0 24px, #ececea 24px 48px);
  border:1px solid var(--line);
  position:relative;
  overflow:hidden;
  display:grid;place-items:center;
}
.hero--dark .hero-visual{
  background:
    repeating-linear-gradient(135deg, rgba(255,255,255,.04) 0 24px, rgba(255,255,255,.02) 24px 48px);
  border-color:rgba(255,255,255,.08);
}
.hero-visual .placeholder-tag{
  font-family:'JetBrains Mono','SF Mono',ui-monospace,monospace;
  font-size:.78rem;
  color:var(--muted-2);
  background:rgba(255,255,255,.85);
  padding:8px 14px;border-radius:999px;
  border:1px solid var(--line);
  letter-spacing:.04em;
}
.hero--dark .hero-visual .placeholder-tag{
  background:rgba(0,0,0,.55);color:#cfcfcf;border-color:rgba(255,255,255,.1);
}
.hero-visual .stat-chip{
  position:absolute; bottom:18px; left:18px;
  background:#fff; padding:14px 16px; border-radius:var(--r);
  box-shadow:var(--shadow); border:1px solid var(--line);
  display:flex; align-items:center; gap:12px;
}
.hero-visual .stat-chip .n{font-size:1.5rem;font-weight:700;color:var(--ink);letter-spacing:-.02em}
.hero-visual .stat-chip .l{font-size:.74rem;color:var(--muted-2);text-transform:uppercase;letter-spacing:.1em}

@media (max-width:880px){
  .hero{padding:60px 22px 64px}
  .hero-inner{grid-template-columns:1fr;gap:36px}
  .hero-visual{aspect-ratio:16/10}
}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  padding:14px 24px;
  font-weight:600;font-size:.95rem;
  border-radius:var(--r);
  border:1.5px solid transparent;
  cursor:pointer;
  transition:transform var(--t),background var(--t),color var(--t),border-color var(--t),box-shadow var(--t);
  white-space:nowrap;
}
.btn:active{transform:translateY(0)}
.btn-primary{background:var(--orange);color:#fff;border-color:var(--orange)}
.btn-primary:hover{background:var(--orange-deep);border-color:var(--orange-deep);transform:translateY(-1px);box-shadow:0 8px 22px -8px rgba(21,128,61,.55)}
.btn-dark{background:var(--ink);color:#fff;border-color:var(--ink)}
.btn-dark:hover{background:#000;transform:translateY(-1px)}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--line)}
.btn-ghost:hover{border-color:var(--ink);background:var(--bg-soft)}
.btn-ghost-light{background:transparent;color:#fff;border-color:rgba(255,255,255,.25)}
.btn-ghost-light:hover{border-color:#fff;background:rgba(255,255,255,.06)}
.btn-link{
  background:none;border:none;color:var(--orange);padding:0;
  font-weight:600;display:inline-flex;align-items:center;gap:6px;
}
.btn-link::after{content:"→";transition:transform var(--t)}
.btn-link:hover::after{transform:translateX(3px)}

.btn svg{width:16px;height:16px}

/* ---------- Service grid cards ---------- */
.svc-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(320px,1fr));
  gap:24px;
  margin-top:48px;
}
.svc-card{
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--r-lg);
  overflow:hidden;
  transition:transform var(--t),box-shadow var(--t),border-color var(--t);
  display:flex;flex-direction:column;
}
.svc-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg);border-color:#d4d4d4}
.svc-card .img{
  aspect-ratio:16/10;
  background:
    repeating-linear-gradient(135deg, #f0f0ee 0 18px, #e8e8e6 18px 36px);
  position:relative;
  display:grid;place-items:center;
  border-bottom:1px solid var(--line);
}
.svc-card .img .tag{
  font-family:'JetBrains Mono','SF Mono',ui-monospace,monospace;
  font-size:.72rem;letter-spacing:.05em;color:var(--muted-2);
  background:rgba(255,255,255,.9);padding:6px 12px;border-radius:999px;border:1px solid var(--line);
}
.svc-card .img .num{
  position:absolute;top:14px;left:14px;
  font-family:'JetBrains Mono','SF Mono',ui-monospace,monospace;
  font-size:.74rem;color:var(--ink);
  background:#fff;padding:5px 10px;border-radius:6px;font-weight:600;
  border:1px solid var(--line);
}
.svc-card .body{padding:26px 24px 24px;display:flex;flex-direction:column;flex:1}
.svc-card h3{margin-bottom:10px;font-size:1.25rem}
.svc-card p{font-size:.95rem;margin-bottom:18px;flex:1}
.svc-card .actions{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:16px}
.svc-card .cities{
  display:flex;flex-wrap:wrap;gap:6px;
  padding-top:16px;border-top:1px dashed var(--line);
}
.svc-card .cities .label{
  font-size:.7rem;color:var(--muted-2);text-transform:uppercase;letter-spacing:.1em;
  width:100%;margin-bottom:6px;
}
.svc-card .cities a{
  font-size:.78rem;
  padding:5px 10px;
  border-radius:999px;
  background:var(--bg-soft);
  color:var(--ink-2);
  border:1px solid var(--line);
  transition:all var(--t);
  font-weight:500;
}
.svc-card .cities a:hover{background:var(--orange);color:#fff;border-color:var(--orange)}

/* ---------- Feature / why grid ---------- */
.feat-grid{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));
  gap:22px;margin-top:40px;
}
.feat{
  padding:28px 26px;
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--r-lg);
  transition:border-color var(--t),transform var(--t),box-shadow var(--t);
}
.feat:hover{border-color:var(--orange);transform:translateY(-2px);box-shadow:var(--shadow)}
.feat .icon{
  width:42px;height:42px;border-radius:10px;
  background:var(--orange-soft);color:var(--orange);
  display:grid;place-items:center;margin-bottom:18px;
}
.feat .icon svg{width:20px;height:20px}
.feat h4{margin-bottom:8px;font-size:1.05rem}
.feat p{margin:0;font-size:.93rem}

.section--ink .feat{
  background:rgba(255,255,255,.04);
  border-color:rgba(255,255,255,.08);
}
.section--ink .feat:hover{border-color:var(--orange);background:rgba(255,255,255,.06)}
.section--ink .feat .icon{background:rgba(21,128,61,.18)}

/* ---------- Process / steps ---------- */
.steps{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));
  gap:18px;margin-top:48px;
}
.step{
  position:relative;
  padding:26px 22px 24px;
  background:#fff;border:1px solid var(--line);
  border-radius:var(--r-lg);
}
.step .num{
  font-family:'JetBrains Mono','SF Mono',ui-monospace,monospace;
  font-size:.78rem;font-weight:700;color:var(--orange);
  letter-spacing:.08em;margin-bottom:14px;display:block;
}
.step h4{margin-bottom:6px;font-size:1rem}
.step p{font-size:.88rem;margin:0;color:var(--muted)}

/* ---------- Areas (city chip grid) ---------- */
.areas-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(220px,1fr));
  gap:10px;
  margin-top:36px;
}
.area-chip{
  display:flex;align-items:center;justify-content:space-between;gap:8px;
  padding:13px 16px;
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--r);
  font-size:.9rem;font-weight:500;color:var(--ink);
  transition:all var(--t);
}
.area-chip::after{content:"→";color:var(--muted-2);transition:transform var(--t),color var(--t)}
.area-chip:hover{border-color:var(--orange);background:var(--orange-soft);color:var(--orange-deep)}
.area-chip:hover::after{transform:translateX(3px);color:var(--orange)}

.section--ink .area-chip{
  background:rgba(255,255,255,.04);
  border-color:rgba(255,255,255,.08);
  color:#f5f5f5;
}
.section--ink .area-chip::after{color:#737373}
.section--ink .area-chip:hover{background:rgba(21,128,61,.16);border-color:var(--orange);color:#fff}
.section--ink .area-chip:hover::after{color:var(--orange)}

/* ---------- Related cards ---------- */
.rel-grid{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
  gap:16px;margin-top:36px;
}
.rel-card{
  display:flex;flex-direction:column;justify-content:space-between;
  padding:24px 22px;
  background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);
  min-height:140px;
  transition:all var(--t);
}
.rel-card:hover{border-color:var(--orange);transform:translateY(-2px);box-shadow:var(--shadow)}
.rel-card h4{margin-bottom:6px;font-size:1rem}
.rel-card .sub{font-size:.85rem;color:var(--muted);margin-bottom:16px}
.rel-card .arr{
  font-size:.85rem;font-weight:600;color:var(--orange);
  display:inline-flex;align-items:center;gap:6px;
}
.rel-card:hover .arr::after{transform:translateX(3px)}
.rel-card .arr::after{content:"→";transition:transform var(--t)}

/* ---------- Highlight callouts ---------- */
.callout{
  padding:24px 26px;
  border-left:3px solid var(--orange);
  background:var(--orange-soft);
  border-radius:0 var(--r) var(--r) 0;
  margin:32px 0;
}
.callout h4{color:var(--orange-deep);margin-bottom:10px;font-size:1rem;letter-spacing:.01em}
.callout p,.callout li{color:#14532D}
.callout strong{color:#14532D}
.callout ul{margin-bottom:0}

.callout--ink{
  background:#0a0a0a;
  border-left-color:var(--orange);
  color:#e5e5e5;
}
.callout--ink h4{color:#fff}
.callout--ink p,.callout--ink li{color:#bdbdbd}
.callout--ink strong{color:#fff}

/* ---------- FAQ ---------- */
.faq{margin-top:36px;display:flex;flex-direction:column;gap:10px}
.faq details{
  background:#fff;border:1px solid var(--line);border-radius:var(--r);
  overflow:hidden;transition:border-color var(--t);
}
.faq details[open]{border-color:#d4d4d4;box-shadow:var(--shadow-sm)}
.faq summary{
  cursor:pointer;list-style:none;
  padding:20px 22px;
  font-weight:600;font-size:1rem;color:var(--ink);
  display:flex;align-items:center;justify-content:space-between;gap:16px;
}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{
  content:"+";
  font-size:1.3rem;font-weight:400;color:var(--orange);
  transition:transform var(--t);
  flex-shrink:0;
}
.faq details[open] summary::after{content:"–"}
.faq .a{padding:0 22px 22px;color:var(--muted);max-width:none}

/* ---------- CTA panel ---------- */
.cta-panel{
  background:linear-gradient(135deg,#0e0e0e 0%,#1f1f1f 100%);
  color:#fff;
  padding:64px 40px;
  border-radius:var(--r-xl);
  display:grid;grid-template-columns:1.3fr .7fr;gap:48px;align-items:center;
  position:relative;overflow:hidden;
  margin-top:40px;
}
.cta-panel::before{
  content:"";position:absolute;top:-40%;right:-10%;
  width:520px;height:520px;
  background:radial-gradient(circle, rgba(21,128,61,.32) 0%, transparent 60%);
  pointer-events:none;
}
.cta-panel h2{color:#fff;margin-bottom:14px;position:relative}
.cta-panel p{color:#bdbdbd;position:relative;max-width:50ch}
.cta-actions{display:flex;flex-direction:column;gap:14px;position:relative}
.cta-actions .row{display:flex;gap:12px;flex-wrap:wrap}
.cta-actions .row .btn{flex:1;min-width:160px}
.cta-actions .hint{font-size:.82rem;color:#a3a3a3;display:flex;align-items:center;gap:8px}
@media (max-width:880px){
  .cta-panel{grid-template-columns:1fr;padding:40px 28px}
}

/* ---------- Bottom contact bar (allowed — content section, not footer nav) ---------- */
.contact-bar{
  padding:48px 24px;
  background:var(--bg-soft);
  border-top:1px solid var(--line);
}
.contact-bar .wrap{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
  gap:32px;
}
.contact-bar .b h4{font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted-2);margin-bottom:10px;font-weight:600}
.contact-bar .b a,.contact-bar .b p{font-size:1.05rem;font-weight:600;color:var(--ink);margin:0}
.contact-bar .b p{font-weight:500;color:var(--muted)}
.contact-bar .b a:hover{color:var(--orange)}

/* ---------- Trust strip ---------- */
.trust{
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
  padding:22px 24px;
  background:#fff;
}
.trust .wrap{display:flex;gap:36px;justify-content:space-between;flex-wrap:wrap;align-items:center}
.trust .t{
  display:flex;align-items:center;gap:10px;
  font-size:.86rem;color:var(--muted);font-weight:500;
}
.trust .t svg{width:18px;height:18px;color:var(--orange)}
.trust .t strong{color:var(--ink);font-weight:600}

/* ---------- Internal links cluster ---------- */
.linkcluster{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));
  gap:24px;margin-top:36px;
}
.linkcluster .col h4{
  font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;
  color:var(--muted-2);margin-bottom:14px;font-weight:600;
}
.linkcluster .col ul{margin:0;list-style:none;padding:0}
.linkcluster .col li{margin-bottom:8px}
.linkcluster .col a{
  font-size:.93rem;color:var(--ink);font-weight:500;
  border-bottom:1px solid transparent;
  transition:border-color var(--t),color var(--t);
  padding-bottom:1px;
}
.linkcluster .col a:hover{color:var(--orange);border-color:var(--orange)}

/* ---------- Long-form content block ---------- */
.prose{max-width:var(--max-narrow);margin:0 auto}
.prose h2{margin-top:0}
.prose h3{margin-top:48px}
.prose p,.prose ul,.prose ol{margin-bottom:1.1em}
.prose ul,.prose ol{padding-left:1.2em;margin-left:0}
.prose li{max-width:68ch}

/* Two-column content */
.split{
  display:grid;grid-template-columns:1.1fr .9fr;gap:56px;align-items:start;
  margin-top:40px;
}
.split .vis{
  aspect-ratio:4/5;
  border-radius:var(--r-lg);
  background:
    repeating-linear-gradient(135deg, #f0f0ee 0 22px, #e8e8e6 22px 44px);
  border:1px solid var(--line);
  display:grid;place-items:center;
  position:relative;
}
.split .vis .placeholder-tag{
  font-family:'JetBrains Mono','SF Mono',ui-monospace,monospace;
  font-size:.78rem;color:var(--muted-2);
  background:rgba(255,255,255,.9);padding:8px 14px;border-radius:999px;border:1px solid var(--line);
}
@media (max-width:880px){
  .split{grid-template-columns:1fr;gap:32px}
  .split .vis{aspect-ratio:16/10}
}

/* ---------- Sitemap helper page ---------- */
.sitemap-hdr{padding:60px 24px 30px;border-bottom:1px solid var(--line)}
.sitemap-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:32px;padding:40px 24px;max-width:var(--max);margin:0 auto}
.sitemap-grid h3{font-size:1.05rem;margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid var(--line)}
.sitemap-grid ul{list-style:none;margin:0;padding:0}
.sitemap-grid li{margin-bottom:6px}
.sitemap-grid a{font-size:.9rem;color:var(--ink-2)}
.sitemap-grid a:hover{color:var(--orange)}

/* ---------- Mobile tweaks ---------- */
@media (max-width:680px){
  .section{padding:64px 22px}
  .hero{padding:48px 22px 56px}
  .cta-panel{padding:36px 24px}
  .cta-actions .row .btn{width:100%;min-width:0}
  h1{font-size:2.05rem}
  h2{font-size:1.55rem}
  .utility{font-size:.78rem;padding:8px 16px}
  .utility .u-left,.utility .u-right{gap:12px}
}

/* ---------- Animated hero visual (when no photo) ---------- */
.hero-visual.has-anim{
  background:#0a0a0a;
  border:1px solid rgba(255,255,255,.06);
  padding:0;
  overflow:hidden;
  display:grid;
  place-items:center;
  position:relative;
  isolation:isolate;
}
.hero-visual.has-anim::before{
  content:"";
  position:absolute;inset:-30%;
  background:
    radial-gradient(circle at 30% 30%, rgba(234,179,8,.42), transparent 45%),
    radial-gradient(circle at 70% 70%, rgba(21,128,61,.32), transparent 50%),
    radial-gradient(circle at 50% 50%, rgba(101,163,13,.16), transparent 60%);
  filter:blur(40px);
  animation: anim-blob 18s ease-in-out infinite;
  z-index:0;
}
.hero-visual.has-anim::after{
  content:"";
  position:absolute;inset:0;
  background:
    repeating-linear-gradient(
      135deg,
      rgba(255,255,255,.03) 0 1px,
      transparent 1px 28px
    );
  z-index:1;
  pointer-events:none;
  animation: anim-stripes 32s linear infinite;
}
.hero-visual.has-anim .stat-chip{z-index:3}
.hero-visual.has-anim .placeholder-tag{display:none}

.anim-text{
  position:relative;z-index:2;
  text-align:center;
  padding:32px;
  width:100%;
}
.anim-text .small{
  display:block;
  font-family:'JetBrains Mono','SF Mono',ui-monospace,monospace;
  font-size:.72rem;letter-spacing:.28em;text-transform:uppercase;
  color:rgba(253,224,71,.92);
  margin-bottom:18px;
  animation: anim-fadein .9s ease both;
  animation-delay:.1s;
}
.anim-text .big{
  display:block;
  font-family:'Inter','Helvetica Neue',Helvetica,Arial,sans-serif;
  font-size:clamp(1.6rem, 3.2vw, 2.6rem);
  font-weight:700;
  letter-spacing:-.02em;
  line-height:1.04;
  background:linear-gradient(120deg, #fff 0%, #fff 30%, #FDE68A 50%, #fff 70%, #fff 100%);
  background-size:200% 100%;
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
  -webkit-text-fill-color:transparent;
  animation: anim-shimmer 6s linear infinite, anim-rise .9s ease .25s both;
}
.anim-text .ticks{
  display:flex;justify-content:center;gap:6px;margin-top:22px;
}
.anim-text .ticks i{
  width:24px;height:2px;background:rgba(255,255,255,.18);
  display:block;border-radius:2px;
  animation: anim-pulse 2.4s ease-in-out infinite;
}
.anim-text .ticks i:nth-child(2){animation-delay:.3s}
.anim-text .ticks i:nth-child(3){animation-delay:.6s}
.anim-text .ticks i:nth-child(4){animation-delay:.9s}

@keyframes anim-blob{
  0%,100%{transform:translate(0,0) rotate(0deg) scale(1)}
  33%{transform:translate(4%,-6%) rotate(60deg) scale(1.08)}
  66%{transform:translate(-5%,3%) rotate(-40deg) scale(.95)}
}
@keyframes anim-stripes{
  0%{background-position:0 0}
  100%{background-position:560px 560px}
}
@keyframes anim-shimmer{
  0%{background-position:200% 0}
  100%{background-position:-200% 0}
}
@keyframes anim-fadein{
  from{opacity:0;transform:translateY(6px)}
  to{opacity:1;transform:translateY(0)}
}
@keyframes anim-rise{
  from{opacity:0;transform:translateY(14px)}
  to{opacity:1;transform:translateY(0)}
}
@keyframes anim-pulse{
  0%,100%{background:rgba(255,255,255,.16);transform:scaleX(1)}
  50%{background:#EAB308;transform:scaleX(1.4)}
}
@media (prefers-reduced-motion: reduce){
  .hero-visual.has-anim::before,
  .hero-visual.has-anim::after,
  .anim-text .big,
  .anim-text .ticks i{animation:none!important}
}

/* ---------- Real photo support ---------- */
.hero-visual.has-photo{
  background:#0a0a0a;
  padding:0;
  border:none;
}
.hero-visual.has-photo img{
  width:100%;height:100%;object-fit:cover;
  border-radius:var(--r-lg);
}
.hero-visual.has-photo .placeholder-tag{display:none}
.hero-visual.has-photo .stat-chip{z-index:2}

/* Gallery strip */
.gallery{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
  gap:14px;
  margin-top:36px;
}
.gallery .g-item{
  aspect-ratio:4/3;
  border-radius:var(--r);
  overflow:hidden;
  background:#0a0a0a;
  position:relative;
  border:1px solid var(--line);
  transition:transform var(--t),box-shadow var(--t);
}
.gallery .g-item:hover{transform:translateY(-2px);box-shadow:var(--shadow)}
.gallery .g-item img{
  width:100%;height:100%;object-fit:cover;
  display:block;
}
.gallery .g-item .cap{
  position:absolute;left:10px;bottom:10px;
  background:rgba(0,0,0,.72);
  color:#fff;
  font-family:'JetBrains Mono','SF Mono',ui-monospace,monospace;
  font-size:.7rem;letter-spacing:.04em;
  padding:5px 9px;border-radius:6px;
  pointer-events:none;
}
.gallery--wide{grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}
.gallery .g-tall{grid-row:span 1}
@media (max-width:680px){
  .gallery{grid-template-columns:repeat(2,1fr);gap:10px}
}

/* Featured photo card in svc-card */
.svc-card .img.has-photo{
  background:#0a0a0a;
  padding:0;
}
.svc-card .img.has-photo img{
  width:100%;height:100%;object-fit:cover;display:block;
}
.svc-card .img.has-photo .tag{
  position:absolute;left:14px;bottom:14px;
  background:rgba(0,0,0,.72);color:#fff;border-color:transparent;
}

/* Mini animated visual for svc-card (when no photo) */
.svc-card .img.has-anim{
  background:#0a0a0a;
  border-bottom:none;
  overflow:hidden;
  position:relative;
  isolation:isolate;
}
.svc-card .img.has-anim::before{
  content:"";position:absolute;inset:-30%;
  background:
    radial-gradient(circle at 35% 35%, rgba(234,179,8,.45), transparent 50%),
    radial-gradient(circle at 70% 70%, rgba(21,128,61,.30), transparent 55%);
  filter:blur(36px);
  animation: anim-blob 14s ease-in-out infinite;
  z-index:0;
}
.svc-card .img.has-anim::after{
  content:"";position:absolute;inset:0;
  background:repeating-linear-gradient(135deg, rgba(255,255,255,.03) 0 1px, transparent 1px 24px);
  z-index:1;animation: anim-stripes 28s linear infinite;
}
.svc-card .img.has-anim .num{z-index:2;background:rgba(0,0,0,.65);color:#fff;border-color:rgba(255,255,255,.12)}
.svc-card .img.has-anim .anim-mini{
  position:absolute;inset:0;z-index:2;
  display:grid;place-items:center;text-align:center;padding:18px;
}
.svc-card .img.has-anim .anim-mini .big{
  font-size:clamp(1.2rem,2.4vw,1.7rem);font-weight:700;letter-spacing:-.02em;line-height:1.05;
  background:linear-gradient(120deg, #fff 0%, #fff 30%, #FDE68A 50%, #fff 70%, #fff 100%);
  background-size:200% 100%;
  -webkit-background-clip:text;background-clip:text;color:transparent;-webkit-text-fill-color:transparent;
  animation: anim-shimmer 6s linear infinite;
  max-width:90%;
}

/* ---------- Logo placement ---------- */
.brand-logo{
  display:block;
  height:auto;
  object-fit:contain;
}
/* Logo in hero card animated visual */
.hero-visual.has-anim .anim-text .brand-logo{
  width:clamp(180px, 38%, 280px);
  margin:0 auto 14px;
  filter:drop-shadow(0 6px 20px rgba(0,0,0,.45));
  animation: anim-rise .9s ease both;
}
/* Big logo (when replacing the heading text) */
.hero-visual.has-anim.is-logo-hero .anim-text .brand-logo{
  width:clamp(220px, 60%, 380px);
  margin:0 auto;
}
/* Small logo in service-card mini visual */
.svc-card .img.has-anim .anim-mini .brand-logo{
  width:clamp(70px, 30%, 110px);
  margin:0 auto 10px;
  filter:drop-shadow(0 4px 12px rgba(0,0,0,.5));
}

/* Reduce motion respect */
@media (prefers-reduced-motion:reduce){
  *{transition:none!important;animation:none!important}
  html{scroll-behavior:auto}
}


/* ===================================================================
   GCC site header + footer (matches greatchoiceconstructions.com)
   =================================================================== */
.gcc-utility{background:#274082;color:#fff;font-size:.82rem;padding:0;border:0}
.gcc-utility-inner{max-width:1240px;margin:0 auto;padding:10px 24px;display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap}
.gcc-utility a{color:#fff;text-decoration:none;display:inline-flex;align-items:center;gap:6px;transition:opacity .2s}
.gcc-utility a:hover{opacity:.85}
.gcc-utility-left{display:flex;gap:22px;flex-wrap:wrap;align-items:center}
.gcc-utility-right{display:flex;gap:14px;align-items:center}
.gcc-utility-right a svg{display:block}

.gcc-header{background:#fff;border-bottom:1px solid #e5e7eb;position:sticky;top:0;z-index:100;box-shadow:0 1px 8px rgba(0,0,0,.04)}
.gcc-header-inner{max-width:1240px;margin:0 auto;padding:12px 24px;display:flex;align-items:center;justify-content:space-between;gap:24px}
.gcc-logo{display:flex;align-items:center;flex-shrink:0}
.gcc-logo img{height:64px;width:auto;display:block}
.gcc-nav{display:flex;gap:6px;align-items:center;flex:1;justify-content:center}
.gcc-nav a{color:#274082;font-weight:500;font-size:.95rem;padding:10px 14px;border-radius:6px;text-decoration:none;transition:background .2s,color .2s;font-family:'Poppins','Inter',-apple-system,BlinkMacSystemFont,sans-serif}
.gcc-nav a:hover{background:#F0F5FA;color:#274082}
.gcc-cta{background:#274082;color:#fff !important;padding:13px 26px;border-radius:6px;font-weight:600;font-size:.92rem;text-decoration:none;white-space:nowrap;transition:background .2s,transform .2s;font-family:'Poppins','Inter',sans-serif;flex-shrink:0}
.gcc-cta:hover{background:#1e3470;transform:translateY(-1px)}
.gcc-burger{display:none;background:none;border:0;width:36px;height:36px;cursor:pointer;flex-direction:column;justify-content:center;align-items:center;gap:5px;padding:0}
.gcc-burger span{display:block;width:24px;height:2.5px;background:#274082;border-radius:2px;transition:transform .3s,opacity .3s}
.gcc-burger.open span:nth-child(1){transform:translateY(7.5px) rotate(45deg)}
.gcc-burger.open span:nth-child(2){opacity:0}
.gcc-burger.open span:nth-child(3){transform:translateY(-7.5px) rotate(-45deg)}

@media (max-width:921px){
  .gcc-utility-inner{padding:8px 16px;font-size:.76rem}
  .gcc-utility-left{gap:14px}
  .gcc-header-inner{padding:10px 16px;gap:12px}
  .gcc-logo img{height:48px}
  .gcc-cta{display:none}
  .gcc-burger{display:flex}
  .gcc-nav{position:absolute;top:100%;left:0;right:0;background:#fff;flex-direction:column;border-top:1px solid #e5e7eb;padding:8px 16px;gap:0;justify-content:flex-start;max-height:0;overflow:hidden;transition:max-height .35s ease;box-shadow:0 8px 20px -4px rgba(0,0,0,.08)}
  .gcc-nav.open{max-height:500px;padding:12px 16px}
  .gcc-nav a{padding:12px 8px;border-bottom:1px solid #f3f4f6;border-radius:0;width:100%}
  .gcc-nav a:last-child{border-bottom:0}
}

.gcc-footer{background:#274082;color:#fff;padding:60px 24px 0;font-family:'Poppins','Inter',-apple-system,BlinkMacSystemFont,sans-serif;margin-top:0}
.gcc-footer-inner{max-width:1240px;margin:0 auto;display:grid;grid-template-columns:1.4fr .8fr 1fr;gap:50px;padding-bottom:48px;border-bottom:1px solid rgba(255,255,255,.12)}
.gcc-footer-col h4{color:#fff;font-size:1rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;margin-bottom:18px}
.gcc-footer-col p{color:rgba(255,255,255,.85);font-size:.92rem;line-height:1.7;margin:0 0 18px;max-width:100%}
.gcc-footer-col ul{list-style:none;margin:0;padding:0}
.gcc-footer-col ul li{margin-bottom:10px;color:rgba(255,255,255,.85);font-size:.92rem;line-height:1.55}
.gcc-footer-col ul li a{color:rgba(255,255,255,.85);text-decoration:none;transition:color .2s}
.gcc-footer-col ul li a:hover{color:#fff}
.gcc-footer-contact li{display:flex;gap:8px;align-items:flex-start}
.gcc-footer-logo img{height:56px;width:auto;display:block;margin-bottom:18px;background:#fff;border-radius:6px;padding:4px}
.gcc-footer-social{display:flex;gap:10px;margin-top:8px}
.gcc-footer-social a{display:flex;align-items:center;justify-content:center;width:36px;height:36px;background:rgba(255,255,255,.1);border-radius:50%;color:#fff;transition:background .2s,transform .2s}
.gcc-footer-social a:hover{background:rgba(255,255,255,.2);transform:translateY(-2px)}
.gcc-footer-bottom{max-width:1240px;margin:0 auto;padding:20px 0;text-align:center}
.gcc-footer-bottom p{color:rgba(255,255,255,.65);font-size:.84rem;margin:0}
@media (max-width:921px){
  .gcc-footer-inner{grid-template-columns:1fr;gap:36px;padding-bottom:36px}
  .gcc-footer{padding:48px 16px 0}
}
