/* lantern-roof.com — single external stylesheet (cached across all pages) */
:root{
  --ink:#16212B; --ink-soft:#2A3947; --sky:#2E7FB0; --sky-light:#6FB3D8;
  --sun:#E8B04B; --paper:#F6F8FA; --line:#D8E0E6; --white:#fff;
  --grad:linear-gradient(90deg,var(--sky-light),var(--sun));
  --disp:'Sora',system-ui,sans-serif; --body:'Lora',Georgia,serif;
  --rad:10px; --shadow:0 8px 30px rgba(22,33,43,.10);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--body);font-size:1.06rem;line-height:1.7;color:var(--ink);background:var(--white)}
img,svg{max-width:100%;height:auto;display:block}
a{color:var(--sky);text-decoration:none}
a:hover{text-decoration:underline}
h1,h2,h3,h4{font-family:var(--disp);line-height:1.22;color:var(--ink);font-weight:700;letter-spacing:-.01em}
h1{font-size:clamp(1.7rem,4.6vw,2.7rem)}
h2{font-size:clamp(1.35rem,3.2vw,1.9rem);margin-bottom:.7rem}
h3{font-size:1.13rem;margin-bottom:.4rem}
p{margin-bottom:1rem}
.wrap{max-width:1140px;margin:0 auto;padding:0 1.1rem}
.sec{padding:3.2rem 0}
.sec-alt{background:var(--paper)}
.center{text-align:center}
.lead{font-size:1.13rem;color:var(--ink-soft)}
:focus-visible{outline:3px solid var(--sun);outline-offset:2px}
@media (prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}}

/* signature: the glazing bar */
.bar{height:4px;background:var(--grad);border-radius:2px;width:84px;margin:.85rem 0 1.1rem}
.center .bar{margin-left:auto;margin-right:auto}

/* header */
.top{background:var(--white);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:50}
.top-in{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.65rem 1.1rem;max-width:1280px;margin:0 auto}
.logo{display:flex;align-items:center;gap:.55rem;font-family:var(--disp);font-weight:700;font-size:1.14rem;color:var(--ink);letter-spacing:.01em}
.logo:hover{text-decoration:none}
.logo svg{width:34px;height:34px;flex:none}
nav.main{display:flex;gap:1.15rem;align-items:center;flex-wrap:wrap}
nav.main a{font-family:var(--disp);font-weight:600;font-size:.93rem;color:var(--ink-soft)}
nav.main a:hover{color:var(--sky);text-decoration:none}
.call{display:flex;align-items:center;gap:.8rem}
.call-num{font-family:var(--disp);font-weight:700;color:var(--ink);font-size:1.02rem;white-space:nowrap}
.btn{display:inline-block;font-family:var(--disp);font-weight:600;font-size:.97rem;padding:.72rem 1.35rem;border-radius:var(--rad);text-align:center;border:2px solid transparent;cursor:pointer}
.btn:hover{text-decoration:none;opacity:.92}
.btn-sun{background:var(--sun);color:var(--ink)}
.btn-ink{background:var(--ink);color:#fff}
.btn-line{border-color:var(--ink);color:var(--ink);background:transparent}
.btn-wa{background:#25D366;color:#fff}
@media(max-width:900px){nav.main{display:none}.call-num{display:none}}

/* hero */
.hero{background:linear-gradient(180deg,var(--ink) 0%,#1D2C3A 100%);color:#EAF1F6;position:relative;overflow:hidden}
.hero::after{content:"";position:absolute;left:0;right:0;bottom:0;height:5px;background:var(--grad)}
.hero-in{display:grid;grid-template-columns:1.15fr .85fr;gap:2.4rem;align-items:center;padding:3.4rem 0}
.hero h1{color:#fff}
.hero .lead{color:#C9D8E2}
.crumbs{font-family:var(--disp);font-size:.8rem;margin-bottom:1rem;color:#9FB6C6}
.crumbs a{color:#C9D8E2}
.hero-ctas{display:flex;gap:.8rem;flex-wrap:wrap;margin:1.3rem 0 .7rem}
.risk{font-family:var(--disp);font-size:.86rem;color:var(--sun);font-weight:600}
.hero-art{filter:drop-shadow(0 18px 40px rgba(0,0,0,.35))}
@media(max-width:820px){.hero-in{grid-template-columns:1fr;padding:2.4rem 0}.hero-art{max-width:380px;margin:0 auto}}

/* trust strip */
.trust{background:var(--white);border-bottom:1px solid var(--line)}
.trust-in{display:grid;grid-template-columns:repeat(5,1fr);gap:.6rem;padding:.95rem 0}
.trust b{display:flex;align-items:center;justify-content:center;gap:.45rem;font-family:var(--disp);font-size:.8rem;font-weight:600;color:var(--ink-soft);text-align:center}
.trust svg{width:17px;height:17px;flex:none;color:var(--sky)}
@media(max-width:820px){.trust-in{grid-template-columns:repeat(2,1fr)}.trust b:last-child{grid-column:1/-1}}

/* cards & grids */
.grid{display:grid;gap:1.15rem}
.g3{grid-template-columns:repeat(3,1fr)}
.g4{grid-template-columns:repeat(4,1fr)}
@media(max-width:920px){.g3,.g4{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.g3,.g4{grid-template-columns:1fr}}
.card{background:var(--white);border:1px solid var(--line);border-radius:var(--rad);padding:1.35rem;box-shadow:var(--shadow);position:relative}
.card::before{content:"";position:absolute;top:0;left:1.35rem;right:1.35rem;height:3px;background:var(--grad);border-radius:0 0 3px 3px;opacity:0;transition:opacity .2s}
.card:hover::before{opacity:1}
.card h3 a{color:var(--ink)}
.card p{font-size:.96rem;color:var(--ink-soft);margin-bottom:.6rem}
.card .more{font-family:var(--disp);font-weight:600;font-size:.88rem}

/* features */
.feat{display:grid;grid-template-columns:repeat(2,1fr);gap:.55rem .9rem;margin:1rem 0}
.feat li{list-style:none;display:flex;gap:.5rem;align-items:flex-start;font-size:.97rem}
.feat svg{width:18px;height:18px;flex:none;margin-top:.22rem;color:var(--sky)}
@media(max-width:640px){.feat{grid-template-columns:1fr}}

/* link pills (towns/counties/services) */
.pills{display:flex;flex-wrap:wrap;gap:.5rem}
.pills a{font-family:var(--disp);font-size:.86rem;font-weight:600;color:var(--ink-soft);background:var(--paper);border:1px solid var(--line);padding:.42rem .8rem;border-radius:999px}
.pills a:hover{border-color:var(--sky);color:var(--sky);text-decoration:none}

/* shop */
.shop-card{display:flex;flex-direction:column;gap:.45rem}
.size{font-family:var(--disp);font-weight:700;font-size:1.25rem}
.price{font-family:var(--disp);font-weight:700;color:var(--sky);font-size:1.12rem}
.price small{font-weight:600;color:var(--ink-soft);font-size:.78rem}
.tbc{font-family:var(--disp);font-size:.88rem;color:var(--ink-soft);background:var(--paper);border:1px dashed var(--line);border-radius:8px;padding:.5rem .7rem}
table.spec{width:100%;border-collapse:collapse;margin:1rem 0;font-size:.97rem}
table.spec th,table.spec td{text-align:left;padding:.6rem .7rem;border-bottom:1px solid var(--line);vertical-align:top}
table.spec th{font-family:var(--disp);font-size:.84rem;width:38%;color:var(--ink-soft)}
.note{background:var(--paper);border-left:4px solid var(--sun);padding:.85rem 1rem;border-radius:0 8px 8px 0;font-size:.95rem;margin:1rem 0}

/* FAQ */
details{border:1px solid var(--line);border-radius:var(--rad);margin-bottom:.7rem;background:var(--white)}
summary{cursor:pointer;padding:.95rem 1.1rem;font-family:var(--disp);font-weight:600;font-size:.99rem;list-style:none;display:flex;justify-content:space-between;gap:.8rem;align-items:center}
summary::-webkit-details-marker{display:none}
summary::after{content:"+";font-size:1.25rem;color:var(--sky);flex:none}
details[open] summary::after{content:"\2212"}
details div{padding:0 1.1rem 1rem;font-size:.98rem;color:var(--ink-soft)}

/* form */
.formbox{background:var(--white);border:1px solid var(--line);border-radius:var(--rad);padding:1.6rem;box-shadow:var(--shadow)}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:.85rem;margin-bottom:.85rem}
@media(max-width:640px){.frow{grid-template-columns:1fr}}
label{font-family:var(--disp);font-size:.83rem;font-weight:600;display:block;margin-bottom:.3rem;color:var(--ink-soft)}
input,select,textarea{width:100%;padding:.7rem .8rem;border:1px solid var(--line);border-radius:8px;font-family:var(--body);font-size:1rem;background:var(--white);color:var(--ink)}
input:focus,select:focus,textarea:focus{outline:2px solid var(--sky);border-color:var(--sky)}
.steps{counter-reset:s;display:grid;gap:1rem;margin:1.2rem 0}
.steps li{list-style:none;display:flex;gap:.9rem;align-items:flex-start}
.steps li::before{counter-increment:s;content:counter(s);font-family:var(--disp);font-weight:700;background:var(--grad);color:var(--ink);width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex:none;font-size:.92rem}

/* footer */
footer{background:var(--ink);color:#B9C9D5;font-size:.94rem;margin-top:3rem;padding-bottom:4.2rem}
footer .bar-top{height:5px;background:var(--grad)}
.foot-in{display:grid;grid-template-columns:1.2fr 1fr 1fr 1.1fr;gap:2rem;padding:2.6rem 0 1.6rem}
footer h4{color:#fff;font-size:.95rem;margin-bottom:.7rem}
footer a{color:#B9C9D5}
footer a:hover{color:var(--sun)}
footer ul{list-style:none}
footer li{margin-bottom:.45rem}
.foot-base{border-top:1px solid #2A3947;padding:1rem 0;font-size:.83rem;display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap}
@media(max-width:880px){.foot-in{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.foot-in{grid-template-columns:1fr}}

/* sticky mobile bar */
.sticky{position:fixed;bottom:0;left:0;right:0;display:none;z-index:60;box-shadow:0 -6px 20px rgba(0,0,0,.18)}
.sticky a{flex:1;text-align:center;font-family:var(--disp);font-weight:700;font-size:.97rem;padding:.95rem .5rem;color:#fff}
.sticky a:hover{text-decoration:none}
.sticky .s-call{background:var(--sky)}
.sticky .s-quote{background:var(--ink)}
@media(max-width:820px){.sticky{display:flex}}

/* misc */
.two{display:grid;grid-template-columns:1fr 1fr;gap:2.2rem;align-items:start}
@media(max-width:860px){.two{grid-template-columns:1fr}}
.kicker{font-family:var(--disp);font-size:.8rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--sky);margin-bottom:.45rem}
.cta-band{background:var(--ink);color:#EAF1F6;border-radius:var(--rad);padding:2rem;display:flex;justify-content:space-between;align-items:center;gap:1.4rem;flex-wrap:wrap;position:relative;overflow:hidden}
.cta-band::before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:var(--grad)}
.cta-band h2{color:#fff;margin:0}
.cta-band p{color:#C9D8E2;margin:0}
