﻿/*
Theme Name: GeneratePress Child Solar Angle
Template: generatepress
Description: Editable homepage design for Solar Panel Angle Calculator.
Version: 1.0.0
*/

:root {
  --primary: #0A2F6B;
  --primary-dark: #061E45;
  --primary-mid: #0B3D91;
  --primary-soft: #EAF2FF;
  --secondary: #F4B000;
  --secondary-dark: #B97800;
  --secondary-soft: #FFF4CC;
  --accent: #12A8E0;
  --accent-dark: #087CA8;
  --accent-soft: #E6F8FF;
  --text: #0F172A;
  --body: #334155;
  --muted: #64748B;
  --border: #D8E0EC;
  --border-strong: #AFC0D4;
  --page: #F6F8FB;
  --surface: #FFFFFF;
  --success: #16A34A;
  --warning: #F59E0B;
  --error: #DC2626;
  --radius: 8px;
  --shadow: 0 18px 48px rgba(10, 47, 107, .10);
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; overflow-x: hidden; }
body { margin: 0; background: var(--page); color: var(--body); font-family: Inter, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif; line-height: 1.65; overflow-x: hidden; max-width: 100vw; }
a { color: var(--primary); text-decoration-color: var(--accent); text-underline-offset: 4px; font-weight: 700; }
p { margin: 0 0 18px; }
strong { color: var(--text); font-weight: 800; }
ul, ol { margin: 12px 0 22px; padding-left: 22px; }
li { margin: 8px 0; }
.container { width: min(1280px, calc(100% - 48px)); max-width: 100%; margin: 0 auto; }
.container.narrow { width: min(900px, calc(100% - 48px)); }
.site-header { position: sticky; top: 0; z-index: 20; background: rgba(255,255,255,.94); backdrop-filter: blur(14px); border-bottom: 1px solid var(--border); }
.nav-inner { min-height: 78px; display: flex; align-items: center; justify-content: space-between; gap: 18px; }
.brand { display: flex; align-items: center; gap: 12px; text-decoration: none; color: var(--text); flex: 0 0 auto; min-width: 300px; }
.brand img { height: 68px; width: 68px; object-fit: contain; }
.brand-wordmark { display: grid; gap: 0; line-height: 1.02; min-width: 0; }
.brand-wordmark strong { font-size: 23px; letter-spacing: -0.035em; white-space: nowrap; }
.brand-solar { color: #FFC20A; }
.brand-panel { color: #0B4FA8; }
.brand-angle, .brand-calc { color: #333333; }
.nav-links { display: flex; gap: 14px; align-items: center; justify-content: flex-end; font-size: 13px; font-weight: 800; margin-left: auto; min-width: 0; flex: 1 1 auto; }
.nav-links a { text-decoration: none; color: var(--body); white-space: nowrap; }
.nav-item { position: relative; padding: 26px 0; display: flex; align-items: center; }
.nav-home { display: inline-flex; align-items: center; min-height: 34px; }
.nav-item > a:after { content: ""; display: inline-block; width: 7px; height: 7px; margin-left: 7px; border-right: 2px solid currentColor; border-bottom: 2px solid currentColor; transform: rotate(45deg) translateY(-2px); }
.nav-home:after { display: none; }
.mega-menu { position: absolute; top: 100%; left: 50%; transform: translateX(-50%) translateY(10px); width: min(980px, calc(100vw - 48px)); display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 30px; padding: 26px; background: rgba(255,255,255,.98); border: 1px solid var(--border); border-radius: 12px; box-shadow: 0 24px 54px rgba(6,30,69,.16); opacity: 0; visibility: hidden; pointer-events: none; transition: .16s ease; }
.mega-menu.two-col { grid-template-columns: repeat(2, minmax(0, 1fr)); width: min(720px, calc(100vw - 48px)); }
.nav-item:hover .mega-menu, .nav-item:focus-within .mega-menu { opacity: 1; visibility: visible; pointer-events: auto; transform: translateX(-50%) translateY(0); }
.mega-menu h3 { margin: 0 0 12px; padding-bottom: 8px; border-bottom: 2px solid #D7EFFB; font-size: 13px; color: var(--accent-dark); text-transform: uppercase; letter-spacing: .1em; }
.mega-menu a { display: block; padding: 6px 0; color: #334155; font-weight: 750; }
.mega-menu a:hover { color: var(--primary); }
.nav-cta, .calculator-shell button, .check-form > button, .angle-actions button { border: 0; background: var(--secondary); color: #171100; padding: 14px 22px; border-radius: 6px; font-weight: 900; cursor: pointer; box-shadow: 0 8px 16px rgba(185, 120, 0, .18); }
.nav-cta { flex: 0 0 auto; padding: 12px 18px; white-space: nowrap; text-decoration: none; min-width: 142px; text-align: center; }
.nav-cta:hover, .calculator-shell button:hover, .check-form > button:hover { background: #D99600; }
.hero { position: relative; padding: 78px 0 64px; overflow: hidden; background: #EAF4FA; }
.hero-photo { position: absolute; inset: 0; background-image: linear-gradient(180deg, rgba(246,248,251,.04), rgba(246,248,251,.42) 62%, #F6F8FB 100%), url("solar-hero-bg.svg"); background-size: cover; background-position: center top; pointer-events: none; }
.hero-inner { position: relative; }
.hero-copy { max-width: 920px; margin: 0 auto 34px; text-align: center; }
.kicker, .eyebrow { display: inline-flex; align-items: center; gap: 8px; color: var(--accent-dark); background: var(--accent-soft); border: 1px solid #C8ECFA; border-radius: 999px; padding: 5px 12px; font-size: 12px; font-weight: 900; letter-spacing: .08em; text-transform: uppercase; }
h1 { color: var(--primary-dark); font-size: clamp(44px, 5.4vw, 68px); line-height: 1.02; letter-spacing: -0.045em; margin: 18px 0 24px; text-wrap: balance; }
h2 { color: var(--text); font-size: clamp(30px, 3.4vw, 48px); line-height: 1.08; letter-spacing: -0.03em; margin: 14px 0 20px; }
h3 { color: var(--primary); font-size: 22px; line-height: 1.2; margin: 26px 0 10px; }
.hero-copy p { font-size: 19px; max-width: 820px; margin-left: auto; margin-right: auto; }
.hero-copy ul { display: flex; flex-wrap: wrap; justify-content: center; list-style: none; padding: 0; gap: 10px; margin: 22px auto; }
.hero-copy li { margin: 0; background: #fff; border: 1px solid var(--border); border-radius: 999px; padding: 8px 12px; font-weight: 800; color: var(--primary); }
.hero-badges { display: flex; flex-wrap: nowrap; justify-content: center; gap: 10px; margin: 16px auto 0; max-width: 100%; }
.hero-badges span { position: relative; display: inline-flex; align-items: center; white-space: nowrap; background: rgba(255,255,255,.86); color: var(--primary); border: 1px solid #BFD2E7; border-radius: 999px; padding: 9px 13px; font-weight: 900; font-size: 13px; box-shadow: 0 8px 18px rgba(10,47,107,.08); }
.hero-badges span:after { content: attr(data-tip); position: absolute; left: 50%; bottom: calc(100% + 10px); transform: translateX(-50%) translateY(4px); width: 240px; background: var(--primary-dark); color: #fff; border-radius: 8px; padding: 10px 12px; font-size: 12px; line-height: 1.4; white-space: normal; opacity: 0; pointer-events: none; transition: .16s ease; box-shadow: 0 14px 30px rgba(6,30,69,.24); z-index: 5; }
.hero-badges span:hover:after { opacity: 1; transform: translateX(-50%) translateY(0); }
.homepage-intro-card { position: relative; max-width: 980px; margin: 18px auto 0; text-align: center; padding: 8px 56px 8px; }
.homepage-intro-card > p { margin: 0; color: var(--text); font-size: 18px; line-height: 1.62; }
.homepage-intro-card details { position: absolute; inset: 0; pointer-events: none; }
.homepage-intro-card summary { position: absolute; right: 16px; top: 16px; width: 34px; height: 34px; display: grid; place-items: center; color: var(--primary); background: #fff; border: 1px solid var(--border); border-radius: 50%; box-shadow: 0 8px 18px rgba(10,47,107,.1); font-weight: 900; cursor: pointer; list-style: none; pointer-events: auto; transition: .16s ease; }
.homepage-intro-card summary::-webkit-details-marker { display: none; }
.homepage-intro-card summary:after { content: ">"; transform: rotate(90deg); line-height: 1; }
.homepage-intro-card summary:hover { background: var(--primary); color: #fff; border-color: var(--primary); }
.homepage-intro-card details[open] { position: static; display: block; margin-top: 12px; pointer-events: auto; }
.homepage-intro-card details[open] summary { top: 16px; right: 16px; }
.homepage-intro-card details[open] summary:after { transform: rotate(-90deg); }
.homepage-intro-card details div { margin-top: 12px; padding-top: 0; border-top: 0; }
.homepage-intro-card details p { margin: 0; color: var(--text); font-size: 18px; line-height: 1.62; }
.homepage-intro-card details p:last-child { margin-bottom: 0; }
.calculator-shell { background: rgba(255,255,255,.97); border: 1px solid #C9D7E8; border-radius: 8px; box-shadow: 0 22px 50px rgba(10,47,107,.15); padding: 30px; }
.calculator-topline { display: flex; align-items: center; gap: 10px; color: var(--muted); font-size: 13px; font-weight: 800; margin-bottom: 22px; }
.status-dot { width: 10px; height: 10px; background: var(--success); border-radius: 50%; box-shadow: 0 0 0 5px rgba(22,163,74,.12); }
.method-badge { margin-left: auto; color: var(--primary); background: var(--primary-soft); border: 1px solid var(--border); padding: 4px 10px; border-radius: 999px; }
.calculator-grid { display: grid; grid-template-columns: 1fr 1fr .95fr; gap: 24px; }
.field-group { display: grid; gap: 12px; }
.field-group h3 { margin-top: 0; display: flex; align-items: center; gap: 10px; }
label { font-size: 13px; font-weight: 900; color: var(--muted); letter-spacing: .04em; }
input, select { width: 100%; border: 1px solid var(--border-strong); background: #fff; color: var(--text); border-radius: 6px; padding: 13px 14px; font: inherit; }
input:focus, select:focus { outline: 3px solid var(--accent-soft); border-color: var(--accent); }
.inline-field-row { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 8px; }
.ghost-tool-button { border: 1px solid var(--border); background: #F8FBFF; color: var(--primary); border-radius: 6px; padding: 10px 12px; font-weight: 900; cursor: pointer; }
.ghost-tool-button:hover { background: var(--primary-soft); border-color: var(--primary); }
.location-detect-status { margin: 8px 0 12px; color: var(--muted); background: #F8FBFF; border: 1px solid var(--border); border-radius: 7px; padding: 9px 10px; font-size: 12px; line-height: 1.45; font-weight: 800; }
.coordinate-grid { display: none; grid-template-columns: repeat(2, minmax(0,1fr)); gap: 10px; padding: 12px; border: 1px solid var(--border); border-radius: 8px; background: #F8FBFF; }
.coordinate-grid.is-open { display: grid; }
.result-preview { background: linear-gradient(180deg, #F9FBFE, #EEF5FF); border: 1px solid var(--border); border-radius: 8px; padding: 24px; display: grid; gap: 18px; }
.result-row { display: flex; justify-content: space-between; border-top: 1px solid var(--border); padding-top: 14px; }
.result-row b { color: var(--primary-dark); font-size: 24px; }
.result-preview a { text-align: center; font-size: 14px; }
.post-tool-trust { display: grid; grid-template-columns: minmax(420px, .9fr) minmax(0, 1.1fr); gap: 16px; margin-top: 24px; align-items: stretch; }
.live-output-board { margin-top: 24px; background: #fff; border: 1px solid var(--border); border-radius: 12px; box-shadow: 0 18px 44px rgba(10,47,107,.11); padding: 28px; display: grid; grid-template-columns: 1fr 430px; gap: 28px; align-items: stretch; }
.live-output-board h2 { font-size: 32px; margin-bottom: 12px; }
.output-stat-grid { display: grid; grid-template-columns: repeat(4, minmax(0,1fr)); gap: 12px; margin: 22px 0; }
.output-stat-grid div { background: #F8FBFF; border: 1px solid var(--border); border-radius: 8px; padding: 14px; }
.output-stat-grid span { display: block; color: var(--muted); font-size: 12px; font-weight: 900; text-transform: uppercase; letter-spacing: .06em; }
.output-stat-grid b { display: block; color: var(--primary-dark); font-size: 26px; line-height: 1.1; margin-top: 6px; }
.mini-month-table { display: grid; grid-template-columns: repeat(12, minmax(0,1fr)); gap: 6px; margin: 18px 0 6px; }
.mini-month-table span { display: grid; gap: 4px; justify-items: center; align-content: center; min-height: 54px; border: 1px solid var(--border); border-radius: 7px; background: #F8FBFF; color: var(--primary); font-size: 11px; font-weight: 900; }
.mini-month-table b { color: var(--primary-dark); font-size: 14px; line-height: 1; }
.mini-month-table span.is-current { background: var(--secondary-soft); border-color: var(--secondary); color: #8A5A00; }
.output-note { margin: 8px 0 0; color: var(--muted); font-size: 14px; line-height: 1.45; }
.output-note a { font-weight: 900; }
.after-result-actions { display: flex; flex-wrap: wrap; gap: 10px; width: 100%; margin-top: 16px; }
.after-result-actions button { border: 1px solid var(--border); background: #fff; color: var(--primary); padding: 12px 14px; border-radius: 6px; font-weight: 900; cursor: pointer; }
.after-result-actions button:first-child { background: var(--secondary); color: #171100; border-color: var(--secondary-dark); }
.live-output-visual { background: var(--primary-dark); border-radius: 10px; padding: 22px; display: grid; place-items: center; }
.live-output-visual svg { width: 100%; height: 100%; min-height: 260px; background: rgba(255,255,255,.04); border: 1px dashed rgba(221,231,246,.32); border-radius: 10px; display: block; }
.live-output-visual .axis { stroke: #AFC0D4; stroke-width: 4; }
.live-output-visual .panel-line { stroke: var(--primary-mid); stroke-width: 9; }
.live-output-visual .arc { fill: none; stroke: var(--accent); stroke-width: 5; stroke-dasharray: 10 8; }
.live-output-visual .sun { fill: var(--secondary); }
.live-output-visual text { fill: #D9E6F7; font-size: 14px; font-weight: 800; }
.live-output-visual .vertical { opacity: .55; }
.live-output-visual .ray { stroke: var(--secondary); stroke-width: 4; opacity: .7; }
.restored-result-cards { grid-column: 1 / -1; border-top: 1px solid var(--border); padding-top: 26px; margin-top: 4px; }
.result-detail-card-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 16px; align-items: start; }
.result-detail-card-grid .entity-card { min-height: 100%; }
.result-detail-card-grid .entity-card h3 { font-size: 18px; }
.result-detail-card-grid .entity-card p, .result-detail-card-grid .entity-card li { font-size: 14px; }
.result-detail-card-grid .entity-card:nth-child(7) {
  grid-column: 1 / -1;
  min-height: auto;
  display: grid;
  grid-template-columns: 240px minmax(0, 1fr);
  column-gap: 28px;
  align-items: start;
}
.result-detail-card-grid .entity-card:nth-child(7) .card-icon {
  grid-column: 1;
  grid-row: 1;
}
.result-detail-card-grid .entity-card:nth-child(7) h3 {
  grid-column: 1;
  grid-row: 2;
  margin-top: 0;
}
.result-detail-card-grid .entity-card:nth-child(7) p,
.result-detail-card-grid .entity-card:nth-child(7) ul,
.result-detail-card-grid .entity-card:nth-child(7) .list-lead {
  grid-column: 2;
}
.review-slider { margin-top: 24px; background: rgba(255,255,255,.76); border: 1px solid var(--border); border-radius: 12px; padding: 18px; box-shadow: 0 12px 30px rgba(10,47,107,.08); overflow: hidden; }
.slider-head { display: flex; justify-content: space-between; align-items: center; gap: 16px; margin-bottom: 14px; }
.slider-controls { display: flex; gap: 8px; }
.slider-controls button { position: relative; width: 40px; height: 40px; border-radius: 50%; border: 1px solid var(--border); background: #fff; color: var(--primary); cursor: pointer; box-shadow: 0 8px 18px rgba(10,47,107,.08); }
.slider-controls button:before { content: ""; position: absolute; top: 50%; left: 50%; width: 9px; height: 9px; border-top: 3px solid var(--primary); border-right: 3px solid var(--primary); }
.slider-prev:before { transform: translate(-35%, -50%) rotate(-135deg); }
.slider-next:before { transform: translate(-65%, -50%) rotate(45deg); }
.review-strip { display: flex; gap: 14px; overflow-x: hidden; scroll-snap-type: x mandatory; padding-bottom: 0; scrollbar-width: none; }
.review-strip::-webkit-scrollbar { display: none; }
.review-card { flex: 0 0 300px; scroll-snap-align: start; background: #fff; border: 1px solid var(--border); border-radius: 10px; padding: 18px; box-shadow: 0 10px 24px rgba(10,47,107,.06); }
.review-card b { color: #F4B000; display: block; letter-spacing: .04em; margin-bottom: 8px; }
.review-card p { font-size: 14px; margin-bottom: 10px; }
.review-card span { color: var(--muted); font-size: 12px; font-weight: 900; }
.author-card, .disclaimer-card { background: #fff; border: 1px solid var(--border); border-radius: 10px; padding: 16px 18px; box-shadow: 0 8px 20px rgba(10,47,107,.06); min-height: 0; height: 100%; align-self: stretch; }
.author-card { display: grid; grid-template-columns: 72px minmax(0,1fr); gap: 16px; align-items: center; border-color: #1F2937; min-width: 0; border-top: 4px solid var(--primary); }
.author-card > p { display: none !important; }
.author-card > img { flex: 0 0 72px; }
.author-card > div { flex: 1 1 auto; min-width: 0; }
.author-card p { margin: 0; }
.avatar { width: 52px; height: 52px; border-radius: 50%; background: var(--primary); color: #fff; display: grid; place-items: center; font-weight: 900; }
.author-card .eyebrow { background: transparent; border: 0; border-radius: 0; padding: 0; color: var(--muted); font-size: 11px; line-height: 1; letter-spacing: .08em; }
.author-title-row { display: flex; align-items: center; justify-content: space-between; gap: 10px; flex-wrap: wrap; margin: 6px 0 3px; }
.author-title-row p { margin: 0; display: inline-flex; }
.author-card h2 { font-size: 19px; margin: 0; line-height: 1.2; }
.verified-chip { display: inline-flex; align-items: center; border-radius: 999px; background: #FFF4CC; color: #B45309; border: 1px solid #FFE08A; padding: 4px 9px; font-size: 12px; font-weight: 800; }
.verified-chip:before { content: ""; margin-right: 0; font-size: 0; }
.author-role { color: var(--primary); font-weight: 900; margin: 0; font-size: 14px; line-height: 1.25; }
.author-bio { color: var(--muted); font-size: 13px; line-height: 1.4; margin: 7px 0 0 !important; max-width: 640px; }
.author-stats { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 10px; }
.author-stats span { display: inline-flex; align-items: center; gap: 6px; border: 1px solid #BDE7CC; background: #ECFDF3; color: #087443; border-radius: 7px; padding: 7px 10px; font-size: 12px; font-weight: 900; }
.credential-row { display: flex; flex-wrap: wrap; gap: 8px; margin: 10px 0 0; line-height: 1; }
.credential-row br { display: none; }
.credential-row span { display: inline-flex; border: 1px solid var(--border-strong); border-radius: 5px; padding: 5px 9px; color: var(--primary); background: #fff; font-size: 12px; font-weight: 800; }
.disclaimer-card { position: relative; background: #FFF8E1; border-color: var(--secondary); color: #854D0E; display: flex; align-items: center; }
.disclaimer-card p { margin: 0; font-size: 14px; line-height: 1.55; padding-right: 22px; }
.disclaimer-card button { position: absolute; right: 12px; top: 10px; border: 0; background: transparent; color: #B45309; font-size: 22px; line-height: 1; cursor: pointer; }
.first-panel { margin-top: 24px; }
.moved-hero-copy { background: #F8FBFF; border: 1px solid var(--border); border-radius: 10px; padding: 18px 20px; margin-bottom: 22px; }
.moved-hero-copy ul { display: flex; flex-wrap: wrap; list-style: none; padding: 0; gap: 8px; }
.moved-hero-copy li { margin: 0; background: var(--primary-soft); color: var(--primary); border-radius: 999px; padding: 6px 10px; font-weight: 900; font-size: 13px; }
.section { padding: 86px 0; border-top: 1px solid var(--border); }
.section-grid { display: grid; grid-template-columns: minmax(0, 1.2fr) minmax(340px, .8fr); gap: 54px; align-items: start; }
.section-grid.reverse { grid-template-columns: minmax(340px, .8fr) minmax(0, 1.2fr); }
.section-grid.reverse .content-panel { order: 2; }
.section-grid.reverse .visual-wrap { order: 1; }
.content-panel { background: var(--surface); border: 1px solid var(--border); border-radius: 12px; padding: clamp(26px, 4vw, 44px); box-shadow: 0 8px 30px rgba(10,47,107,.05); }
.content-panel > p:first-of-type { font-size: 18px; }
.content-panel h3 { border-top: 1px solid var(--border); padding-top: 24px; }
.list-lead { color: var(--text); font-weight: 900; margin-top: 20px; }
.calculator-info-card-grid, .entity-card-grid, .result-card-grid { display: grid; gap: 16px; margin-top: 26px; }
.calculator-info-card-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.entity-card-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.result-card-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 18px; align-self: start; }
.entity-card {
  position: relative;
  background: linear-gradient(180deg, #FFFFFF, #F8FBFF);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 22px;
  overflow: hidden;
  box-shadow: 0 8px 22px rgba(10,47,107,.055);
}
.entity-card:before {
  content: "";
  position: absolute;
  inset: 0 auto 0 0;
  width: 4px;
  background: var(--primary);
}
.entity-card h3 {
  border: 0;
  margin: 0 0 12px;
  padding: 0;
  color: var(--text);
  font-size: 19px;
}
.entity-card p { font-size: 15px; margin-bottom: 12px; }
.entity-card ul, .entity-card ol { margin-bottom: 12px; }
.card-icon {
  width: 34px;
  height: 34px;
  border-radius: 8px;
  display: grid;
  place-items: center;
  background: var(--primary-soft);
  color: var(--primary);
  font-weight: 900;
  margin-bottom: 14px;
}
.location-card:before { background: var(--accent); }
.location-card .card-icon { background: var(--accent-soft); color: var(--accent-dark); }
.roof-mini-card:before { background: #64748B; }
.season-card:before { background: var(--secondary); }
.season-card .card-icon { background: var(--secondary-soft); color: #8A5A00; }
.month-card:before { background: #16A34A; }
.compass-mini-card:before { background: var(--primary-mid); }
.result-mini-card {
  background: linear-gradient(180deg, #FFFFFF, #EDF5FF);
  border-color: #C9D7E8;
}
.result-mini-card:before { background: var(--accent); }
.source-mini-card {
  background: #FFF9E8;
  border-color: #F4D47A;
}
.source-mini-card:before { background: var(--secondary); }
.variant-2:before { background: var(--accent); }
.variant-3:before { background: var(--secondary); }
.variant-4:before { background: #16A34A; }
.section, .section-grid { overflow: visible; }
.visual-wrap { position: sticky; top: 96px; align-self: start; }
.visual-wrap.visual-pin-host { position: relative; top: auto; align-self: stretch; }
.visual-wrap.visual-pin-host > .visual-card { width: 100%; }
.visual-card { min-height: 340px; background: #fff; border: 1px solid var(--border); border-radius: 12px; box-shadow: 0 18px 38px rgba(10,47,107,.08); padding: 28px; overflow: hidden; }
.visual-card.dark { background: var(--primary-dark); color: #fff; }
.formula-stack { display: grid; gap: 14px; margin-top: 26px; }
.formula-stack div { background: rgba(255,255,255,.08); border: 1px solid rgba(255,255,255,.14); border-radius: 8px; padding: 16px; }
.formula-stack b, .formula-stack span { display: block; }
.formula-stack span { opacity: .78; }
svg { max-width: 100%; }
.axis { stroke: #AFC0D4; stroke-width: 3; }
.panel, .roof { fill: var(--primary-mid); }
.panel-line { stroke: var(--primary-mid); stroke-width: 8; }
.arc { fill: none; stroke: var(--accent); stroke-width: 4; stroke-dasharray: 8 8; }
.sun, .mini-sun { fill: var(--secondary); }
.angle-graphic text, .sunpath-card text, .roof-card text, .incidence-card text { fill: var(--muted); font-size: 15px; font-weight: 800; }
.css-visual { position: relative; min-height: 340px; display: block; }
.css-visual p { position: absolute; left: 30px; right: 30px; bottom: 28px; margin: 0; color: var(--muted); font-weight: 800; text-align: center; }
.css-axis { position: absolute; left: 70px; right: 54px; bottom: 86px; height: 3px; background: #AFC0D4; }
.css-axis:before { content: ""; position: absolute; left: 0; bottom: 0; width: 3px; height: 180px; background: #AFC0D4; opacity: .9; }
.css-panel { position: absolute; left: 70px; bottom: 86px; width: 212px; height: 9px; background: var(--primary-mid); border-radius: 999px; transform: rotate(-28deg); transform-origin: left center; box-shadow: 0 7px 0 rgba(10,47,107,.12); }
.css-arc { position: absolute; left: 70px; bottom: 86px; width: 128px; height: 128px; border: 5px dashed var(--accent); border-top-color: transparent; border-right-color: transparent; border-radius: 50%; transform: rotate(6deg); }
.css-sun { position: absolute; right: 84px; top: 70px; width: 48px; height: 48px; border-radius: 50%; background: var(--secondary); box-shadow: 0 0 0 12px rgba(244,176,0,.14); }
.chart-card { display: grid; align-content: center; gap: 18px; }
.bar-row { display: grid; grid-template-columns: 100px 1fr; align-items: center; gap: 14px; }
.bar-row span { display: block; height: 18px; background: linear-gradient(90deg, var(--primary), var(--accent)); border-radius: 999px; }
.month-grid .months { display: grid; grid-template-columns: repeat(12, 1fr); gap: 4px; margin: 26px 0; }
.month-grid .months span { text-align: center; font-weight: 900; color: var(--primary); background: var(--primary-soft); border-radius: 4px; padding: 8px 0; }
.month-wave { position: relative; height: 140px; margin-top: 10px; border-bottom: 3px solid #AFC0D4; }
.month-wave:before { content: ""; position: absolute; left: 6%; right: 6%; top: 18px; height: 90px; border-bottom: 7px solid var(--accent); border-radius: 0 0 50% 50%; transform: skewX(-8deg); }
.month-wave:after { content: "winter steeper  |  summer flatter  |  winter steeper"; position: absolute; left: 0; right: 0; bottom: 16px; color: var(--muted); font-size: 12px; font-weight: 900; text-align: center; }
.month-wave span { position: absolute; left: 50%; top: 44px; width: 16px; height: 16px; border-radius: 50%; background: var(--secondary); box-shadow: -150px 44px 0 var(--secondary), 150px 44px 0 var(--secondary); }
.map-card { position: relative; min-height: 340px; background: linear-gradient(135deg, #fff, var(--accent-soft)); }
.map-grid { position: absolute; inset: 0; background-image: linear-gradient(var(--border) 1px, transparent 1px), linear-gradient(90deg, var(--border) 1px, transparent 1px); background-size: 38px 38px; opacity: .6; }
.pin { position: absolute; left: 54%; top: 38%; width: 24px; height: 24px; background: var(--secondary); border-radius: 50% 50% 50% 0; transform: rotate(-45deg); box-shadow: 0 0 0 9px rgba(244,176,0,.18); }
.map-note { position: absolute; left: 24px; right: 24px; bottom: 24px; background: #fff; border: 1px solid var(--border); border-radius: 8px; padding: 14px; }
.map-note b, .map-note span { display: block; }
.zip-preview-card { display: grid; align-content: center; gap: 18px; background: linear-gradient(145deg, #fff 0%, #F5FBFF 52%, #EAF7FF 100%); }
.zip-search-box { border: 1px solid var(--border); background: #fff; border-radius: 10px; padding: 18px; box-shadow: 0 12px 24px rgba(10,47,107,.06); }
.zip-search-box span { display: block; color: var(--muted); font-size: 12px; font-weight: 900; text-transform: uppercase; letter-spacing: .06em; }
.zip-search-box b { display: block; color: var(--primary-dark); font-size: 34px; line-height: 1.05; margin-top: 6px; }
.zip-table-mini { display: grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap: 10px; }
.zip-table-mini div { border: 1px solid var(--border); background: rgba(255,255,255,.82); border-radius: 8px; padding: 12px; }
.zip-table-mini span { display: block; color: var(--muted); font-size: 11px; font-weight: 900; text-transform: uppercase; letter-spacing: .04em; }
.zip-table-mini b { display: block; color: var(--primary); margin-top: 4px; font-size: 15px; line-height: 1.2; }
.zip-preview-card p { color: var(--muted); margin: 0; font-weight: 800; }
.compass-card { text-align: center; }
.compass { width: 230px; height: 230px; border: 2px solid var(--border); border-radius: 50%; margin: 0 auto 22px; position: relative; display: grid; place-items: center; }
.compass span { position: absolute; font-weight: 900; color: var(--primary); }
.compass span:nth-child(1){top:12px}.compass span:nth-child(2){right:14px}.compass span:nth-child(3){bottom:12px}.compass span:nth-child(4){left:14px}
.compass i { width: 8px; height: 92px; background: var(--secondary); transform: rotate(38deg); transform-origin: center bottom; border-radius: 999px; }
.sunpath { fill: none; stroke: var(--secondary); stroke-width: 6; stroke-dasharray: 12 10; }
.ray { stroke: var(--secondary); stroke-width: 5; }
.ray.muted { opacity: .45; }
.sunpath-card .sunpath-axis { position: absolute; left: 58px; right: 48px; bottom: 92px; height: 3px; background: #AFC0D4; }
.sunpath-card .sunpath-axis:before { content: ""; position: absolute; left: 0; bottom: 0; width: 3px; height: 160px; background: #AFC0D4; }
.sunpath-card .sunpath-arc { position: absolute; left: 66px; right: 66px; bottom: 96px; height: 168px; border-top: 7px dashed var(--secondary); border-radius: 50% 50% 0 0; }
.sunpath-card .sunpath-sun { right: 58px; top: 88px; width: 42px; height: 42px; }
.roof-card .roof-shape { position: absolute; left: 50px; right: 50px; bottom: 92px; height: 130px; background: linear-gradient(135deg, transparent 49%, #AFC0D4 50%, #AFC0D4 53%, transparent 54%), linear-gradient(45deg, transparent 49%, #AFC0D4 50%, #AFC0D4 53%, transparent 54%); }
.roof-card .roof-panel { position: absolute; left: 150px; bottom: 154px; width: 160px; height: 86px; background: var(--primary-mid); transform: rotate(-22deg); box-shadow: 0 9px 0 #fff; }
.incidence-card .inc-panel { position: absolute; left: 82px; bottom: 92px; width: 210px; height: 10px; background: var(--primary-mid); transform: rotate(-23deg); transform-origin: left center; border-radius: 999px; }
.incidence-card .inc-ray { position: absolute; left: 182px; top: 68px; width: 7px; height: 190px; background: var(--secondary); transform: rotate(32deg); transform-origin: center bottom; border-radius: 999px; }
.incidence-card .inc-ray-muted { left: 238px; opacity: .35; transform: rotate(8deg); }
.incidence-card .inc-arc { position: absolute; left: 116px; bottom: 80px; width: 118px; height: 118px; border: 5px dashed var(--accent); border-top-color: transparent; border-right-color: transparent; border-radius: 50%; }
.mini-system { position: relative; }
.mini-sun { width: 82px; height: 82px; border-radius: 50%; position: absolute; left: 34px; top: 42px; }
.mini-panel { width: 210px; height: 120px; background: var(--primary-mid); position: absolute; right: 40px; bottom: 72px; transform: rotate(-13deg); box-shadow: 0 14px 0 #fff; }
.mini-arc { position: absolute; width: 230px; height: 110px; border-bottom: 12px dashed var(--accent); border-radius: 0 0 50% 50%; right: 28px; bottom: 28px; }
.results-section { background: #fff; }
.section-head { max-width: 760px; margin-bottom: 34px; }
.section-head.center { text-align: center; margin-left: auto; margin-right: auto; }
.results-layout { display: grid; grid-template-columns: 1fr 420px; gap: 34px; align-items: start; }
.sticky-visual { position: sticky; top: 96px; align-self: start; }
.angle-meter { background: var(--primary-dark); color: #fff; border-radius: 12px; padding: 22px; }
.angle-meter svg { background: rgba(255,255,255,.04); border: 1px solid rgba(255,255,255,.1); border-radius: 8px; }
.angle-meter text { fill: #D9E6F7; font-weight: 800; }
.angle-actions { display: grid; gap: 10px; margin-top: 16px; }
.angle-actions .ghost { background: transparent; border: 1px solid rgba(255,255,255,.22); color: #fff; box-shadow: none; }
.table-wrap { overflow-x: auto; margin: 20px 0 28px; border: 1px solid var(--border); border-radius: 8px; }
table { border-collapse: collapse; width: 100%; background: #fff; }
th, td { text-align: left; padding: 14px 16px; border-bottom: 1px solid var(--border); vertical-align: top; }
th { background: #F1F5F9; color: var(--text); font-size: 13px; text-transform: uppercase; letter-spacing: .06em; }
.data-table-wrap { border-radius: 12px; box-shadow: 0 14px 34px rgba(10,47,107,.07); background: #fff; }
.data-table { min-width: 760px; }
.data-table th { background: #EAF7FF; color: var(--primary); font-size: 12px; font-weight: 900; white-space: nowrap; }
.data-table td { color: var(--text); font-weight: 650; }
.data-table td:nth-child(n+4) { color: var(--primary-dark); font-weight: 900; white-space: nowrap; }
.data-table tbody tr:nth-child(even) { background: #F8FBFF; }
.data-table tbody tr:hover { background: #FFF7E1; }
.latitude-chart td:first-child { color: var(--primary); font-weight: 900; white-space: nowrap; }
.content-panel .data-table-wrap + p { margin-top: 8px; }
.check-section { background: linear-gradient(135deg, #fff, var(--primary-soft)); }
.check-grid { display: grid; grid-template-columns: .95fr 1.05fr; gap: 28px; align-items: start; }
.check-copy { border-left: 6px solid var(--primary); }
.check-form { background: #fff; border: 1px solid var(--border); border-radius: 12px; padding: 28px; box-shadow: var(--shadow); display: grid; gap: 14px; }
.pill-grid { display: grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap: 10px; }
.pill-grid button { border: 1px solid var(--border); background: #fff; border-radius: 6px; padding: 12px; font-weight: 800; color: var(--primary); cursor: pointer; }
.pill-grid button:hover { border-color: var(--primary); background: var(--primary-soft); }
.consent { display: flex; gap: 10px; align-items: start; font-weight: 600; letter-spacing: 0; }
.consent input { width: auto; margin-top: 4px; }
.faq-section { background: #fff; }
.faq-list { display: grid; gap: 12px; }
.faq-item { border: 1px solid var(--border); border-radius: 8px; background: #fff; overflow: hidden; }
.faq-item summary { cursor: pointer; padding: 18px 22px; font-weight: 900; color: var(--text); background: #F8FAFC; }
.faq-item[open] summary { background: var(--primary-soft); color: var(--primary); }
.faq-item div { padding: 18px 22px; border-top: 1px solid var(--border); }
.faq-extra { display: none; }
.faq-list.show-all .faq-extra { display: block; }
.faq-reveal { display: block; margin: 22px auto 0; border: 1px solid var(--primary); background: var(--primary); color: #fff; border-radius: 999px; padding: 12px 20px; font-weight: 900; cursor: pointer; box-shadow: 0 12px 24px rgba(10,47,107,.16); }
.dark-section { background: var(--primary-dark); color: #D9E6F7; }
.dark-section .content-panel { background: rgba(255,255,255,.06); border-color: rgba(255,255,255,.12); color: #D9E6F7; }
.dark-section h2, .dark-section h3, .dark-section strong { color: #fff; }
.dark-section a { color: #7DD3FC; }
.card-icon { min-width: 42px; height: 34px; font-size: 11px; letter-spacing: .04em; padding: 0 8px; }
.review-card b, .review-card .stars { color: #F4B000; display: block; letter-spacing: .04em; margin-bottom: 8px; font-size: 16px; }
.author-photo { width: 72px; height: 72px; border-radius: 50%; object-fit: cover; object-position: center top; border: 3px solid #D8E7F7; background: #F1F7FF; flex: 0 0 auto; }
.review-meta { font-size: 13px; color: var(--muted); font-weight: 800; }
.source-audit-card, .tool-network-card, .methodology-card { position: relative; min-height: 340px; }
.source-audit-card .source-node { position: absolute; width: 82px; height: 48px; border-radius: 10px; display: grid; place-items: center; background: #EDF5FF; color: var(--primary); border: 1px solid var(--border); font-weight: 900; z-index: 2; }
.source-audit-card .source-node.primary { left: calc(50% - 62px); top: 86px; width: 124px; background: var(--primary); color: #fff; }
.source-audit-card .source-node:nth-of-type(2) { left: 44px; bottom: 88px; }
.source-audit-card .source-node:nth-of-type(3) { left: calc(50% - 41px); bottom: 60px; }
.source-audit-card .source-node:nth-of-type(4) { right: 44px; bottom: 88px; }
.source-line { position: absolute; height: 3px; background: var(--accent); transform-origin: left center; opacity: .75; }
.source-line.line-one { width: 142px; left: 126px; top: 196px; transform: rotate(-32deg); }
.source-line.line-two { width: 115px; left: calc(50% - 8px); top: 150px; transform: rotate(90deg); }
.source-line.line-three { width: 142px; right: 126px; top: 196px; transform: rotate(32deg); transform-origin: right center; }
.source-audit-card p, .tool-network-card p { position: absolute; left: 26px; right: 26px; bottom: 24px; margin: 0; color: var(--muted); font-weight: 800; text-align: center; font-size: 14px; }
.tool-node { position: absolute; width: 98px; height: 52px; border-radius: 12px; display: grid; place-items: center; background: #F8FBFF; border: 1px solid var(--border); color: var(--primary); font-weight: 900; z-index: 2; text-align: center; font-size: 13px; }
.tool-node.core { left: calc(50% - 54px); top: 84px; width: 108px; background: var(--primary); color: #fff; }
.tool-node.orient { left: 34px; top: 178px; }
.tool-node.sunpos { right: 34px; top: 178px; }
.tool-node.roof { left: 78px; bottom: 70px; }
.tool-node.season { right: 78px; bottom: 70px; }
.tool-link { position: absolute; height: 3px; background: linear-gradient(90deg, var(--primary), var(--accent)); opacity: .75; transform-origin: left center; }
.tool-link.link-a { width: 150px; left: 130px; top: 168px; transform: rotate(-29deg); }
.tool-link.link-b { width: 150px; right: 130px; top: 168px; transform: rotate(29deg); transform-origin: right center; }
.tool-link.link-c { width: 118px; left: 140px; top: 233px; transform: rotate(20deg); }
.tool-link.link-d { width: 118px; right: 140px; top: 233px; transform: rotate(-20deg); transform-origin: right center; }
.methodology-card { display: grid; gap: 14px; align-content: center; }
.methodology-card .method-step { display: grid; grid-template-columns: 42px 1fr; gap: 12px; align-items: center; background: #F8FBFF; border: 1px solid var(--border); border-radius: 10px; padding: 14px; }
.methodology-card .method-step b { width: 34px; height: 34px; border-radius: 50%; background: var(--secondary); color: #171100; display: grid; place-items: center; }
.methodology-card .method-step span { color: var(--primary); font-weight: 900; }
.site-footer { background: #fff; color: #475569; padding: 54px 0 28px; border-top: 1px solid var(--border); }
.footer-grid { display: grid; grid-template-columns: 1.35fr repeat(4, 1fr); gap: 30px; align-items: start; }
.site-footer h2, .site-footer h3 { color: var(--text); margin-top: 0; }
.site-footer h3 { font-size: 15px; margin-bottom: 14px; }
.site-footer p { font-size: 14px; line-height: 1.55; margin: 0 0 10px; }
.site-footer a { color: #475569; text-decoration: none; font-weight: 600; font-size: 14px; }
.site-footer a:hover { color: var(--primary); }
.footer-logo { display: inline-flex; align-items: center; gap: 12px; margin-bottom: 14px; max-width: 270px; }
.footer-logo img { width: 86px; height: 86px; object-fit: contain; flex: 0 0 auto; }
.footer-logo b { display: block; font-size: 22px; line-height: 1.06; letter-spacing: -0.03em; }
.footer-brand p { max-width: 250px; }
.footer-social { display: flex; gap: 10px; margin-top: 18px; }
.footer-social a { width: 34px; height: 34px; border-radius: 50%; display: grid; place-items: center; color: #fff; background: var(--primary); font-size: 12px; font-weight: 900; text-transform: uppercase; }
.footer-bottom { display: flex; justify-content: space-between; align-items: center; gap: 20px; border-top: 1px solid var(--border); border-bottom: 1px solid var(--border); padding: 18px 0; margin-top: 34px; }
.footer-bottom p { margin: 0; }
.footer-bottom nav { display: flex; gap: 12px; align-items: center; flex-wrap: wrap; }
.footer-bottom span { color: #CBD5E1; }
.footer-disclaimer { text-align: center; padding-top: 18px; }
.footer-disclaimer p { max-width: 1060px; margin: 0 auto; color: #64748B; }
@media (max-width: 980px) {
  .nav-inner { min-height: auto; padding: 12px 0; align-items: center; flex-wrap: wrap; }
  .brand { min-width: 0; flex: 1 1 auto; }
  .brand img { height: 58px; width: 58px; }
  .brand-wordmark strong { font-size: 18px; white-space: normal; }
  .nav-cta { order: 2; min-width: 132px; padding: 10px 14px; }
  .nav-links { order: 3; width: 100%; overflow-x: auto; gap: 18px; padding: 8px 0 2px; align-items: center; justify-content: flex-start; scrollbar-width: none; }
  .nav-links::-webkit-scrollbar { display: none; }
  .nav-item { position: static; padding: 0; flex: 0 0 auto; }
  .nav-item > a:after { display: none; }
  .mega-menu { display: none; }
  .calculator-grid, .post-tool-trust, .live-output-board, .section-grid, .section-grid.reverse, .results-layout, .check-grid, .footer-grid { grid-template-columns: 1fr; }
  .review-card { flex-basis: min(82vw, 320px); }
  .output-stat-grid { grid-template-columns: repeat(2, minmax(0,1fr)); }
  .mini-month-table { grid-template-columns: repeat(4, minmax(0,1fr)); }
  .result-detail-card-grid { grid-template-columns: 1fr; }
  .result-detail-card-grid .entity-card:nth-child(7) {
    grid-column: auto;
    display: block;
    grid-template-columns: none;
  }
  .result-detail-card-grid .entity-card:nth-child(7) .card-icon,
  .result-detail-card-grid .entity-card:nth-child(7) h3,
  .result-detail-card-grid .entity-card:nth-child(7) p,
  .result-detail-card-grid .entity-card:nth-child(7) ul,
  .result-detail-card-grid .entity-card:nth-child(7) .list-lead {
    grid-column: auto;
    grid-row: auto;
  }
  .result-detail-card-grid .entity-card:nth-child(7) h3 {
    margin-top: 16px;
  }
  .hero-badges { flex-wrap: wrap; }
  .section-grid.reverse .content-panel, .section-grid.reverse .visual-wrap { order: initial; }
  .calculator-info-card-grid, .entity-card-grid, .result-card-grid { grid-template-columns: 1fr; }
  .visual-wrap, .sticky-visual { position: static; }
  .visual-wrap.visual-pin-host { height: auto !important; }
  .visual-wrap.visual-pin-host > .visual-card { position: static !important; width: 100% !important; left: auto !important; top: auto !important; bottom: auto !important; }
}
@media (max-width: 620px) {
  .container, .container.narrow { width: min(100% - 28px, 1280px); }
  .hero { padding-top: 42px; }
  .calculator-shell, .content-panel, .check-form { padding: 20px; }
  .pill-grid { grid-template-columns: 1fr; }
  .inline-field-row, .coordinate-grid { grid-template-columns: 1fr; }
  .mini-month-table { grid-template-columns: repeat(3, minmax(0,1fr)); }
  .author-card { align-items: flex-start; }
  .author-card > img { flex-basis: 64px; width: 64px; height: 64px; }
  .author-photo { width: 64px; height: 64px; }
  .brand-wordmark strong { font-size: 16px; }
  .nav-cta { width: 100%; order: 3; }
  .nav-links { order: 4; }
  .footer-bottom { align-items: flex-start; flex-direction: column; }
  h1 { font-size: 42px; }
}


body.solar-angle-homepage-template .calculator-page-main { background: #F6F8FB; }
.calc-page-hero { position: relative; overflow: hidden; padding: 82px 0 46px; background: #EAF7FF url("/wp-content/themes/generatepress-child-solar-angle/assets/solar-hero-bg.svg") center/cover no-repeat; border-bottom: 1px solid var(--border); }
.calc-page-hero:before { content: ""; position: absolute; inset: 0; background: rgba(245,250,255,.70); }
.calc-page-hero .container { position: relative; z-index: 1; }
.calc-page-hero-inner { max-width: 900px; margin: 0 auto; text-align: center; }
.calc-page-hero p { max-width: 760px; margin: 14px auto 0; font-size: 18px; color: var(--body); }
.calc-page-badges { display: flex; justify-content: center; flex-wrap: wrap; gap: 10px; margin-top: 24px; }
.calc-page-badges span { border: 1px solid rgba(10,47,107,.16); background: rgba(255,255,255,.72); color: var(--primary); padding: 8px 12px; border-radius: 999px; font-size: 12px; font-weight: 900; }
.calc-tool-section { padding: 42px 0 34px; background: linear-gradient(180deg, rgba(232,245,255,.84), #F6F8FB); }
.calc-page-tool { background: #fff; border: 1px solid var(--border); border-radius: 14px; padding: 28px; box-shadow: var(--shadow); }
.calc-page-tool-grid { display: grid; grid-template-columns: minmax(0, 1fr) minmax(340px, .54fr); gap: 28px; align-items: stretch; }
.calc-input-grid { display: grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap: 16px; }
.calc-field label { display: block; color: var(--muted); font-size: 12px; font-weight: 900; margin-bottom: 7px; }
.fake-input, .fake-select { width: 100%; min-height: 54px; border: 1px solid var(--border); border-radius: 7px; padding: 14px; font: inherit; color: var(--text); background: #fff; display: flex; align-items: center; justify-content: space-between; gap: 12px; }
.fake-input { color: #64748B; }
.fake-select:after { content: "v"; color: var(--primary); font-weight: 900; font-size: 12px; }
.calc-control { width: 100%; min-height: 54px; border: 1px solid var(--border); border-radius: 7px; padding: 14px; font: inherit; color: var(--text); background: #fff; }
.calc-control::placeholder { color: #64748B; opacity: 1; }
.calc-control:focus { outline: 3px solid rgba(24,169,216,.18); border-color: var(--accent); }
.check-form .calc-control { min-height: 50px; }
.calc-control-proxy { width: 100%; min-height: 54px; border: 1px solid var(--border); border-radius: 7px; padding: 14px; font: inherit; color: #64748B; background: #fff; display: flex; align-items: center; }
.tool-display-title { font-size: clamp(36px, 5vw, 56px); line-height: 1.04; letter-spacing: -0.045em; color: var(--text); font-weight: 500; margin: 12px 0 16px; }
.output-display-title { font-size: clamp(34px, 4vw, 52px); line-height: 1.05; color: #fff; font-weight: 800; margin: 8px 0 12px; }
.calc-page-preview { background: linear-gradient(180deg, #F8FBFF, #EEF6FF); border: 1px solid var(--border); border-radius: 10px; padding: 22px; display: grid; gap: 16px; }
.calc-result-line { display: flex; justify-content: space-between; gap: 12px; padding-bottom: 12px; border-bottom: 1px solid var(--border); color: var(--muted); }
.calc-result-line b { color: var(--primary-dark); }
.calc-page-actions { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 18px; }
.calc-page-actions button, .calc-page-actions a { border: 1px solid var(--border); background: #fff; color: var(--primary); padding: 12px 16px; border-radius: 7px; font-weight: 900; text-decoration: none; cursor: pointer; }
.calc-page-actions .primary { background: var(--secondary); border-color: #D99600; color: #171100; }
.calc-output-visual { background: var(--primary-dark); color: #fff; border-radius: 14px; padding: 24px; display: grid; grid-template-columns: minmax(0,1fr) minmax(300px,.65fr); gap: 26px; align-items: center; margin-top: 30px; }
.calc-output-visual h2, .calc-output-visual p { color: #fff; }
.calc-output-visual svg { width: 100%; background: rgba(255,255,255,.05); border: 1px dashed rgba(255,255,255,.28); border-radius: 12px; }
.calc-result-section { padding: 56px 0; background: #fff; }
.calc-result-card { border: 1px solid var(--border); border-radius: 14px; padding: 34px; background: #fff; box-shadow: var(--shadow); }
.calc-result-card .section-grid { padding: 0; }
.calc-result-card .content-panel { box-shadow: none; border: 0; padding: 0; }
.result-action-row { display: flex; flex-wrap: wrap; gap: 12px; padding-top: 22px; margin-top: 22px; border-top: 1px solid var(--border); }
.result-action-row button { border: 1px solid var(--border); background: #fff; color: var(--primary); padding: 13px 18px; border-radius: 7px; font-weight: 900; cursor: pointer; }
.result-action-row .primary { background: var(--secondary); border-color: #D99600; color: #171100; }
.tool-trust-row { display: grid; grid-template-columns: minmax(0, .9fr) minmax(0, 1.1fr); gap: 18px; margin-top: 22px; }
.calc-review-section { padding: 54px 0; background: linear-gradient(180deg, #EAF4FF, #F6F8FB); }
.calc-check-section { padding: 54px 0; }
.calc-check-card { background: #fff; border: 1px solid var(--border); border-radius: 12px; padding: 34px; box-shadow: var(--shadow); border-left: 7px solid var(--primary); }
.calc-check-grid { display: grid; grid-template-columns: minmax(0,.86fr) minmax(0,1fr); gap: 28px; align-items: start; }
.calc-check-copy h2 { font-size: clamp(34px, 5vw, 58px); line-height: 1.05; }
.calc-check-copy .section-title-like, .review-title-like { font-size: clamp(34px, 5vw, 58px); line-height: 1.05; letter-spacing: -0.045em; color: var(--text); margin: 12px 0 16px; }
.review-title-like { font-size: clamp(32px, 4vw, 48px); }
.calc-check-copy ul { margin-top: 16px; }
.check-form { display: grid; gap: 12px; align-content: start; }
.check-form label { color: var(--muted); font-size: 12px; font-weight: 900; margin-top: 4px; }
.check-form > button { margin-top: 8px; border: 0; background: var(--primary); color: #fff; border-radius: 8px; padding: 15px 18px; font-weight: 900; cursor: pointer; }
.fake-checkbox { width: 18px; height: 18px; border: 1px solid var(--border); border-radius: 4px; background: #fff; display: inline-block; flex: 0 0 auto; }
.consent { display: flex; align-items: flex-start; gap: 10px; line-height: 1.45; }
.calc-page-content { padding: 30px 0 70px; }
.calc-page-content .content-panel h2 { font-size: clamp(34px, 4vw, 58px); }
.calculator-page-main .site-section { padding: 48px 0; }
.calculator-page-main .visual-card svg { width: 100%; height: auto; display: block; }
.css-visual { position: relative; min-height: 300px; overflow: hidden; }
.css-visual .base { position: absolute; left: 12%; right: 12%; bottom: 58px; height: 4px; background: #B9C8D9; border-radius: 99px; }
.css-visual .vertical { position: absolute; left: 20%; bottom: 58px; width: 4px; height: 170px; background: #B9C8D9; border-radius: 99px; }
.css-visual .panel { position: absolute; left: 19%; bottom: 62px; width: 210px; height: 10px; border-radius: 99px; background: var(--primary); transform: rotate(-28deg); transform-origin: left center; box-shadow: 10px 10px 0 rgba(10,47,107,.08); }
.css-visual .ray { position: absolute; right: 18%; top: 74px; width: 150px; height: 7px; border-radius: 99px; background: var(--secondary); transform: rotate(-42deg); transform-origin: right center; }
.css-visual .sun-dot { position: absolute; right: 16%; top: 48px; width: 54px; height: 54px; border-radius: 50%; background: var(--secondary); box-shadow: 0 0 0 20px rgba(245,180,0,.14); }
.css-visual .arc { position: absolute; left: 18%; bottom: 52px; width: 120px; height: 120px; border: 6px dashed var(--accent); border-right-color: transparent; border-top-color: transparent; border-radius: 50%; }
.css-visual .visual-caption { position: absolute; left: 0; right: 0; bottom: 16px; text-align: center; color: var(--muted); font-weight: 900; font-size: 13px; }
.css-visual.map .node { position: absolute; top: 72px; width: 92px; height: 58px; border-radius: 12px; display: grid; place-items: center; font-weight: 900; color: var(--primary); background: #EAF7FF; border: 1px solid var(--border); }
.css-visual.map .node:nth-child(2) { left: 12%; }
.css-visual.map .node:nth-child(3) { left: calc(50% - 46px); background: #FFF4CC; color: #7C4A00; border-color: #F7D36C; }
.css-visual.map .node:nth-child(4) { right: 12%; }
.css-visual.map .flow { position: absolute; left: 18%; right: 18%; top: 168px; height: 70px; border-bottom: 6px solid var(--accent); border-radius: 0 0 50% 50%; }
.css-visual.network .hub { position: absolute; left: calc(50% - 44px); top: 54px; width: 88px; height: 88px; border-radius: 50%; background: var(--primary-dark); color: #fff; display: grid; place-items: center; font-weight: 900; }
.css-visual.network .mini { position: absolute; bottom: 64px; width: 66px; height: 66px; border-radius: 50%; background: #EAF7FF; border: 1px solid var(--border); }
.css-visual.network .mini.a { left: 17%; }
.css-visual.network .mini.b { left: calc(50% - 33px); background: #FFF4CC; border-color: #F7D36C; }
.css-visual.network .mini.c { right: 17%; }
.css-visual.bars .bar { position: absolute; bottom: 58px; width: 48px; border-radius: 9px 9px 0 0; background: var(--primary); }
.css-visual.bars .bar.a { left: 22%; height: 88px; }
.css-visual.bars .bar.b { left: 38%; height: 136px; background: var(--accent); }
.css-visual.bars .bar.c { left: 54%; height: 72px; background: var(--secondary); }
.css-visual.bars .bar.d { left: 70%; height: 126px; }
.css-visual.compass .dial { position: absolute; left: calc(50% - 112px); top: 48px; width: 224px; height: 224px; border: 3px solid #D7E3F2; border-radius: 50%; }
.css-visual.compass .needle { position: absolute; left: calc(50% - 4px); top: 84px; width: 8px; height: 118px; background: var(--secondary); border-radius: 99px; transform: rotate(35deg); transform-origin: 50% 86%; }
.css-visual.compass b { position: absolute; color: var(--primary); }
.css-visual.compass .n { left: calc(50% - 7px); top: 62px; }
.css-visual.compass .s { left: calc(50% - 7px); bottom: 60px; }
.css-visual.compass .e { right: calc(50% - 94px); top: 150px; }
.css-visual.compass .w { left: calc(50% - 94px); top: 150px; }
.css-visual.questions .qbox { border: 1px solid var(--border); border-radius: 8px; background: #F8FBFF; padding: 12px 14px; font-weight: 900; color: var(--primary); }
.visual-card.dark { background: var(--primary-dark); color: #fff; }
.visual-card.dark .eyebrow { background: rgba(232,247,255,.95); color: var(--primary); border-color: rgba(255,255,255,.3); }
.visual-card.dark .visual-caption { color: #EAF7FF; }
.visual-card.dark.css-visual.compass .dial { border-color: rgba(234,247,255,.92); }
.visual-card.dark.css-visual.compass b { color: #D9ECFF; }
.visual-card.dark .base, .visual-card.dark .vertical { background: rgba(234,247,255,.7); }
.calc-compass { display: grid; place-items: center; min-height: 300px; }
.calc-compass .dial { position: relative; width: 230px; height: 230px; border: 3px solid #D7E3F2; border-radius: 50%; }
.calc-compass .needle { position: absolute; width: 8px; height: 110px; left: calc(50% - 4px); top: 30px; background: var(--secondary); border-radius: 999px; transform: rotate(35deg); transform-origin: 50% 86%; }
.calc-compass span { position: absolute; font-weight: 900; color: var(--primary); }
.calc-compass .n { top: 12px; left: 50%; transform: translateX(-50%); }
.calc-compass .s { bottom: 12px; left: 50%; transform: translateX(-50%); }
.calc-compass .e { right: 16px; top: 50%; transform: translateY(-50%); }
.calc-compass .w { left: 16px; top: 50%; transform: translateY(-50%); }
.menu-heading, .footer-heading { display: block; color: var(--primary); font-size: 12px; font-weight: 900; letter-spacing: .08em; text-transform: uppercase; margin-bottom: 12px; }
.site-footer .footer-heading { color: var(--text); font-size: 15px; letter-spacing: 0; text-transform: none; }
.calc-page-field-grid { display: grid; gap: 14px; }
.review-shell { background: rgba(255,255,255,.76); border: 1px solid var(--border); border-radius: 12px; padding: 18px; box-shadow: 0 12px 30px rgba(10,47,107,.08); overflow: hidden; }
@media (max-width: 980px) {
  .calc-page-tool-grid, .calc-output-visual, .tool-trust-row, .calc-check-grid { grid-template-columns: 1fr; }
  .calc-input-grid { grid-template-columns: 1fr; }
}


body.solar-angle-homepage-template .calculator-page-main { background: #F6F8FB; }
.calc-page-hero { position: relative; overflow: hidden; padding: 82px 0 46px; background: #EAF7FF url("/wp-content/themes/generatepress-child-solar-angle/assets/solar-hero-bg.svg") center/cover no-repeat; border-bottom: 1px solid var(--border); }
.calc-page-hero:before { content: ""; position: absolute; inset: 0; background: rgba(245,250,255,.70); }
.calc-page-hero .container { position: relative; z-index: 1; }
.calc-page-hero-inner { max-width: 900px; margin: 0 auto; text-align: center; }
.calc-page-hero p { max-width: 760px; margin: 14px auto 0; font-size: 18px; color: var(--body); }
.calc-page-badges { display: flex; justify-content: center; flex-wrap: wrap; gap: 10px; margin-top: 24px; }
.calc-page-badges span { border: 1px solid rgba(10,47,107,.16); background: rgba(255,255,255,.72); color: var(--primary); padding: 8px 12px; border-radius: 999px; font-size: 12px; font-weight: 900; }
.calc-tool-section { padding: 42px 0 34px; background: linear-gradient(180deg, rgba(232,245,255,.84), #F6F8FB); }
.calc-page-tool { background: #fff; border: 1px solid var(--border); border-radius: 14px; padding: 28px; box-shadow: var(--shadow); }
.calc-page-tool-grid { display: grid; grid-template-columns: minmax(0, 1fr) minmax(340px, .54fr); gap: 28px; align-items: stretch; }
.calc-input-grid { display: grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap: 16px; }
.calc-field label { display: block; color: var(--muted); font-size: 12px; font-weight: 900; margin-bottom: 7px; }
.fake-input, .fake-select { width: 100%; min-height: 54px; border: 1px solid var(--border); border-radius: 7px; padding: 14px; font: inherit; color: var(--text); background: #fff; display: flex; align-items: center; justify-content: space-between; gap: 12px; }
.fake-input { color: #64748B; }
.fake-select:after { content: "v"; color: var(--primary); font-weight: 900; font-size: 12px; }
.calc-control { width: 100%; min-height: 54px; border: 1px solid var(--border); border-radius: 7px; padding: 14px; font: inherit; color: var(--text); background: #fff; }
.calc-control::placeholder { color: #64748B; opacity: 1; }
.calc-control:focus { outline: 3px solid rgba(24,169,216,.18); border-color: var(--accent); }
.check-form .calc-control { min-height: 50px; }
.calc-control-proxy { width: 100%; min-height: 54px; border: 1px solid var(--border); border-radius: 7px; padding: 14px; font: inherit; color: #64748B; background: #fff; display: flex; align-items: center; }
.tool-display-title { font-size: clamp(36px, 5vw, 56px); line-height: 1.04; letter-spacing: -0.045em; color: var(--text); font-weight: 500; margin: 12px 0 16px; }
.output-display-title { font-size: clamp(34px, 4vw, 52px); line-height: 1.05; color: #fff; font-weight: 800; margin: 8px 0 12px; }
.calc-page-preview { background: linear-gradient(180deg, #F8FBFF, #EEF6FF); border: 1px solid var(--border); border-radius: 10px; padding: 22px; display: grid; gap: 16px; }
.calc-result-line { display: flex; justify-content: space-between; gap: 12px; padding-bottom: 12px; border-bottom: 1px solid var(--border); color: var(--muted); }
.calc-result-line b { color: var(--primary-dark); }
.calc-page-actions { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 18px; }
.calc-page-actions button, .calc-page-actions a { border: 1px solid var(--border); background: #fff; color: var(--primary); padding: 12px 16px; border-radius: 7px; font-weight: 900; text-decoration: none; cursor: pointer; }
.calc-page-actions .primary { background: var(--secondary); border-color: #D99600; color: #171100; }
.calc-output-visual { background: var(--primary-dark); color: #fff; border-radius: 14px; padding: 24px; display: grid; grid-template-columns: minmax(0,1fr) minmax(300px,.65fr); gap: 26px; align-items: center; margin-top: 30px; }
.calc-output-visual h2, .calc-output-visual p { color: #fff; }
.calc-output-visual svg { width: 100%; background: rgba(255,255,255,.05); border: 1px dashed rgba(255,255,255,.28); border-radius: 12px; }
.calc-result-section { padding: 56px 0; background: #fff; }
.calc-result-card { border: 1px solid var(--border); border-radius: 14px; padding: 34px; background: #fff; box-shadow: var(--shadow); }
.calc-result-card .section-grid { padding: 0; }
.calc-result-card .content-panel { box-shadow: none; border: 0; padding: 0; }
.calc-result-card .content-panel h2 { font-size: clamp(36px, 4.2vw, 52px); }
.calc-result-card .section-grid { grid-template-columns: minmax(0, 1.25fr) minmax(380px, .75fr); gap: 34px; align-items: stretch; }
.calc-result-detail { border-top: 1px solid var(--border); margin-top: 28px; padding-top: 26px; }
.calc-result-detail .entity-card-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.calc-result-detail .entity-card { min-height: 100%; }
.calc-result-detail .entity-card h3 { font-size: 19px; }
.result-action-row { display: flex; flex-wrap: wrap; gap: 12px; padding-top: 22px; margin-top: 22px; border-top: 1px solid var(--border); }
.result-action-row button { border: 1px solid var(--border); background: #fff; color: var(--primary); padding: 13px 18px; border-radius: 7px; font-weight: 900; cursor: pointer; }
.result-action-row .primary { background: var(--secondary); border-color: #D99600; color: #171100; }
.tool-trust-row { display: grid; grid-template-columns: minmax(0, .9fr) minmax(0, 1.1fr); gap: 18px; margin-top: 22px; }
.calc-review-section { padding: 54px 0; background: linear-gradient(180deg, #EAF4FF, #F6F8FB); }
.calc-check-section { padding: 54px 0; }
.calc-check-card { background: #fff; border: 1px solid var(--border); border-radius: 12px; padding: 34px; box-shadow: var(--shadow); border-left: 7px solid var(--primary); }
.calc-check-grid { display: grid; grid-template-columns: minmax(0,.86fr) minmax(0,1fr); gap: 28px; align-items: start; }
.calc-check-copy h2 { font-size: clamp(34px, 5vw, 58px); line-height: 1.05; }
.calc-check-copy .section-title-like, .review-title-like { font-size: clamp(34px, 5vw, 58px); line-height: 1.05; letter-spacing: -0.045em; color: var(--text); margin: 12px 0 16px; }
.review-title-like { font-size: clamp(32px, 4vw, 48px); }
.calc-check-copy ul { margin-top: 16px; }
.check-form { display: grid; gap: 12px; align-content: start; }
.check-form label { color: var(--muted); font-size: 12px; font-weight: 900; margin-top: 4px; }
.check-form > button { margin-top: 8px; border: 0; background: var(--primary); color: #fff; border-radius: 8px; padding: 15px 18px; font-weight: 900; cursor: pointer; }
.fake-checkbox { width: 18px; height: 18px; border: 1px solid var(--border); border-radius: 4px; background: #fff; display: inline-block; flex: 0 0 auto; }
.consent { display: flex; align-items: flex-start; gap: 10px; line-height: 1.45; }
.calc-page-content { padding: 30px 0 70px; }
.calc-page-content .content-panel h2 { font-size: clamp(34px, 4vw, 58px); }
.calculator-page-main .site-section { padding: 48px 0; }
.calculator-page-main .visual-card svg { width: 100%; height: auto; display: block; }
.css-visual { position: relative; min-height: 300px; overflow: hidden; }
.css-visual .base { position: absolute; left: 12%; right: 12%; bottom: 58px; height: 4px; background: #B9C8D9; border-radius: 99px; }
.css-visual .vertical { position: absolute; left: 20%; bottom: 58px; width: 4px; height: 170px; background: #B9C8D9; border-radius: 99px; }
.css-visual .panel { position: absolute; left: 19%; bottom: 62px; width: 210px; height: 10px; border-radius: 99px; background: var(--primary); transform: rotate(-28deg); transform-origin: left center; box-shadow: 10px 10px 0 rgba(10,47,107,.08); }
.css-visual .ray { position: absolute; right: 18%; top: 74px; width: 150px; height: 7px; border-radius: 99px; background: var(--secondary); transform: rotate(-42deg); transform-origin: right center; }
.css-visual .sun-dot { position: absolute; right: 16%; top: 48px; width: 54px; height: 54px; border-radius: 50%; background: var(--secondary); box-shadow: 0 0 0 20px rgba(245,180,0,.14); }
.css-visual .arc { position: absolute; left: 18%; bottom: 52px; width: 120px; height: 120px; border: 6px dashed var(--accent); border-right-color: transparent; border-top-color: transparent; border-radius: 50%; }
.css-visual .visual-caption { position: absolute; left: 0; right: 0; bottom: 16px; text-align: center; color: var(--muted); font-weight: 900; font-size: 13px; }
.css-visual.map .node { position: absolute; top: 72px; width: 92px; height: 58px; border-radius: 12px; display: grid; place-items: center; font-weight: 900; color: var(--primary); background: #EAF7FF; border: 1px solid var(--border); }
.css-visual.map .node:nth-child(2) { left: 12%; }
.css-visual.map .node:nth-child(3) { left: calc(50% - 46px); background: #FFF4CC; color: #7C4A00; border-color: #F7D36C; }
.css-visual.map .node:nth-child(4) { right: 12%; }
.css-visual.map .flow { position: absolute; left: 18%; right: 18%; top: 168px; height: 70px; border-bottom: 6px solid var(--accent); border-radius: 0 0 50% 50%; }
.css-visual.network .hub { position: absolute; left: calc(50% - 44px); top: 54px; width: 88px; height: 88px; border-radius: 50%; background: var(--primary-dark); color: #fff; display: grid; place-items: center; font-weight: 900; }
.css-visual.network .mini { position: absolute; bottom: 64px; width: 66px; height: 66px; border-radius: 50%; background: #EAF7FF; border: 1px solid var(--border); }
.css-visual.network .mini.a { left: 17%; }
.css-visual.network .mini.b { left: calc(50% - 33px); background: #FFF4CC; border-color: #F7D36C; }
.css-visual.network .mini.c { right: 17%; }
.css-visual.bars .bar { position: absolute; bottom: 58px; width: 48px; border-radius: 9px 9px 0 0; background: var(--primary); }
.css-visual.bars .bar.a { left: 22%; height: 88px; }
.css-visual.bars .bar.b { left: 38%; height: 136px; background: var(--accent); }
.css-visual.bars .bar.c { left: 54%; height: 72px; background: var(--secondary); }
.css-visual.bars .bar.d { left: 70%; height: 126px; }
.css-visual.compass .dial { position: absolute; left: calc(50% - 112px); top: 48px; width: 224px; height: 224px; border: 3px solid #D7E3F2; border-radius: 50%; }
.css-visual.compass .needle { position: absolute; left: calc(50% - 4px); top: 84px; width: 8px; height: 118px; background: var(--secondary); border-radius: 99px; transform: rotate(35deg); transform-origin: 50% 86%; }
.css-visual.compass b { position: absolute; color: var(--primary); }
.css-visual.compass .n { left: calc(50% - 7px); top: 62px; }
.css-visual.compass .s { left: calc(50% - 7px); bottom: 60px; }
.css-visual.compass .e { right: calc(50% - 94px); top: 150px; }
.css-visual.compass .w { left: calc(50% - 94px); top: 150px; }
.css-visual.questions .qbox { border: 1px solid var(--border); border-radius: 8px; background: #F8FBFF; padding: 12px 14px; font-weight: 900; color: var(--primary); }
.orientation-board { min-height: 380px; background:
  radial-gradient(circle at 76% 24%, rgba(245,180,0,.20), transparent 18%),
  linear-gradient(180deg, #fff, #F8FBFF); }
.orientation-board .roof-plane { position: absolute; left: 12%; right: 12%; bottom: 74px; height: 86px; border-radius: 12px; background: linear-gradient(135deg, #0A2F6B, #0B4FA8); transform: skewX(-14deg); box-shadow: 0 18px 34px rgba(10,47,107,.14); }
.orientation-board .roof-plane:before { content: ""; position: absolute; inset: 14px; border: 1px solid rgba(255,255,255,.32); border-radius: 7px; }
.orientation-board .compass-rail { position: absolute; left: 13%; right: 13%; bottom: 42px; height: 8px; border-radius: 999px; background: #D7E3F2; }
.orientation-board .compass-rail span { position: absolute; top: 16px; color: var(--primary); font-weight: 900; font-size: 12px; }
.orientation-board .compass-rail .west { left: 0; }
.orientation-board .compass-rail .south { left: 50%; transform: translateX(-50%); }
.orientation-board .compass-rail .east { right: 0; }
.orientation-board .azimuth-beam { position: absolute; left: 50%; bottom: 50px; width: 8px; height: 160px; border-radius: 999px; background: var(--secondary); transform: rotate(36deg); transform-origin: bottom center; box-shadow: 0 0 0 12px rgba(245,180,0,.13); }
.orientation-board .azimuth-tag { position: absolute; right: 11%; top: 96px; background: var(--primary-dark); color: #fff; border-radius: 8px; padding: 9px 12px; font-weight: 900; font-size: 13px; }
.orientation-board .direction-pills { position: absolute; left: 10%; top: 88px; display: grid; gap: 8px; }
.orientation-board .direction-pills span { display: inline-flex; background: #EAF7FF; border: 1px solid var(--border); color: var(--primary); border-radius: 999px; padding: 7px 10px; font-size: 12px; font-weight: 900; }
.orientation-board.dark { background:
  radial-gradient(circle at 76% 24%, rgba(245,180,0,.28), transparent 18%),
  linear-gradient(180deg, #08285C, #061E45); }
.orientation-board.dark .roof-plane { background: linear-gradient(135deg, #1E63C6, #0B4FA8); box-shadow: 0 18px 34px rgba(0,0,0,.2); }
.orientation-board.dark .compass-rail { background: rgba(234,247,255,.62); }
.orientation-board.dark .compass-rail span { color: #EAF7FF; }
.orientation-board.dark .direction-pills span { background: rgba(232,247,255,.12); color: #EAF7FF; border-color: rgba(232,247,255,.22); }
.visual-card.dark { background: var(--primary-dark); color: #fff; }
.visual-card.dark .eyebrow { background: rgba(232,247,255,.95); color: var(--primary); border-color: rgba(255,255,255,.3); }
.visual-card.dark .visual-caption { color: #EAF7FF; }
.visual-card.dark.css-visual.compass .dial { border-color: rgba(234,247,255,.92); }
.visual-card.dark.css-visual.compass b { color: #D9ECFF; }
.visual-card.dark .base, .visual-card.dark .vertical { background: rgba(234,247,255,.7); }
.calc-compass { display: grid; place-items: center; min-height: 300px; }
.calc-compass .dial { position: relative; width: 230px; height: 230px; border: 3px solid #D7E3F2; border-radius: 50%; }
.calc-compass .needle { position: absolute; width: 8px; height: 110px; left: calc(50% - 4px); top: 30px; background: var(--secondary); border-radius: 999px; transform: rotate(35deg); transform-origin: 50% 86%; }
.calc-compass span { position: absolute; font-weight: 900; color: var(--primary); }
.calc-compass .n { top: 12px; left: 50%; transform: translateX(-50%); }
.calc-compass .s { bottom: 12px; left: 50%; transform: translateX(-50%); }
.calc-compass .e { right: 16px; top: 50%; transform: translateY(-50%); }
.calc-compass .w { left: 16px; top: 50%; transform: translateY(-50%); }
.menu-heading, .footer-heading { display: block; color: var(--primary); font-size: 12px; font-weight: 900; letter-spacing: .08em; text-transform: uppercase; margin-bottom: 12px; }
.site-footer .footer-heading { color: var(--text); font-size: 15px; letter-spacing: 0; text-transform: none; }
.calc-page-field-grid { display: grid; gap: 14px; }
.review-shell { background: rgba(255,255,255,.76); border: 1px solid var(--border); border-radius: 12px; padding: 18px; box-shadow: 0 12px 30px rgba(10,47,107,.08); overflow: hidden; }
@media (max-width: 980px) {
  .calc-page-tool-grid, .calc-output-visual, .tool-trust-row, .calc-check-grid { grid-template-columns: 1fr; }
  .calc-input-grid { grid-template-columns: 1fr; }
  .calc-result-card .section-grid, .calc-result-detail .entity-card-grid { grid-template-columns: 1fr; }
}


body.solar-angle-homepage-template .calculator-page-main { background: #F6F8FB; }
.calc-page-hero { position: relative; overflow: hidden; padding: 82px 0 46px; background: #EAF7FF url("/wp-content/themes/generatepress-child-solar-angle/assets/solar-hero-bg.svg") center/cover no-repeat; border-bottom: 1px solid var(--border); }
.calc-page-hero:before { content: ""; position: absolute; inset: 0; background: rgba(245,250,255,.70); }
.calc-page-hero .container { position: relative; z-index: 1; }
.calc-page-hero-inner { max-width: 900px; margin: 0 auto; text-align: center; }
.calc-page-hero p { max-width: 760px; margin: 14px auto 0; font-size: 18px; color: var(--body); }
.calc-page-badges { display: flex; justify-content: center; flex-wrap: wrap; gap: 10px; margin-top: 24px; }
.calc-page-badges span { border: 1px solid rgba(10,47,107,.16); background: rgba(255,255,255,.72); color: var(--primary); padding: 8px 12px; border-radius: 999px; font-size: 12px; font-weight: 900; }
.calc-tool-section { padding: 42px 0 34px; background: linear-gradient(180deg, rgba(232,245,255,.84), #F6F8FB); }
.calc-page-tool { background: #fff; border: 1px solid var(--border); border-radius: 14px; padding: 28px; box-shadow: var(--shadow); }
.calc-page-tool-grid { display: grid; grid-template-columns: minmax(0, 1fr) minmax(340px, .54fr); gap: 28px; align-items: stretch; }
.calc-input-grid { display: grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap: 16px; }
.calc-field label { display: block; color: var(--muted); font-size: 12px; font-weight: 900; margin-bottom: 7px; }
.fake-input, .fake-select { width: 100%; min-height: 54px; border: 1px solid var(--border); border-radius: 7px; padding: 14px; font: inherit; color: var(--text); background: #fff; display: flex; align-items: center; justify-content: space-between; gap: 12px; }
.fake-input { color: #64748B; }
.fake-select:after { content: "v"; color: var(--primary); font-weight: 900; font-size: 12px; }
.calc-control { width: 100%; min-height: 54px; border: 1px solid var(--border); border-radius: 7px; padding: 14px; font: inherit; color: var(--text); background: #fff; }
.calc-control::placeholder { color: #64748B; opacity: 1; }
.calc-control:focus { outline: 3px solid rgba(24,169,216,.18); border-color: var(--accent); }
.check-form .calc-control { min-height: 50px; }
.calc-control-proxy { width: 100%; min-height: 54px; border: 1px solid var(--border); border-radius: 7px; padding: 14px; font: inherit; color: #64748B; background: #fff; display: flex; align-items: center; }
.tool-display-title { font-size: clamp(36px, 5vw, 56px); line-height: 1.04; letter-spacing: -0.045em; color: var(--text); font-weight: 500; margin: 12px 0 16px; }
.output-display-title { font-size: clamp(34px, 4vw, 52px); line-height: 1.05; color: #fff; font-weight: 800; margin: 8px 0 12px; }
.calc-page-preview { background: linear-gradient(180deg, #F8FBFF, #EEF6FF); border: 1px solid var(--border); border-radius: 10px; padding: 22px; display: grid; gap: 16px; }
.calc-result-line { display: flex; justify-content: space-between; gap: 12px; padding-bottom: 12px; border-bottom: 1px solid var(--border); color: var(--muted); }
.calc-result-line b { color: var(--primary-dark); }
.calc-page-actions { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 18px; }
.calc-page-actions button, .calc-page-actions a { border: 1px solid var(--border); background: #fff; color: var(--primary); padding: 12px 16px; border-radius: 7px; font-weight: 900; text-decoration: none; cursor: pointer; }
.calc-page-actions .primary { background: var(--secondary); border-color: #D99600; color: #171100; }
.calc-output-visual { background: var(--primary-dark); color: #fff; border-radius: 14px; padding: 24px; display: grid; grid-template-columns: minmax(0,1fr) minmax(300px,.65fr); gap: 26px; align-items: center; margin-top: 30px; }
.calc-output-visual h2, .calc-output-visual p { color: #fff; }
.calc-output-visual svg { width: 100%; background: rgba(255,255,255,.05); border: 1px dashed rgba(255,255,255,.28); border-radius: 12px; }
.calc-result-section { padding: 56px 0; background: #fff; }
.calc-result-card { border: 1px solid var(--border); border-radius: 14px; padding: 34px; background: #fff; box-shadow: var(--shadow); }
.calc-result-card .section-grid { padding: 0; }
.calc-result-card .content-panel { box-shadow: none; border: 0; padding: 0; }
.calc-result-card .content-panel h2 { font-size: clamp(36px, 4.2vw, 52px); }
.calc-result-card .section-grid { grid-template-columns: minmax(0, 1.25fr) minmax(380px, .75fr); gap: 34px; align-items: stretch; }
.calc-result-detail { border-top: 1px solid var(--border); margin-top: 28px; padding-top: 26px; }
.calc-result-detail .entity-card-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.calc-result-detail .entity-card { min-height: 100%; }
.calc-result-detail .entity-card h3 { font-size: 19px; }
.result-action-row { display: flex; flex-wrap: wrap; gap: 12px; padding-top: 22px; margin-top: 22px; border-top: 1px solid var(--border); }
.result-action-row button { border: 1px solid var(--border); background: #fff; color: var(--primary); padding: 13px 18px; border-radius: 7px; font-weight: 900; cursor: pointer; }
.result-action-row .primary { background: var(--secondary); border-color: #D99600; color: #171100; }
.tool-trust-row { display: grid; grid-template-columns: minmax(0, .9fr) minmax(0, 1.1fr); gap: 18px; margin-top: 22px; }
.calc-review-section { padding: 54px 0; background: linear-gradient(180deg, #EAF4FF, #F6F8FB); }
.calc-check-section { padding: 54px 0; }
.calc-check-card { background: #fff; border: 1px solid var(--border); border-radius: 12px; padding: 34px; box-shadow: var(--shadow); border-left: 7px solid var(--primary); }
.calc-check-grid { display: grid; grid-template-columns: minmax(0,.86fr) minmax(0,1fr); gap: 28px; align-items: start; }
.calc-check-copy h2 { font-size: clamp(34px, 5vw, 58px); line-height: 1.05; }
.calc-check-copy .section-title-like, .review-title-like { font-size: clamp(34px, 5vw, 58px); line-height: 1.05; letter-spacing: -0.045em; color: var(--text); margin: 12px 0 16px; }
.review-title-like { font-size: clamp(32px, 4vw, 48px); }
.calc-check-copy ul { margin-top: 16px; }
.check-form { display: grid; gap: 12px; align-content: start; }
.check-form label { color: var(--muted); font-size: 12px; font-weight: 900; margin-top: 4px; }
.check-form > button { margin-top: 8px; border: 0; background: var(--primary); color: #fff; border-radius: 8px; padding: 15px 18px; font-weight: 900; cursor: pointer; }
.fake-checkbox { width: 18px; height: 18px; border: 1px solid var(--border); border-radius: 4px; background: #fff; display: inline-block; flex: 0 0 auto; }
.consent { display: flex; align-items: flex-start; gap: 10px; line-height: 1.45; }
.calc-page-content { padding: 30px 0 70px; }
.calc-page-content .content-panel h2 { font-size: clamp(34px, 4vw, 58px); }
.calculator-page-main .site-section { padding: 48px 0; }
.calculator-page-main .visual-card svg { width: 100%; height: auto; display: block; }
.css-visual { position: relative; min-height: 300px; overflow: hidden; }
.css-visual .base { position: absolute; left: 12%; right: 12%; bottom: 58px; height: 4px; background: #B9C8D9; border-radius: 99px; }
.css-visual .vertical { position: absolute; left: 20%; bottom: 58px; width: 4px; height: 170px; background: #B9C8D9; border-radius: 99px; }
.css-visual .panel { position: absolute; left: 19%; bottom: 62px; width: 210px; height: 10px; border-radius: 99px; background: var(--primary); transform: rotate(-28deg); transform-origin: left center; box-shadow: 10px 10px 0 rgba(10,47,107,.08); }
.css-visual .ray { position: absolute; right: 18%; top: 74px; width: 150px; height: 7px; border-radius: 99px; background: var(--secondary); transform: rotate(-42deg); transform-origin: right center; }
.css-visual .sun-dot { position: absolute; right: 16%; top: 48px; width: 54px; height: 54px; border-radius: 50%; background: var(--secondary); box-shadow: 0 0 0 20px rgba(245,180,0,.14); }
.css-visual .arc { position: absolute; left: 18%; bottom: 52px; width: 120px; height: 120px; border: 6px dashed var(--accent); border-right-color: transparent; border-top-color: transparent; border-radius: 50%; }
.css-visual .visual-caption { position: absolute; left: 0; right: 0; bottom: 16px; text-align: center; color: var(--muted); font-weight: 900; font-size: 13px; }
.css-visual.map .node { position: absolute; top: 72px; width: 92px; height: 58px; border-radius: 12px; display: grid; place-items: center; font-weight: 900; color: var(--primary); background: #EAF7FF; border: 1px solid var(--border); }
.css-visual.map .node:nth-child(2) { left: 12%; }
.css-visual.map .node:nth-child(3) { left: calc(50% - 46px); background: #FFF4CC; color: #7C4A00; border-color: #F7D36C; }
.css-visual.map .node:nth-child(4) { right: 12%; }
.css-visual.map .flow { position: absolute; left: 18%; right: 18%; top: 168px; height: 70px; border-bottom: 6px solid var(--accent); border-radius: 0 0 50% 50%; }
.css-visual.network .hub { position: absolute; left: calc(50% - 44px); top: 54px; width: 88px; height: 88px; border-radius: 50%; background: var(--primary-dark); color: #fff; display: grid; place-items: center; font-weight: 900; }
.css-visual.network .mini { position: absolute; bottom: 64px; width: 66px; height: 66px; border-radius: 50%; background: #EAF7FF; border: 1px solid var(--border); }
.css-visual.network .mini.a { left: 17%; }
.css-visual.network .mini.b { left: calc(50% - 33px); background: #FFF4CC; border-color: #F7D36C; }
.css-visual.network .mini.c { right: 17%; }
.css-visual.bars .bar { position: absolute; bottom: 58px; width: 48px; border-radius: 9px 9px 0 0; background: var(--primary); }
.css-visual.bars .bar.a { left: 22%; height: 88px; }
.css-visual.bars .bar.b { left: 38%; height: 136px; background: var(--accent); }
.css-visual.bars .bar.c { left: 54%; height: 72px; background: var(--secondary); }
.css-visual.bars .bar.d { left: 70%; height: 126px; }
.css-visual.compass .dial { position: absolute; left: calc(50% - 112px); top: 48px; width: 224px; height: 224px; border: 3px solid #D7E3F2; border-radius: 50%; }
.css-visual.compass .needle { position: absolute; left: calc(50% - 4px); top: 84px; width: 8px; height: 118px; background: var(--secondary); border-radius: 99px; transform: rotate(35deg); transform-origin: 50% 86%; }
.css-visual.compass b { position: absolute; color: var(--primary); }
.css-visual.compass .n { left: calc(50% - 7px); top: 62px; }
.css-visual.compass .s { left: calc(50% - 7px); bottom: 60px; }
.css-visual.compass .e { right: calc(50% - 94px); top: 150px; }
.css-visual.compass .w { left: calc(50% - 94px); top: 150px; }
.css-visual.questions .qbox { border: 1px solid var(--border); border-radius: 8px; background: #F8FBFF; padding: 12px 14px; font-weight: 900; color: var(--primary); }
.orientation-board { min-height: 380px; background:
  radial-gradient(circle at 76% 24%, rgba(245,180,0,.20), transparent 18%),
  linear-gradient(180deg, #fff, #F8FBFF); }
.orientation-board .roof-plane { position: absolute; left: 12%; right: 12%; bottom: 74px; height: 86px; border-radius: 12px; background: linear-gradient(135deg, #0A2F6B, #0B4FA8); transform: skewX(-14deg); box-shadow: 0 18px 34px rgba(10,47,107,.14); }
.orientation-board .roof-plane:before { content: ""; position: absolute; inset: 14px; border: 1px solid rgba(255,255,255,.32); border-radius: 7px; }
.orientation-board .compass-rail { position: absolute; left: 13%; right: 13%; bottom: 42px; height: 8px; border-radius: 999px; background: #D7E3F2; }
.orientation-board .compass-rail span { position: absolute; top: 16px; color: var(--primary); font-weight: 900; font-size: 12px; }
.orientation-board .compass-rail .west { left: 0; }
.orientation-board .compass-rail .south { left: 50%; transform: translateX(-50%); }
.orientation-board .compass-rail .east { right: 0; }
.orientation-board .azimuth-beam { position: absolute; left: 50%; bottom: 50px; width: 8px; height: 160px; border-radius: 999px; background: var(--secondary); transform: rotate(36deg); transform-origin: bottom center; box-shadow: 0 0 0 12px rgba(245,180,0,.13); }
.orientation-board .azimuth-tag { position: absolute; right: 10%; top: 138px; background: var(--primary-dark); color: #fff; border-radius: 8px; padding: 9px 12px; font-weight: 900; font-size: 13px; white-space: nowrap; }
.orientation-board .direction-pills { position: absolute; left: 10%; top: 146px; display: grid; gap: 8px; max-width: 190px; }
.orientation-board .direction-pills span { display: inline-flex; background: #EAF7FF; border: 1px solid var(--border); color: var(--primary); border-radius: 999px; padding: 7px 10px; font-size: 12px; font-weight: 900; }
.orientation-board .visual-caption { position: absolute; left: 28px; right: 28px; top: 76px; bottom: auto; margin: 0; color: var(--body); font-weight: 800; text-align: left; line-height: 1.42; }
.orientation-board.dark { background:
  radial-gradient(circle at 76% 24%, rgba(245,180,0,.28), transparent 18%),
  linear-gradient(180deg, #08285C, #061E45); }
.orientation-board.dark .roof-plane { background: linear-gradient(135deg, #1E63C6, #0B4FA8); box-shadow: 0 18px 34px rgba(0,0,0,.2); }
.orientation-board.dark .compass-rail { background: rgba(234,247,255,.62); }
.orientation-board.dark .compass-rail span { color: #EAF7FF; }
.orientation-board.dark .direction-pills span { background: rgba(232,247,255,.12); color: #EAF7FF; border-color: rgba(232,247,255,.22); }
.orientation-board.dark .visual-caption { color: #EAF7FF; }
.visual-card.dark { background: var(--primary-dark); color: #fff; }
.visual-card.dark .eyebrow { background: rgba(232,247,255,.95); color: var(--primary); border-color: rgba(255,255,255,.3); }
.visual-card.dark .visual-caption { color: #EAF7FF; }
.visual-card.dark.css-visual.compass .dial { border-color: rgba(234,247,255,.92); }
.visual-card.dark.css-visual.compass b { color: #D9ECFF; }
.visual-card.dark .base, .visual-card.dark .vertical { background: rgba(234,247,255,.7); }
.calc-compass { display: grid; place-items: center; min-height: 300px; }
.calc-compass .dial { position: relative; width: 230px; height: 230px; border: 3px solid #D7E3F2; border-radius: 50%; }
.calc-compass .needle { position: absolute; width: 8px; height: 110px; left: calc(50% - 4px); top: 30px; background: var(--secondary); border-radius: 999px; transform: rotate(35deg); transform-origin: 50% 86%; }
.calc-compass span { position: absolute; font-weight: 900; color: var(--primary); }
.calc-compass .n { top: 12px; left: 50%; transform: translateX(-50%); }
.calc-compass .s { bottom: 12px; left: 50%; transform: translateX(-50%); }
.calc-compass .e { right: 16px; top: 50%; transform: translateY(-50%); }
.calc-compass .w { left: 16px; top: 50%; transform: translateY(-50%); }
.menu-heading, .footer-heading { display: block; color: var(--primary); font-size: 12px; font-weight: 900; letter-spacing: .08em; text-transform: uppercase; margin-bottom: 12px; }
.site-footer .footer-heading { color: var(--text); font-size: 15px; letter-spacing: 0; text-transform: none; }
.calc-page-field-grid { display: grid; gap: 14px; }
.review-shell { background: rgba(255,255,255,.76); border: 1px solid var(--border); border-radius: 12px; padding: 18px; box-shadow: 0 12px 30px rgba(10,47,107,.08); overflow: hidden; }
@media (max-width: 980px) {
  .calc-page-tool-grid, .calc-output-visual, .tool-trust-row, .calc-check-grid { grid-template-columns: 1fr; }
  .calc-input-grid { grid-template-columns: 1fr; }
  .calc-result-card .section-grid, .calc-result-detail .entity-card-grid { grid-template-columns: 1fr; }
}


body.solar-angle-homepage-template .calculator-page-main { background: #F6F8FB; }
.calc-page-hero { position: relative; overflow: hidden; padding: 82px 0 46px; background: #EAF7FF url("/wp-content/themes/generatepress-child-solar-angle/assets/solar-hero-bg.svg") center/cover no-repeat; border-bottom: 1px solid var(--border); }
.calc-page-hero:before { content: ""; position: absolute; inset: 0; background: rgba(245,250,255,.70); }
.calc-page-hero .container { position: relative; z-index: 1; }
.calc-page-hero-inner { max-width: 900px; margin: 0 auto; text-align: center; }
.calc-page-hero p { max-width: 760px; margin: 14px auto 0; font-size: 18px; color: var(--body); }
.calc-page-badges { display: flex; justify-content: center; flex-wrap: wrap; gap: 10px; margin-top: 24px; }
.calc-page-badges span { border: 1px solid rgba(10,47,107,.16); background: rgba(255,255,255,.72); color: var(--primary); padding: 8px 12px; border-radius: 999px; font-size: 12px; font-weight: 900; }
.calc-tool-section { padding: 42px 0 34px; background: linear-gradient(180deg, rgba(232,245,255,.84), #F6F8FB); }
.calc-page-tool { background: #fff; border: 1px solid var(--border); border-radius: 14px; padding: 28px; box-shadow: var(--shadow); }
.calc-page-tool-grid { display: grid; grid-template-columns: minmax(0, 1fr) minmax(340px, .54fr); gap: 28px; align-items: stretch; }
.calc-input-grid { display: grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap: 16px; }
.calc-field label { display: block; color: var(--muted); font-size: 12px; font-weight: 900; margin-bottom: 7px; }
.fake-input, .fake-select { width: 100%; min-height: 54px; border: 1px solid var(--border); border-radius: 7px; padding: 14px; font: inherit; color: var(--text); background: #fff; display: flex; align-items: center; justify-content: space-between; gap: 12px; }
.fake-input { color: #64748B; }
.fake-select:after { content: "v"; color: var(--primary); font-weight: 900; font-size: 12px; }
.calc-control { width: 100%; min-height: 54px; border: 1px solid var(--border); border-radius: 7px; padding: 14px; font: inherit; color: var(--text); background: #fff; }
.calc-control::placeholder { color: #64748B; opacity: 1; }
.calc-control:focus { outline: 3px solid rgba(24,169,216,.18); border-color: var(--accent); }
.check-form .calc-control { min-height: 50px; }
.calc-control-proxy { width: 100%; min-height: 54px; border: 1px solid var(--border); border-radius: 7px; padding: 14px; font: inherit; color: #64748B; background: #fff; display: flex; align-items: center; }
.tool-display-title { font-size: clamp(36px, 5vw, 56px); line-height: 1.04; letter-spacing: -0.045em; color: var(--text); font-weight: 500; margin: 12px 0 16px; }
.output-display-title { font-size: clamp(34px, 4vw, 52px); line-height: 1.05; color: #fff; font-weight: 800; margin: 8px 0 12px; }
.calc-page-preview { background: linear-gradient(180deg, #F8FBFF, #EEF6FF); border: 1px solid var(--border); border-radius: 10px; padding: 22px; display: grid; gap: 16px; }
.calc-result-line { display: flex; justify-content: space-between; gap: 12px; padding-bottom: 12px; border-bottom: 1px solid var(--border); color: var(--muted); }
.calc-result-line b { color: var(--primary-dark); }
.calc-page-actions { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 18px; }
.calc-page-actions button, .calc-page-actions a { border: 1px solid var(--border); background: #fff; color: var(--primary); padding: 12px 16px; border-radius: 7px; font-weight: 900; text-decoration: none; cursor: pointer; }
.calc-page-actions .primary { background: var(--secondary); border-color: #D99600; color: #171100; }
.calc-output-visual { background: var(--primary-dark); color: #fff; border-radius: 14px; padding: 24px; display: grid; grid-template-columns: minmax(0,1fr) minmax(300px,.65fr); gap: 26px; align-items: center; margin-top: 30px; }
.calc-output-visual h2, .calc-output-visual p { color: #fff; }
.calc-output-visual svg { width: 100%; background: rgba(255,255,255,.05); border: 1px dashed rgba(255,255,255,.28); border-radius: 12px; }
.calc-result-section { padding: 56px 0; background: #fff; }
.calc-result-card { border: 1px solid var(--border); border-radius: 14px; padding: 34px; background: #fff; box-shadow: var(--shadow); }
.calc-result-card .section-grid { padding: 0; }
.calc-result-card .content-panel { box-shadow: none; border: 0; padding: 0; }
.calc-result-card .content-panel h2 { font-size: clamp(36px, 4.2vw, 52px); }
.calc-result-card .section-grid { grid-template-columns: minmax(0, 1.25fr) minmax(380px, .75fr); gap: 34px; align-items: stretch; }
.calc-result-detail { border-top: 1px solid var(--border); margin-top: 28px; padding-top: 26px; }
.calc-result-detail .entity-card-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.calc-result-detail .entity-card { min-height: 100%; }
.calc-result-detail .entity-card h3 { font-size: 19px; }
.result-action-row { display: flex; flex-wrap: wrap; gap: 12px; padding-top: 22px; margin-top: 22px; border-top: 1px solid var(--border); }
.result-action-row button { border: 1px solid var(--border); background: #fff; color: var(--primary); padding: 13px 18px; border-radius: 7px; font-weight: 900; cursor: pointer; }
.result-action-row .primary { background: var(--secondary); border-color: #D99600; color: #171100; }
.tool-trust-row { display: grid; grid-template-columns: minmax(0, .9fr) minmax(0, 1.1fr); gap: 18px; margin-top: 22px; }
.calc-review-section { padding: 54px 0; background: linear-gradient(180deg, #EAF4FF, #F6F8FB); }
.calc-check-section { padding: 54px 0; }
.calc-check-card { background: #fff; border: 1px solid var(--border); border-radius: 12px; padding: 34px; box-shadow: var(--shadow); border-left: 7px solid var(--primary); }
.calc-check-grid { display: grid; grid-template-columns: minmax(0,.86fr) minmax(0,1fr); gap: 28px; align-items: start; }
.calc-check-copy h2 { font-size: clamp(34px, 5vw, 58px); line-height: 1.05; }
.calc-check-copy .section-title-like, .review-title-like { font-size: clamp(34px, 5vw, 58px); line-height: 1.05; letter-spacing: -0.045em; color: var(--text); margin: 12px 0 16px; }
.review-title-like { font-size: clamp(32px, 4vw, 48px); }
.calc-check-copy ul { margin-top: 16px; }
.check-form { display: grid; gap: 12px; align-content: start; }
.check-form label { color: var(--muted); font-size: 12px; font-weight: 900; margin-top: 4px; }
.check-form > button { margin-top: 8px; border: 0; background: var(--primary); color: #fff; border-radius: 8px; padding: 15px 18px; font-weight: 900; cursor: pointer; }
.fake-checkbox { width: 18px; height: 18px; border: 1px solid var(--border); border-radius: 4px; background: #fff; display: inline-block; flex: 0 0 auto; }
.consent { display: flex; align-items: flex-start; gap: 10px; line-height: 1.45; }
.calc-page-content { padding: 30px 0 70px; }
.calc-page-content .content-panel h2 { font-size: clamp(34px, 4vw, 58px); }
.calculator-page-main .site-section { padding: 48px 0; }
.calculator-page-main .visual-card svg { width: 100%; height: auto; display: block; }
.css-visual { position: relative; min-height: 300px; overflow: hidden; }
.css-visual .base { position: absolute; left: 12%; right: 12%; bottom: 58px; height: 4px; background: #B9C8D9; border-radius: 99px; }
.css-visual .vertical { position: absolute; left: 20%; bottom: 58px; width: 4px; height: 170px; background: #B9C8D9; border-radius: 99px; }
.css-visual .panel { position: absolute; left: 19%; bottom: 62px; width: 210px; height: 10px; border-radius: 99px; background: var(--primary); transform: rotate(-28deg); transform-origin: left center; box-shadow: 10px 10px 0 rgba(10,47,107,.08); }
.css-visual .ray { position: absolute; right: 18%; top: 74px; width: 150px; height: 7px; border-radius: 99px; background: var(--secondary); transform: rotate(-42deg); transform-origin: right center; }
.css-visual .sun-dot { position: absolute; right: 16%; top: 48px; width: 54px; height: 54px; border-radius: 50%; background: var(--secondary); box-shadow: 0 0 0 20px rgba(245,180,0,.14); }
.css-visual .arc { position: absolute; left: 18%; bottom: 52px; width: 120px; height: 120px; border: 6px dashed var(--accent); border-right-color: transparent; border-top-color: transparent; border-radius: 50%; }
.css-visual .visual-caption { position: absolute; left: 0; right: 0; bottom: 16px; text-align: center; color: var(--muted); font-weight: 900; font-size: 13px; }
.css-visual.map .node { position: absolute; top: 72px; width: 92px; height: 58px; border-radius: 12px; display: grid; place-items: center; font-weight: 900; color: var(--primary); background: #EAF7FF; border: 1px solid var(--border); }
.css-visual.map .node:nth-child(2) { left: 12%; }
.css-visual.map .node:nth-child(3) { left: calc(50% - 46px); background: #FFF4CC; color: #7C4A00; border-color: #F7D36C; }
.css-visual.map .node:nth-child(4) { right: 12%; }
.css-visual.map .flow { position: absolute; left: 18%; right: 18%; top: 168px; height: 70px; border-bottom: 6px solid var(--accent); border-radius: 0 0 50% 50%; }
.css-visual.network .hub { position: absolute; left: calc(50% - 44px); top: 54px; width: 88px; height: 88px; border-radius: 50%; background: var(--primary-dark); color: #fff; display: grid; place-items: center; font-weight: 900; }
.css-visual.network .mini { position: absolute; bottom: 64px; width: 66px; height: 66px; border-radius: 50%; background: #EAF7FF; border: 1px solid var(--border); }
.css-visual.network .mini.a { left: 17%; }
.css-visual.network .mini.b { left: calc(50% - 33px); background: #FFF4CC; border-color: #F7D36C; }
.css-visual.network .mini.c { right: 17%; }
.css-visual.bars .bar { position: absolute; bottom: 58px; width: 48px; border-radius: 9px 9px 0 0; background: var(--primary); }
.css-visual.bars .bar.a { left: 22%; height: 88px; }
.css-visual.bars .bar.b { left: 38%; height: 136px; background: var(--accent); }
.css-visual.bars .bar.c { left: 54%; height: 72px; background: var(--secondary); }
.css-visual.bars .bar.d { left: 70%; height: 126px; }
.css-visual.compass .dial { position: absolute; left: calc(50% - 112px); top: 48px; width: 224px; height: 224px; border: 3px solid #D7E3F2; border-radius: 50%; }
.css-visual.compass .needle { position: absolute; left: calc(50% - 4px); top: 84px; width: 8px; height: 118px; background: var(--secondary); border-radius: 99px; transform: rotate(35deg); transform-origin: 50% 86%; }
.css-visual.compass b { position: absolute; color: var(--primary); }
.css-visual.compass .n { left: calc(50% - 7px); top: 62px; }
.css-visual.compass .s { left: calc(50% - 7px); bottom: 60px; }
.css-visual.compass .e { right: calc(50% - 94px); top: 150px; }
.css-visual.compass .w { left: calc(50% - 94px); top: 150px; }
.css-visual.questions .qbox { border: 1px solid var(--border); border-radius: 8px; background: #F8FBFF; padding: 12px 14px; font-weight: 900; color: var(--primary); }
.orientation-board { min-height: 380px; background:
  radial-gradient(circle at 76% 22%, rgba(245,180,0,.18), transparent 18%),
  linear-gradient(180deg, #fff, #F8FBFF); }
.orientation-board .visual-caption { position: absolute; left: 28px; right: 28px; top: 74px; bottom: auto; margin: 0; color: var(--body); font-weight: 850; text-align: left; line-height: 1.42; max-width: 360px; }
.orientation-board .compass-disc { position: absolute; left: 50%; bottom: 46px; width: 220px; height: 220px; transform: translateX(-50%); border: 3px solid #D7E3F2; border-radius: 50%; background: radial-gradient(circle, rgba(232,247,255,.72), rgba(255,255,255,.2)); box-shadow: inset 0 0 0 34px rgba(234,247,255,.42); }
.orientation-board .compass-disc:before { content: ""; position: absolute; inset: 34px; border: 1px dashed rgba(10,47,107,.22); border-radius: 50%; }
.orientation-board .compass-disc span { position: absolute; color: var(--primary); font-weight: 900; font-size: 15px; }
.orientation-board .compass-disc .north { left: 50%; top: 12px; transform: translateX(-50%); }
.orientation-board .compass-disc .east { right: 16px; top: 50%; transform: translateY(-50%); }
.orientation-board .compass-disc .south { left: 50%; bottom: 12px; transform: translateX(-50%); }
.orientation-board .compass-disc .west { left: 16px; top: 50%; transform: translateY(-50%); }
.orientation-board .azimuth-beam { position: absolute; left: 50%; bottom: 156px; width: 9px; height: 92px; border-radius: 999px; background: var(--secondary); transform: rotate(38deg); transform-origin: bottom center; box-shadow: 0 0 0 14px rgba(245,180,0,.12); }
.orientation-board .azimuth-tag { position: absolute; right: 32px; top: 126px; background: var(--primary-dark); color: #fff; border-radius: 8px; padding: 9px 12px; font-weight: 900; font-size: 13px; white-space: nowrap; }
.orientation-board .direction-pills { position: absolute; left: 28px; bottom: 42px; display: grid; gap: 8px; max-width: 170px; }
.orientation-board .direction-pills span { display: inline-flex; background: #EAF7FF; border: 1px solid var(--border); color: var(--primary); border-radius: 999px; padding: 7px 10px; font-size: 12px; font-weight: 900; }
.orientation-board.dark { background:
  radial-gradient(circle at 76% 22%, rgba(245,180,0,.24), transparent 18%),
  linear-gradient(180deg, #08285C, #061E45); }
.orientation-board.dark .visual-caption { color: #EAF7FF; }
.orientation-board.dark .compass-disc { border-color: rgba(234,247,255,.78); background: radial-gradient(circle, rgba(24,169,216,.10), rgba(255,255,255,.03)); box-shadow: inset 0 0 0 34px rgba(234,247,255,.06); }
.orientation-board.dark .compass-disc:before { border-color: rgba(234,247,255,.26); }
.orientation-board.dark .compass-disc span { color: #EAF7FF; }
.orientation-board.dark .direction-pills span { background: rgba(232,247,255,.12); color: #EAF7FF; border-color: rgba(232,247,255,.22); }
.visual-card.dark { background: var(--primary-dark); color: #fff; }
.visual-card.dark .eyebrow { background: rgba(232,247,255,.95); color: var(--primary); border-color: rgba(255,255,255,.3); }
.visual-card.dark .visual-caption { color: #EAF7FF; }
.visual-card.dark.css-visual.compass .dial { border-color: rgba(234,247,255,.92); }
.visual-card.dark.css-visual.compass b { color: #D9ECFF; }
.visual-card.dark .base, .visual-card.dark .vertical { background: rgba(234,247,255,.7); }
.calc-compass { display: grid; place-items: center; min-height: 300px; }
.calc-compass .dial { position: relative; width: 230px; height: 230px; border: 3px solid #D7E3F2; border-radius: 50%; }
.calc-compass .needle { position: absolute; width: 8px; height: 110px; left: calc(50% - 4px); top: 30px; background: var(--secondary); border-radius: 999px; transform: rotate(35deg); transform-origin: 50% 86%; }
.calc-compass span { position: absolute; font-weight: 900; color: var(--primary); }
.calc-compass .n { top: 12px; left: 50%; transform: translateX(-50%); }
.calc-compass .s { bottom: 12px; left: 50%; transform: translateX(-50%); }
.calc-compass .e { right: 16px; top: 50%; transform: translateY(-50%); }
.calc-compass .w { left: 16px; top: 50%; transform: translateY(-50%); }
.menu-heading, .footer-heading { display: block; color: var(--primary); font-size: 12px; font-weight: 900; letter-spacing: .08em; text-transform: uppercase; margin-bottom: 12px; }
.site-footer .footer-heading { color: var(--text); font-size: 15px; letter-spacing: 0; text-transform: none; }
.calc-page-field-grid { display: grid; gap: 14px; }
.review-shell { background: rgba(255,255,255,.76); border: 1px solid var(--border); border-radius: 12px; padding: 18px; box-shadow: 0 12px 30px rgba(10,47,107,.08); overflow: hidden; }
@media (max-width: 980px) {
  .calc-page-tool-grid, .calc-output-visual, .tool-trust-row, .calc-check-grid { grid-template-columns: 1fr; }
  .calc-input-grid { grid-template-columns: 1fr; }
  .calc-result-card .section-grid, .calc-result-detail .entity-card-grid { grid-template-columns: 1fr; }
}


body.solar-angle-homepage-template .calculator-page-main { background: #F6F8FB; }
.calc-page-hero { position: relative; overflow: hidden; padding: 82px 0 46px; background: #EAF7FF url("/wp-content/themes/generatepress-child-solar-angle/assets/solar-hero-bg.svg") center/cover no-repeat; border-bottom: 1px solid var(--border); }
.calc-page-hero:before { content: ""; position: absolute; inset: 0; background: rgba(245,250,255,.70); }
.calc-page-hero .container { position: relative; z-index: 1; }
.calc-page-hero-inner { max-width: 900px; margin: 0 auto; text-align: center; }
.calc-page-hero p { max-width: 760px; margin: 14px auto 0; font-size: 18px; color: var(--body); }
.calc-page-badges { display: flex; justify-content: center; flex-wrap: wrap; gap: 10px; margin-top: 24px; }
.calc-page-badges span { border: 1px solid rgba(10,47,107,.16); background: rgba(255,255,255,.72); color: var(--primary); padding: 8px 12px; border-radius: 999px; font-size: 12px; font-weight: 900; }
.calc-tool-section { padding: 42px 0 34px; background: linear-gradient(180deg, rgba(232,245,255,.84), #F6F8FB); }
.calc-page-tool { background: #fff; border: 1px solid var(--border); border-radius: 14px; padding: 28px; box-shadow: var(--shadow); }
.calc-page-tool-grid { display: grid; grid-template-columns: minmax(0, 1fr) minmax(340px, .54fr); gap: 28px; align-items: stretch; }
.calc-input-grid { display: grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap: 16px; }
.calc-field label { display: block; color: var(--muted); font-size: 12px; font-weight: 900; margin-bottom: 7px; }
.fake-input, .fake-select { width: 100%; min-height: 54px; border: 1px solid var(--border); border-radius: 7px; padding: 14px; font: inherit; color: var(--text); background: #fff; display: flex; align-items: center; justify-content: space-between; gap: 12px; }
.fake-input { color: #64748B; }
.fake-select:after { content: "v"; color: var(--primary); font-weight: 900; font-size: 12px; }
.calc-control { width: 100%; min-height: 54px; border: 1px solid var(--border); border-radius: 7px; padding: 14px; font: inherit; color: var(--text); background: #fff; }
.calc-control::placeholder { color: #64748B; opacity: 1; }
.calc-control:focus { outline: 3px solid rgba(24,169,216,.18); border-color: var(--accent); }
.check-form .calc-control { min-height: 50px; }
.calc-control-proxy { width: 100%; min-height: 54px; border: 1px solid var(--border); border-radius: 7px; padding: 14px; font: inherit; color: #64748B; background: #fff; display: flex; align-items: center; }
.tool-display-title { font-size: clamp(36px, 5vw, 56px); line-height: 1.04; letter-spacing: -0.045em; color: var(--text); font-weight: 500; margin: 12px 0 16px; }
.output-display-title { font-size: clamp(34px, 4vw, 52px); line-height: 1.05; color: #fff; font-weight: 800; margin: 8px 0 12px; }
.calc-page-preview { background: linear-gradient(180deg, #F8FBFF, #EEF6FF); border: 1px solid var(--border); border-radius: 10px; padding: 22px; display: grid; gap: 16px; }
.calc-result-line { display: flex; justify-content: space-between; gap: 12px; padding-bottom: 12px; border-bottom: 1px solid var(--border); color: var(--muted); }
.calc-result-line b { color: var(--primary-dark); }
.calc-page-actions { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 18px; }
.calc-page-actions button, .calc-page-actions a { border: 1px solid var(--border); background: #fff; color: var(--primary); padding: 12px 16px; border-radius: 7px; font-weight: 900; text-decoration: none; cursor: pointer; }
.calc-page-actions .primary { background: var(--secondary); border-color: #D99600; color: #171100; }
.calc-output-visual { background: var(--primary-dark); color: #fff; border-radius: 14px; padding: 24px; display: grid; grid-template-columns: minmax(0,1fr) minmax(300px,.65fr); gap: 26px; align-items: center; margin-top: 30px; }
.calc-output-visual h2, .calc-output-visual p { color: #fff; }
.calc-output-visual svg { width: 100%; background: rgba(255,255,255,.05); border: 1px dashed rgba(255,255,255,.28); border-radius: 12px; }
.calc-result-section { padding: 56px 0; background: #fff; }
.calc-result-card { border: 1px solid var(--border); border-radius: 14px; padding: 34px; background: #fff; box-shadow: var(--shadow); }
.calc-result-card .section-grid { padding: 0; }
.calc-result-card .content-panel { box-shadow: none; border: 0; padding: 0; }
.calc-result-card .content-panel h2 { font-size: clamp(36px, 4.2vw, 52px); }
.calc-result-card .section-grid { grid-template-columns: minmax(0, 1.25fr) minmax(380px, .75fr); gap: 34px; align-items: stretch; }
.calc-result-detail { border-top: 1px solid var(--border); margin-top: 28px; padding-top: 26px; }
.calc-result-detail .entity-card-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.calc-result-detail .entity-card { min-height: 100%; }
.calc-result-detail .entity-card h3 { font-size: 19px; }
.result-action-row { display: flex; flex-wrap: wrap; gap: 12px; padding-top: 22px; margin-top: 22px; border-top: 1px solid var(--border); }
.result-action-row button { border: 1px solid var(--border); background: #fff; color: var(--primary); padding: 13px 18px; border-radius: 7px; font-weight: 900; cursor: pointer; }
.result-action-row .primary { background: var(--secondary); border-color: #D99600; color: #171100; }
.tool-trust-row { display: grid; grid-template-columns: minmax(0, .9fr) minmax(0, 1.1fr); gap: 18px; margin-top: 22px; }
.calc-review-section { padding: 54px 0; background: linear-gradient(180deg, #EAF4FF, #F6F8FB); }
.calc-check-section { padding: 54px 0; }
.calc-check-card { background: #fff; border: 1px solid var(--border); border-radius: 12px; padding: 34px; box-shadow: var(--shadow); border-left: 7px solid var(--primary); }
.calc-check-grid { display: grid; grid-template-columns: minmax(0,.86fr) minmax(0,1fr); gap: 28px; align-items: start; }
.calc-check-copy h2 { font-size: clamp(34px, 5vw, 58px); line-height: 1.05; }
.calc-check-copy .section-title-like, .review-title-like { font-size: clamp(34px, 5vw, 58px); line-height: 1.05; letter-spacing: -0.045em; color: var(--text); margin: 12px 0 16px; }
.review-title-like { font-size: clamp(32px, 4vw, 48px); }
.calc-check-copy ul { margin-top: 16px; }
.check-form { display: grid; gap: 12px; align-content: start; }
.check-form label { color: var(--muted); font-size: 12px; font-weight: 900; margin-top: 4px; }
.check-form > button { margin-top: 8px; border: 0; background: var(--primary); color: #fff; border-radius: 8px; padding: 15px 18px; font-weight: 900; cursor: pointer; }
.fake-checkbox { width: 18px; height: 18px; border: 1px solid var(--border); border-radius: 4px; background: #fff; display: inline-block; flex: 0 0 auto; }
.consent { display: flex; align-items: flex-start; gap: 10px; line-height: 1.45; }
.calc-page-content { padding: 30px 0 70px; }
.calc-page-content .content-panel h2 { font-size: clamp(34px, 4vw, 58px); }
.calculator-page-main .site-section { padding: 48px 0; }
.calculator-page-main .visual-card svg { width: 100%; height: auto; display: block; }
.css-visual { position: relative; min-height: 300px; overflow: hidden; }
.css-visual .base { position: absolute; left: 12%; right: 12%; bottom: 58px; height: 4px; background: #B9C8D9; border-radius: 99px; }
.css-visual .vertical { position: absolute; left: 20%; bottom: 58px; width: 4px; height: 170px; background: #B9C8D9; border-radius: 99px; }
.css-visual .panel { position: absolute; left: 19%; bottom: 62px; width: 210px; height: 10px; border-radius: 99px; background: var(--primary); transform: rotate(-28deg); transform-origin: left center; box-shadow: 10px 10px 0 rgba(10,47,107,.08); }
.css-visual .ray { position: absolute; right: 18%; top: 74px; width: 150px; height: 7px; border-radius: 99px; background: var(--secondary); transform: rotate(-42deg); transform-origin: right center; }
.css-visual .sun-dot { position: absolute; right: 16%; top: 48px; width: 54px; height: 54px; border-radius: 50%; background: var(--secondary); box-shadow: 0 0 0 20px rgba(245,180,0,.14); }
.css-visual .arc { position: absolute; left: 18%; bottom: 52px; width: 120px; height: 120px; border: 6px dashed var(--accent); border-right-color: transparent; border-top-color: transparent; border-radius: 50%; }
.css-visual .visual-caption { position: absolute; left: 0; right: 0; bottom: 16px; text-align: center; color: var(--muted); font-weight: 900; font-size: 13px; }
.css-visual.map .node { position: absolute; top: 72px; width: 92px; height: 58px; border-radius: 12px; display: grid; place-items: center; font-weight: 900; color: var(--primary); background: #EAF7FF; border: 1px solid var(--border); }
.css-visual.map .node:nth-child(2) { left: 12%; }
.css-visual.map .node:nth-child(3) { left: calc(50% - 46px); background: #FFF4CC; color: #7C4A00; border-color: #F7D36C; }
.css-visual.map .node:nth-child(4) { right: 12%; }
.css-visual.map .flow { position: absolute; left: 18%; right: 18%; top: 168px; height: 70px; border-bottom: 6px solid var(--accent); border-radius: 0 0 50% 50%; }
.css-visual.network .hub { position: absolute; left: calc(50% - 44px); top: 54px; width: 88px; height: 88px; border-radius: 50%; background: var(--primary-dark); color: #fff; display: grid; place-items: center; font-weight: 900; }
.css-visual.network .mini { position: absolute; bottom: 64px; width: 66px; height: 66px; border-radius: 50%; background: #EAF7FF; border: 1px solid var(--border); }
.css-visual.network .mini.a { left: 17%; }
.css-visual.network .mini.b { left: calc(50% - 33px); background: #FFF4CC; border-color: #F7D36C; }
.css-visual.network .mini.c { right: 17%; }
.css-visual.bars .bar { position: absolute; bottom: 58px; width: 48px; border-radius: 9px 9px 0 0; background: var(--primary); }
.css-visual.bars .bar.a { left: 22%; height: 88px; }
.css-visual.bars .bar.b { left: 38%; height: 136px; background: var(--accent); }
.css-visual.bars .bar.c { left: 54%; height: 72px; background: var(--secondary); }
.css-visual.bars .bar.d { left: 70%; height: 126px; }
.css-visual.compass .dial { position: absolute; left: calc(50% - 112px); top: 48px; width: 224px; height: 224px; border: 3px solid #D7E3F2; border-radius: 50%; }
.css-visual.compass .needle { position: absolute; left: calc(50% - 4px); top: 84px; width: 8px; height: 118px; background: var(--secondary); border-radius: 99px; transform: rotate(35deg); transform-origin: 50% 86%; }
.css-visual.compass b { position: absolute; color: var(--primary); }
.css-visual.compass .n { left: calc(50% - 7px); top: 62px; }
.css-visual.compass .s { left: calc(50% - 7px); bottom: 60px; }
.css-visual.compass .e { right: calc(50% - 94px); top: 150px; }
.css-visual.compass .w { left: calc(50% - 94px); top: 150px; }
.css-visual.questions .qbox { border: 1px solid var(--border); border-radius: 8px; background: #F8FBFF; padding: 12px 14px; font-weight: 900; color: var(--primary); }
.orientation-board { min-height: 520px; background:
  radial-gradient(circle at 76% 22%, rgba(245,180,0,.18), transparent 18%),
  linear-gradient(180deg, #fff, #F8FBFF); }
.orientation-board .visual-caption { position: absolute; left: 28px; right: 28px; top: 74px; bottom: auto; margin: 0; color: var(--body); font-weight: 850; text-align: left; line-height: 1.42; max-width: 360px; }
.orientation-board .compass-disc { position: absolute; left: 50%; top: 190px; width: 230px; height: 230px; transform: translateX(-50%); border: 3px solid #D7E3F2; border-radius: 50%; background: radial-gradient(circle, rgba(232,247,255,.72), rgba(255,255,255,.2)); box-shadow: inset 0 0 0 34px rgba(234,247,255,.42); }
.orientation-board .compass-disc:before { content: ""; position: absolute; inset: 34px; border: 1px dashed rgba(10,47,107,.22); border-radius: 50%; }
.orientation-board .compass-disc span { position: absolute; color: var(--primary); font-weight: 900; font-size: 15px; }
.orientation-board .compass-disc .north { left: 50%; top: 12px; transform: translateX(-50%); }
.orientation-board .compass-disc .east { right: 16px; top: 50%; transform: translateY(-50%); }
.orientation-board .compass-disc .south { left: 50%; bottom: 12px; transform: translateX(-50%); }
.orientation-board .compass-disc .west { left: 16px; top: 50%; transform: translateY(-50%); }
.orientation-board .azimuth-beam { position: absolute; left: 50%; top: 250px; width: 9px; height: 96px; border-radius: 999px; background: var(--secondary); transform: rotate(38deg); transform-origin: bottom center; box-shadow: 0 0 0 14px rgba(245,180,0,.12); }
.orientation-board .azimuth-tag { position: absolute; right: 32px; top: 144px; background: var(--primary-dark); color: #fff; border-radius: 8px; padding: 9px 12px; font-weight: 900; font-size: 13px; white-space: nowrap; }
.orientation-board .direction-pills { position: absolute; left: 24px; right: 24px; bottom: 28px; display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 8px; }
.orientation-board .direction-pills span { display: inline-flex; justify-content: center; text-align: center; background: #EAF7FF; border: 1px solid var(--border); color: var(--primary); border-radius: 999px; padding: 7px 9px; font-size: 11px; line-height: 1.25; font-weight: 900; }
.orientation-board.dark { background:
  radial-gradient(circle at 76% 22%, rgba(245,180,0,.24), transparent 18%),
  linear-gradient(180deg, #08285C, #061E45); }
.orientation-board.dark .visual-caption { color: #EAF7FF; }
.orientation-board.dark .compass-disc { border-color: rgba(234,247,255,.78); background: radial-gradient(circle, rgba(24,169,216,.10), rgba(255,255,255,.03)); box-shadow: inset 0 0 0 34px rgba(234,247,255,.06); }
.orientation-board.dark .compass-disc:before { border-color: rgba(234,247,255,.26); }
.orientation-board.dark .compass-disc span { color: #EAF7FF; }
.orientation-board.dark .direction-pills span { background: rgba(232,247,255,.12); color: #EAF7FF; border-color: rgba(232,247,255,.22); }
.visual-card.dark { background: var(--primary-dark); color: #fff; }
.visual-card.dark .eyebrow { background: rgba(232,247,255,.95); color: var(--primary); border-color: rgba(255,255,255,.3); }
.visual-card.dark .visual-caption { color: #EAF7FF; }
.visual-card.dark.css-visual.compass .dial { border-color: rgba(234,247,255,.92); }
.visual-card.dark.css-visual.compass b { color: #D9ECFF; }
.visual-card.dark .base, .visual-card.dark .vertical { background: rgba(234,247,255,.7); }
.calc-compass { display: grid; place-items: center; min-height: 300px; }
.calc-compass .dial { position: relative; width: 230px; height: 230px; border: 3px solid #D7E3F2; border-radius: 50%; }
.calc-compass .needle { position: absolute; width: 8px; height: 110px; left: calc(50% - 4px); top: 30px; background: var(--secondary); border-radius: 999px; transform: rotate(35deg); transform-origin: 50% 86%; }
.calc-compass span { position: absolute; font-weight: 900; color: var(--primary); }
.calc-compass .n { top: 12px; left: 50%; transform: translateX(-50%); }
.calc-compass .s { bottom: 12px; left: 50%; transform: translateX(-50%); }
.calc-compass .e { right: 16px; top: 50%; transform: translateY(-50%); }
.calc-compass .w { left: 16px; top: 50%; transform: translateY(-50%); }
.menu-heading, .footer-heading { display: block; color: var(--primary); font-size: 12px; font-weight: 900; letter-spacing: .08em; text-transform: uppercase; margin-bottom: 12px; }
.site-footer .footer-heading { color: var(--text); font-size: 15px; letter-spacing: 0; text-transform: none; }
.calc-page-field-grid { display: grid; gap: 14px; }
.review-shell { background: rgba(255,255,255,.76); border: 1px solid var(--border); border-radius: 12px; padding: 18px; box-shadow: 0 12px 30px rgba(10,47,107,.08); overflow: hidden; }
@media (max-width: 980px) {
  .calc-page-tool-grid, .calc-output-visual, .tool-trust-row, .calc-check-grid { grid-template-columns: 1fr; }
  .calc-input-grid { grid-template-columns: 1fr; }
  .calc-result-card .section-grid, .calc-result-detail .entity-card-grid { grid-template-columns: 1fr; }
  .orientation-board { min-height: 500px; }
  .orientation-board .direction-pills { grid-template-columns: 1fr; }
}


body.solar-angle-homepage-template .calculator-page-main { background: #F6F8FB; }
.calc-page-hero { position: relative; overflow: hidden; padding: 82px 0 46px; background: #EAF7FF url("/wp-content/themes/generatepress-child-solar-angle/assets/solar-hero-bg.svg") center/cover no-repeat; border-bottom: 1px solid var(--border); }
.calc-page-hero:before { content: ""; position: absolute; inset: 0; background: rgba(245,250,255,.70); }
.calc-page-hero .container { position: relative; z-index: 1; }
.calc-page-hero-inner { max-width: 900px; margin: 0 auto; text-align: center; }
.calc-page-hero p { max-width: 760px; margin: 14px auto 0; font-size: 18px; color: var(--body); }
.calc-page-badges { display: flex; justify-content: center; flex-wrap: wrap; gap: 10px; margin-top: 24px; }
.calc-page-badges span { border: 1px solid rgba(10,47,107,.16); background: rgba(255,255,255,.72); color: var(--primary); padding: 8px 12px; border-radius: 999px; font-size: 12px; font-weight: 900; }
.calc-tool-section { padding: 42px 0 34px; background: linear-gradient(180deg, rgba(232,245,255,.84), #F6F8FB); }
.calc-page-tool { background: #fff; border: 1px solid var(--border); border-radius: 14px; padding: 28px; box-shadow: var(--shadow); }
.calc-page-tool-grid { display: grid; grid-template-columns: minmax(0, 1fr) minmax(340px, .54fr); gap: 28px; align-items: stretch; }
.calc-input-grid { display: grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap: 16px; }
.calc-field label { display: block; color: var(--muted); font-size: 12px; font-weight: 900; margin-bottom: 7px; }
.fake-input, .fake-select { width: 100%; min-height: 54px; border: 1px solid var(--border); border-radius: 7px; padding: 14px; font: inherit; color: var(--text); background: #fff; display: flex; align-items: center; justify-content: space-between; gap: 12px; }
.fake-input { color: #64748B; }
.fake-select:after { content: "v"; color: var(--primary); font-weight: 900; font-size: 12px; }
.calc-control { width: 100%; min-height: 54px; border: 1px solid var(--border); border-radius: 7px; padding: 14px; font: inherit; color: var(--text); background: #fff; }
.calc-control::placeholder { color: #64748B; opacity: 1; }
.calc-control:focus { outline: 3px solid rgba(24,169,216,.18); border-color: var(--accent); }
.check-form .calc-control { min-height: 50px; }
.calc-control-proxy { width: 100%; min-height: 54px; border: 1px solid var(--border); border-radius: 7px; padding: 14px; font: inherit; color: #64748B; background: #fff; display: flex; align-items: center; }
.tool-display-title { font-size: clamp(36px, 5vw, 56px); line-height: 1.04; letter-spacing: -0.045em; color: var(--text); font-weight: 500; margin: 12px 0 16px; }
.output-display-title { font-size: clamp(34px, 4vw, 52px); line-height: 1.05; color: #fff; font-weight: 800; margin: 8px 0 12px; }
.calc-page-preview { background: linear-gradient(180deg, #F8FBFF, #EEF6FF); border: 1px solid var(--border); border-radius: 10px; padding: 22px; display: grid; gap: 16px; }
.calc-result-line { display: flex; justify-content: space-between; gap: 12px; padding-bottom: 12px; border-bottom: 1px solid var(--border); color: var(--muted); }
.calc-result-line b { color: var(--primary-dark); }
.calc-page-actions { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 18px; }
.calc-page-actions button, .calc-page-actions a { border: 1px solid var(--border); background: #fff; color: var(--primary); padding: 12px 16px; border-radius: 7px; font-weight: 900; text-decoration: none; cursor: pointer; }
.calc-page-actions .primary { background: var(--secondary); border-color: #D99600; color: #171100; }
.calc-output-visual { background: var(--primary-dark); color: #fff; border-radius: 14px; padding: 24px; display: grid; grid-template-columns: minmax(0,1fr) minmax(300px,.65fr); gap: 26px; align-items: center; margin-top: 30px; }
.calc-output-visual h2, .calc-output-visual p { color: #fff; }
.calc-output-visual svg { width: 100%; background: rgba(255,255,255,.05); border: 1px dashed rgba(255,255,255,.28); border-radius: 12px; }
.calc-result-section { padding: 56px 0; background: #fff; }
.calc-result-card { border: 1px solid var(--border); border-radius: 14px; padding: 34px; background: #fff; box-shadow: var(--shadow); }
.calc-result-card .section-grid { padding: 0; }
.calc-result-card .content-panel { box-shadow: none; border: 0; padding: 0; }
.calc-result-card .content-panel h2 { font-size: clamp(36px, 4.2vw, 52px); }
.calc-result-card .section-grid { grid-template-columns: minmax(0, 1.25fr) minmax(380px, .75fr); gap: 34px; align-items: stretch; }
.calc-result-detail { border-top: 1px solid var(--border); margin-top: 28px; padding-top: 26px; }
.calc-result-detail .entity-card-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.calc-result-detail .entity-card { min-height: 100%; }
.calc-result-detail .entity-card h3 { font-size: 19px; }
.result-action-row { display: flex; flex-wrap: wrap; gap: 12px; padding-top: 22px; margin-top: 22px; border-top: 1px solid var(--border); }
.result-action-row button { border: 1px solid var(--border); background: #fff; color: var(--primary); padding: 13px 18px; border-radius: 7px; font-weight: 900; cursor: pointer; }
.result-action-row .primary { background: var(--secondary); border-color: #D99600; color: #171100; }
.tool-trust-row { display: grid; grid-template-columns: minmax(0, .9fr) minmax(0, 1.1fr); gap: 18px; margin-top: 22px; }
.calc-review-section { padding: 54px 0; background: linear-gradient(180deg, #EAF4FF, #F6F8FB); }
.calc-check-section { padding: 54px 0; }
.calc-check-card { background: #fff; border: 1px solid var(--border); border-radius: 12px; padding: 34px; box-shadow: var(--shadow); border-left: 7px solid var(--primary); }
.calc-check-grid { display: grid; grid-template-columns: minmax(0,.86fr) minmax(0,1fr); gap: 28px; align-items: start; }
.calc-check-copy h2 { font-size: clamp(34px, 5vw, 58px); line-height: 1.05; }
.calc-check-copy .section-title-like, .review-title-like { font-size: clamp(34px, 5vw, 58px); line-height: 1.05; letter-spacing: -0.045em; color: var(--text); margin: 12px 0 16px; }
.review-title-like { font-size: clamp(32px, 4vw, 48px); }
.calc-check-copy ul { margin-top: 16px; }
.check-form { display: grid; gap: 12px; align-content: start; }
.check-form label { color: var(--muted); font-size: 12px; font-weight: 900; margin-top: 4px; }
.check-form > button { margin-top: 8px; border: 0; background: var(--primary); color: #fff; border-radius: 8px; padding: 15px 18px; font-weight: 900; cursor: pointer; }
.fake-checkbox { width: 18px; height: 18px; border: 1px solid var(--border); border-radius: 4px; background: #fff; display: inline-block; flex: 0 0 auto; }
.consent { display: flex; align-items: flex-start; gap: 10px; line-height: 1.45; }
.calc-page-content { padding: 30px 0 70px; }
.calc-page-content .content-panel h2 { font-size: clamp(34px, 4vw, 58px); }
.calculator-page-main .site-section { padding: 48px 0; }
.calculator-page-main .visual-card svg { width: 100%; height: auto; display: block; }
.css-visual { position: relative; min-height: 300px; overflow: hidden; }
.css-visual .base { position: absolute; left: 12%; right: 12%; bottom: 58px; height: 4px; background: #B9C8D9; border-radius: 99px; }
.css-visual .vertical { position: absolute; left: 20%; bottom: 58px; width: 4px; height: 170px; background: #B9C8D9; border-radius: 99px; }
.css-visual .panel { position: absolute; left: 19%; bottom: 62px; width: 210px; height: 10px; border-radius: 99px; background: var(--primary); transform: rotate(-28deg); transform-origin: left center; box-shadow: 10px 10px 0 rgba(10,47,107,.08); }
.css-visual .ray { position: absolute; right: 18%; top: 74px; width: 150px; height: 7px; border-radius: 99px; background: var(--secondary); transform: rotate(-42deg); transform-origin: right center; }
.css-visual .sun-dot { position: absolute; right: 16%; top: 48px; width: 54px; height: 54px; border-radius: 50%; background: var(--secondary); box-shadow: 0 0 0 20px rgba(245,180,0,.14); }
.css-visual .arc { position: absolute; left: 18%; bottom: 52px; width: 120px; height: 120px; border: 6px dashed var(--accent); border-right-color: transparent; border-top-color: transparent; border-radius: 50%; }
.css-visual .visual-caption { position: absolute; left: 0; right: 0; bottom: 16px; text-align: center; color: var(--muted); font-weight: 900; font-size: 13px; }
.css-visual.map .node { position: absolute; top: 72px; width: 92px; height: 58px; border-radius: 12px; display: grid; place-items: center; font-weight: 900; color: var(--primary); background: #EAF7FF; border: 1px solid var(--border); }
.css-visual.map .node:nth-child(2) { left: 12%; }
.css-visual.map .node:nth-child(3) { left: calc(50% - 46px); background: #FFF4CC; color: #7C4A00; border-color: #F7D36C; }
.css-visual.map .node:nth-child(4) { right: 12%; }
.css-visual.map .flow { position: absolute; left: 18%; right: 18%; top: 168px; height: 70px; border-bottom: 6px solid var(--accent); border-radius: 0 0 50% 50%; }
.css-visual.network .hub { position: absolute; left: calc(50% - 44px); top: 54px; width: 88px; height: 88px; border-radius: 50%; background: var(--primary-dark); color: #fff; display: grid; place-items: center; font-weight: 900; }
.css-visual.network .mini { position: absolute; bottom: 64px; width: 66px; height: 66px; border-radius: 50%; background: #EAF7FF; border: 1px solid var(--border); }
.css-visual.network .mini.a { left: 17%; }
.css-visual.network .mini.b { left: calc(50% - 33px); background: #FFF4CC; border-color: #F7D36C; }
.css-visual.network .mini.c { right: 17%; }
.css-visual.bars .bar { position: absolute; bottom: 58px; width: 48px; border-radius: 9px 9px 0 0; background: var(--primary); }
.css-visual.bars .bar.a { left: 22%; height: 88px; }
.css-visual.bars .bar.b { left: 38%; height: 136px; background: var(--accent); }
.css-visual.bars .bar.c { left: 54%; height: 72px; background: var(--secondary); }
.css-visual.bars .bar.d { left: 70%; height: 126px; }
.css-visual.compass .dial { position: absolute; left: calc(50% - 112px); top: 48px; width: 224px; height: 224px; border: 3px solid #D7E3F2; border-radius: 50%; }
.css-visual.compass .needle { position: absolute; left: calc(50% - 4px); top: 84px; width: 8px; height: 118px; background: var(--secondary); border-radius: 99px; transform: rotate(35deg); transform-origin: 50% 86%; }
.css-visual.compass b { position: absolute; color: var(--primary); }
.css-visual.compass .n { left: calc(50% - 7px); top: 62px; }
.css-visual.compass .s { left: calc(50% - 7px); bottom: 60px; }
.css-visual.compass .e { right: calc(50% - 94px); top: 150px; }
.css-visual.compass .w { left: calc(50% - 94px); top: 150px; }
.css-visual.questions .qbox { border: 1px solid var(--border); border-radius: 8px; background: #F8FBFF; padding: 12px 14px; font-weight: 900; color: var(--primary); }
.orientation-board { min-height: 560px; background:
  radial-gradient(circle at 76% 22%, rgba(245,180,0,.18), transparent 18%),
  linear-gradient(180deg, #fff, #F8FBFF); }
.orientation-board .visual-caption { position: absolute; left: 32px; right: 32px; top: 92px; bottom: auto; margin: 0; color: var(--body); font-weight: 850; text-align: left; line-height: 1.42; max-width: none; }
.orientation-board .compass-disc { position: absolute; left: 50%; top: 235px; width: 240px; height: 240px; transform: translateX(-50%); border: 3px solid #D7E3F2; border-radius: 50%; background: radial-gradient(circle, rgba(232,247,255,.72), rgba(255,255,255,.2)); box-shadow: inset 0 0 0 34px rgba(234,247,255,.42); }
.orientation-board .compass-disc:before { content: ""; position: absolute; inset: 34px; border: 1px dashed rgba(10,47,107,.22); border-radius: 50%; }
.orientation-board .compass-disc span { position: absolute; color: var(--primary); font-weight: 900; font-size: 15px; }
.orientation-board .compass-disc .north { left: 50%; top: 12px; transform: translateX(-50%); }
.orientation-board .compass-disc .east { right: 16px; top: 50%; transform: translateY(-50%); }
.orientation-board .compass-disc .south { left: 50%; bottom: 12px; transform: translateX(-50%); }
.orientation-board .compass-disc .west { left: 16px; top: 50%; transform: translateY(-50%); }
.orientation-board .azimuth-beam { position: absolute; left: 50%; top: 298px; width: 9px; height: 98px; border-radius: 999px; background: var(--secondary); transform: rotate(38deg); transform-origin: bottom center; box-shadow: 0 0 0 14px rgba(245,180,0,.12); }
.orientation-board .azimuth-tag { position: absolute; left: 50%; top: 190px; transform: translateX(-50%); background: var(--primary-dark); color: #fff; border-radius: 8px; padding: 9px 12px; font-weight: 900; font-size: 13px; white-space: nowrap; }
.orientation-board.dark { background:
  radial-gradient(circle at 76% 22%, rgba(245,180,0,.24), transparent 18%),
  linear-gradient(180deg, #08285C, #061E45); }
.orientation-board.dark .visual-caption { color: #EAF7FF; }
.orientation-board.dark .compass-disc { border-color: rgba(234,247,255,.78); background: radial-gradient(circle, rgba(24,169,216,.10), rgba(255,255,255,.03)); box-shadow: inset 0 0 0 34px rgba(234,247,255,.06); }
.orientation-board.dark .compass-disc:before { border-color: rgba(234,247,255,.26); }
.orientation-board.dark .compass-disc span { color: #EAF7FF; }
.visual-card.dark { background: var(--primary-dark); color: #fff; }
.visual-card.dark .eyebrow { background: rgba(232,247,255,.95); color: var(--primary); border-color: rgba(255,255,255,.3); }
.visual-card.dark .visual-caption { color: #EAF7FF; }
.visual-card.dark.css-visual.compass .dial { border-color: rgba(234,247,255,.92); }
.visual-card.dark.css-visual.compass b { color: #D9ECFF; }
.visual-card.dark .base, .visual-card.dark .vertical { background: rgba(234,247,255,.7); }
.calc-compass { display: grid; place-items: center; min-height: 300px; }
.calc-compass .dial { position: relative; width: 230px; height: 230px; border: 3px solid #D7E3F2; border-radius: 50%; }
.calc-compass .needle { position: absolute; width: 8px; height: 110px; left: calc(50% - 4px); top: 30px; background: var(--secondary); border-radius: 999px; transform: rotate(35deg); transform-origin: 50% 86%; }
.calc-compass span { position: absolute; font-weight: 900; color: var(--primary); }
.calc-compass .n { top: 12px; left: 50%; transform: translateX(-50%); }
.calc-compass .s { bottom: 12px; left: 50%; transform: translateX(-50%); }
.calc-compass .e { right: 16px; top: 50%; transform: translateY(-50%); }
.calc-compass .w { left: 16px; top: 50%; transform: translateY(-50%); }
.menu-heading, .footer-heading { display: block; color: var(--primary); font-size: 12px; font-weight: 900; letter-spacing: .08em; text-transform: uppercase; margin-bottom: 12px; }
.site-footer .footer-heading { color: var(--text); font-size: 15px; letter-spacing: 0; text-transform: none; }
.calc-page-field-grid { display: grid; gap: 14px; }
.review-shell { background: rgba(255,255,255,.76); border: 1px solid var(--border); border-radius: 12px; padding: 18px; box-shadow: 0 12px 30px rgba(10,47,107,.08); overflow: hidden; }
@media (max-width: 980px) {
  .calc-page-tool-grid, .calc-output-visual, .tool-trust-row, .calc-check-grid { grid-template-columns: 1fr; }
  .calc-input-grid { grid-template-columns: 1fr; }
  .calc-result-card .section-grid, .calc-result-detail .entity-card-grid { grid-template-columns: 1fr; }
  .orientation-board { min-height: 540px; }
}


/* CALCULATOR_DYNAMIC_VISUAL_V4 */
.calculator-page-main .visual-card { --live-panel-rotation: -28deg; --live-ray-rotation: -42deg; --live-azimuth-rotation: 38deg; --live-sun-x: 82%; --live-sun-y: 20%; --live-arc-scale: 1; }
.calculator-page-main .css-visual .panel { transform: rotate(var(--live-panel-rotation)); transition: transform .28s ease; }
.calculator-page-main .css-visual .ray { transform: rotate(var(--live-ray-rotation)); transition: transform .28s ease; }
.calculator-page-main .css-visual .sun-dot { right: auto; left: var(--live-sun-x); top: var(--live-sun-y); transform: translate(-50%, -50%); transition: left .28s ease, top .28s ease; }
.calculator-page-main .css-visual .arc { transform: scale(var(--live-arc-scale)); transform-origin: left bottom; transition: transform .28s ease; }
.calculator-page-main .orientation-board .azimuth-beam { transform: rotate(var(--live-azimuth-rotation)); transition: transform .28s ease; }
.calculator-page-main .orientation-board .compass-disc { transition: box-shadow .28s ease; }
.calculator-page-main .orientation-board.is-live .compass-disc { box-shadow: inset 0 0 0 34px rgba(24,169,216,.10), 0 0 0 8px rgba(24,169,216,.10); }
.calculator-page-main .visual-card.is-live .sun-dot,
.calculator-page-main .visual-card.is-live .azimuth-beam { filter: saturate(1.08); }

/* SUPPORT_PAGE_ZIP_CODE_V1 */
.support-page-main { background: var(--page); color: var(--body); }
.support-hero { position: relative; padding: 78px 0 58px; background: radial-gradient(circle at 10% 20%, rgba(18,168,224,.16), transparent 32%), linear-gradient(135deg, #F7FBFF 0%, #EAF4FA 100%); border-bottom: 1px solid var(--border); overflow: hidden; }
.support-hero:after { content: ""; position: absolute; right: -140px; top: 30px; width: 420px; height: 420px; border-radius: 50%; border: 54px solid rgba(10,47,107,.06); pointer-events: none; }
.support-hero-grid { position: relative; z-index: 1; display: grid; grid-template-columns: minmax(0, 1.08fr) minmax(380px, .72fr); gap: 36px; align-items: center; }
.support-hero-copy h1 { margin: 16px 0 18px; max-width: 780px; }
.support-lede { font-size: 20px; line-height: 1.65; color: var(--text); }
.support-hero-actions { display: flex; flex-wrap: wrap; gap: 12px; margin-top: 24px; }
.support-primary, .support-secondary { display: inline-flex; align-items: center; justify-content: center; min-height: 48px; padding: 12px 18px; border-radius: 7px; font-weight: 900; text-decoration: none; }
.support-primary { background: var(--secondary); color: #171100; box-shadow: 0 12px 22px rgba(185,120,0,.18); }
.support-secondary { background: #fff; color: var(--primary); border: 1px solid var(--border); }
.zip-lookup-panel { background: rgba(255,255,255,.96); border: 1px solid #C9D7E8; border-radius: 14px; padding: 26px; box-shadow: 0 24px 60px rgba(10,47,107,.13); }
.zip-preview-code { margin: 22px 0; padding: 20px; border: 1px solid var(--border); border-radius: 12px; background: #F8FBFF; }
.zip-preview-code span, .zip-preview-grid span { display: block; color: var(--muted); font-size: 12px; font-weight: 900; text-transform: uppercase; letter-spacing: .08em; }
.zip-preview-code strong { display: block; margin-top: 6px; color: var(--primary-dark); font-size: 48px; line-height: 1; }
.zip-preview-grid { display: grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap: 12px; margin-bottom: 18px; }
.zip-preview-grid div { background: #fff; border: 1px solid var(--border); border-radius: 10px; padding: 14px; }
.zip-preview-grid b { display: block; margin-top: 6px; color: var(--primary); font-size: 18px; }
.support-section { padding: 62px 0; }
.support-section.tinted { background: #EEF5FA; border-block: 1px solid var(--border); }
.support-split { display: grid; grid-template-columns: minmax(0,1fr) minmax(360px,.72fr); gap: 28px; align-items: stretch; }
.support-card { background: #fff; border: 1px solid var(--border); border-radius: 14px; padding: 30px; box-shadow: 0 16px 44px rgba(10,47,107,.08); }
.support-card h2 { font-size: clamp(30px, 3vw, 44px); }
.support-answer { border-left: 5px solid var(--accent); }
.zip-concept-visual { display: grid; place-items: center; min-height: 420px; border-radius: 14px; background: linear-gradient(135deg, #0A2F6B, #061E45); box-shadow: var(--shadow); padding: 34px; }
.zip-flow-card { width: min(280px, 100%); background: rgba(255,255,255,.96); border-radius: 12px; padding: 18px; text-align: center; border: 1px solid rgba(255,255,255,.2); }
.zip-flow-card span { display: block; color: var(--muted); font-size: 12px; font-weight: 900; text-transform: uppercase; letter-spacing: .08em; }
.zip-flow-card b { display: block; color: var(--primary-dark); font-size: 30px; margin-top: 4px; }
.zip-flow-card.dark { background: var(--secondary); }
.zip-flow-line { width: 3px; height: 36px; background: var(--accent); margin: 7px auto; border-radius: 99px; }
.section-heading-row { max-width: 980px; margin-bottom: 26px; }
.process-ribbon { display: grid; grid-template-columns: repeat(6, minmax(0,1fr)); gap: 12px; }
.process-ribbon article { background: #fff; border: 1px solid var(--border); border-radius: 12px; padding: 18px; min-height: 160px; }
.process-ribbon span { display: inline-grid; place-items: center; width: 38px; height: 38px; border-radius: 50%; background: var(--primary); color: #fff; font-weight: 900; margin-bottom: 12px; }
.process-ribbon b { display: block; color: var(--text); font-size: 18px; }
.source-note { margin-top: 18px; padding: 16px; border-left: 4px solid var(--accent); background: #fff; border-radius: 8px; }
.zip-table-shell { background: #fff; border: 1px solid var(--border); border-radius: 16px; box-shadow: var(--shadow); overflow: hidden; }
.zip-table-head { display: grid; grid-template-columns: minmax(0,1fr) 340px; gap: 24px; padding: 30px; border-bottom: 1px solid var(--border); }
.zip-search-card { display: grid; gap: 8px; background: #F8FBFF; border: 1px solid var(--border); border-radius: 12px; padding: 18px; align-self: start; }
.zip-table-note { display: grid; grid-template-columns: 120px 1fr; gap: 18px; padding: 18px 30px; background: var(--accent-soft); border-bottom: 1px solid #C8ECFA; }
.zip-table-note span { color: var(--accent-dark); font-weight: 900; text-transform: uppercase; letter-spacing: .08em; }
.zip-table-note p { margin: 0; color: var(--text); }
.support-table-wrap { overflow-x: auto; max-height: 620px; }
.support-data-table { width: 100%; border-collapse: collapse; min-width: 780px; font-size: 15px; }
.support-data-table th { position: sticky; top: 0; z-index: 2; background: #EEF3FA; color: var(--primary-dark); text-align: left; padding: 14px 16px; font-size: 12px; text-transform: uppercase; letter-spacing: .08em; border-bottom: 1px solid var(--border); }
.support-data-table td { padding: 13px 16px; border-bottom: 1px solid var(--border); color: var(--text); }
.support-data-table tbody tr:hover { background: #FFF8E3; cursor: pointer; }
.support-card-grid { display: grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap: 26px; }
.accent-blue { border-top: 5px solid var(--primary); }
.accent-gold { border-top: 5px solid var(--secondary); }
.mini-badge { display: inline-flex; padding: 7px 12px; border-radius: 999px; background: var(--primary-soft); color: var(--primary); font-size: 12px; font-weight: 900; text-transform: uppercase; letter-spacing: .08em; }
.coverage-grid { display: grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap: 12px; margin-top: 18px; }
.coverage-grid div { border: 1px solid var(--border); border-radius: 10px; padding: 14px; background: #F8FBFF; }
.coverage-grid b, .intent-list b { display: block; color: var(--primary-dark); }
.coverage-grid span, .intent-list span { display: block; color: var(--body); margin-top: 4px; }
.intent-list { list-style: none; padding: 0; }
.intent-list li { border-left: 4px solid var(--secondary); padding: 12px 0 12px 14px; margin: 0; border-bottom: 1px solid var(--border); }
.check-list li { margin: 10px 0; }
.next-link-list { display: grid; gap: 10px; }
.next-link-list a { display: flex; justify-content: space-between; align-items: center; padding: 14px 16px; border: 1px solid var(--border); border-radius: 9px; background: #F8FBFF; text-decoration: none; }
.next-link-list a:after { content: ">"; color: var(--accent-dark); font-weight: 900; }
.review-disclaimer-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 22px; align-items: stretch; }
.reviewed-by-card, .disclaimer-card.compact { min-height: 180px; }
.faq-support-section .faq-grid { display: grid; gap: 12px; margin-top: 20px; }
.faq-support-section details { background: #fff; border: 1px solid var(--border); border-radius: 10px; padding: 16px 18px; }
.faq-support-section summary { cursor: pointer; color: var(--primary-dark); font-weight: 900; }
.faq-support-section details p { margin-top: 12px; }
.source-card { background: #fff; border: 1px solid var(--border); border-radius: 14px; padding: 28px; }
@media (max-width: 980px) {
  .support-hero-grid, .support-split, .zip-table-head, .support-card-grid, .review-disclaimer-grid { grid-template-columns: 1fr; }
  .process-ribbon { grid-template-columns: repeat(2, minmax(0,1fr)); }
  .zip-concept-visual { min-height: 320px; }
}
@media (max-width: 640px) {
  .support-hero { padding: 46px 0 38px; }
  .support-section { padding: 42px 0; }
  .support-card, .zip-lookup-panel, .zip-table-head { padding: 20px; }
  .zip-preview-grid, .coverage-grid, .process-ribbon { grid-template-columns: 1fr; }
  .support-hero-actions { flex-direction: column; }
  .support-primary, .support-secondary { width: 100%; }
  .support-table-wrap { max-height: 520px; }
}

