/* J Cubed Custom Inc — conversion-first local roofing site
   Brand: charcoal #161616 + copper #AC814D on warm white */
:root{
  --ink:#161616; --ink-2:#2a2826; --copper:#AC814D; --copper-2:#c2935b;
  --copper-dk:#8c7157; --paper:#faf8f7; --card:#ffffff; --line:#e7e2dd;
  --grey:#5f5d5a; --grey-2:#8a8884; --ok:#2e7d4f;
  --maxw:1140px; --r:14px; --shadow:0 6px 24px rgba(22,22,22,.08);
  --shadow-lg:0 18px 48px rgba(22,22,22,.16);
  --font:'Inter',system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--font);color:var(--ink);background:var(--paper);line-height:1.6;-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 22px}
h1,h2,h3{line-height:1.12;letter-spacing:-.02em;font-weight:800}
h1{font-size:clamp(2.1rem,5.2vw,3.5rem)}
h2{font-size:clamp(1.7rem,3.6vw,2.4rem)}
h3{font-size:1.18rem}
.eyebrow{font-size:.8rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--copper-dk)}
.muted{color:var(--grey)}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:.55rem;font-weight:700;font-size:1.02rem;
  padding:.95rem 1.5rem;border-radius:999px;border:2px solid transparent;transition:.18s;cursor:pointer;white-space:nowrap}
.btn-primary{background:var(--copper);color:#fff;box-shadow:0 8px 22px rgba(172,129,77,.35)}
.btn-primary:hover{background:var(--copper-2);transform:translateY(-1px)}
.btn-ghost{background:rgba(20,18,16,.30);color:#fff;border-color:rgba(255,255,255,.65);backdrop-filter:blur(2px)}
.btn-ghost:hover{border-color:#fff;background:rgba(20,18,16,.5)}
.btn-dark{background:var(--ink);color:#fff}
.btn-dark:hover{background:var(--ink-2)}

/* header */
header.site{position:sticky;top:0;z-index:50;background:rgba(250,248,247,.92);
  backdrop-filter:saturate(140%) blur(10px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.55rem 0}
.brand{display:flex;align-items:center;gap:.6rem}
.brand .mark{height:46px;width:auto;flex:none}
.brand-name{display:flex;flex-direction:column;line-height:1.05;font-weight:800;font-size:1.2rem;color:var(--ink);letter-spacing:-.01em;white-space:nowrap}
.brand-name small{font-weight:700;font-size:.6rem;letter-spacing:.17em;text-transform:uppercase;color:var(--copper-dk);margin-top:3px}
.brand-name.dark{color:#fff}.brand-name.dark small{color:var(--copper-2)}
.nav-links{display:flex;gap:1.4rem;font-weight:600;font-size:.97rem}
.nav-links a:hover{color:var(--copper-dk)}
.nav-cta{display:flex;align-items:center;gap:.8rem}
.phone-top{font-weight:800;font-size:1.06rem;color:var(--ink);display:flex;align-items:center;gap:.4rem}
.phone-top span{color:var(--copper-dk)}

/* hero */
.hero{position:relative;color:#fff;background:linear-gradient(180deg,rgba(15,15,15,.72),rgba(15,15,15,.82)),
  url('hero.jpg') center/cover no-repeat,var(--ink);padding:clamp(3.2rem,8vw,6rem) 0}
.hero .badges{display:flex;flex-wrap:wrap;gap:.6rem;margin-bottom:1.1rem}
.badge{display:inline-flex;align-items:center;gap:.4rem;font-size:.82rem;font-weight:700;
  background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.2);padding:.4rem .8rem;border-radius:999px}
.hero h1{max-width:16ch}
.hero p.sub{font-size:1.18rem;max-width:46ch;margin:1rem 0 1.8rem;color:#eee}
.hero-cta{display:flex;flex-wrap:wrap;gap:.9rem}
.stars{color:#f5b301;letter-spacing:1px}

/* trust strip */
.trust{background:var(--ink);color:#fff;padding:1rem 0}
.trust .wrap{display:flex;flex-wrap:wrap;justify-content:center;gap:1.4rem 2.4rem;text-align:center}
.trust .item{display:flex;align-items:center;gap:.5rem;font-weight:600;font-size:.95rem}
.trust .item b{color:var(--copper-2)}

/* sections */
section{padding:clamp(3rem,7vw,5rem) 0}
.section-head{text-align:center;max-width:60ch;margin:0 auto 2.4rem}
.section-head p{margin-top:.7rem;color:var(--grey)}

/* services grid */
.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.2rem}
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:1.5rem;
  box-shadow:var(--shadow);transition:.18s;display:flex;flex-direction:column;gap:.5rem}
.card:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg);border-color:var(--copper)}
.card .ico{width:44px;height:44px;border-radius:11px;background:linear-gradient(135deg,var(--copper),var(--copper-dk));
  display:grid;place-items:center;color:#fff;font-size:1.3rem;margin-bottom:.3rem}
.card h3{font-size:1.12rem}
.card .more{margin-top:auto;font-weight:700;color:var(--copper-dk);font-size:.95rem}

/* why us */
.why{background:#fff;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.why .grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}
.why .feat{display:flex;gap:.8rem;align-items:flex-start}
.why .feat .tick{flex:none;width:28px;height:28px;border-radius:50%;background:rgba(46,125,79,.12);
  color:var(--ok);display:grid;place-items:center;font-weight:800}

/* reviews */
.reviews{background:var(--paper)}
.review{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:1.5rem;box-shadow:var(--shadow)}
.review p{font-style:italic;color:var(--ink-2)}
.review .who{margin-top:.9rem;font-weight:700;font-size:.92rem;font-style:normal}

/* CTA band */
.cta-band{background:linear-gradient(135deg,var(--ink),#000);color:#fff;text-align:center}
.cta-band h2{color:#fff}
.cta-band p{color:#ccc;max-width:50ch;margin:.8rem auto 1.6rem}
.cta-band .hero-cta{justify-content:center}

/* service page layout */
.page-hero{background:linear-gradient(180deg,rgba(15,15,15,.78),rgba(15,15,15,.88)),url('hero-sub.jpg') center/cover no-repeat,var(--ink);color:#fff;padding:clamp(2.6rem,6vw,4.2rem) 0}

/* photo gallery grid */
.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:10px}
.gallery-grid img{width:100%;height:200px;object-fit:cover;border-radius:10px;border:1px solid var(--line)}
.workstrip{display:grid;grid-template-columns:repeat(6,1fr);gap:8px;margin-top:1.6rem}
.workstrip img{width:100%;height:130px;object-fit:cover;border-radius:8px}
@media(max-width:860px){.workstrip{grid-template-columns:repeat(3,1fr)}}
.crumbs{font-size:.85rem;color:#e7d9c5;margin-bottom:.9rem}
.crumbs a:hover{color:#fff;text-decoration:underline}
.layout{display:grid;grid-template-columns:1fr 320px;gap:2.4rem;align-items:start}
.prose h2{margin:2rem 0 .8rem}
.prose h3{margin:1.4rem 0 .5rem}
.prose p{margin:.7rem 0;color:var(--ink-2)}
.prose ul{margin:.6rem 0 1rem 1.2rem}
.prose li{margin:.35rem 0}
.aside{position:sticky;top:84px;background:#fff;border:1px solid var(--line);border-radius:var(--r);
  padding:1.5rem;box-shadow:var(--shadow)}
.aside h3{margin-bottom:.4rem}
.aside .phone{font-size:1.5rem;font-weight:800;color:var(--copper-dk);margin:.4rem 0 1rem;display:block}
.aside .btn{width:100%;justify-content:center;margin-bottom:.6rem}

/* footer */
footer.site{background:var(--ink);color:#cfcdca;padding:3rem 0 1.4rem;font-size:.93rem}
footer.site .cols{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:2rem;margin-bottom:2rem}
footer.site h4{color:#fff;font-size:1rem;margin-bottom:.8rem}
footer.site a:hover{color:#fff}
footer.site .brand-lock{display:flex;align-items:center;gap:.7rem;margin-bottom:1rem}
footer.site .fbrand .mark{height:52px;width:auto;flex:none}
footer.site ul{list-style:none;display:flex;flex-direction:column;gap:.45rem}
footer.site .legal{border-top:1px solid #333;padding-top:1.2rem;display:flex;justify-content:space-between;flex-wrap:wrap;gap:.6rem;color:var(--grey-2);font-size:.85rem}

/* svg icons */
.card .ico svg{width:24px;height:24px;stroke:#fff;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.feat .tick svg{width:15px;height:15px;stroke:var(--ok);fill:none;stroke-width:3}
.ilink svg,.phone-top svg,.btn svg{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;flex:none}
.stars svg{width:16px;height:16px;fill:#f5b301;stroke:none;vertical-align:-2px}

/* richer hero treatment */
.hero,.page-hero{position:relative;overflow:hidden}
.hero::before,.page-hero::before{content:"";position:absolute;inset:0;
  background:radial-gradient(1200px 480px at 78% -10%,rgba(172,129,77,.30),transparent 60%);pointer-events:none}
.hero .wrap,.page-hero .wrap{position:relative;z-index:1}

/* certifications row */
.certs{background:#fff;border-bottom:1px solid var(--line);padding:1.4rem 0}
.certs .wrap{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:1rem 1.6rem}
.cert-chip{display:inline-flex;align-items:center;gap:.5rem;font-weight:700;font-size:.9rem;color:var(--ink-2)}
.cert-chip .dot{width:9px;height:9px;border-radius:50%;background:var(--copper)}
.certs img{height:42px;width:auto}

/* inline text links */
.ilink{display:inline-flex;align-items:center;gap:.4rem;font-weight:700;color:var(--copper-dk)}
.ilink:hover{color:var(--copper)}

/* related services chips */
.related{display:flex;flex-wrap:wrap;gap:.6rem;margin-top:1.4rem}
.related a{font-size:.9rem;font-weight:600;padding:.5rem .9rem;border:1px solid var(--line);
  border-radius:999px;background:#fff;transition:.15s}
.related a:hover{border-color:var(--copper);color:var(--copper-dk)}

/* faq */
.faq details{background:#fff;border:1px solid var(--line);border-radius:12px;padding:.2rem 1.1rem;margin:.6rem 0}
.faq summary{font-weight:700;padding:.9rem 0;cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";color:var(--copper-dk);font-size:1.4rem;font-weight:400}
.faq details[open] summary::after{content:"–"}
.faq p{padding:0 0 1rem;color:var(--ink-2)}

/* mobile sticky call bar */
.callbar{display:none}
@media(max-width:860px){
  .nav-links{display:none}
  .phone-top .lbl{display:none}
  .layout{grid-template-columns:1fr}
  .aside{position:static}
  footer.site .cols{grid-template-columns:1fr 1fr}
  .callbar{display:flex;position:fixed;bottom:0;left:0;right:0;z-index:60;
    box-shadow:0 -6px 20px rgba(0,0,0,.18)}
  .callbar a{flex:1;text-align:center;padding:1rem;font-weight:800;color:#fff;display:flex;align-items:center;justify-content:center;gap:.5rem}
  .callbar .call{background:var(--copper)}
  .callbar .quote{background:var(--ink)}
  body{padding-bottom:60px}
}
@media(max-width:520px){footer.site .cols{grid-template-columns:1fr}}

/* ---- improvement pass ---- */
/* constrain footer + mobile call-bar icons (were rendering at default SVG size) */
footer.site a svg,.callbar a svg{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;flex:none;vertical-align:-3px}

/* keyboard focus visibility (WCAG 2.4.7) */
:focus-visible{outline:3px solid var(--copper);outline-offset:2px;border-radius:4px}
.btn:focus-visible{outline-offset:3px}

/* quote form */
.qform{display:flex;flex-direction:column;gap:.35rem;max-width:34rem}
.qform label{font-weight:700;font-size:.92rem;margin-top:.6rem}
.qform label .opt{font-weight:400;color:var(--grey-2)}
.qform input,.qform textarea{padding:.85rem;border:1px solid var(--line);border-radius:10px;font:inherit;background:#fff}
.qform input:focus,.qform textarea:focus{border-color:var(--copper);outline:none}
.qform button{margin-top:1rem}
.formnote{margin-top:.8rem;padding:.9rem 1rem;background:rgba(46,125,79,.1);border:1px solid rgba(46,125,79,.35);border-radius:10px;color:var(--ink-2);font-weight:600}
.formnote a{color:var(--copper-dk);font-weight:800}

/* truthful Google-rating panel */
.rev-panel{display:grid;grid-template-columns:300px 1fr;gap:2rem;align-items:center;background:#fff;border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--shadow);padding:2rem;max-width:900px;margin:0 auto}
.rev-score{text-align:center;display:flex;flex-direction:column;align-items:center;gap:.4rem;border-right:1px solid var(--line);padding-right:1.6rem}
.rev-score .big{font-size:3.4rem;font-weight:800;line-height:1;color:var(--ink)}
.rev-score .stars svg{width:22px;height:22px}
.rev-score .btn{margin-top:.6rem}
.rev-points{list-style:none;display:flex;flex-direction:column;gap:.7rem}
.rev-points li{display:flex;gap:.7rem;align-items:flex-start;font-weight:600;color:var(--ink-2)}
.rev-points .tick{flex:none;width:26px;height:26px;border-radius:50%;background:rgba(46,125,79,.12);color:var(--ok);display:grid;place-items:center}
.rev-points .tick svg{width:14px;height:14px;stroke:var(--ok);fill:none;stroke-width:3}
@media(max-width:680px){
  .rev-panel{grid-template-columns:1fr;gap:1.4rem;padding:1.6rem}
  .rev-score{border-right:none;border-bottom:1px solid var(--line);padding-right:0;padding-bottom:1.4rem}
}

/* mobile hamburger menu */
.m-menu{display:none}
@media(max-width:860px){
  .m-menu{display:block;position:relative}
  .m-menu summary{list-style:none;cursor:pointer;width:42px;height:42px;display:grid;place-items:center;border:1px solid var(--line);border-radius:10px;background:#fff}
  .m-menu summary::-webkit-details-marker{display:none}
  .m-menu summary svg{width:22px;height:22px;stroke:var(--ink);fill:none;stroke-width:2;stroke-linecap:round}
  .m-panel{position:absolute;right:0;top:calc(100% + 10px);min-width:220px;background:#fff;border:1px solid var(--line);border-radius:12px;box-shadow:var(--shadow-lg);padding:.4rem;z-index:70}
  .m-menu[open] .m-panel{display:flex;flex-direction:column}
  .m-panel a{padding:.75rem .9rem;border-radius:8px;font-weight:600;font-size:1rem}
  .m-panel a:last-child{color:var(--copper-dk);font-weight:800}
  .m-panel a:hover{background:var(--paper)}
  .nav-cta .btn-primary{display:none}        /* redundant with sticky bottom call-bar */
  .phone-top .pnum{display:none}             /* collapse wide number to an icon button */
  .phone-top{width:42px;height:42px;justify-content:center;border:1px solid var(--line);border-radius:10px;background:#fff;color:var(--copper-dk)}
  .phone-top svg{width:20px;height:20px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
}
@media(max-width:380px){.phone-top{font-size:.95rem}}
