*,*::before,*::after{border-radius:0 !important}   /* flat: no rounded corners anywhere */
:root{
  --ink:#1F2429;--ink-2:#3a4047;--line:#e6eaee;--bg:#f3f3f3;
  --accent:#1c6cb4;--accent-d:#155693;--muted:#6b7280;
  --link:#1c6cb4;--num:#6b7280;--surface:#fff;--container:1400px;
  --color-num-dark:#14181c;--color-surface:#fff;
  --border-soft:#f0f0f0;--border-line:#f2f4f6;
  --p-shingle:#b0573a;--p-slate:#3f5566;--p-cedar-shingle:#c08a3e;
  --p-cedar-shake:#6e4a2a;--p-tile:#e0822e;--p-standing-seam:#2e7d8f;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:"Inter",system-ui,-apple-system,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;color:var(--ink);background:var(--bg);line-height:1.6}
h1,h2,h3,h4,h5,h6{line-height:1.2;font-weight:200}
a{color:var(--accent-d);text-decoration:none}
a:hover{text-decoration:underline}

.topbar{height:56px;background:linear-gradient(135deg,#2a2f3d,#1f2330 55%,#181b25);color:#fff;display:flex;align-items:center;gap:18px;padding:0 20px;position:sticky;top:0;z-index:30}
.topbar a{color:#fff}
.brand{display:flex;align-items:center;gap:10px}
.brand .logo{height:30px;width:auto;display:block}
.brand .divider{width:1px;height:22px;background:rgba(255,255,255,.22)}
.wordmark{font-weight:800;letter-spacing:.16em;font-size:18px}
.sub{color:#aab2bd;font-weight:600;font-size:12px;letter-spacing:.14em;text-transform:uppercase}
.nav{margin-left:auto;display:flex;gap:18px;font-size:14px;font-weight:500}
.nav a:hover{color:#05ADED}

.wrap{max-width:1020px;margin:0 auto;padding:26px 20px 60px}
.crumbs{font-size:13px;color:var(--muted);margin:6px 0 18px}
.crumbs a{color:var(--muted)}
h1{font-size:40px;margin:.2em 0 .3em}
h2{font-size:26px;margin:1.5em 0 .6em;padding-bottom:6px;border-bottom:1px solid var(--line)}
.lede{font-size:17px;color:var(--ink-2);max-width:70ch}

.stats{display:flex;flex-wrap:wrap;gap:14px;margin:22px 0}
.stat{background:#fff;border:1px solid var(--line);border-radius:10px;padding:12px 16px;min-width:120px}
.stat .n{font-size:22px;font-weight:800;font-variant-numeric:tabular-nums}
.stat .l{font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.05em}

.bars{display:flex;flex-direction:column;gap:8px;max-width:560px}
.bar{display:grid;grid-template-columns:140px 1fr 52px;align-items:center;gap:10px;font-size:14px}
.bar .track{height:10px;background:#eceef1;border-radius:6px;overflow:hidden}
.bar .fill{display:block;height:100%;border-radius:6px}
.bar .v{text-align:right;color:var(--muted);font-variant-numeric:tabular-nums;font-size:13px}

.chips{display:flex;flex-wrap:wrap;gap:8px;margin:6px 0}
.chip{display:inline-flex;align-items:center;gap:6px;background:#fff;border:1px solid var(--line);border-radius:20px;padding:5px 12px;font-size:13px}
.chip .sw{width:11px;height:11px;border-radius:3px}

.cols{columns:220px;column-gap:26px;margin:8px 0}
.cols a{display:block;padding:3px 0;font-size:14px}
.cols .c{color:var(--muted);font-variant-numeric:tabular-nums}

.cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px;margin:10px 0}
.card{background:#fff;border:1px solid var(--line);border-radius:10px;padding:12px 14px}
.card .ttl{font-weight:600;font-size:14px}
.card .sub2{font-size:13px;color:var(--muted);margin-top:3px}
.card .tag{display:inline-block;font-size:11px;color:#fff;border-radius:20px;padding:2px 8px;margin-top:8px}
/* /profiles/ product showcase — 3 across × 2 rows, product photos, square corners */
.product-grid{grid-template-columns:repeat(3,1fr);gap:16px}
.product-grid .card{display:block;padding:0;border-radius:0;overflow:hidden;color:inherit;text-decoration:none;transition:border-color .15s,box-shadow .15s}
.product-grid .card:hover{border-color:var(--accent);box-shadow:0 6px 18px rgba(0,0,0,.10)}
.product-grid .pthumb{display:block;line-height:0;background:#f1efe8}
.product-grid .pthumb img{width:100%;height:184px;object-fit:cover;display:block;border-radius:0}
.product-grid .cbody{display:block;padding:13px 16px 16px}
.product-grid .ttl{display:block;font-weight:600;font-size:15px}
.product-grid .sub2{display:block;margin-top:6px;font-size:12.5px;line-height:1.5}
.product-grid .tag{border-radius:0;margin-top:10px}
@media(max-width:680px){.product-grid{grid-template-columns:1fr}}

.cta{display:inline-block;background:var(--accent-d);color:#fff;border-radius:8px;padding:11px 18px;font-weight:600;margin-top:8px}
.cta:hover{background:#854f1b;text-decoration:none}
.maplink{display:inline-block;margin:10px 0;font-weight:600}

.revs{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:14px;margin:10px 0}
.rev{margin:0;background:#fff;border:1px solid var(--line);border-left:3px solid var(--accent);border-radius:10px;padding:13px 15px}
.rev .stars{color:#e0a826;font-size:14px;letter-spacing:1px}
.rev p{margin:6px 0 8px;font-size:14px;line-height:1.5;color:var(--ink-2)}
.rev cite{font-style:normal;font-size:12.5px;color:var(--muted);display:block}
.rev-src{display:inline-flex;align-items:center;margin-top:9px;text-decoration:none}
.rev-src-txt{font-size:12.5px;color:var(--link)}
.rev-src-txt:hover{text-decoration:underline}
.gq-logo{height:20px;width:auto;display:block;opacity:.9}
.g-logo{height:18px;width:auto;display:block;opacity:.95}
.rev-src:hover .gq-logo,.rev-src:hover .g-logo{opacity:1}
/* Reviews block matched to the interlockroofing.com product pages (sky band + cards) */
.pr-reviews{background:#E9F2FB;padding:56px 0;margin:44px 0;box-shadow:0 0 0 100vmax #E9F2FB;clip-path:inset(0 -100vmax)}
.pr-reviews .pr-eyebrow{text-transform:uppercase;letter-spacing:.14em;font-size:.85rem;font-weight:600;color:#4DA3DE;margin:0 0 .9rem}
.pr-reviews .pr-h2{color:#1c6cb4;font-weight:500;font-size:clamp(1.5rem,2.6vw,2.1rem);line-height:1.3;margin:0 0 1.4rem;border:0;padding:0}
.pr-review{margin:0 0 22px;background:#fff;padding:30px 36px;box-shadow:0 2px 10px rgba(15,23,42,.06)}
.pr-review:last-child{margin-bottom:0}
.pr-review .rev-stars{font-size:1.05rem;line-height:1;letter-spacing:2px;margin:0 0 .9rem}
.rev-stars-full{color:#F5B301}
.rev-stars-empty{color:#C9D6E3}
.pr-review-text{color:#1F2429;margin:0 0 1.1rem;line-height:1.75;font-size:15.5px}
.pr-review footer{display:flex;flex-direction:column;gap:2px;font-size:.93rem;font-style:italic;background:none;color:#555;margin:0;padding:0}
.pr-review-author{color:#1F2429}
.pr-review-loc{color:#555}
.pr-review-source{font-style:normal;margin-top:10px}
@media(max-width:680px){.pr-reviews{padding:36px 0}.pr-review{padding:22px 20px}}
.phstrip{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px;margin:10px 0}
.ph{margin:0;background:#fff;border:1px solid var(--line);border-radius:10px;overflow:hidden}
.ph img{width:100%;height:165px;object-fit:cover;display:block;background:#eceef1}
.ph figcaption{padding:8px 11px;font-size:12.5px;color:var(--ink-2);line-height:1.4}
.ph{cursor:zoom-in;transition:border-color .15s,box-shadow .15s}
.ph:hover{border-color:var(--accent);box-shadow:0 6px 18px rgba(0,0,0,.12)}
.plb{position:fixed;inset:0;z-index:200;background:rgba(8,9,12,.92);display:flex;align-items:center;justify-content:center;padding:24px}
.plb[hidden]{display:none}
.plb figure{margin:0;max-width:92vw;max-height:90vh;display:flex;flex-direction:column;align-items:center}
.plb img{max-width:92vw;max-height:80vh;object-fit:contain;display:block;background:#15171a}
.plb figcaption{color:#cfd3da;font-size:13px;line-height:1.5;margin-top:12px;text-align:center;max-width:680px}
.plb-x{position:absolute;top:16px;right:20px;background:rgba(255,255,255,.14);color:#fff;border:0;width:42px;height:42px;font-size:24px;line-height:1;cursor:pointer}
.plb-x:hover{background:rgba(255,255,255,.26)}

/* ---- service-areas template — matches interlockroofing.com/service-areas exactly ---- */
.sa-wrap{max-width:var(--container);margin:0 auto;background:var(--surface);padding:40px 0 64px;overflow:hidden}
.sa-inner{max-width:1200px;margin:0 auto;padding:0 48px}
.sa-h1{font-size:40px;font-weight:200;line-height:1.2;color:var(--ink);margin:0 0 .35rem;padding:44px 0 24px}
.sa-intro{color:var(--ink);font-size:16px;line-height:1.7;margin:0 0 4px;max-width:none}
.sa-intro a{color:var(--link)}
.sa-filterbar{display:flex;flex-wrap:wrap;gap:.6rem;margin:1.25rem 0 1rem;background:var(--surface);border:1px solid var(--border-soft);padding:1rem;box-shadow:0 6px 16px rgba(0,0,0,.06)}
.sa-search{flex:2 1 220px;min-width:0}
.sa-search input{width:100%}
.sa-filterbar input,.sa-filterbar select{min-width:0;padding:.6rem .7rem;border:1px solid var(--border-soft);border-radius:0;font:inherit;font-size:14px;background:var(--surface);cursor:pointer;color:var(--ink)}
.sa-filterbar input[type=search]{cursor:text}
.sa-filterbar input:focus,.sa-filterbar select:focus{outline:none;border-color:#08adee}
.sa-select{flex:1 1 160px}
.sa-group{margin:2.5rem 0 0;border-top:1px solid #eef1f4;padding-top:1.25rem}
.sa-group>h2{margin:0 0 .75rem;font-size:32px;font-weight:200;line-height:1.2;border:0;padding:0;color:var(--ink)}
.sa-grid{list-style:none;padding:0;margin:0;display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:.4rem .75rem}
.sa-link{display:flex;justify-content:space-between;align-items:baseline;gap:.5rem;padding:.4rem .1rem;border-bottom:1px solid var(--border-line)}
.sa-link a{color:var(--link);text-decoration:none;font-size:.98rem}
.sa-link a:hover{text-decoration:underline}
.sa-count{color:var(--num);font-size:.85rem;font-variant-numeric:tabular-nums;flex:0 0 auto}
.sa-empty{color:var(--muted);font-size:14px;padding:10px 0}
.sa-updated{color:#5f6975;font-size:.8rem;margin-top:1.25rem;text-align:right}
@media(max-width:680px){.sa-wrap{padding:24px 0 48px}.sa-inner{padding:0 18px}.sa-h1{font-size:30px;padding:24px 0 16px}.sa-group>h2{font-size:26px}.sa-select{flex:1 1 45%}.sa-search{flex:1 1 100%}}

footer{background:linear-gradient(135deg,#2a2f3d,#1f2330 55%,#181b25);color:#c8ccd1;margin-top:40px}
footer .fwrap{max-width:1200px;margin:0 auto;padding:30px 20px;display:grid;grid-template-columns:repeat(3,1fr);column-gap:10%;row-gap:24px;font-size:14px}
footer h4{color:#fff;font-size:13px;text-transform:uppercase;letter-spacing:.06em;margin:0 0 10px}
footer .fwrap a{color:#c8ccd1;display:block;padding:2px 0}
footer .fwrap a:hover{color:#1c6cb4}
footer .legal{grid-column:1/-1;border-top:1px solid #33373c;padding-top:16px;font-size:12px;color:#8a9098}
@media(max-width:680px){footer .fwrap{grid-template-columns:1fr}h1{font-size:24px}}

/* ---- interlockroofing.com site footer (exact copy, scoped via data-astro-cid-sz7xmlte) ---- */
.site-footer[data-astro-cid-sz7xmlte]{background:var(--color-num-dark);color:#c7ced6;margin-top:0}
.inner[data-astro-cid-sz7xmlte]{max-width:1200px;margin:0 auto;padding:2.5rem 1.25rem}
.f-logo[data-astro-cid-sz7xmlte]{height:34px;margin-bottom:1.25rem}
.f-explore[data-astro-cid-sz7xmlte]{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:1.5rem 2.5rem;margin:0 0 2rem;padding-bottom:1.75rem;border-bottom:1px solid #232a31}
.f-col-h[data-astro-cid-sz7xmlte]{font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--color-surface);margin:0 0 .7rem}
.f-col[data-astro-cid-sz7xmlte] ul[data-astro-cid-sz7xmlte]{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.4rem}
.f-col[data-astro-cid-sz7xmlte] a[data-astro-cid-sz7xmlte]{color:#c7ced6;text-decoration:none;font-size:.9rem}
.f-col[data-astro-cid-sz7xmlte] a[data-astro-cid-sz7xmlte]:hover{color:var(--color-surface);text-decoration:underline}
.f-links[data-astro-cid-sz7xmlte]{list-style:none;padding:0;margin:0 0 1.25rem;display:flex;flex-wrap:wrap;gap:.4rem 1.25rem}
.f-links[data-astro-cid-sz7xmlte] a[data-astro-cid-sz7xmlte]{color:#c7ced6;text-decoration:none;font-size:.9rem}
.f-links[data-astro-cid-sz7xmlte] a[data-astro-cid-sz7xmlte]:hover{color:var(--color-surface);text-decoration:underline}
.f-social[data-astro-cid-sz7xmlte]{list-style:none;padding:0;margin:0 0 1.25rem;display:flex;flex-wrap:wrap;gap:.75rem 1.25rem}
.f-social[data-astro-cid-sz7xmlte] a[data-astro-cid-sz7xmlte]{color:var(--color-surface);text-decoration:none;font-size:.85rem;font-weight:600}
.f-social[data-astro-cid-sz7xmlte] a[data-astro-cid-sz7xmlte]:hover{color:#c8102e}
.copy[data-astro-cid-sz7xmlte]{font-size:.8rem;color:#8a949e;line-height:1.6;border-top:1px solid #232a31;padding-top:1.25rem;margin:0}
@media(max-width:700px){.f-explore[data-astro-cid-sz7xmlte]{grid-template-columns:1fr 1fr}}
@media(max-width:440px){.f-explore[data-astro-cid-sz7xmlte]{grid-template-columns:1fr}}
/* FAQ (AEO) + visible aggregate rating */
.agg{display:inline-block;margin:.4rem 0 .2rem;font-weight:600;color:#0d2233}
.faq{margin-top:2rem}
.faq .faq-q{border-top:1px solid #e6ecf1;padding:.85rem 0}
.faq .faq-q h3{margin:0 0 .25rem;font-size:1rem;color:#0d2233}
.faq .faq-q p{margin:0;color:#3a4a55;line-height:1.5}

/* a11y: skip link, hidden labels, focus, reduced motion */
.skip-link{position:absolute;left:8px;top:-48px;z-index:2147483600;background:#0d2233;color:#fff;padding:10px 14px;border-radius:8px;text-decoration:none}
.skip-link:focus{top:8px}
.visually-hidden{position:absolute!important;width:1px;height:1px;margin:-1px;padding:0;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0}
:focus-visible{outline:3px solid #1b72e7;outline-offset:2px}
@media (prefers-reduced-motion: reduce){*,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto!important}}
