/* ============================================================
   sol.css — Solar v5 page layer  (rides on v5-base + v5-kit)
   ------------------------------------------------------------
   Financial-first C&I Solar page. Reuses the v5 token system:
     · dark   = graphite #2A2C2F   (.tw-pal-solar-dark)
     · light  = bone     #F4F1EC   (.tw-pal-solar-bone)
     · ink    = near-black #16181B (.sol-ink — the upload band)
     · accent = saffron   #E8B92E  (--tw-mark, all palettes)
   Every component below is driven by --tw-* tokens so it inherits
   whichever section palette wraps it. Ported & retoned from the
   EnergyCloud ec.css proof / estimator / bill components.
   ============================================================ */

/* ---- deep ink band (the conversion moment — bill upload) ---- */
.sol-ink{
  --tw-bg:#16181B; --tw-fg:#F4F1EC; --tw-mark:var(--tw-saffron-hot,#F1B82A);
  --tw-slogan-fg:#9A9CA1; --tw-line:rgba(244,241,236,0.13); --tw-data-bg:rgba(244,241,236,0.045);
  --v5-on-mark:#1A1D21;
  background:
    radial-gradient(120% 80% at 82% 0%, rgba(232,185,46,0.10) 0%, rgba(232,185,46,0) 55%),
    #16181B;
  color:var(--tw-fg);
}
.sol-ink .v5-btn--primary{ background:var(--tw-mark); color:#1A1D21; border-color:var(--tw-mark); }
.sol-ink .v5-btn--primary:hover{ filter:brightness(1.08); }
.sol-ink .v5-btn:not(.v5-btn--primary){ color:#F4F1EC; border-color:rgba(244,241,236,0.26); }
.sol-ink .v5-btn:not(.v5-btn--primary):hover{ border-color:var(--tw-mark); color:var(--tw-mark); }

/* ---- inline {{CONFIRM}} marker — visible to the team, quiet on the page ---- */
.sol-confirm{ font-family:var(--tw-font-mono); font-size:.82em; letter-spacing:.04em;
  color:var(--tw-mark); border-bottom:1px dashed color-mix(in srgb,var(--tw-mark) 60%,transparent);
  padding:0 1px; white-space:nowrap; }
.sol-confirm::before{ content:"⚑ "; opacity:.7; }

/* ---- HERO trust strip card ---- */
.sol-trust{ background:rgba(14,16,18,.62); border:1px solid rgba(244,241,236,.2); border-radius:var(--v5-radius);
  backdrop-filter:blur(12px) saturate(160%); -webkit-backdrop-filter:blur(12px) saturate(160%); overflow:hidden; }
.sol-trust__top{ display:flex; justify-content:space-between; align-items:center; gap:12px; padding:13px 18px;
  border-bottom:1px solid rgba(244,241,236,.16); font-family:var(--tw-font-mono); font-size:10px; letter-spacing:.2em;
  text-transform:uppercase; color:rgba(244,241,236,.7); }
.sol-trust__top .live{ display:inline-flex; align-items:center; gap:7px; color:var(--tw-saffron); }
.sol-trust__top .live .d{ width:6px; height:6px; border-radius:50%; background:var(--tw-saffron); display:inline-block; }
.sol-trust__grid{ display:grid; grid-template-columns:1fr 1fr; }
.sol-trust__cell{ padding:18px; border-top:1px solid rgba(244,241,236,.12); }
.sol-trust__cell:nth-child(2n){ border-left:1px solid rgba(244,241,236,.12); }
.sol-trust__cell:nth-child(-n+2){ border-top:0; }
.sol-trust__v{ font-family:var(--tw-font-display); font-weight:800; letter-spacing:-.04em; font-size:clamp(1.5rem,2.4vw,2rem); line-height:1; color:#F4F1EC; }
.sol-trust__v .u{ font-size:.45em; color:var(--tw-saffron); margin-left:4px; font-weight:700; }
.sol-trust__l{ font-family:var(--tw-font-mono); font-size:9.5px; letter-spacing:.16em; text-transform:uppercase; color:rgba(244,241,236,.62); margin-top:8px; }
.sol-trust__l .sol-confirm{ color:var(--tw-saffron); border-bottom-color:rgba(232,185,46,.5); }

/* ---- reframe stat strip ---- */
.sol-statstrip{ display:flex; flex-wrap:wrap; gap:0; margin-top:clamp(32px,4vw,48px);
  border:1px solid var(--tw-line); border-radius:8px; overflow:hidden; background:var(--tw-data-bg); }
.sol-statstrip__cell{ flex:1 1 200px; padding:clamp(20px,2.4vw,28px); border-right:1px solid var(--tw-line); }
.sol-statstrip__cell:last-child{ border-right:0; }
.sol-statstrip__v{ font-family:var(--tw-font-display); font-weight:800; letter-spacing:-.04em; font-size:clamp(1.875rem,3.4vw,2.75rem); line-height:1; color:var(--tw-mark); }
.sol-statstrip__l{ font-family:var(--tw-font-mono); font-size:10.5px; letter-spacing:.16em; text-transform:uppercase; color:var(--tw-slogan-fg); margin-top:10px; line-height:1.5; }
@media(max-width:680px){ .sol-statstrip__cell{ flex-basis:100%; border-right:0; border-bottom:1px solid var(--tw-line); } .sol-statstrip__cell:last-child{ border-bottom:0; } }

/* ---- ROI estimator (ported from ec-roi, token-driven) ---- */
.sol-roi{ border:1px solid var(--tw-line); border-radius:10px; background:var(--tw-data-bg); overflow:hidden; margin-top:clamp(32px,4vw,48px); }
.sol-roi__head{ display:flex; justify-content:space-between; align-items:center; gap:16px; flex-wrap:wrap; padding:14px 22px; border-bottom:1px solid var(--tw-line);
  font-family:var(--tw-font-mono); font-size:10.5px; letter-spacing:.18em; text-transform:uppercase; color:var(--tw-slogan-fg); }
.sol-roi__head .lead{ color:var(--tw-mark); }
.sol-roi__body{ display:grid; grid-template-columns:minmax(0,1fr) minmax(0,1.3fr); }
.sol-roi__controls{ padding:clamp(22px,3vw,32px); border-right:1px solid var(--tw-line); display:flex; flex-direction:column; gap:22px; }
.sol-roi__row .top{ display:flex; justify-content:space-between; align-items:baseline; gap:12px; }
.sol-roi__row label{ font-family:var(--tw-font-mono); font-size:10.5px; letter-spacing:.2em; text-transform:uppercase; color:var(--tw-slogan-fg); }
.sol-roi__row .out{ font-family:var(--tw-font-display); font-weight:700; font-size:1.25rem; letter-spacing:-.02em; color:var(--tw-fg); text-align:right; }
.sol-roi__row input[type=range]{ width:100%; margin-top:12px; accent-color:var(--tw-mark); }
.sol-roi__seg{ display:flex; gap:6px; margin-top:12px; }
.sol-roi__seg button{ flex:1; font-family:var(--tw-font-mono); font-size:10px; letter-spacing:.1em; text-transform:uppercase; cursor:pointer;
  padding:9px 6px; border-radius:4px; border:1px solid var(--tw-line); background:transparent; color:var(--tw-slogan-fg); transition:all .18s var(--v5-ease); }
.sol-roi__seg button.is-on{ background:var(--tw-mark); color:var(--v5-on-mark,#1A1D21); border-color:var(--tw-mark); font-weight:600; }
.sol-roi__note{ margin-top:auto; padding-top:14px; border-top:1px solid var(--tw-line); font-family:var(--tw-font-mono); font-size:10.5px; letter-spacing:.04em; color:var(--tw-slogan-fg); line-height:1.55; }
.sol-roi__out{ display:grid; grid-template-columns:repeat(2,1fr); }
.sol-roi__cell{ padding:clamp(18px,2.5vw,26px); border-bottom:1px solid var(--tw-line); }
.sol-roi__cell:nth-child(odd){ border-right:1px solid var(--tw-line); }
.sol-roi__cell .k{ font-family:var(--tw-font-mono); font-size:10px; letter-spacing:.18em; text-transform:uppercase; color:var(--tw-slogan-fg); }
.sol-roi__cell .v{ font-family:var(--tw-font-display); font-weight:800; letter-spacing:-.03em; font-size:clamp(1.6rem,3vw,2.25rem); line-height:1; margin-top:9px; color:var(--tw-fg); }
.sol-roi__cell.hl .v{ color:var(--tw-mark); }
.sol-roi__cta{ grid-column:1 / -1; padding:clamp(18px,2.5vw,24px); display:flex; }
.sol-roi__cta .v5-btn{ width:100%; justify-content:center; }
@media(max-width:820px){ .sol-roi__body{ grid-template-columns:1fr; } .sol-roi__controls{ border-right:0; border-bottom:1px solid var(--tw-line); } }
@media(max-width:520px){ .sol-roi__out{ grid-template-columns:1fr; } .sol-roi__cell:nth-child(odd){ border-right:0; } }

/* ---- bill upload: dropbox + report figure + WhatsApp fallback ---- */
.sol-uploadfig{ position:relative; }
.sol-frame{ border:1px solid var(--tw-line); border-radius:12px; overflow:hidden; background:#0E0F11; box-shadow:0 30px 70px -30px rgba(0,0,0,0.6); }
.sol-frame__bar{ display:flex; align-items:center; gap:12px; padding:10px 14px; background:#1C1E21; border-bottom:1px solid var(--tw-line); }
.sol-frame__dots{ display:flex; gap:6px; flex:none; }
.sol-frame__dots i{ width:10px; height:10px; border-radius:50%; background:rgba(244,241,236,.28); }
.sol-frame__addr{ font-family:var(--tw-font-mono); font-size:10px; letter-spacing:.06em; color:var(--tw-slogan-fg); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.sol-frame image-slot{ display:block; width:100%; aspect-ratio:4/3; background:#0E0F11; }
.sol-frame img{ display:block; width:100%; aspect-ratio:4/3; object-fit:cover; }
.sol-fallback{ margin-top:18px; display:flex; align-items:center; gap:14px; padding:16px 18px; border:1px solid var(--tw-line); border-radius:8px; background:var(--tw-data-bg); }
.sol-fallback__ico{ width:38px; height:38px; flex:none; border-radius:50%; background:#25D366; display:flex; align-items:center; justify-content:center; color:#fff; }
.sol-fallback__ico svg{ width:20px; height:20px; }
.sol-fallback__t{ font-size:.875rem; line-height:1.4; color:var(--tw-slogan-fg); }
.sol-fallback__t b{ color:var(--tw-fg); font-weight:600; display:block; font-family:var(--tw-font-display); font-size:1rem; }

/* ---- process: 6-step numbered rail ---- */
.sol-process{ display:grid; grid-template-columns:repeat(6,1fr); gap:0; margin-top:clamp(36px,4vw,52px);
  border:1px solid var(--tw-line); border-radius:10px; overflow:hidden; background:var(--tw-data-bg); }
.sol-process__step{ padding:clamp(18px,2vw,24px); border-right:1px solid var(--tw-line); display:flex; flex-direction:column; gap:10px; }
.sol-process__step:last-child{ border-right:0; }
.sol-process__n{ font-family:var(--tw-font-mono); font-size:11px; letter-spacing:.2em; color:var(--tw-mark); font-weight:500; }
.sol-process__step h4{ font-family:var(--tw-font-display); font-weight:700; letter-spacing:-.02em; font-size:1.0625rem; line-height:1.12; margin:0; color:var(--tw-fg); }
.sol-process__step p{ font-size:.8125rem; line-height:1.45; color:var(--tw-slogan-fg); margin:0; }
@media(max-width:980px){ .sol-process{ grid-template-columns:repeat(2,1fr); } .sol-process__step{ border-bottom:1px solid var(--tw-line); } .sol-process__step:nth-child(2n){ border-right:0; } .sol-process__step:nth-last-child(-n+2){ border-bottom:0; } }
@media(max-width:560px){ .sol-process{ grid-template-columns:1fr; } .sol-process__step{ border-right:0; } }

/* ---- bill: before/after annual energy cost (ported from ec-bill) ---- */
.sol-bill{ background:var(--tw-bg); border:1px solid var(--tw-line); border-radius:8px; padding:clamp(20px,2.4vw,26px); }
.sol-bill__head{ display:flex; justify-content:space-between; align-items:center; gap:12px; padding-bottom:14px; margin-bottom:6px; border-bottom:1px solid var(--tw-line);
  font-family:var(--tw-font-mono); font-size:10px; letter-spacing:.18em; text-transform:uppercase; color:var(--tw-slogan-fg); }
.sol-bill__legend{ display:flex; gap:14px; }
.sol-bill__legend span{ display:inline-flex; align-items:center; gap:6px; }
.sol-bill__legend i{ width:10px; height:8px; border-radius:2px; display:inline-block; }
.sol-bline{ display:grid; grid-template-columns:140px 1fr auto; gap:14px; align-items:center; padding:11px 0; border-bottom:1px solid var(--tw-line); }
.sol-bline__name{ font-size:.8125rem; color:var(--tw-fg); font-weight:500; }
.sol-bline__bars{ display:flex; flex-direction:column; gap:4px; }
.sol-bline__bar{ height:7px; border-radius:2px; }
.sol-bline__bar.is-before{ background:rgba(26,29,33,0.18); }
.sol-bline__bar.is-after{ background:var(--tw-mark); }
.sol-bline__delta{ font-family:var(--tw-font-mono); font-size:11px; color:var(--tw-slogan-fg); text-align:right; white-space:nowrap; }
.sol-bline__delta b{ color:#1b8f5a; font-weight:600; }
.sol-bill__total{ display:grid; grid-template-columns:140px 1fr auto; gap:14px; align-items:center; padding-top:14px; }
.sol-bill__total .t{ font-family:var(--tw-font-display); font-weight:700; font-size:.9375rem; color:var(--tw-fg); }
.sol-bill__total .nums{ grid-column:3; text-align:right; }
.sol-bill__total .was{ font-family:var(--tw-font-mono); font-size:11px; color:var(--tw-slogan-fg); text-decoration:line-through; }
.sol-bill__total .now{ font-family:var(--tw-font-display); font-weight:800; font-size:1.25rem; letter-spacing:-.03em; color:var(--tw-mark); margin-left:8px; }
@media(max-width:560px){ .sol-bline,.sol-bill__total{ grid-template-columns:96px 1fr auto; } }

/* ---- savings waterfall (ported from ec-fall) ---- */
.sol-fall{ display:flex; flex-direction:column; gap:14px; }
.sol-fall__top{ display:flex; justify-content:space-between; align-items:baseline; margin-bottom:6px; }
.sol-fall__lbl{ font-size:.8125rem; color:var(--tw-fg); font-weight:500; }
.sol-fall__val{ font-family:var(--tw-font-mono); font-size:11px; color:var(--tw-mark); }
.sol-fall__track{ height:10px; background:var(--tw-data-bg); border:1px solid var(--tw-line); border-radius:3px; overflow:hidden; }
.sol-fall__fill{ height:100%; background:var(--tw-mark); border-radius:2px; }

/* ---- finance: funding menu rows ---- */
.sol-finance{ display:flex; flex-direction:column; border:1px solid var(--tw-line); border-radius:10px; overflow:hidden; background:var(--tw-data-bg); margin-top:clamp(32px,4vw,48px); }
.sol-fund{ display:grid; grid-template-columns:minmax(0,.85fr) minmax(0,1.6fr) auto; gap:clamp(16px,2.5vw,32px); align-items:center; padding:clamp(18px,2.2vw,24px) clamp(20px,2.4vw,28px); border-bottom:1px solid var(--tw-line); }
.sol-fund:last-child{ border-bottom:0; }
.sol-fund.is-flag{ background:color-mix(in srgb,var(--tw-mark) 8%,transparent); }
.sol-fund__name{ font-family:var(--tw-font-display); font-weight:800; letter-spacing:-.025em; font-size:1.25rem; line-height:1.08; color:var(--tw-fg); }
.sol-fund__name .tag{ display:block; font-family:var(--tw-font-mono); font-size:9.5px; letter-spacing:.18em; text-transform:uppercase; color:var(--tw-mark); margin-bottom:6px; font-weight:500; }
.sol-fund__desc{ font-size:.9375rem; line-height:1.5; color:var(--tw-slogan-fg); }
.sol-fund__desc strong{ color:var(--tw-fg); font-weight:600; }
.sol-fund__chip{ font-family:var(--tw-font-mono); font-size:10px; letter-spacing:.14em; text-transform:uppercase; color:var(--tw-mark); border:1px solid var(--tw-line); border-radius:99px; padding:7px 14px; white-space:nowrap; }
@media(max-width:820px){ .sol-fund{ grid-template-columns:1fr; gap:10px; align-items:start; } .sol-fund__chip{ justify-self:start; } }

/* ---- objections → reassurance (ported from ec-pain) ---- */
.sol-obj{ display:grid; grid-template-columns:repeat(2,1fr); gap:0 clamp(28px,4vw,56px); margin-top:clamp(28px,3vw,40px); }
.sol-obj__row{ padding:18px 0; border-top:1px solid var(--tw-line); }
.sol-obj__q{ font-family:var(--tw-font-display); font-weight:600; font-style:italic; font-size:1.0625rem; line-height:1.3; color:var(--tw-fg); margin:0 0 8px; }
.sol-obj__a{ font-size:.9375rem; line-height:1.5; color:var(--tw-slogan-fg); margin:0; padding-left:20px; position:relative; }
.sol-obj__a::before{ content:"→"; position:absolute; left:0; color:var(--tw-mark); font-weight:700; }
@media(max-width:760px){ .sol-obj{ grid-template-columns:1fr; } }

/* ---- credibility / customer quote ---- */
.sol-quote{ margin:clamp(28px,3.5vw,40px) 0 0; padding:clamp(26px,3vw,36px); border:1px solid var(--tw-line); border-left:3px solid var(--tw-mark);
  border-radius:0 10px 10px 0; background:var(--tw-data-bg); }
.sol-quote p{ font-family:var(--tw-font-display); font-weight:500; font-size:clamp(1.25rem,2.2vw,1.625rem); line-height:1.3; letter-spacing:-.02em; color:var(--tw-fg); margin:0; text-wrap:pretty; }
.sol-quote cite{ display:block; margin-top:16px; font-family:var(--tw-font-mono); font-size:10.5px; letter-spacing:.16em; text-transform:uppercase; color:var(--tw-slogan-fg); font-style:normal; }

/* ---- trust signal chips (why terawatt) ---- */
.sol-signals{ display:grid; grid-template-columns:repeat(3,1fr); gap:12px; margin-top:clamp(28px,3vw,40px); }
@media(max-width:880px){ .sol-signals{ grid-template-columns:1fr 1fr; } }
@media(max-width:520px){ .sol-signals{ grid-template-columns:1fr; } }
.sol-signal{ border:1px solid var(--tw-line); border-radius:8px; background:var(--tw-data-bg); padding:16px 18px; }
.sol-signal h4{ font-family:var(--tw-font-display); font-weight:700; letter-spacing:-.02em; font-size:1.0625rem; line-height:1.1; margin:0 0 6px; color:var(--tw-fg); }
.sol-signal p{ font-size:.8125rem; line-height:1.45; color:var(--tw-slogan-fg); margin:0; }

/* ---- real-photography figure (team-supplied via image-slot) ---- */
.sol-photo{ position:relative; border:1px solid var(--tw-line); border-radius:10px; overflow:hidden; background:var(--tw-data-bg); box-shadow:0 24px 60px -34px rgba(0,0,0,.5); }
.sol-photo image-slot{ display:block; width:100%; aspect-ratio:var(--photo-ar,16/10); background:var(--tw-data-bg); }
.sol-photo img{ display:block; width:100%; aspect-ratio:var(--photo-ar,16/10); object-fit:cover; }
.sol-photo__cap{ position:absolute; left:0; right:0; bottom:0; z-index:2; padding:14px 16px;
  display:flex; align-items:center; gap:10px; font-family:var(--tw-font-mono); font-size:10px; letter-spacing:.16em; text-transform:uppercase; color:#F4F1EC;
  background:linear-gradient(180deg, rgba(12,14,16,0) 0%, rgba(12,14,16,.78) 100%); pointer-events:none; }
.sol-photo__cap b{ color:var(--tw-saffron); font-weight:600; }

/* SAWEM band scrim — keep type legible on the generated dawn-grid photo */
.sol-marketband .v5-section__media img{ filter:brightness(1.18) saturate(1.08) contrast(1.02); }
.sol-marketband .v5-section__scrim{
  background:linear-gradient(90deg, rgba(20,22,25,.90) 0%, rgba(20,22,25,.50) 50%, rgba(20,22,25,.16) 100%),
            linear-gradient(180deg, rgba(20,22,25,.18) 0%, rgba(20,22,25,.66) 100%); }

