/* SolarCancellation.com — shared styles
   Premium navy / gold / white legal-marketing system.
   Used by the homepage, utility pages, and every resource-library article. */

:root{
  --navy:#0a1f3c;        /* deep brand navy */
  --navy-2:#102a4f;      /* lifted navy for gradients */
  --navy-3:#163566;      /* hover navy */
  --ink:#0c1c33;         /* body text on light */
  --muted:#54657f;       /* secondary text */
  --muted-2:#6f7f96;
  --line:#dbe3ef;        /* hairline borders */
  --bg:#f3f6fc;          /* page background */
  --surface:#ffffff;
  --surface-2:#f6f9ff;
  --gold:#c8a23c;        /* primary gold accent */
  --gold-d:#a9851f;      /* darker gold for hover/contrast */
  --gold-soft:#f3e6c0;
  --ok:#0f7a55;
  --radius:14px;
  --radius-lg:20px;
  --max:1120px;
  --serif:"Iowan Old Style","Palatino Linotype",Palatino,"Book Antiqua",Georgia,"Times New Roman",serif;
  --sans:ui-sans-serif,system-ui,-apple-system,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:var(--sans);color:var(--ink);background:var(--bg);line-height:1.6;-webkit-font-smoothing:antialiased}
a{color:var(--navy-3)}
img{max-width:100%}
.wrap{max-width:var(--max);margin:auto;padding:0 22px}
.serif{font-family:var(--serif)}

/* ---------- Header / nav ---------- */
.topbar{position:sticky;top:0;z-index:60;background:rgba(255,255,255,.92);backdrop-filter:saturate(140%) blur(8px);border-bottom:1px solid var(--line)}
.nav{min-height:72px;display:flex;justify-content:space-between;align-items:center;gap:18px}
.brand{display:flex;gap:12px;align-items:center;text-decoration:none;color:var(--navy);font-weight:800;letter-spacing:-.01em;line-height:1.1}
.mark{width:42px;height:42px;border-radius:11px;background:linear-gradient(150deg,var(--navy),var(--navy-3));display:grid;place-items:center;color:var(--gold);font-weight:900;font-size:17px;border:1px solid rgba(200,162,60,.5);box-shadow:inset 0 0 0 1px rgba(255,255,255,.06)}
.brand b{font-size:17px}
.brand small{display:block;color:var(--muted);text-transform:uppercase;letter-spacing:.13em;font-size:9.5px;font-weight:700;margin-top:2px}
.navlinks{display:flex;gap:24px;align-items:center;color:var(--ink);font-size:14.5px;font-weight:600}
.navlinks a{text-decoration:none;color:var(--ink);opacity:.82;transition:opacity .15s}
.navlinks a:hover{opacity:1}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;min-height:50px;padding:13px 24px;border-radius:11px;border:1px solid transparent;background:var(--gold);color:var(--navy);text-decoration:none;font-weight:800;font-size:15px;letter-spacing:.01em;cursor:pointer;transition:transform .12s,background .15s,box-shadow .15s;box-shadow:0 8px 22px rgba(200,162,60,.28)}
.btn:hover,.btn:focus{background:var(--gold-d);color:#fff;transform:translateY(-1px);outline:none}
.btn:focus-visible{outline:3px solid rgba(200,162,60,.45);outline-offset:2px}
.btn.line{background:#fff;color:var(--navy);border-color:var(--line);box-shadow:none}
.btn.line:hover{background:var(--surface-2);color:var(--navy);border-color:#c6d3e6}
.btn.ghost{background:rgba(255,255,255,.10);color:#fff;border-color:rgba(255,255,255,.42);box-shadow:none}
.btn.ghost:hover{background:rgba(255,255,255,.20);color:#fff}
.btn.sm{min-height:42px;padding:9px 16px;font-size:14px}

/* ---------- Hero ---------- */
.hero{position:relative;overflow:hidden;background:linear-gradient(165deg,#081a33 0%,#0f2950 55%,#163b71 100%);color:#fff;padding:74px 0 132px}
.hero:after{content:"";position:absolute;inset:0;pointer-events:none;background:radial-gradient(circle at 82% -8%,rgba(200,162,60,.28),transparent 42%),radial-gradient(circle at -6% 116%,rgba(53,118,201,.30),transparent 44%)}
.hero .wrap{position:relative;text-align:center}
.eyebrow{display:inline-flex;align-items:center;gap:9px;padding:7px 15px;border:1px solid rgba(200,162,60,.45);border-radius:999px;font-size:12.5px;font-weight:700;letter-spacing:.04em;color:var(--gold-soft);background:rgba(200,162,60,.10);text-transform:uppercase}
.hero h1{font-family:var(--serif);font-weight:700;font-size:clamp(34px,5.4vw,60px);line-height:1.06;letter-spacing:-.015em;margin:20px auto 16px;max-width:20ch}
.hero .lede{font-size:clamp(17px,2vw,21px);color:rgba(255,255,255,.85);max-width:64ch;margin:0 auto}
.hero-actions{display:flex;flex-wrap:wrap;gap:13px;justify-content:center;margin-top:30px}
.trust{display:flex;flex-wrap:wrap;gap:11px 30px;justify-content:center;margin-top:34px;color:rgba(255,255,255,.82);font-size:13.5px;font-weight:600}
.trust span{display:inline-flex;align-items:center;gap:8px}
.trust svg{flex:none;color:var(--gold)}

/* ---------- Lead form card ---------- */
.formwrap{margin-top:-92px;position:relative;z-index:5}
.form-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);box-shadow:0 30px 70px rgba(8,26,51,.20);padding:30px;max-width:680px;margin:0 auto}
.form-card h2{font-family:var(--serif);font-size:26px;letter-spacing:-.01em;margin:0 0 5px}
.form-card .sub{color:var(--muted);margin:0 0 20px;font-size:14.5px}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:15px}
.full{grid-column:1/-1}
label{display:block;font-size:12.5px;font-weight:700;margin:0 0 6px;color:#33455e;letter-spacing:.01em}
input,select{width:100%;min-height:50px;padding:13px 14px;border:1px solid #c4d1e6;border-radius:10px;background:#fff;color:var(--ink);font:inherit}
input::placeholder{color:#9aa9bd}
input:focus,select:focus{outline:3px solid rgba(22,53,102,.16);border-color:var(--navy-3)}
.form-card .btn{width:100%;margin-top:20px}
.fine{font-size:11.5px;color:var(--muted);margin-top:13px;line-height:1.55}

/* ---------- Sections ---------- */
section{padding:62px 0}
.section-head{max-width:62ch;margin:0 auto 34px;text-align:center}
.section-head .kicker{color:var(--gold-d);font-weight:800;font-size:13px;letter-spacing:.14em;text-transform:uppercase;display:block;margin-bottom:10px}
.section-head h2{font-family:var(--serif);font-weight:700;font-size:clamp(27px,3.6vw,42px);letter-spacing:-.015em;line-height:1.1;margin:0 0 12px}
.section-head p{color:var(--muted);font-size:17px;margin:0}
.alt{background:linear-gradient(180deg,#fff,var(--surface-2))}

/* ---------- Process flow ---------- */
.flow{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;counter-reset:s}
.flow .node{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:26px 22px;position:relative;overflow:hidden}
.flow .node:before{content:"";position:absolute;left:0;top:0;height:4px;width:100%;background:linear-gradient(90deg,var(--gold),var(--navy-3))}
.flow .node .dot{counter-increment:s;width:38px;height:38px;border-radius:50%;background:var(--navy);color:var(--gold);display:grid;place-items:center;font-weight:800;margin-bottom:15px;border:1px solid rgba(200,162,60,.4)}
.flow .node .dot:before{content:counter(s)}
.flow .node b{display:block;font-size:17px;margin-bottom:7px}
.flow .node p{color:var(--muted);margin:0;font-size:14.5px}

/* ---------- Situation / tile grids ---------- */
.grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.tile{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:24px;transition:transform .12s,box-shadow .15s,border-color .15s}
.tile .ico{width:44px;height:44px;border-radius:11px;background:var(--surface-2);border:1px solid var(--line);display:grid;place-items:center;color:var(--gold-d);margin-bottom:14px}
.tile h3{font-size:17px;margin:0 0 7px;letter-spacing:-.01em}
.tile p{color:var(--muted);margin:0;font-size:14.5px}
a.tile{text-decoration:none;color:inherit;display:block}
a.tile:hover{transform:translateY(-3px);box-shadow:0 16px 36px rgba(8,26,51,.10);border-color:#c6d3e6}
a.tile .more{display:inline-block;margin-top:12px;color:var(--gold-d);font-weight:800;font-size:13.5px}

/* ---------- Resource hub ---------- */
.hub{display:grid;grid-template-columns:repeat(2,1fr);gap:26px}
.hub-group{background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);padding:26px}
.hub-group h3{font-family:var(--serif);font-size:20px;margin:0 0 4px;display:flex;align-items:center;gap:10px}
.hub-group .gl{color:var(--muted);font-size:13.5px;margin:0 0 16px}
.hub-group .pill{font-size:10.5px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:var(--gold-d);background:var(--gold-soft);border-radius:999px;padding:3px 9px}
.hub-list{list-style:none;margin:0;padding:0;display:grid;gap:2px}
.hub-list a{display:flex;align-items:center;justify-content:space-between;gap:12px;text-decoration:none;color:var(--ink);font-weight:600;font-size:15px;padding:11px 12px;border-radius:9px;transition:background .12s}
.hub-list a:hover{background:var(--surface-2)}
.hub-list a span.desc{display:block;font-weight:500;color:var(--muted);font-size:12.5px;margin-top:2px}
.hub-list a .arr{color:var(--gold-d);font-weight:800;flex:none}

/* ---------- CTA band ---------- */
.cta-band{background:linear-gradient(125deg,var(--navy),var(--navy-3));color:#fff;border-radius:var(--radius-lg);padding:46px;text-align:center;position:relative;overflow:hidden}
.cta-band:after{content:"";position:absolute;inset:0;pointer-events:none;background:radial-gradient(circle at 88% -20%,rgba(200,162,60,.25),transparent 45%)}
.cta-band .wrap2{position:relative}
.cta-band h2{font-family:var(--serif);font-weight:700;font-size:clamp(25px,3.4vw,38px);letter-spacing:-.01em;margin:0 0 10px}
.cta-band p{margin:0 auto 22px;color:rgba(255,255,255,.85);max-width:60ch}

/* ---------- FAQ ---------- */
.faqlist{max-width:780px;margin:0 auto;display:grid;gap:12px}
.faqlist details{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:18px 22px;transition:box-shadow .15s}
.faqlist details[open]{box-shadow:0 12px 30px rgba(8,26,51,.07)}
.faqlist summary{font-weight:700;cursor:pointer;list-style:none;display:flex;justify-content:space-between;gap:14px;align-items:center}
.faqlist summary::-webkit-details-marker{display:none}
.faqlist summary:after{content:"+";color:var(--gold-d);font-weight:800;font-size:20px;flex:none}
.faqlist details[open] summary:after{content:"–"}
.faqlist p{color:var(--muted);margin:12px 0 0;font-size:14.5px}

/* ---------- Notices ---------- */
.notice{max-width:820px;margin:24px auto 0;background:#fbf7ea;border:1px solid var(--gold-soft);color:#5a4a1f;border-radius:var(--radius);padding:17px 20px;font-size:13px;line-height:1.65}
.notice b{color:var(--gold-d)}

/* ---------- Article / content pages ---------- */
.page-hero{position:relative;overflow:hidden;background:linear-gradient(165deg,#081a33,#11305c);color:#fff;padding:58px 0 64px}
.page-hero:after{content:"";position:absolute;inset:0;pointer-events:none;background:radial-gradient(circle at 88% -20%,rgba(200,162,60,.22),transparent 44%)}
.page-hero .wrap{position:relative}
.crumbs{font-size:13px;color:rgba(255,255,255,.7);margin-bottom:16px}
.crumbs a{color:rgba(255,255,255,.85);text-decoration:none}
.crumbs a:hover{text-decoration:underline}
.page-hero .cat{color:var(--gold);font-weight:800;font-size:12.5px;letter-spacing:.14em;text-transform:uppercase}
.page-hero h1{font-family:var(--serif);font-weight:700;font-size:clamp(30px,4.6vw,48px);line-height:1.07;letter-spacing:-.015em;margin:12px 0 14px;max-width:22ch}
.page-hero .lede{font-size:clamp(16px,1.9vw,20px);color:rgba(255,255,255,.85);max-width:66ch;margin:0}

.layout{display:grid;grid-template-columns:minmax(0,1fr) 320px;gap:44px;align-items:start;padding:54px 0}
.article{max-width:none}
.article h2{font-family:var(--serif);font-weight:700;font-size:clamp(23px,2.8vw,31px);letter-spacing:-.01em;line-height:1.16;margin:40px 0 14px}
.article h2:first-child{margin-top:0}
.article h3{font-size:19px;margin:28px 0 9px;letter-spacing:-.01em}
.article p{color:#2c3c54;font-size:16.5px;margin:0 0 16px}
.article ul,.article ol{color:#2c3c54;font-size:16.5px;margin:0 0 18px;padding-left:22px}
.article li{margin:0 0 9px}
.article strong{color:var(--ink)}
.article .lead-para{font-size:18.5px;color:#243349}
.callout{background:var(--surface-2);border:1px solid var(--line);border-left:4px solid var(--gold);border-radius:var(--radius);padding:20px 22px;margin:24px 0}
.callout h4{margin:0 0 7px;font-size:15px;color:var(--navy)}
.callout p{margin:0;font-size:14.5px;color:var(--muted)}
.checklist{list-style:none;padding:0;margin:0 0 18px}
.checklist li{position:relative;padding-left:30px;margin:0 0 11px;font-size:16px;color:#2c3c54}
.checklist li:before{content:"";position:absolute;left:0;top:4px;width:18px;height:18px;border-radius:5px;background:var(--gold-soft);border:1px solid var(--gold)}
.checklist li:after{content:"✓";position:absolute;left:4px;top:2px;color:var(--gold-d);font-weight:900;font-size:12px}

/* sidebar */
.sidebar{position:sticky;top:96px;display:grid;gap:20px}
.side-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:22px}
.side-card.cta{background:linear-gradient(160deg,var(--navy),var(--navy-3));color:#fff;border-color:transparent}
.side-card.cta h3{font-family:var(--serif);font-size:20px;margin:0 0 8px}
.side-card.cta p{color:rgba(255,255,255,.82);font-size:13.5px;margin:0 0 16px}
.side-card.cta .btn{width:100%}
.side-card h3{font-size:15px;margin:0 0 12px;letter-spacing:.01em}
.side-links{list-style:none;margin:0;padding:0;display:grid;gap:1px}
.side-links a{display:block;text-decoration:none;color:var(--ink);font-weight:600;font-size:14px;padding:9px 10px;border-radius:8px;transition:background .12s}
.side-links a:hover{background:var(--surface-2)}
.side-links a.current{background:var(--surface-2);color:var(--gold-d)}

/* related */
.related{border-top:1px solid var(--line);padding:50px 0}
.related .grid3{margin-top:6px}

/* ---------- Utility (privacy/terms/thank-you) ---------- */
.simple-hero{padding:54px 0 10px}
.simple-hero .tag{display:inline-flex;padding:7px 15px;border:1px solid var(--line);border-radius:999px;font-size:12.5px;font-weight:700;color:var(--gold-d);background:#fff}
.simple-hero h1{font-family:var(--serif);font-weight:700;font-size:clamp(30px,5vw,46px);letter-spacing:-.015em;line-height:1.07;margin:16px 0 12px}
.simple-hero .lede{font-size:18px;color:var(--muted);max-width:66ch;margin:0}
.prose{max-width:820px;margin:0 auto;padding:10px 0 20px}
.prose h2{font-family:var(--serif);font-size:24px;margin:34px 0 10px;letter-spacing:-.01em}
.prose p{color:#2c3c54;font-size:16px;margin:0 0 14px}
.prose ul{color:#2c3c54;font-size:16px;margin:0 0 16px;padding-left:22px}
.prose li{margin:0 0 8px}

/* thank-you */
.ty-hero{padding:72px 0 40px;text-align:center}
.check{width:70px;height:70px;border-radius:50%;background:linear-gradient(150deg,var(--gold),var(--gold-d));display:grid;place-items:center;margin:0 auto 20px;color:#fff;font-size:32px;font-weight:900;box-shadow:0 14px 34px rgba(200,162,60,.4)}
.ty-hero h1{font-family:var(--serif);font-weight:700;font-size:clamp(28px,4.6vw,44px);letter-spacing:-.015em;line-height:1.08;margin:14px 0 12px}
.ty-hero .lede{font-size:18px;color:var(--muted);max-width:60ch;margin:0 auto}
.ty-actions{display:flex;gap:13px;justify-content:center;flex-wrap:wrap;margin-top:28px}
.next-steps{max-width:680px;margin:34px auto 0;text-align:left;display:grid;gap:12px}
.next-steps .step{display:flex;gap:14px;align-items:flex-start;background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:16px 18px}
.next-steps .n{flex:none;width:30px;height:30px;border-radius:50%;background:var(--navy);color:var(--gold);display:grid;place-items:center;font-weight:800;font-size:14px}
.next-steps .step b{display:block;font-size:15px}
.next-steps .step p{margin:3px 0 0;color:var(--muted);font-size:14px}

/* ---------- Footer ---------- */
footer{background:var(--navy);color:#9fb4d0;padding:48px 0 36px;font-size:13.5px}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr;gap:30px;align-items:start}
.footer-brand .brand{color:#fff}
.footer-brand .brand b{color:#fff}
.footer-brand p{margin:14px 0 0;color:#8ba3c2;font-size:13px;line-height:1.65;max-width:42ch}
.footer-col h4{color:#fff;font-size:13px;letter-spacing:.08em;text-transform:uppercase;margin:0 0 12px;opacity:.85}
.footer-col a{display:block;color:#c2d4ea;text-decoration:none;font-weight:600;margin-bottom:9px;font-size:14px}
.footer-col a:hover{color:#fff}
.footer-bottom{border-top:1px solid rgba(255,255,255,.10);margin-top:34px;padding-top:22px}
.foot-disc{color:#7c93b3;font-size:12px;line-height:1.7;max-width:none}
.foot-disc b{color:#aebfd8}

/* ---------- Mobile sticky CTA ---------- */
.sticky-mobile{display:none}

@media(max-width:920px){
  .flow{grid-template-columns:1fr 1fr}
  .layout{grid-template-columns:1fr;gap:34px}
  .sidebar{position:static}
}
@media(max-width:860px){
  .grid3,.grid2,.hub{grid-template-columns:1fr}
  .form-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
  .navlinks a:not(.btn){display:none}
  .sticky-mobile{display:block;position:fixed;left:14px;right:14px;bottom:14px;z-index:70}
  .sticky-mobile .btn{width:100%;box-shadow:0 16px 40px rgba(8,26,51,.28)}
  body{padding-bottom:88px}
}
@media(max-width:560px){
  .wrap{padding:0 16px}
  .hero{padding-top:50px}
  .flow{grid-template-columns:1fr}
  .form-card{padding:20px}
  .footer-grid{grid-template-columns:1fr}
  .cta-band{padding:30px 22px}
}
