﻿/* Solar Panel Angle by ZIP Code article page - scoped so WordPress/theme CSS cannot distort the approved design. */
html:has(.zip-article-page),
body:has(.zip-article-page){
  overflow-x:clip!important;
  overflow-y:visible!important;
}
.zip-article-page {
  --navy:#071f49;
  --blue:#0b4fa8;
  --sky:#12a8e0;
  --gold:#f4b000;
  --ink:#0f172a;
  --body:#334155;
  --muted:#64748b;
  --line:#d7e1ee;
  --soft:#f4f8fc;
  --sky-soft:#e8f8ff;
  --gold-soft:#fff6d8;
  --white:#fff;
  --shadow:0 22px 55px rgba(7,31,73,.10);
  margin:0;
  color:var(--body);
  background:#eef6fb;
  font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  line-height:1.7;
  overflow-x:visible;
  min-height:100vh;
}
.zip-article-page *{box-sizing:border-box}
.zip-article-page a{color:var(--blue);font-weight:800;text-underline-offset:4px}
.zip-article-page p{margin:0 0 18px}
.zip-article-page strong{color:var(--ink);font-weight:900}
.zip-article-page .wrap{width:min(1160px,calc(100% - 42px));margin:0 auto}
.zip-article-page .site-head{background:rgba(255,255,255,.94);border-bottom:1px solid var(--line);position:sticky;top:var(--wp-admin--admin-bar--height,0px);z-index:10;backdrop-filter:blur(14px)}
.zip-article-page .head-inner{min-height:74px;display:flex;align-items:center;justify-content:space-between;gap:24px}
.zip-article-page .brand{display:flex;align-items:center;gap:12px;color:var(--ink);text-decoration:none;font-weight:950;letter-spacing:-.04em;font-size:22px;line-height:1.05}
.zip-article-page .brand img{width:54px;height:54px;object-fit:contain;flex:0 0 54px}
.zip-article-page .brand span span:nth-child(1){color:#ffc20a}
.zip-article-page .brand span span:nth-child(2){color:#0b4fa8}
.zip-article-page .top-nav{display:flex;gap:22px;font-size:14px;align-items:center}
.zip-article-page .top-nav a{color:var(--body);text-decoration:none;white-space:nowrap}
.zip-article-page .hero{position:relative;overflow:hidden;background:radial-gradient(circle at 12% 18%,rgba(18,168,224,.18),transparent 30%),linear-gradient(135deg,#f7fbff 0%,#e5f4fb 100%);border-bottom:1px solid var(--line);padding:70px 0 48px}
.zip-article-page .hero:after{content:"";position:absolute;width:560px;height:560px;border-radius:50%;border:56px solid rgba(11,79,168,.055);right:-170px;top:-190px;pointer-events:none}
.zip-article-page .breadcrumb{display:flex;flex-wrap:wrap;gap:8px;font-size:13px;font-weight:800;color:var(--muted);margin-bottom:24px}
.zip-article-page .hero-grid{position:relative;z-index:1;display:grid;grid-template-columns:minmax(0,1fr) 330px;gap:44px;align-items:end}
.zip-article-page .hero-centered{display:block;text-align:center}
.zip-article-page .hero-centered .kicker{margin-inline:auto}
.zip-article-page .kicker{display:inline-flex;padding:6px 13px;border-radius:999px;background:var(--sky-soft);border:1px solid #bfeeff;color:#05779f;font-size:12px;font-weight:950;letter-spacing:.09em;text-transform:uppercase;line-height:1.2;max-width:max-content}
.zip-article-page h1{color:var(--navy);font-size:clamp(42px,5.2vw,66px);line-height:1;letter-spacing:-.05em;margin:18px auto 20px;max-width:900px;font-weight:950}
.zip-article-page h2{color:var(--ink);font-size:clamp(30px,3.1vw,44px);line-height:1.1;letter-spacing:-.03em;margin:0 0 18px;font-weight:850}
.zip-article-page h3{color:var(--navy);font-size:20px;line-height:1.25;margin:0 0 10px;font-weight:850}
.zip-article-page .lede{font-size:20px;max-width:920px;color:#24344d;margin-inline:auto}
.zip-article-page .meta-panel{background:var(--white);border:1px solid var(--line);border-top:5px solid var(--blue);border-radius:14px;padding:22px;box-shadow:var(--shadow)}
.zip-article-page .meta-panel b{display:block;color:var(--ink)}
.zip-article-page .meta-panel span{display:block;color:var(--muted);font-size:14px;margin-bottom:12px}
.zip-article-page .meta-badges{display:flex;flex-wrap:wrap;justify-content:center;gap:10px;margin:26px auto 0;max-width:1060px;padding:0;background:transparent;border:0;box-shadow:none}
.zip-article-page .meta-badges span{display:inline-flex;align-items:center;gap:7px;margin:0;padding:10px 14px;border:1px solid var(--line);border-radius:999px;background:rgba(255,255,255,.86);color:var(--body);font-size:14px}
.zip-article-page .meta-badges b{display:inline;color:var(--navy)}
.zip-article-page .article-shell{display:grid;grid-template-columns:270px minmax(0,1fr);gap:34px;padding:44px 0 76px;align-items:start}
.zip-article-page .toc{position:sticky;top:calc(var(--wp-admin--admin-bar--height,0px) + 94px);align-self:start;max-height:calc(100vh - var(--wp-admin--admin-bar--height,0px) - 116px);overflow:auto;background:var(--white);border:1px solid var(--line);border-radius:14px;padding:18px;box-shadow:0 14px 40px rgba(7,31,73,.07);z-index:2;transition:transform .22s ease,box-shadow .22s ease}
.zip-article-page .toc strong{display:block;margin-bottom:12px}
.zip-article-page .toc:hover{transform:translateY(-3px);box-shadow:0 18px 46px rgba(7,31,73,.11)}
.zip-article-page .toc a{display:block;color:var(--body);text-decoration:none;border-top:1px solid #edf2f7;padding:10px 0;font-size:14px;line-height:1.35;transition:transform .18s ease,color .18s ease,padding-left .18s ease}
.zip-article-page .toc a:hover{color:var(--blue);transform:translateX(4px);padding-left:4px}
.zip-article-page .article{display:grid;gap:34px;min-width:0}
.zip-article-page .section{background:var(--white);border:1px solid var(--line);border-radius:16px;box-shadow:var(--shadow);padding:clamp(24px,4vw,46px);overflow:hidden}
.zip-article-page .takeaway-card{border-top:6px solid var(--gold);background:linear-gradient(180deg,#fffdf4,#fff)}
.zip-article-page .takeaway-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin-top:22px}
.zip-article-page .takeaway-grid div{display:grid;grid-template-columns:34px 1fr;gap:12px;padding:14px;border:1px solid #f1df9f;border-radius:10px;background:rgba(255,255,255,.75)}
.zip-article-page .num{width:34px;height:34px;display:grid;place-items:center;border-radius:50%;background:var(--gold);color:#201600;font-weight:950;line-height:1}
.zip-article-page .meaning-layout{display:grid;grid-template-columns:minmax(0,1fr) 380px;gap:30px;align-items:center}
.zip-article-page .zip-flow{padding:26px;border-radius:16px;background:linear-gradient(145deg,var(--navy),#0b3d76);color:#fff}
.zip-article-page .flow-row{display:grid;grid-template-columns:86px 1fr;gap:16px;align-items:center;padding:15px 0;border-bottom:1px solid rgba(255,255,255,.18)}
.zip-article-page .flow-row:last-child{border-bottom:0}
.zip-article-page .flow-row span{background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.2);border-radius:999px;text-align:center;padding:8px 10px;font-weight:950;color:#ccefff}
.zip-article-page .zip-flow strong{color:#fff}
.zip-article-page .feature-matrix{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:12px;margin-top:22px}
.zip-article-page .feature-matrix article{border:1px solid var(--line);border-radius:12px;background:#fbfdff;padding:16px}
.zip-article-page .feature-matrix b{display:block;color:var(--blue);margin-bottom:6px}
.zip-article-page .table-card{padding:0}
.zip-article-page .table-intro{padding:36px 40px 24px;display:grid;grid-template-columns:minmax(0,1fr) 320px;gap:28px;align-items:end;border-bottom:1px solid var(--line)}
.zip-article-page .table-intro > div:first-child{text-align:left}
.zip-article-page .table-intro > div:first-child .kicker{margin-inline:0}
.zip-article-page .table-tools{display:grid;gap:10px;padding:16px;background:var(--soft);border:1px solid var(--line);border-radius:12px}
.zip-article-page .zip-table-controls{display:grid;gap:12px}
.zip-article-page .control-slot{display:grid;gap:7px}
.zip-article-page .control-slot label{color:var(--ink);font-size:14px;line-height:1.2}
.zip-article-page input,.zip-article-page select{width:100%;border:1px solid var(--line);border-radius:7px;min-height:46px;padding:10px 12px;font:inherit;background:#fff;color:var(--ink);line-height:1.2}
.zip-article-page .table-scroll{overflow:auto;max-height:660px;width:100%}
.zip-article-page table{border-collapse:collapse;width:100%;min-width:820px;margin:0;background:#fff}
.zip-article-page th{position:sticky;top:0;background:#edf4fa;color:var(--navy);text-align:left;font-size:12px;letter-spacing:.08em;text-transform:uppercase;padding:15px 18px;border-bottom:1px solid var(--line);z-index:1;line-height:1.3}
.zip-article-page td{padding:14px 18px;border-bottom:1px solid var(--line);color:var(--body);vertical-align:middle}
.zip-article-page tr:nth-child(even) td{background:#fbfdff}
.zip-article-page .angle-pill{display:inline-flex;min-width:74px;justify-content:center;border-radius:999px;padding:5px 10px;background:var(--sky-soft);color:#006d98;font-weight:950;white-space:nowrap}
.zip-article-page .method-timeline{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;margin-top:24px}
.zip-article-page .method-timeline article{border:1px solid var(--line);border-radius:12px;padding:18px;background:#fbfdff;min-height:142px}
.zip-article-page .method-timeline h3{color:var(--blue);font-size:20px;margin-bottom:10px}
.zip-article-page .coverage-table{border:1px solid var(--line);border-radius:12px;overflow:hidden;margin-top:18px}
.zip-article-page .intent-list{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin-top:20px}
.zip-article-page .intent-list div{border-left:5px solid var(--sky);background:#fbfdff;border-radius:10px;padding:14px 16px}
.zip-article-page .intent-list b{display:block;color:var(--ink)}
.zip-article-page .limit-panel{border-left:7px solid var(--gold);background:var(--gold-soft);box-shadow:none}
.zip-article-page .related-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
.zip-article-page .related-grid a{display:flex;justify-content:space-between;gap:18px;text-decoration:none;border:1px solid var(--line);border-radius:10px;padding:15px;background:#fbfdff;color:var(--body)}
.zip-article-page .related-grid a:after{content:">";color:var(--sky)}
.zip-article-page details{border:1px solid var(--line);border-radius:10px;background:#fff;padding:16px 18px;margin-top:10px}
.zip-article-page summary{cursor:pointer;color:var(--navy);font-weight:950}
.zip-article-page .author-card{display:grid;grid-template-columns:90px 1fr auto;gap:20px;align-items:center;border-top:5px solid var(--blue)}
.zip-article-page .author-card img{width:90px;height:90px;border-radius:50%;object-fit:cover;border:4px solid #e4edf7}
.zip-article-page .verify{background:#fff1c2;color:#a35b00;border:1px solid #ffd879;border-radius:999px;padding:8px 12px;font-weight:950;white-space:nowrap}
.zip-article-page .tag-row{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}
.zip-article-page .tag-row span{border:1px solid #b8cbe1;border-radius:6px;padding:5px 9px;color:var(--navy);font-weight:850;font-size:13px}
.zip-article-page .site-foot{padding:40px 0;background:var(--navy);color:#d9e7fb}
.zip-article-page .site-foot a{color:#fff}
.zip-article-page .hidden-row{display:none!important}
@media(max-width:1100px){
  .zip-article-page .feature-matrix{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media(max-width:1000px){
  .zip-article-page .hero-grid,.zip-article-page .article-shell,.zip-article-page .meaning-layout,.zip-article-page .table-intro{grid-template-columns:1fr}
  .zip-article-page .toc{position:static}
  .zip-article-page .top-nav{display:none}
  .zip-article-page .related-grid,.zip-article-page .intent-list{grid-template-columns:1fr}
}
@media(max-width:640px){
  .zip-article-page .wrap{width:min(100% - 28px,1160px)}
  .zip-article-page .hero{padding:46px 0 34px}
  .zip-article-page h1{font-size:clamp(38px,12vw,54px);letter-spacing:-.04em}
  .zip-article-page h2{font-size:clamp(28px,9vw,40px)}
  .zip-article-page .lede{font-size:18px}
  .zip-article-page .section{padding:22px}
  .zip-article-page .takeaway-grid,.zip-article-page .method-timeline,.zip-article-page .feature-matrix{grid-template-columns:1fr}
  .zip-article-page .author-card{grid-template-columns:72px 1fr}
  .zip-article-page .author-card img{width:72px;height:72px}
  .zip-article-page .verify{grid-column:1/-1;width:fit-content}
  .zip-article-page .table-intro{padding:22px}
  .zip-article-page .table-scroll{max-height:560px}
}
