/* Homellie — design system v2 (from design mockups: violet/aqua/yellow, light) */
:root{
  --bg:#f8f7fb;
  --surface:#ffffff;
  --line:#e8e6f0;
  --ink:#221e41;
  --muted:#6e6a8a;
  --primary:#6b3df4;
  --primary-deep:#4b21c8;
  --primary-soft:#efeaff;
  --toggle-on:#7c5cff;
  --mint:#d9f1ee;
  --mint-ink:#14524b;
  --aqua:#4be1e8;
  --teal:#22b8a8;
  --yellow:#ffc531;
  --navy1:#211b46;
  --navy2:#0f0c22;
  --chip:#f4f3f9;
  --r-card:26px;
  --r-tile:22px;
  --r-btn:14px;
  --sh-card:rgba(34,30,65,.06) 0 2px 10px -4px;
  --sh-pop:rgba(34,30,65,.14) 0 12px 36px -16px;
  --sh-primary:rgba(107,61,244,.55) 0 12px 32px -10px;
  --sh-navy:rgba(15,12,34,.55) 0 20px 50px -16px;
}
*{margin:0;padding:0;box-sizing:border-box}
body{font-family:'IBM Plex Sans','Segoe UI',system-ui,sans-serif;background:var(--bg);color:var(--ink);line-height:1.6}
h1,h2,h3,h4{font-family:'Sora','IBM Plex Sans',sans-serif;font-weight:800;line-height:1.15;letter-spacing:-.02em}
a{color:var(--primary);text-decoration:none}
.wrap{max-width:1160px;margin:0 auto;padding:0 24px}

/* Nav */
nav{position:sticky;top:0;background:rgba(255,255,255,.94);backdrop-filter:blur(8px);border-bottom:1px solid var(--line);z-index:10}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:72px;padding:0 24px;max-width:1160px;margin:0 auto;gap:16px}
.logo{display:flex;align-items:center;gap:9px;font-family:'Sora',sans-serif;font-weight:800;font-size:20px;letter-spacing:-.02em;color:var(--ink)}
.logo-badge{width:30px;height:30px;border-radius:10px;background:var(--primary);display:flex;align-items:center;justify-content:center;flex:0 0 auto}
.logo-badge svg{width:16px;height:16px;stroke:#fff}
.nav-links{display:flex;gap:26px;font-size:14px;font-weight:500}
.nav-links a{color:var(--muted)}
.nav-links a:hover,.nav-links a[aria-current]{color:var(--ink)}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;background:var(--primary);color:#fff;height:48px;padding:0 26px;border-radius:var(--r-btn);font-size:15px;font-weight:600;box-shadow:var(--sh-primary);transition:.2s;border:0;cursor:pointer;font-family:inherit}
.btn:hover{background:#5a2fe0;transform:translateY(-1px)}
.btn.small{height:44px;padding:0 22px;font-size:14px}
.btn-outline{background:var(--surface);color:var(--ink);border:2px solid var(--line);box-shadow:none}
.btn-outline:hover{background:var(--chip);border-color:#d8d5e6}
.btn-yellow{background:var(--yellow);color:var(--ink);box-shadow:rgba(255,197,49,.5) 0 12px 32px -10px}
.btn-yellow:hover{background:#f0b71f}

/* Hero */
header.hero{position:relative;padding:64px 0 56px;overflow:hidden}
header.hero::before{content:"";position:absolute;top:-140px;right:-100px;width:460px;height:460px;border-radius:50%;background:rgba(107,61,244,.09);filter:blur(80px);pointer-events:none}
header.hero::after{content:"";position:absolute;bottom:-160px;left:-80px;width:420px;height:420px;border-radius:50%;background:rgba(122,220,211,.3);filter:blur(70px);pointer-events:none}
header.hero .wrap{position:relative;z-index:1}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:44px;align-items:center}
.badge{display:inline-flex;align-items:center;gap:8px;padding:7px 14px;border-radius:9999px;background:var(--surface);border:1px solid var(--line);font-size:12px;font-weight:600;letter-spacing:.08em;color:var(--primary)}
h1{font-family:'Sora',sans-serif;font-weight:800;font-size:clamp(2.1rem,4.2vw,3.125rem);line-height:1.06;letter-spacing:-.03em}
h1 em{font-style:normal;color:var(--primary)}
.sub{font-size:18px;line-height:1.6;color:var(--muted);max-width:480px}
.hero-col{display:flex;flex-direction:column;align-items:flex-start;gap:24px}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap}
.trust{display:flex;gap:32px;flex-wrap:wrap;margin-top:12px}
.trust b{display:block;font-family:'Sora',sans-serif;font-weight:800;font-size:24px;color:var(--ink)}
.trust span{font-size:12px;color:var(--muted)}
.crumbs{font-size:13px;color:var(--muted);margin-bottom:18px}
.crumbs a{color:var(--muted)}
.crumbs a:hover{color:var(--primary)}
header.hero.compact{padding:48px 0 40px}
header.hero.compact h1{font-size:clamp(1.9rem,3.6vw,2.6rem)}

/* Panel domu (navy dashboard) */
.panel{background:linear-gradient(165deg,var(--navy1),var(--navy2));border-radius:var(--r-card);padding:22px 24px;box-shadow:var(--sh-navy);border:1px solid rgba(255,255,255,.08);color:#fff}
.panel-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}
.panel-head b{font-family:'Sora',sans-serif;font-weight:700;font-size:15px}
.live{display:inline-flex;align-items:center;gap:6px;font-size:11px;font-weight:600;letter-spacing:.06em;color:var(--aqua)}
.live::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--aqua)}
.panel-rows{display:flex;flex-direction:column;gap:10px}
.prow{display:flex;align-items:center;justify-content:space-between;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.07);border-radius:14px;padding:11px 14px}
.prow .lbl{display:flex;align-items:center;gap:10px;font-size:14px;font-weight:500}
.prow .lbl svg{width:18px;height:18px;color:var(--yellow)}
.prow.off .lbl{color:rgba(255,255,255,.45)}
.prow.off .lbl svg{color:rgba(255,255,255,.3)}
.toggle{position:relative;flex:0 0 auto;width:44px;height:26px;border-radius:9999px;cursor:pointer;transition:background .3s;background:rgba(255,255,255,.16);border:0}
.toggle::after{content:"";position:absolute;top:3px;left:3px;width:20px;height:20px;border-radius:50%;background:#fff;box-shadow:rgba(0,0,0,.35) 0 1px 3px;transition:left .3s cubic-bezier(.22,.61,.36,1)}
.toggle[aria-pressed="true"]{background:var(--toggle-on)}
.toggle[aria-pressed="true"]::after{left:21px}
.panel-slider{display:flex;align-items:center;gap:12px;margin-top:16px;padding-top:16px;border-top:1px solid rgba(255,255,255,.08)}
.panel-slider svg{width:16px;height:16px;color:var(--yellow);flex:0 0 auto}
.hslider{-webkit-appearance:none;appearance:none;flex:1;height:6px;border-radius:9999px;outline:none;background:linear-gradient(90deg,var(--yellow) 95%,rgba(255,255,255,.15) 95%)}
.hslider::-webkit-slider-thumb{-webkit-appearance:none;width:18px;height:18px;border-radius:50%;background:#fff;box-shadow:rgba(0,0,0,.35) 0 1px 3px;cursor:pointer;border:0}
.hslider::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:#fff;box-shadow:rgba(0,0,0,.35) 0 1px 3px;cursor:pointer;border:0}
.panel-slider .val{font-size:13px;font-weight:600;width:38px;text-align:right}
.panel-temp{display:flex;align-items:center;justify-content:space-between;margin-top:14px}
.panel-temp .cap{font-size:13px;color:rgba(255,255,255,.55)}
.panel-temp .ctrl{display:flex;align-items:center;gap:12px}
.panel-temp button{width:30px;height:30px;border-radius:50%;border:1px solid rgba(255,255,255,.2);background:transparent;color:#fff;font-size:16px;cursor:pointer;line-height:1}
.panel-temp .deg{font-family:'Sora',sans-serif;font-weight:800;font-size:22px;color:var(--aqua)}

/* Bento tiles */
.hero-side{display:flex;flex-direction:column;gap:16px}
.tiles2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.tile{border-radius:var(--r-tile);padding:20px}
.tile.mint{background:var(--mint);color:var(--mint-ink)}
.tile.mint b{display:block;font-family:'Sora',sans-serif;font-weight:800;font-size:26px}
.tile.mint p{font-size:13px;line-height:1.45;margin-top:4px}
.tile.violet{background:var(--primary);color:#fff}
.tile.violet .t-head{display:flex;align-items:center;gap:6px;font-family:'Sora',sans-serif;font-weight:700;font-size:14px}
.tile.violet .t-head svg{width:16px;height:16px;color:var(--yellow)}
.tile.violet p{font-size:13px;line-height:1.45;color:rgba(255,255,255,.85);margin-top:6px}

/* Sections */
section{padding:56px 0}
section.tight{padding:40px 0}
h2{font-size:32px;margin-bottom:8px}
.lead{font-size:16px;color:var(--muted);max-width:560px;margin-bottom:28px}
.sec-head{display:flex;align-items:baseline;justify-content:space-between;gap:16px;margin-bottom:22px;flex-wrap:wrap}
.sec-head .note{font-size:13px;color:var(--muted)}

/* Cards */
.grid2{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:20px}
.grid3{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:20px}
.grid4{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:20px}
.card{background:var(--surface);border:1px solid var(--line);border-radius:24px;padding:24px;box-shadow:var(--sh-card)}
.card h3{font-weight:700;font-size:16.5px;margin-bottom:6px}
.card p{font-size:14px;line-height:1.55;color:var(--muted)}
.iconbox{width:44px;height:44px;border-radius:14px;background:var(--primary-soft);display:flex;align-items:center;justify-content:center;margin-bottom:14px;color:var(--primary)}
.iconbox svg{width:22px;height:22px}
svg.ico{width:22px;height:22px;color:var(--primary)}
svg.ico-inline{width:18px;height:18px;color:var(--primary);display:inline-block;vertical-align:-4px;margin-right:8px}

/* Quote / steps bento */
.bento3{display:grid;grid-template-columns:1fr 1.2fr 1fr;gap:20px}
.quote-tile{background:var(--primary);border-radius:var(--r-card);padding:28px;display:flex;flex-direction:column;gap:16px;color:#fff}
.quote-tile svg{width:30px;height:30px;fill:var(--yellow)}
.quote-tile p{font-family:'Sora',sans-serif;font-weight:700;font-size:19px;line-height:1.35}
.quote-tile span{font-size:13px;color:#cdbcff;font-weight:600}
.steps-tile{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-card);padding:28px}
.steps-tile>b{display:block;font-family:'Sora',sans-serif;font-weight:700;font-size:17px;margin-bottom:18px}
.step{display:flex;gap:16px;align-items:baseline;border-bottom:1px solid var(--line);padding:12px 0}
.step:last-child{border-bottom:0}
.step .no{font-family:'Sora',sans-serif;font-weight:800;font-size:26px;color:rgba(34,30,65,.14);flex:0 0 auto}
.step b{display:block;font-weight:600;font-size:14.5px}
.step p{font-size:13px;color:var(--muted)}
.stat-tile{background:var(--mint);border-radius:var(--r-card);padding:28px;display:flex;flex-direction:column;justify-content:space-between;color:var(--mint-ink)}
.stat-tile b{font-family:'Sora',sans-serif;font-weight:800;font-size:44px;letter-spacing:-.02em}
.stat-tile p{font-size:14px;line-height:1.5;margin-top:6px}
.stat-tile a{display:inline-flex;align-items:center;gap:6px;font-size:14px;font-weight:600;color:var(--mint-ink);margin-top:18px}
.stat-tile a svg{width:15px;height:15px}

/* Pricing */
.plans{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:20px}
.plan{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-card);padding:26px;display:flex;flex-direction:column}
.plan .k{font-size:12px;font-weight:700;letter-spacing:.1em;color:var(--primary);text-transform:uppercase}
.plan .price{font-family:'Sora',sans-serif;font-weight:800;font-size:28px;margin:8px 0 4px}
.plan .cap{font-size:13px;color:var(--muted);margin-bottom:12px}
.plan ul{list-style:none;margin:6px 0 20px;flex:1}
.plan li{padding:6px 0 6px 26px;position:relative;font-size:14px;line-height:1.45}
.plan li::before{content:"✓";position:absolute;left:0;color:var(--teal);font-weight:700}
.plan.featured{background:linear-gradient(150deg,var(--primary),var(--primary-deep));border:0;box-shadow:rgba(107,61,244,.55) 0 16px 40px -14px;color:#fff}
.plan.featured .k{color:var(--yellow)}
.plan.featured .cap{color:rgba(255,255,255,.75)}
.plan.featured li{color:rgba(255,255,255,.92)}
.plan.featured li::before{color:var(--aqua)}
.plan.dark{background:linear-gradient(165deg,var(--navy1),var(--navy2));border:0;color:#fff}
.plan.dark .k{color:var(--aqua)}
.plan.dark .cap{color:rgba(255,255,255,.6)}
.plan.dark li::before{color:var(--aqua)}
.plan .btn{width:100%;margin-top:auto}
.plan.featured .btn{background:var(--yellow);color:var(--ink);box-shadow:none}
.plan.dark .btn{background:rgba(255,255,255,.1);color:#fff;box-shadow:none;border:1px solid rgba(255,255,255,.2)}

/* Package tab switcher (homepage) */
.pkg-tabs{display:flex;gap:10px;margin-bottom:20px;flex-wrap:wrap}
.pkg-tabs button{cursor:pointer;font-family:inherit;font-weight:600;font-size:13px;letter-spacing:.06em;height:40px;padding:0 22px;border-radius:9999px;background:var(--surface);color:var(--muted);border:1px solid var(--line);transition:.3s}
.pkg-tabs button[aria-selected="true"]{background:var(--primary);color:#fff;border-color:var(--primary);font-weight:700;box-shadow:rgba(107,61,244,.55) 0 10px 26px -10px}
.pkg-card{display:grid;grid-template-columns:340px 1fr;gap:32px;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-card);padding:32px;box-shadow:var(--sh-pop)}
.pkg-card .k{font-size:12px;font-weight:700;letter-spacing:.1em;color:var(--primary);text-transform:uppercase}
.pkg-card .price{font-family:'Sora',sans-serif;font-weight:800;font-size:38px;letter-spacing:-.02em;margin:6px 0 4px}
.pkg-card .cap{font-size:13px;color:var(--muted);margin-bottom:16px}
.pkg-card .desc{font-size:15px;line-height:1.55;margin-bottom:20px}
.pkg-feats{display:grid;grid-template-columns:1fr 1fr;gap:12px;align-content:center}
.feat{display:flex;align-items:flex-start;gap:10px;background:var(--chip);border-radius:14px;padding:14px 16px;font-size:14px;line-height:1.45}
.feat svg{width:18px;height:18px;color:var(--teal);flex:0 0 auto;margin-top:1px}

/* Checklists & prose */
.check{list-style:none;margin:18px 0}
.check li{padding:7px 0 7px 30px;position:relative;font-size:15px}
.check li::before{content:"✓";position:absolute;left:0;color:var(--teal);font-weight:700}
.prose{max-width:760px}
.prose h2{margin-top:44px}
.prose h3{margin-top:26px;margin-bottom:8px;font-size:18px}
.prose p{margin:14px 0;color:#3c3760}
.prose ul,.prose ol{margin:14px 0 14px 22px;color:#3c3760}
.prose li{margin:6px 0}
table.tbl{width:100%;border-collapse:separate;border-spacing:0;margin:24px 0;font-size:14.5px;background:var(--surface);border:1px solid var(--line);border-radius:16px;overflow:hidden}
table.tbl th,table.tbl td{border-bottom:1px solid var(--line);padding:12px 16px;text-align:left}
table.tbl tr:last-child td{border-bottom:0}
table.tbl th{background:var(--chip);font-family:'Sora',sans-serif;font-size:13px;font-weight:700}
table.tbl td{color:#3c3760}

/* FAQ */
details{background:var(--surface);border:1px solid var(--line);border-radius:16px;margin-bottom:12px;overflow:hidden}
details summary{cursor:pointer;padding:18px 22px;font-weight:600;list-style:none;position:relative;padding-right:48px}
details summary::-webkit-details-marker{display:none}
details summary::after{content:"+";position:absolute;right:22px;top:14px;font-size:1.4rem;color:var(--primary);transition:.2s}
details[open] summary::after{transform:rotate(45deg)}
details .a{padding:0 22px 18px;color:var(--muted);font-size:14.5px}

/* Forms */
form.contact{display:grid;gap:14px}
.form-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-card);padding:32px;box-shadow:var(--sh-card)}
.f2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
label.fl{font-size:13px;font-weight:600;display:block;margin-bottom:6px}
input,select,textarea{background:var(--bg);border:1px solid #d8d5e6;border-radius:12px;padding:12px 15px;color:var(--ink);font:inherit;font-size:14.5px;width:100%}
input:focus,select:focus,textarea:focus{outline:2px solid var(--primary);border-color:var(--primary)}
label.small{font-size:13px;color:var(--muted)}
#formMsg{font-size:14.5px;font-weight:600}

/* Contact aside */
.kt-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:24px;align-items:start}
.kt-side{display:flex;flex-direction:column;gap:16px}
.kt-48{background:linear-gradient(165deg,var(--navy1),var(--navy2));border-radius:var(--r-card);padding:28px;color:#fff}
.kt-48 b{font-family:'Sora',sans-serif;font-weight:800;font-size:34px;color:var(--aqua)}
.kt-48 p{font-size:14px;line-height:1.55;color:rgba(255,255,255,.8);margin-top:8px}
.kt-contact{background:var(--mint);border-radius:var(--r-tile);padding:20px 24px;color:var(--mint-ink);display:flex;flex-direction:column;gap:8px;font-weight:600;font-size:15px}
.kt-contact a{color:var(--mint-ink);display:inline-flex;align-items:center;gap:10px}
.kt-contact svg{width:17px;height:17px}

/* CTA band */
.cta-band{background:var(--primary-soft);border-radius:var(--r-card);padding:32px;display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap}
.cta-band h2{font-size:22px;margin:0}
.cta-band p{color:var(--muted);font-size:14.5px;margin-top:4px}

/* HEMS hero variant */
header.hero.mint-hero{background:var(--mint)}
header.hero.mint-hero::before,header.hero.mint-hero::after{display:none}
header.hero.mint-hero h1,header.hero.mint-hero .crumbs{color:#123f39}
header.hero.mint-hero h1 em{color:var(--primary)}
header.hero.mint-hero .sub{color:#2c5d55}
.chart{display:flex;align-items:flex-end;gap:10px;height:150px;margin:18px 0 14px}
.chart i{flex:1;border-radius:8px 8px 4px 4px;background:linear-gradient(180deg,#8ec5ff,#6b3df4)}
.chart-meta{display:flex;justify-content:space-between;gap:12px;font-size:12px;color:rgba(255,255,255,.6)}
.chart-meta b{display:block;font-family:'Sora',sans-serif;font-size:16px;color:#fff}
.chart-meta .aq b{color:var(--aqua)}
.chart-meta .yl b{color:var(--yellow)}

footer{border-top:1px solid var(--line);background:var(--surface);padding:24px 0;color:var(--muted);font-size:13px;margin-top:24px}
.foot{display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px}
.foot a{color:var(--muted)}
.foot a:hover{color:var(--primary)}

@media(max-width:900px){
  .hero-grid,.kt-grid,.pkg-card{grid-template-columns:1fr}
  .bento3{grid-template-columns:1fr}
  .nav-links{display:none}
  .pkg-feats{grid-template-columns:1fr}
}
@media(max-width:560px){.f2{grid-template-columns:1fr}.tiles2{grid-template-columns:1fr}}

/* Hamburger */
.nav-toggle{display:none;width:44px;height:44px;border:1px solid var(--line);border-radius:12px;background:var(--surface);cursor:pointer;padding:0;flex-direction:column;align-items:center;justify-content:center;gap:5px}
.nav-toggle span{display:block;width:18px;height:2px;border-radius:2px;background:var(--ink);transition:.25s}
.nav-toggle.x span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-toggle.x span:nth-child(2){opacity:0}
.nav-toggle.x span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
@media(max-width:900px){
  .nav-toggle{display:flex}
  nav .nav-links{display:none;position:absolute;top:72px;left:0;right:0;background:var(--surface);border-bottom:1px solid var(--line);flex-direction:column;gap:0;padding:8px 0;box-shadow:var(--sh-pop)}
  nav .nav-links.open{display:flex}
  nav .nav-links a{padding:14px 24px;font-size:16px;color:var(--ink)}
  nav .nav-links a:hover{background:var(--chip)}
}
/* Consent bar */
.consent{position:fixed;left:16px;right:16px;bottom:16px;z-index:50;background:var(--surface);border:1px solid var(--line);border-radius:18px;box-shadow:var(--sh-pop);padding:18px 20px;display:flex;align-items:center;justify-content:space-between;gap:18px;flex-wrap:wrap;max-width:920px;margin:0 auto}
.consent p{font-size:13.5px;color:var(--muted);margin:0;flex:1;min-width:240px}
.consent-btns{display:flex;gap:10px}

.tel-reveal{display:inline-flex;align-items:center;gap:10px;background:transparent;border:0;padding:0;font:inherit;font-weight:600;font-size:15px;color:var(--mint-ink);cursor:pointer;text-decoration:underline;text-underline-offset:3px}
a.tel-reveal{text-decoration:none}
.tel-reveal svg{width:17px;height:17px}
