/* =====================================================================
   SolarSafe / Izza Auliya · Shared stylesheet
   Tema: bumi · energi surya · green lifestyle. Mobile-first.
   ===================================================================== */
:root{
  --leaf:#1c7d4d; --leaf-2:#37b06b; --leaf-deep:#0c3a26;
  --ocean:#1d7ea3; --ocean-deep:#072233;
  --space:#040814; --space-2:#0a1430;
  --sun:#f4b740; --sun-soft:#ffd57a;
  --eco:#f1f8f3; --paper:#ffffff;
  --ink:#15302a; --muted:#5a6f66; --line:#dcecdf;
  --radius:20px;
  --shadow:0 22px 55px -24px rgba(7,34,51,.55);
  --shadow-sm:0 10px 26px -16px rgba(7,34,51,.4);
  --maxw:1160px;
  --font:'Segoe UI',system-ui,-apple-system,Roboto,Helvetica,Arial,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--font);color:var(--ink);background:var(--eco);line-height:1.65;-webkit-font-smoothing:antialiased;overflow-x:hidden}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 22px;position:relative}
section{padding:84px 0;position:relative}
h1,h2,h3{line-height:1.18;letter-spacing:-.01em}
.eyebrow{display:inline-flex;align-items:center;gap:8px;font-size:.76rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--leaf);margin-bottom:14px}
.sec-title{font-size:clamp(1.7rem,3.6vw,2.6rem);color:var(--leaf-deep);margin-bottom:14px}
.sec-lead{max-width:700px;color:var(--muted);font-size:1.05rem}
.center{text-align:center}.center .eyebrow{justify-content:center}.center .sec-lead{margin:0 auto}

/* ---------- Buttons & interactive links ---------- */
.btn{position:relative;display:inline-flex;align-items:center;gap:9px;font-weight:700;font-size:.97rem;padding:14px 27px;border-radius:999px;cursor:pointer;border:2px solid transparent;transition:transform .2s ease,box-shadow .2s ease,filter .2s ease;white-space:nowrap;overflow:hidden}
.btn::after{content:"";position:absolute;top:0;left:-120%;width:60%;height:100%;background:linear-gradient(100deg,transparent,rgba(255,255,255,.45),transparent);transform:skewX(-18deg);transition:.5s}
.btn:hover::after{left:130%}
.btn-primary{background:linear-gradient(135deg,var(--leaf-2),var(--leaf));color:#fff;box-shadow:0 12px 26px -12px rgba(28,125,77,.8)}
.btn-primary:hover{transform:translateY(-2px);filter:brightness(1.06)}
.btn-sun{background:linear-gradient(135deg,var(--sun),var(--sun-soft));color:#4a3206;box-shadow:0 12px 26px -12px rgba(244,183,64,.8)}
.btn-sun:hover{transform:translateY(-2px)}
.btn-ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.45)}
.btn-ghost:hover{border-color:#fff;background:rgba(255,255,255,.1)}
.btn-dark{background:var(--leaf-deep);color:#fff}
.btn-dark:hover{background:var(--leaf);transform:translateY(-2px)}
.btn-line{background:transparent;border-color:var(--leaf);color:var(--leaf)}
.btn-line:hover{background:var(--leaf);color:#fff;transform:translateY(-2px)}
.link-arrow{display:inline-flex;align-items:center;gap:7px;font-weight:700;color:var(--leaf);transition:.2s}
.link-arrow span{transition:.2s}
.link-arrow:hover{color:var(--leaf-2)}
.link-arrow:hover span{transform:translateX(5px)}

/* ---------- Nav ---------- */
header.nav{position:sticky;top:0;z-index:60;background:rgba(241,248,243,.85);backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:68px}
.brand{display:flex;align-items:center;gap:11px;font-weight:800;color:var(--leaf-deep);font-size:1.04rem}
.brand .mark{width:40px;height:40px;border-radius:50%;background:radial-gradient(circle at 32% 28%,#7fd6ff,#1d7ea3 45%,#0c3a26);color:#fff;display:grid;place-items:center;font-weight:800;font-size:.9rem;box-shadow:inset -4px -4px 8px rgba(0,0,0,.3)}
.nav-links{display:flex;gap:24px;align-items:center}
.nav-links a{font-weight:600;font-size:.92rem;color:var(--ink);opacity:.84;position:relative}
.nav-links a:not(.btn)::after{content:"";position:absolute;left:0;bottom:-5px;width:0;height:2px;background:var(--leaf-2);transition:.25s}
.nav-links a:not(.btn):hover{opacity:1;color:var(--leaf)}
.nav-links a:not(.btn):hover::after{width:100%}
.nav-cta{padding:9px 18px;font-size:.88rem}
.nav-links a.btn{opacity:1}
.nav-links a.btn-dark{color:#fff}
.nav-links a.btn-sun{color:#4a3206}
.nav-links a.btn-primary{color:#fff}
.nav-links a.btn-ghost{color:#fff}
.menu-btn{display:none;background:none;border:none;font-size:1.6rem;cursor:pointer;color:var(--leaf-deep)}
@media(max-width:760px){
  .nav-links{display:none}.menu-btn{display:block}
  .nav-links.open{display:flex;position:absolute;top:68px;left:0;right:0;flex-direction:column;background:var(--eco);border-bottom:1px solid var(--line);padding:18px 22px;gap:16px}
}

/* ---------- Space hero (Earth) ---------- */
.space-hero{position:relative;overflow:hidden;color:#fff;background:radial-gradient(1200px 700px at 78% -8%,#13315c 0%,var(--space-2) 38%,var(--space) 100%)}
#starfield{position:absolute;inset:0;z-index:0;display:block}
.sun-far{position:absolute;top:8%;left:6%;width:120px;height:120px;border-radius:50%;z-index:1;
  background:radial-gradient(circle,#fff 0%,var(--sun-soft) 28%,var(--sun) 55%,rgba(244,183,64,0) 72%);
  filter:blur(2px);box-shadow:0 0 120px 40px rgba(244,183,64,.45);animation:sunpulse 6s ease-in-out infinite}
@keyframes sunpulse{50%{transform:scale(1.08);filter:blur(3px)}}
.hero-inner{position:relative;z-index:3;display:grid;grid-template-columns:1.1fr .95fr;gap:30px;align-items:center;padding:84px 0 110px;min-height:90vh}
.hero-eyebrow{display:inline-flex;align-items:center;gap:9px;font-size:.82rem;font-weight:600;color:#bfeede;background:rgba(55,176,107,.16);border:1px solid rgba(55,176,107,.5);padding:7px 15px;border-radius:999px}
.hero-eyebrow .dot{width:8px;height:8px;border-radius:50%;background:#4ade80;box-shadow:0 0 0 4px rgba(74,222,128,.25);animation:pulse 2s infinite}
@keyframes pulse{50%{box-shadow:0 0 0 9px rgba(74,222,128,0)}}
.space-hero h1{font-size:clamp(2.1rem,5vw,3.6rem);margin:18px 0;color:#fff;text-shadow:0 2px 30px rgba(0,0,0,.4)}
.space-hero h1 .hl{color:var(--sun-soft)}
.space-hero .lead{font-size:1.12rem;color:#cfe1ea;max-width:540px;margin-bottom:14px}
.pills{display:flex;flex-wrap:wrap;gap:9px;margin:22px 0 30px}
.pill{font-size:.82rem;font-weight:600;padding:7px 14px;border-radius:999px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.18);color:#eafaf2}
.hero-cta{display:flex;flex-wrap:wrap;gap:14px}

/* Earth */
.earth-stage{position:relative;display:grid;place-items:center;min-height:440px;z-index:2}
.earth-wrap{position:relative;width:340px;height:340px;cursor:grab;touch-action:none}
.earth-wrap:active{cursor:grabbing}
.earth-glow{position:absolute;inset:-22px;border-radius:50%;background:radial-gradient(circle,rgba(90,170,255,.35),rgba(55,176,107,.12) 55%,transparent 70%);filter:blur(6px);animation:floaty 8s ease-in-out infinite}
@keyframes floaty{50%{transform:translateY(-12px)}}
.earth{position:absolute;inset:0;border-radius:50%;overflow:hidden;animation:floaty 8s ease-in-out infinite;
  box-shadow:inset -30px -26px 70px rgba(0,0,0,.7),inset 18px 16px 40px rgba(140,210,255,.35),0 0 60px rgba(40,120,200,.4)}
.earth .map{position:absolute;top:0;left:0;height:100%;width:200%;background-repeat:repeat-x}
.earth .clouds{position:absolute;top:0;left:0;height:100%;width:200%;background-repeat:repeat-x;opacity:.55;mix-blend-mode:screen}
.earth .shade{position:absolute;inset:0;border-radius:50%;pointer-events:none;
  background:radial-gradient(circle at 32% 30%,rgba(255,255,255,.25) 0%,transparent 38%),
             linear-gradient(100deg,transparent 40%,rgba(0,0,10,.55) 78%)}
.earth .atmos{position:absolute;inset:0;border-radius:50%;pointer-events:none;box-shadow:inset 0 0 26px 6px rgba(120,200,255,.5)}
.earth-hint{position:absolute;bottom:-2px;width:100%;text-align:center;font-size:.8rem;color:#9fc3d6;z-index:4}
.earth-hint b{color:var(--sun-soft)}

/* Ticker */
.ticker{position:relative;z-index:3;display:flex;flex-wrap:wrap;gap:14px;justify-content:center;padding-bottom:70px;margin-top:-40px}
.tk{display:flex;align-items:center;gap:11px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.16);border-radius:14px;padding:13px 18px;min-width:160px;backdrop-filter:blur(4px)}
.tk b{font-size:1.45rem;color:var(--sun-soft);line-height:1;display:block}
.tk small{font-size:.73rem;color:#cfe1ea}.tk .e{font-size:1.45rem}

/* ---------- Generic page header (sub pages) ---------- */
.page-head{background:radial-gradient(1000px 500px at 80% -20%,#13315c,var(--leaf-deep) 60%,#072a1c);color:#fff;padding:96px 0 70px;position:relative;overflow:hidden}
.page-head .eyebrow{color:var(--sun-soft)}.page-head .eyebrow::before{background:var(--sun)}
.page-head h1{font-size:clamp(1.9rem,4.4vw,3rem);margin-bottom:14px}
.page-head p{color:#cfe1ea;max-width:620px;font-size:1.06rem}
.crumb{font-size:.85rem;color:#9fc3b4;margin-bottom:18px}
.crumb a:hover{color:var(--sun-soft)}

/* ---------- Cards / grids ---------- */
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.leaf-card{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:30px;box-shadow:var(--shadow-sm)}

/* Venture / link cards (interactive) */
.v-card{position:relative;background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:28px 26px;transition:transform .28s cubic-bezier(.2,.7,.3,1),box-shadow .28s,border-color .28s;overflow:hidden;display:block}
.v-card::after{content:"";position:absolute;inset:0;border-radius:var(--radius);background:radial-gradient(240px circle at var(--mx,50%) var(--my,0%),rgba(55,176,107,.16),transparent 60%);opacity:0;transition:.3s}
.v-card:hover{transform:translateY(-8px);box-shadow:var(--shadow);border-color:rgba(55,176,107,.5)}
.v-card:hover::after{opacity:1}
.v-card .vicon{width:56px;height:56px;border-radius:15px;display:grid;place-items:center;font-size:1.6rem;margin-bottom:18px;background:linear-gradient(135deg,#e3f5e9,#d2efdb);position:relative;z-index:2;transition:.3s}
.v-card:hover .vicon{transform:scale(1.08) rotate(-4deg)}
.v-card h3{font-size:1.16rem;margin-bottom:9px;color:var(--leaf-deep);position:relative;z-index:2}
.v-card .vtag{display:inline-block;font-size:.7rem;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:var(--leaf);margin-bottom:12px;position:relative;z-index:2}
.v-card p{color:var(--muted);font-size:.94rem;margin-bottom:18px;position:relative;z-index:2}
.v-card .vgo{position:relative;z-index:2}

/* ---------- Services ---------- */
.svc{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:32px;box-shadow:var(--shadow-sm);position:relative;overflow:hidden}
.svc::before{content:"";position:absolute;top:0;left:0;width:100%;height:5px;background:linear-gradient(90deg,var(--leaf-2),var(--sun))}
.svc .stag{font-size:.74rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--leaf)}
.svc h3{color:var(--leaf-deep);font-size:1.25rem;margin:8px 0 14px}
.svc p{color:var(--muted);margin-bottom:18px;font-size:.97rem}
.svc ul{list-style:none;display:flex;flex-direction:column;gap:11px;margin-bottom:24px}
.svc ul li{display:flex;gap:11px;font-size:.95rem}
.svc ul li .chk{flex:0 0 22px;height:22px;border-radius:7px;background:#e3f5e9;color:var(--leaf);display:grid;place-items:center;font-size:.78rem;font-weight:800}

/* ---------- Calculator ---------- */
.calc-wrap{display:grid;grid-template-columns:1fr 1fr;gap:32px;align-items:start}
.calc-panel{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:30px;box-shadow:var(--shadow-sm)}
.calc-panel h3{color:var(--leaf-deep);font-size:1.15rem;margin-bottom:4px}
.calc-panel .hint{color:var(--muted);font-size:.88rem;margin-bottom:20px}
.seg{display:flex;gap:8px;background:#eef6f0;border-radius:12px;padding:5px;margin-bottom:20px}
.seg button{flex:1;border:none;background:transparent;padding:11px 6px;border-radius:9px;font-weight:700;font-size:.86rem;color:var(--muted);cursor:pointer;transition:.2s;font-family:inherit}
.seg button.active{background:#fff;color:var(--leaf);box-shadow:var(--shadow-sm)}
.ctrl{margin-bottom:20px}
.ctrl label{display:flex;justify-content:space-between;align-items:baseline;font-weight:600;font-size:.9rem;color:var(--ink);margin-bottom:9px}
.ctrl label b{color:var(--leaf);font-size:1rem}
input[type=range]{-webkit-appearance:none;appearance:none;width:100%;height:8px;border-radius:999px;background:linear-gradient(90deg,var(--leaf-2),var(--sun));outline:none}
input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:24px;height:24px;border-radius:50%;background:#fff;border:4px solid var(--leaf);cursor:pointer;box-shadow:0 4px 10px rgba(0,0,0,.2)}
input[type=range]::-moz-range-thumb{width:24px;height:24px;border-radius:50%;background:#fff;border:4px solid var(--leaf);cursor:pointer}
.num-in,select.num-in{width:100%;padding:12px 14px;border-radius:12px;border:1px solid var(--line);font-size:.95rem;font-family:inherit;color:var(--ink);background:#fff}
.num-in:focus{outline:none;border-color:var(--leaf-2)}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.result-panel{background:linear-gradient(160deg,var(--leaf-deep),#062018);color:#fff;border-radius:var(--radius);padding:30px;box-shadow:var(--shadow)}
.res-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.res{background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.14);border-radius:15px;padding:18px}
.res .rlabel{font-size:.76rem;color:#bfe0d2;display:flex;align-items:center;gap:6px;margin-bottom:7px}
.res .rval{font-size:1.5rem;font-weight:800;color:#fff;line-height:1.05}
.res .rval.sun{color:var(--sun-soft)}
.res .rsub{font-size:.74rem;color:#9fc3b4;margin-top:4px}
.res.big{grid-column:span 2;background:rgba(244,183,64,.14);border-color:rgba(244,183,64,.3)}
.res.big .rval{font-size:1.9rem;color:var(--sun-soft)}
.rlife{margin-top:14px;padding-top:14px;border-top:1px dashed rgba(255,255,255,.2);display:flex;flex-direction:column;gap:3px}
.rlife-cap{font-size:.74rem;color:#cfe1ea;letter-spacing:.03em;text-transform:uppercase}
.rlife-num{font-size:2rem;font-weight:800;color:var(--sun-soft);line-height:1.05;letter-spacing:-.01em}
#backupTile{background:rgba(120,180,255,.12);border-color:rgba(120,180,255,.32)}
#backupTile .rval{color:#bcd7ff}
.bat-hint{font-size:.78rem;color:var(--muted);margin-top:6px}
.capex-break{margin-top:16px;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.12);border-radius:14px;padding:16px 18px}
.capex-break h4{font-size:.82rem;color:#cfe1ea;margin-bottom:12px;letter-spacing:.04em;text-transform:uppercase}
.cap-line{display:flex;align-items:center;gap:10px;margin-bottom:9px;font-size:.85rem}
.cap-line .bar{flex:1;height:7px;border-radius:99px;background:rgba(255,255,255,.12);overflow:hidden}
.cap-line .bar i{display:block;height:100%;border-radius:99px;background:linear-gradient(90deg,var(--leaf-2),var(--sun))}
.cap-line .cv{color:#fff;font-weight:600;min-width:96px;text-align:right;font-size:.82rem}
.cap-line .cn{min-width:118px;color:#bfe0d2}
.solarsafe-box{margin-top:16px;background:linear-gradient(120deg,rgba(244,183,64,.2),rgba(55,176,107,.14));border:1px solid rgba(255,213,122,.35);border-radius:15px;padding:18px}
.solarsafe-box .ss-h{display:flex;align-items:center;gap:8px;font-weight:800;color:var(--sun-soft);margin-bottom:6px}
.solarsafe-box p{font-size:.84rem;color:#e9f3ec}
.calc-note{font-size:.76rem;color:var(--muted);margin-top:18px;line-height:1.6}

/* ---------- Steps ---------- */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.step{background:var(--paper);border:1px solid var(--line);border-radius:16px;padding:24px 22px;transition:.25s}
.step:hover{transform:translateY(-5px);box-shadow:var(--shadow-sm)}
.step .num{width:42px;height:42px;border-radius:12px;background:linear-gradient(135deg,var(--leaf),var(--leaf-deep));color:#fff;display:grid;place-items:center;font-weight:800;margin-bottom:14px}
.step h4{color:var(--leaf-deep);font-size:1rem;margin-bottom:7px}
.step p{color:var(--muted);font-size:.89rem}

/* ---------- Gallery ---------- */
.gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.ph{aspect-ratio:4/3;border-radius:16px;border:1px dashed var(--line);background:linear-gradient(160deg,#eef6f0,#e2efe6);display:grid;place-items:center;color:var(--muted);text-align:center;font-size:.85rem;padding:16px;overflow:hidden;transition:.3s}
.ph:hover{transform:scale(1.02)}
.ph img{width:100%;height:100%;object-fit:cover;border-radius:16px}

/* ---------- Forms ---------- */
.form-card{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:32px;box-shadow:var(--shadow-sm)}
.form-card .field{margin-bottom:16px}
.form-card label{display:block;font-size:.86rem;font-weight:600;color:var(--ink);margin-bottom:7px}
.form-card input,.form-card select,.form-card textarea{width:100%;padding:13px 15px;border-radius:12px;border:1px solid var(--line);background:#fff;font-family:inherit;font-size:.95rem;color:var(--ink)}
.form-card input:focus,.form-card select:focus,.form-card textarea:focus{outline:none;border-color:var(--leaf-2)}
.form-note{font-size:.8rem;color:var(--muted);margin-top:10px}

/* ---------- Contact (dark) ---------- */
.contact{background:linear-gradient(160deg,#072233,var(--leaf-deep));color:#fff;overflow:hidden}
.contact .eyebrow{color:var(--sun-soft)}.contact .eyebrow::before{background:var(--sun)}
.contact .sec-title{color:#fff}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start}
.c-item{display:flex;gap:15px;align-items:flex-start;margin-bottom:18px}
.c-item .ci{width:48px;height:48px;border-radius:13px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.15);display:grid;place-items:center;font-size:1.25rem;flex:0 0 48px;transition:.25s}
.c-item:hover .ci{background:rgba(244,183,64,.2);transform:translateY(-3px)}
.c-item b{display:block;color:#fff;font-size:.97rem}.c-item span{color:#9fc3b4;font-size:.92rem}
.contact .form-card{background:rgba(255,255,255,.05);border-color:rgba(255,255,255,.14)}
.contact .form-card label{color:#cfe1ea}
.contact .form-card input,.contact .form-card select,.contact .form-card textarea{background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.18);color:#fff}
.contact .form-card select option{color:#15302a}

/* ---------- Footer ---------- */
footer.foot{background:#06231a;color:#9fc3b4;padding:46px 0 28px}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:34px;margin-bottom:28px}
.foot h5{color:#fff;font-size:.95rem;margin-bottom:14px}
.foot a{display:block;color:#9fc3b4;font-size:.9rem;margin-bottom:9px;transition:.2s}
.foot a:hover{color:var(--sun-soft);transform:translateX(3px)}
.foot-bottom{border-top:1px solid rgba(255,255,255,.1);padding-top:18px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;font-size:.82rem}
.disclaimer{font-size:.77rem;color:#5f7d72;margin-top:14px;max-width:680px;line-height:1.6}

/* ---------- Floating WA + reveal ---------- */
.wa{position:fixed;right:20px;bottom:20px;z-index:70;background:#25d366;color:#fff;width:58px;height:58px;border-radius:50%;display:grid;place-items:center;box-shadow:0 12px 30px -8px rgba(37,211,102,.7);font-size:1.6rem;transition:.2s}
.wa:hover{transform:scale(1.09)}
.reveal{opacity:0;transform:translateY(26px);transition:.6s ease}
.reveal.show{opacity:1;transform:none}

/* ---------- Responsive ---------- */
@media(max-width:940px){
  .hero-inner,.calc-wrap,.grid-2,.contact-grid{grid-template-columns:1fr;gap:34px}
  .hero-inner{padding:60px 0 80px;min-height:auto}
  .earth-stage{min-height:360px;order:-1}
  .grid-3,.steps,.gallery{grid-template-columns:1fr 1fr}
  .foot-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:680px){
  section{padding:60px 0}
  .grid-3,.steps,.gallery,.field-row,.res-row{grid-template-columns:1fr}
  .res.big{grid-column:span 1}
  .foot-grid{grid-template-columns:1fr}
  .earth-wrap{width:260px;height:260px}.sun-far{width:80px;height:80px}
  .hero-cta{width:100%}.hero-cta .btn{flex:1;justify-content:center}
}
/* ---------- ICON SYSTEM ---------- */
.ico{display:inline-grid;place-items:center;line-height:0;color:currentColor}
.ico svg{width:1em;height:1em;display:block}
.vicon{font-size:1.5rem;color:var(--leaf)}
.pill{display:inline-flex;align-items:center;gap:7px}
.pill .ico{font-size:1rem;color:var(--sun-soft)}
.kbox{flex:0 0 38px;height:38px;border-radius:11px;background:linear-gradient(135deg,#e3f5e9,#d2efdb);display:grid;place-items:center;font-size:1.15rem;color:var(--leaf)}
.c-item .ci{font-size:1.2rem}
.rlabel .ico{font-size:1rem}
.rlabel{gap:7px}
.chkico{flex:0 0 22px;height:22px;border-radius:7px;background:#e3f5e9;color:var(--leaf);display:grid;place-items:center;font-size:.8rem}
.chkico.dark{background:rgba(255,255,255,.12);color:var(--sun-soft)}

/* ---------- PALE BLUE DOT ---------- */
.pbd-stage{position:relative;display:grid;place-items:center;min-height:460px;width:100%;z-index:2}
.pbd-beam{position:absolute;width:150%;height:46%;top:6%;left:-18%;transform:rotate(18deg);pointer-events:none;
  background:linear-gradient(90deg,transparent 8%,rgba(244,213,140,.14) 42%,rgba(255,255,255,.10) 55%,rgba(120,170,255,.10) 66%,transparent 92%);
  filter:blur(10px);transition:transform .3s ease}
.pbd-beam.b2{height:30%;top:30%;opacity:.6;background:linear-gradient(90deg,transparent,rgba(255,255,255,.08),transparent)}
.pbd-ring{position:absolute;width:150px;height:150px;border-radius:50%;border:1px solid rgba(150,190,255,.12);animation:floaty 9s ease-in-out infinite}
.pbd-ring.r2{width:240px;height:240px;border-color:rgba(150,190,255,.07);animation-duration:12s}
.pbd-dot{position:relative;width:14px;height:14px;border-radius:50%;z-index:3;transition:transform .25s ease;
  background:radial-gradient(circle at 38% 36%,#eaf5ff,#9cc6ff 42%,#4f8ddd 72%,#1c3f73);
  box-shadow:0 0 22px 6px rgba(120,180,255,.55),0 0 64px 20px rgba(90,150,240,.22)}
.pbd-dot::after{content:"";position:absolute;inset:0;border-radius:50%;animation:dotpulse 4.5s ease-in-out infinite}
@keyframes dotpulse{0%,100%{box-shadow:0 0 0 0 rgba(150,200,255,.35)}50%{box-shadow:0 0 0 7px rgba(150,200,255,0)}}
.pbd-cap{position:absolute;bottom:4%;width:100%;max-width:380px;text-align:center;font-size:.9rem;color:#cdd9e6;font-style:italic;line-height:1.6;z-index:3;padding:0 12px}
.pbd-cap b{color:#bcd7ff;font-style:normal}
.pbd-cap .src{display:block;margin-top:8px;font-style:normal;color:#a6bdd2;font-size:.74rem;letter-spacing:.05em;text-transform:uppercase}
@media(max-width:680px){.pbd-stage{min-height:360px}.pbd-ring{width:120px;height:120px}.pbd-ring.r2{width:190px;height:190px}}

/* ---------- SolarSafe scheme box (highlight) ---------- */
.solarsafe-box .ss-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:12px}
.ss-cell{background:rgba(0,0,0,.16);border:1px solid rgba(255,213,122,.25);border-radius:13px;padding:14px 16px;display:flex;flex-direction:column;gap:3px}
.ss-cap{font-size:.7rem;text-transform:uppercase;letter-spacing:.07em;color:#e9d9b4}
.ss-strike{font-size:.95rem;color:#d9caa1;text-decoration:line-through;text-decoration-color:#e8965f}
.ss-big{font-size:1.55rem;font-weight:800;color:var(--sun-soft);line-height:1.05}
.ss-big small{font-size:.78rem;font-weight:600;color:#e9d9b4}
.ss-badge{align-self:flex-start;margin-top:5px;font-size:.7rem;font-weight:800;color:#3a2606;background:var(--sun-soft);padding:3px 10px;border-radius:999px}
.ss-sub{font-size:.74rem;color:#e9d9b4;margin-top:2px}
.ss-offset{margin-top:13px;background:rgba(55,176,107,.16);border:1px solid rgba(55,176,107,.32);border-radius:13px;padding:13px 16px}
.ss-off-row{display:flex;justify-content:space-between;align-items:center;font-size:.88rem;color:#eafaf2}
.ss-pos{color:#86e7ad;font-weight:800}
.ss-net{margin-top:7px;font-size:.9rem;color:#fff;font-weight:700;line-height:1.4}
.ss-note{font-size:.74rem;color:#d9c69a;margin-top:10px}
@media(max-width:680px){.solarsafe-box .ss-grid{grid-template-columns:1fr}}

/* ---------- Calculator gating ---------- */
.calc-banner{display:flex;align-items:center;gap:14px;background:linear-gradient(120deg,rgba(244,183,64,.16),rgba(55,176,107,.1));border:1px solid rgba(244,183,64,.4);border-radius:14px;padding:14px 18px;color:var(--leaf-deep);font-size:.92rem;margin-top:30px}
.calc-banner .ico{font-size:1.4rem;color:var(--leaf);flex:0 0 auto}
.calc-banner .btn{padding:10px 18px;font-size:.86rem}
@media(max-width:680px){.calc-banner{flex-direction:column;align-items:flex-start}}
.comm-lock{display:flex;gap:16px;align-items:flex-start;margin-top:16px;background:linear-gradient(160deg,rgba(255,255,255,.07),rgba(255,255,255,.02));border:1px dashed rgba(244,183,64,.5);border-radius:16px;padding:22px}
.comm-lock-ic{font-size:1.9rem;color:var(--sun-soft);flex:0 0 auto;margin-top:2px}
.comm-lock b{color:#fff;font-size:1.02rem}
.comm-lock p{color:#bfe0d2;font-size:.9rem;margin-top:6px}
.comm-actions{display:flex;flex-wrap:wrap;gap:14px;align-items:center;margin-top:16px}
.comm-form{display:flex;flex-wrap:wrap;gap:10px;align-items:center;margin-top:16px}
.comm-form input{flex:1;min-width:200px;padding:13px 15px;border-radius:12px;border:1px solid rgba(255,255,255,.2);background:rgba(255,255,255,.07);color:#fff;font-family:inherit;font-size:.95rem}
.comm-form input::placeholder{color:#86a59a}
.comm-form input:focus{outline:none;border-color:var(--sun)}
.comm-form .btn{white-space:nowrap}
.comm-msg{font-size:.85rem;color:#bfe0d2;margin-top:10px;min-height:1em}
.comm-sub{font-size:.82rem;color:#9fc3b4;margin-top:12px}

@media(prefers-reduced-motion:reduce){*{animation-duration:.001s!important}}
