/* ============================================================
   CALLISON — interior page styles (loads after styles.css)
   Reuses tokens + components from styles.css
   ============================================================ */

/* ---------- page hero (compact) ---------- */
.phero{ position:relative; color:#fff; overflow:hidden;
  background:
    radial-gradient(90% 130% at 92% -20%, rgba(30,115,216,.34), transparent 55%),
    linear-gradient(180deg, var(--navy) 0%, var(--navy-900) 100%); }
.phero::after{ content:""; position:absolute; left:0; right:0; bottom:0; height:4px; z-index:3;
  background:linear-gradient(90deg, var(--blue) 0%, var(--blue-bright) 45%, var(--gold) 100%); }
.phero .wrap{ position:relative; z-index:2; padding-block:clamp(38px,5vw,68px); }
.phero--media .wrap{ display:grid; grid-template-columns:1.1fr .9fr; gap:clamp(28px,4vw,60px); align-items:center; }
.breadcrumb{ display:flex; flex-wrap:wrap; align-items:center; gap:8px; font-size:13px; color:#9fb1cb;
  font-family:var(--font-mono); letter-spacing:.02em; margin-bottom:18px; }
.breadcrumb a:hover{ color:#fff; }
.breadcrumb svg{ width:13px; height:13px; opacity:.6; }
.phero h1{ font-size:clamp(31px,4.2vw,52px); line-height:1.03; }
.phero h1 .hl{ color:var(--gold); }
.phero__sub{ margin-top:18px; font-size:clamp(16px,1.4vw,19px); color:#c7d3e6; max-width:54ch; }
.phero__actions{ margin-top:26px; display:flex; gap:13px; flex-wrap:wrap; }
.phero__media{ position:relative; }
.phero__media .media{ aspect-ratio:4/3; border-radius:var(--radius-lg); box-shadow:var(--shadow-lg);
  border:1px solid rgba(255,255,255,.12); }
.phero__chips{ margin-top:24px; display:flex; flex-wrap:wrap; gap:10px; }
.phero__chip{ display:inline-flex; align-items:center; gap:8px; font-size:13.5px; color:#dbe6f5;
  background:rgba(255,255,255,.07); border:1px solid var(--line-navy); padding:8px 13px; border-radius:999px; }
.phero__chip svg{ width:15px; height:15px; color:var(--gold); }
@media (max-width:860px){ .phero--media .wrap{ grid-template-columns:1fr; } .phero__media{ order:-1; } .phero__media .media{ aspect-ratio:16/10; } }

/* ---------- AEO quick-answer (light page version) ---------- */
.qa-strip{ background:var(--paper); border-bottom:1px solid var(--line); }
.qa-strip .wrap{ padding-block:clamp(26px,3vw,40px); }
.qa-strip__card{ display:grid; grid-template-columns:auto 1fr; gap:20px; align-items:start;
  background:#fff; border:1px solid var(--line); border-left:5px solid var(--blue);
  border-radius:14px; padding:clamp(20px,2.4vw,30px); box-shadow:var(--shadow-sm); }
.qa-strip__tag{ font-family:var(--font-mono); font-size:11.5px; letter-spacing:.14em; text-transform:uppercase;
  color:#fff; background:var(--blue); padding:7px 11px; border-radius:7px; font-weight:600; white-space:nowrap; }
.qa-strip__card p{ font-size:clamp(16px,1.4vw,19px); color:var(--ink); line-height:1.55; }
.qa-strip__card p strong{ color:var(--navy); }
@media (max-width:620px){ .qa-strip__card{ grid-template-columns:1fr; gap:13px; } }

/* ---------- generic section heading reuse via .shead (in styles.css) ---------- */
.section--tight{ padding-block:clamp(44px,6vw,80px); }
.lead-narrow{ max-width:760px; }

/* ---------- service card grid (hubs) ---------- */
.svcgrid{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.svcgrid--2{ grid-template-columns:repeat(2,1fr); }
.svc-card{ display:flex; flex-direction:column; background:#fff; border:1px solid var(--line);
  border-radius:var(--radius-lg); padding:26px 24px 24px; box-shadow:var(--shadow-sm);
  transition:transform .2s var(--ease), box-shadow .2s var(--ease), border-color .2s; position:relative; overflow:hidden; }
.svc-card::before{ content:""; position:absolute; left:0; top:0; height:4px; width:100%;
  background:linear-gradient(90deg,var(--blue),var(--gold)); transform:scaleX(0); transform-origin:left;
  transition:transform .3s var(--ease); }
.svc-card:hover{ transform:translateY(-4px); box-shadow:var(--shadow); border-color:transparent; }
.svc-card:hover::before{ transform:scaleX(1); }
.svc-card__ic{ width:52px; height:52px; border-radius:13px; display:grid; place-items:center;
  background:var(--paper); color:var(--blue); margin-bottom:16px; }
.svc-card.is-elec .svc-card__ic{ color:var(--gold-deep); }
.svc-card:hover .svc-card__ic{ background:var(--blue); color:#fff; }
.svc-card.is-elec:hover .svc-card__ic{ background:var(--gold); color:var(--navy); }
.svc-card__ic svg{ width:27px; height:27px; }
.svc-card h3{ font-size:20px; color:var(--navy); }
.svc-card p{ margin-top:9px; font-size:15px; color:var(--ink-soft); flex:1; }
.svc-card__link{ margin-top:18px; font-family:var(--font-display); font-weight:700; font-size:15px;
  color:var(--navy); display:inline-flex; align-items:center; gap:7px; }
.svc-card__link svg{ width:16px; height:16px; transition:transform .15s; }
.svc-card:hover .svc-card__link{ color:var(--blue); }
.svc-card:hover .svc-card__link svg{ transform:translateX(4px); }
@media (max-width:900px){ .svcgrid{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:560px){ .svcgrid, .svcgrid--2{ grid-template-columns:1fr; } }

/* ---------- feature row (alternating image/text) ---------- */
.frow{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(28px,4vw,60px); align-items:center; }
.frow + .frow{ margin-top:clamp(40px,5vw,72px); }
.frow__media .media{ aspect-ratio:4/3; border-radius:var(--radius-lg); box-shadow:var(--shadow); }
.frow--rev .frow__text{ order:2; }
.frow__text h2{ font-size:clamp(25px,2.8vw,38px); color:var(--navy); }
.frow__text > p{ margin-top:14px; font-size:17px; color:var(--ink-soft); }
.frow__list{ margin-top:18px; display:grid; gap:11px; }
.frow__list li{ display:flex; gap:11px; align-items:flex-start; font-size:15.5px; color:var(--ink); }
.frow__list svg{ width:20px; height:20px; color:var(--blue); flex:none; margin-top:2px; }
.is-elec .frow__list svg{ color:var(--gold-deep); }
@media (max-width:820px){ .frow{ grid-template-columns:1fr; } .frow--rev .frow__text{ order:0; } }

/* ---------- checklist panel ---------- */
.panel{ background:#fff; border:1px solid var(--line); border-radius:var(--radius-lg); padding:clamp(24px,3vw,36px);
  box-shadow:var(--shadow-sm); }
.panel--paper{ background:var(--paper); border-color:var(--line); box-shadow:none; }
.checks{ display:grid; grid-template-columns:1fr 1fr; gap:13px 24px; margin-top:6px; }
.checks li{ display:flex; gap:11px; align-items:flex-start; font-size:15.5px; color:var(--ink); }
.checks svg{ width:20px; height:20px; color:var(--blue); flex:none; margin-top:2px; }
.is-elec .checks svg{ color:var(--gold-deep); }
@media (max-width:560px){ .checks{ grid-template-columns:1fr; } }

/* ---------- 3-step / process reuse .standard__steps; add 3-col variant ---------- */
.steps3{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
@media (max-width:760px){ .steps3{ grid-template-columns:1fr; } }

/* ---------- CTA band (compact final CTA) ---------- */
.ctaband{ background:linear-gradient(180deg, var(--blue-deep), var(--blue) 65%, #0a4fa0); color:#fff;
  position:relative; overflow:hidden; }
.ctaband::before{ content:""; position:absolute; inset:0;
  background-image:linear-gradient(rgba(255,255,255,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.05) 1px,transparent 1px);
  background-size:40px 40px; -webkit-mask-image:radial-gradient(100% 80% at 70% 0%,#000,transparent 70%);
  mask-image:radial-gradient(100% 80% at 70% 0%,#000,transparent 70%); }
.ctaband .wrap{ position:relative; z-index:1; display:grid; grid-template-columns:1.3fr .7fr; gap:32px; align-items:center;
  padding-block:clamp(40px,5vw,68px); }
.ctaband h2{ font-size:clamp(26px,3.2vw,42px); }
.ctaband h2 .hl{ color:var(--gold); }
.ctaband p{ margin-top:14px; font-size:18px; color:#dceaff; max-width:48ch; }
.ctaband__actions{ display:flex; flex-direction:column; gap:12px; }
.ctaband__phone{ font-family:var(--font-display); font-weight:800; font-size:clamp(26px,3vw,34px); color:#fff;
  display:inline-flex; align-items:center; gap:12px; }
.ctaband__phone svg{ width:30px; height:30px; color:var(--gold); }
.ctaband__phone span{ display:block; font-family:var(--font-mono); font-size:11.5px; letter-spacing:.14em;
  text-transform:uppercase; color:#9fc3f2; margin-bottom:3px; }
@media (max-width:820px){ .ctaband .wrap{ grid-template-columns:1fr; } }

/* ---------- about ---------- */
.about-intro{ display:grid; grid-template-columns:1.05fr .95fr; gap:clamp(30px,4vw,60px); align-items:center; }
@media (max-width:820px){ .about-intro{ grid-template-columns:1fr; } }
.team{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.team-card{ background:#fff; border:1px solid var(--line); border-radius:var(--radius-lg); overflow:hidden;
  box-shadow:var(--shadow-sm); }
.team-card__ph{ aspect-ratio:1; }
.team-card__b{ padding:20px 22px; }
.team-card__b b{ font-family:var(--font-display); font-size:18px; color:var(--navy); display:block; }
.team-card__b span{ font-family:var(--font-mono); font-size:12px; letter-spacing:.08em; text-transform:uppercase; color:var(--blue); }
.team-card__b p{ margin-top:10px; font-size:14.5px; color:var(--ink-soft); }
@media (max-width:760px){ .team{ grid-template-columns:1fr; } }

/* ---------- contact ---------- */
.contact-grid{ display:grid; grid-template-columns:1fr 460px; gap:clamp(30px,4vw,56px); align-items:start; }
.contact-info{ display:grid; gap:16px; }
.cinfo{ display:flex; gap:15px; align-items:flex-start; background:#fff; border:1px solid var(--line);
  border-radius:14px; padding:20px 22px; box-shadow:var(--shadow-sm); }
.cinfo__ic{ width:46px; height:46px; border-radius:11px; background:var(--paper); color:var(--blue);
  display:grid; place-items:center; flex:none; }
.cinfo__ic svg{ width:22px; height:22px; }
.cinfo h3{ font-size:15px; color:var(--navy); font-family:var(--font-display); }
.cinfo p, .cinfo a{ font-size:15.5px; color:var(--ink-soft); margin-top:3px; display:block; }
.cinfo a:hover{ color:var(--blue); }
.map-embed{ margin-top:6px; border-radius:14px; overflow:hidden; border:1px solid var(--line); aspect-ratio:21/9;
  background:var(--paper-2); position:relative; }
.map-embed iframe{ width:100%; height:100%; border:0; display:block; }
@media (max-width:880px){ .contact-grid{ grid-template-columns:1fr; } }

/* ---------- reviews ---------- */
.rev-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.rev{ background:#fff; border:1px solid var(--line); border-radius:var(--radius-lg); padding:26px 24px;
  box-shadow:var(--shadow-sm); display:flex; flex-direction:column; }
.rev__stars{ display:flex; gap:3px; color:var(--gold); margin-bottom:14px; }
.rev__stars svg{ width:18px; height:18px; }
.rev p{ font-size:15.5px; color:var(--ink); line-height:1.6; flex:1; }
.rev__by{ margin-top:18px; padding-top:16px; border-top:1px solid var(--line); display:flex; align-items:center; gap:12px; }
.rev__av{ width:42px; height:42px; border-radius:50%; background:var(--blue); color:#fff; display:grid; place-items:center;
  font-family:var(--font-display); font-weight:800; font-size:16px; flex:none; }
.rev__by b{ font-family:var(--font-display); font-size:15px; color:var(--navy); display:block; }
.rev__by span{ font-size:12.5px; color:var(--muted); }
@media (max-width:900px){ .rev-grid{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:560px){ .rev-grid{ grid-template-columns:1fr; } }

/* ---------- financing ---------- */
.fin-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
@media (max-width:760px){ .fin-grid{ grid-template-columns:1fr; } }

/* ---------- areas list ---------- */
.area-list{ display:grid; grid-template-columns:repeat(3,1fr); gap:16px; }
@media (max-width:760px){ .area-list{ grid-template-columns:1fr 1fr; } }
@media (max-width:480px){ .area-list{ grid-template-columns:1fr; } }

/* ---------- RUUD ---------- */
.ruud-hero-card{ background:#fff; border-radius:var(--radius-lg); box-shadow:var(--shadow-lg);
  padding:clamp(28px,3.4vw,42px); text-align:center; display:flex; flex-direction:column; align-items:center;
  gap:16px; border:1px solid rgba(255,255,255,.5); }
.ruud-hero-card img{ width:min(300px,78%); height:auto; }
.ruud-hero-card .lab{ font-family:var(--font-mono); font-size:11.5px; letter-spacing:.16em; text-transform:uppercase;
  color:var(--blue); font-weight:600; }
.ruud-hero-card .badges{ display:flex; flex-wrap:wrap; justify-content:center; gap:8px; }
.ruud-hero-card .badges span{ display:inline-flex; align-items:center; gap:6px; font-size:12.5px; color:var(--ink-soft);
  background:var(--paper); border:1px solid var(--line); border-radius:999px; padding:6px 11px; font-weight:600; }
.ruud-hero-card .badges svg{ width:14px; height:14px; color:var(--gold-deep); }

/* embedded "Why we install RUUD" section */
.ruud-sec{ background:var(--paper); }
.ruud-card{ background:#fff; border:1px solid var(--line); border-radius:var(--radius-lg); box-shadow:var(--shadow);
  padding:clamp(28px,3.4vw,44px); display:flex; flex-direction:column; align-items:center; gap:20px; text-align:center; }
.ruud-card img{ width:min(260px,72%); height:auto; }
.ruud-card__warranty{ display:flex; align-items:center; gap:13px; background:var(--paper); border-radius:13px;
  padding:14px 20px; border:1px solid var(--line); }
.ruud-card__warranty .n{ font-family:var(--font-display); font-weight:800; font-size:30px; color:var(--blue); line-height:1; }
.ruud-card__warranty .t{ text-align:left; }
.ruud-card__warranty .t b{ font-family:var(--font-display); font-size:14.5px; color:var(--navy); display:block; }
.ruud-card__warranty .t span{ font-size:12.5px; color:var(--muted); }
.ruud-tiers{ display:grid; grid-template-columns:repeat(3,1fr); gap:16px; margin-top:6px; }
.ruud-tier{ background:#fff; border:1px solid var(--line); border-radius:14px; padding:22px 20px; box-shadow:var(--shadow-sm); }
.ruud-tier .tag{ font-family:var(--font-mono); font-size:11px; letter-spacing:.1em; text-transform:uppercase;
  color:var(--gold-deep); font-weight:600; }
.ruud-tier h3{ font-size:18px; color:var(--navy); margin-top:8px; }
.ruud-tier p{ margin-top:7px; font-size:14.5px; color:var(--ink-soft); }
@media (max-width:760px){ .ruud-tiers{ grid-template-columns:1fr; } }
