/* ============================================================
   IDEAL Conditioner — FRESH & SPARKLING variant
   Bright, water-forward cleaning-product look.
   ============================================================ */

:root{
  --cyan:        #00bcd4;
  --cyan-deep:   #0097b8;
  --sky:         #2aa8ff;
  --aqua:        #5fe0e6;
  --mint:        #aef6ef;
  --ink:         #0a3b4a;     /* deep teal text */
  --ink-soft:    #3f6b78;
  --line:        #d6f0f4;
  --white:       #ffffff;
  --foam:        #f3fdff;     /* near-white aqua tint */
  --foam-2:      #e7fafd;
  --bubble:      rgba(255,255,255,.65);
  --radius:      22px;
  --radius-lg:   30px;
  --shadow:      0 18px 50px -22px rgba(0,151,184,.45);
  --shadow-soft: 0 10px 30px -16px rgba(0,151,184,.35);
  --maxw:        1180px;
  --grad-sky:    linear-gradient(180deg,#eafbff 0%, #ffffff 60%);
  --grad-hero:   linear-gradient(160deg,#d6f6ff 0%, #eafdff 40%, #ffffff 100%);
  --grad-cta:    linear-gradient(135deg,#00bcd4 0%, #2aa8ff 100%);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:"Nunito Sans","Nunito",system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  color:var(--ink);
  background:var(--white);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
h1,h2,h3,h4,.brand{font-family:"Poppins",system-ui,sans-serif;font-weight:700;line-height:1.12;letter-spacing:-.01em;color:var(--ink);margin:0}
h1{font-size:clamp(2.3rem,5.2vw,4rem)}
h2{font-size:clamp(1.8rem,3.6vw,2.7rem)}
h3{font-size:1.3rem}
p{margin:0 0 1rem}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 22px}
section{padding:84px 0}
em{font-style:normal;color:var(--cyan-deep);position:relative}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.5rem;
  font-family:"Poppins",sans-serif;font-weight:600;font-size:.98rem;
  padding:.82rem 1.5rem;border-radius:999px;border:0;cursor:pointer;
  transition:transform .18s ease, box-shadow .18s ease, background .18s ease;
  white-space:nowrap;
}
.btn.lg{padding:1rem 1.8rem;font-size:1.05rem}
.btn .arr{transition:transform .2s ease}
.btn:hover .arr{transform:translateX(4px)}
.btn.aqua{background:var(--grad-cta);color:#fff;box-shadow:0 14px 30px -12px rgba(0,151,184,.7)}
.btn.aqua:hover{transform:translateY(-2px);box-shadow:0 20px 40px -12px rgba(0,151,184,.8)}
.btn.solid{background:var(--cyan);color:#fff;box-shadow:0 10px 22px -10px rgba(0,151,184,.7)}
.btn.solid:hover{transform:translateY(-2px);background:var(--cyan-deep)}
.btn.ghost{background:#fff;color:var(--cyan-deep);border:2px solid var(--line)}
.btn.ghost:hover{border-color:var(--cyan);color:var(--cyan-deep);transform:translateY(-2px)}

/* ---------- header ---------- */
.site-header{
  position:sticky;top:0;z-index:50;
  background:rgba(255,255,255,.78);
  backdrop-filter:saturate(180%) blur(14px);
  border-bottom:1px solid transparent;
  transition:box-shadow .2s ease,border-color .2s ease,background .2s ease;
}
.site-header.scrolled{box-shadow:0 8px 24px -16px rgba(0,151,184,.5);border-color:var(--line);background:rgba(255,255,255,.92)}
.nav{display:flex;align-items:center;justify-content:space-between;height:74px}
.brand{display:flex;align-items:center;gap:.6rem;font-size:1.28rem;color:var(--ink)}
.brand .mark{
  width:30px;height:30px;border-radius:50%;
  background:radial-gradient(circle at 32% 30%, #fff 0 14%, var(--aqua) 16%, var(--cyan) 70%);
  box-shadow:0 4px 12px -3px rgba(0,151,184,.6), inset 0 0 0 2px rgba(255,255,255,.5);
  position:relative;flex:none;
}
.brand .mark::after{content:"✦";position:absolute;top:-6px;right:-5px;font-size:.7rem;color:var(--sky)}
.brand b{color:var(--cyan-deep)}
.nav-links{display:flex;align-items:center;gap:1.6rem}
.nav-links a{font-weight:600;font-size:.97rem;color:var(--ink-soft);transition:color .15s}
.nav-links a:hover{color:var(--cyan-deep)}
.nav-cta{display:flex;align-items:center;gap:.8rem}
.menu-toggle{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px}
.menu-toggle span{width:24px;height:2.5px;border-radius:2px;background:var(--cyan-deep);transition:.2s}

/* ---------- hero ---------- */
.hero{position:relative;background:var(--grad-hero);overflow:hidden;padding:72px 0 96px}
.hero-bg{position:absolute;inset:0;pointer-events:none;overflow:hidden}
/* water beads behind hero */
.hero-bg::before,.hero-bg::after{
  content:"";position:absolute;border-radius:50%;
  background:radial-gradient(circle at 35% 30%, rgba(255,255,255,.95) 0 18%, rgba(174,246,239,.55) 30%, rgba(0,188,212,.18) 75%);
  box-shadow:inset 0 -6px 14px rgba(0,151,184,.18);
}
.hero-bg::before{width:230px;height:230px;top:-50px;right:6%;opacity:.8}
.hero-bg::after{width:140px;height:140px;bottom:8%;left:-30px;opacity:.7}
.bead{position:absolute;border-radius:50%;pointer-events:none;
  background:radial-gradient(circle at 34% 30%, rgba(255,255,255,.95) 0 16%, rgba(174,246,239,.5) 32%, rgba(0,188,212,.16) 78%);
  box-shadow:inset 0 -4px 10px rgba(0,151,184,.16);
}
.bead.b1{width:64px;height:64px;top:22%;left:5%;animation:bob 6s ease-in-out infinite}
.bead.b2{width:38px;height:38px;top:60%;right:14%;animation:bob 5s ease-in-out infinite .6s}
.bead.b3{width:90px;height:90px;bottom:-20px;right:30%;animation:bob 7s ease-in-out infinite .3s;opacity:.7}
@keyframes bob{0%,100%{transform:translateY(0)}50%{transform:translateY(-14px)}}

.hero-grid{position:relative;z-index:2;display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:center}
.eyebrow{
  display:inline-flex;align-items:center;gap:.45rem;
  font-family:"Poppins",sans-serif;font-weight:600;font-size:.78rem;letter-spacing:.08em;text-transform:uppercase;
  color:var(--cyan-deep);background:#fff;border:1px solid var(--line);
  padding:.4rem .85rem;border-radius:999px;box-shadow:var(--shadow-soft);
}
.eyebrow::before{content:"✦";color:var(--sky)}
.eyebrow.light{background:rgba(255,255,255,.2);border-color:rgba(255,255,255,.4);color:#fff;box-shadow:none}
.eyebrow.light::before{color:#fff}
.hero h1{margin:1.1rem 0 .9rem}
.lead{font-size:1.18rem;color:var(--ink-soft);max-width:36ch}
.hero-cta{display:flex;flex-wrap:wrap;gap:.8rem;margin:1.7rem 0 1.4rem}
.hero-rating{display:flex;align-items:center;gap:.6rem;color:var(--ink-soft);font-size:.92rem;font-weight:600}
.stars{color:#ffb703;letter-spacing:1px;font-size:1.05rem}

/* hero art — sparkling glass card */
.hero-art{position:relative}
.hero-art .glass{
  position:relative;border-radius:var(--radius-lg);overflow:hidden;
  background:linear-gradient(150deg,#ffffff,#eafdff);
  box-shadow:var(--shadow);border:1px solid #fff;
  padding:26px;
}
.hero-art img{border-radius:18px;width:100%;object-fit:cover;aspect-ratio:4/5}
.hero-art .glass::before{
  content:"";position:absolute;top:-40%;left:-20%;width:60%;height:180%;
  background:linear-gradient(100deg,transparent,rgba(255,255,255,.65),transparent);
  transform:rotate(8deg);animation:shine 4.5s ease-in-out infinite;
}
@keyframes shine{0%{left:-40%}55%,100%{left:120%}}
.spark{position:absolute;color:#fff;font-size:1.2rem;text-shadow:0 0 8px var(--aqua);animation:tw 2.4s ease-in-out infinite;z-index:3}
.spark.s1{top:8%;right:12%;font-size:1.6rem}
.spark.s2{top:46%;left:6%;animation-delay:.7s}
.spark.s3{bottom:14%;right:20%;font-size:1.1rem;animation-delay:1.2s}
@keyframes tw{0%,100%{opacity:.25;transform:scale(.8)}50%{opacity:1;transform:scale(1.15)}}
.hero-badge{
  position:absolute;background:#fff;border-radius:16px;padding:.7rem .95rem;
  box-shadow:var(--shadow);display:flex;align-items:center;gap:.55rem;font-weight:700;font-size:.86rem;color:var(--ink);z-index:4;
}
.hero-badge .t{
  width:34px;height:34px;border-radius:50%;display:grid;place-items:center;color:#fff;font-size:.82rem;
  background:var(--grad-cta);
}
.hero-badge.h1b{top:-14px;left:-18px}
.hero-badge.h2b{bottom:24px;right:-16px}

/* ---------- marquee strip ---------- */
.strip{background:var(--grad-cta);color:#fff;overflow:hidden;padding:.9rem 0;font-family:"Poppins",sans-serif;font-weight:600}
.strip-track{display:flex;white-space:nowrap;animation:slide 26s linear infinite}
.strip-track span{padding-right:2rem;font-size:.95rem;letter-spacing:.02em}
@keyframes slide{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ---------- section heads ---------- */
.sec-head{max-width:680px;margin:0 auto 50px;text-align:center}
.sec-head h2{margin:.8rem 0 .6rem}
.sec-head p{color:var(--ink-soft);font-size:1.08rem}
.tint{background:var(--grad-sky)}
.foam{background:var(--foam)}

/* ---------- value props ---------- */
.props{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.prop{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:30px 26px;box-shadow:var(--shadow-soft);transition:transform .2s,box-shadow .2s;
  position:relative;overflow:hidden;
}
.prop:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.prop .ic{
  width:58px;height:58px;border-radius:18px;display:grid;place-items:center;font-size:1.7rem;margin-bottom:14px;
  background:linear-gradient(150deg,var(--foam-2),#fff);border:1px solid var(--line);
}
.prop h3{margin-bottom:.4rem}
.prop p{color:var(--ink-soft);margin:0}
.prop::after{content:"";position:absolute;width:120px;height:120px;border-radius:50%;right:-50px;top:-50px;
  background:radial-gradient(circle,rgba(174,246,239,.45),transparent 70%)}

/* ---------- products ---------- */
.prod-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:28px}
.card{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);overflow:hidden;
  box-shadow:var(--shadow-soft);transition:transform .22s,box-shadow .22s;display:flex;flex-direction:column;
}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.card-media{position:relative;background:linear-gradient(160deg,#eafdff,#fff);padding:26px;display:grid;place-items:center}
.card-media img{border-radius:18px;width:100%;aspect-ratio:4/3;object-fit:cover}
.card-tag,.card-save{
  position:absolute;top:16px;font-family:"Poppins",sans-serif;font-weight:600;font-size:.74rem;
  padding:.35rem .7rem;border-radius:999px;z-index:2;letter-spacing:.02em;
}
.card-tag{left:16px;background:#fff;color:var(--cyan-deep);border:1px solid var(--line)}
.card-save{right:16px;background:var(--grad-cta);color:#fff}
.card-body{padding:26px 26px 28px;display:flex;flex-direction:column;gap:.55rem;flex:1}
.card-body h3{font-size:1.45rem}
.desc{color:var(--ink-soft);margin:0;flex:1}
.price{display:flex;align-items:baseline;gap:.6rem;margin:.4rem 0 .2rem}
.price .now{font-family:"Poppins",sans-serif;font-weight:700;font-size:1.7rem;color:var(--ink)}
.price .was{color:#9fc2cb;text-decoration:line-through;font-weight:600}
.price .unit{margin-left:auto;color:var(--ink-soft);font-size:.85rem;font-weight:600}
.card-actions{display:flex;gap:.7rem;margin-top:.7rem}
.card-actions .btn{flex:1;justify-content:center}

/* ---------- split feature ---------- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.split-media{position:relative;border-radius:var(--radius-lg);overflow:hidden;background:linear-gradient(160deg,#eafdff,#fff);padding:24px;box-shadow:var(--shadow)}
.split-media img{border-radius:18px;width:100%;aspect-ratio:4/3;object-fit:cover}
.split h2{margin:.7rem 0 .8rem}
.split p{color:var(--ink-soft)}
.ticks{list-style:none;padding:0;margin:1.2rem 0 1.6rem;display:grid;gap:.7rem}
.ticks li{position:relative;padding-left:2rem;color:var(--ink-soft)}
.ticks li::before{content:"✦";position:absolute;left:0;top:-1px;color:var(--cyan);
  font-size:1rem;}
.ticks strong{color:var(--ink)}

/* ---------- testimonial band ---------- */
.band{background:var(--grad-cta);color:#fff;text-align:center;position:relative;overflow:hidden}
.band::before{content:"";position:absolute;inset:0;
  background:radial-gradient(circle at 18% 20%,rgba(255,255,255,.25),transparent 30%),
            radial-gradient(circle at 82% 80%,rgba(255,255,255,.18),transparent 32%)}
.band .wrap{position:relative;z-index:2}
.band .stars{color:#fff;font-size:1.4rem;letter-spacing:3px;display:block;margin:.4rem 0 1rem}
.quote{font-family:"Poppins",sans-serif;font-weight:600;font-size:clamp(1.4rem,3vw,2.1rem);line-height:1.35;max-width:18ch;margin:0 auto .9rem;color:#fff}
.who{opacity:.9;font-weight:600}

/* ---------- faq ---------- */
.faq-list{max-width:760px;margin:0 auto;display:grid;gap:14px}
.faq{background:#fff;border:1px solid var(--line);border-radius:18px;overflow:hidden;box-shadow:var(--shadow-soft)}
.faq summary{list-style:none;cursor:pointer;padding:18px 22px;display:flex;align-items:center;justify-content:space-between;
  font-family:"Poppins",sans-serif;font-weight:600;color:var(--ink);font-size:1.02rem}
.faq summary::-webkit-details-marker{display:none}
.faq .pm{color:var(--cyan);font-size:1.5rem;font-weight:600;transition:transform .2s;line-height:1}
.faq[open] .pm{transform:rotate(45deg)}
.faq .ans{padding:0 22px 20px;color:var(--ink-soft)}

/* ---------- final cta ---------- */
.cta-final{background:var(--grad-hero);text-align:center;position:relative;overflow:hidden}
.cta-final .wrap{position:relative;z-index:2;max-width:680px}
.cta-final h2{margin:.7rem 0 .6rem}
.cta-final p{color:var(--ink-soft);margin-bottom:1.6rem}
.cta-final::before,.cta-final::after{content:"✦";position:absolute;color:var(--aqua);opacity:.5;font-size:2rem}
.cta-final::before{top:18%;left:12%;animation:tw 3s infinite}
.cta-final::after{bottom:20%;right:14%;font-size:2.6rem;animation:tw 3.4s infinite .5s}

/* ---------- sub-page hero ---------- */
.page-hero{background:var(--grad-hero);padding:60px 0;position:relative;overflow:hidden}
.page-hero .eyebrow{margin-bottom:1rem}
.page-hero h1{font-size:clamp(2rem,4.5vw,3.2rem)}
.page-hero p{color:var(--ink-soft);font-size:1.12rem;max-width:54ch;margin-top:.7rem}

/* product detail */
.pd{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start}
.pd-media{position:relative;border-radius:var(--radius-lg);overflow:hidden;background:linear-gradient(160deg,#eafdff,#fff);padding:26px;box-shadow:var(--shadow)}
.pd-media img{border-radius:18px;width:100%;object-fit:cover}
.pd-media .card-save{top:20px;right:20px}
.pd h1{font-size:clamp(1.9rem,4vw,2.8rem)}
.pd .price{margin:1rem 0}
.pd .price .now{font-size:2.1rem}
.pd .buy-row{display:flex;gap:.8rem;flex-wrap:wrap;margin:1.4rem 0}
.pd .ticks{margin-top:1.2rem}
.pill-row{display:flex;flex-wrap:wrap;gap:.5rem;margin:1rem 0}
.pill{background:#fff;border:1px solid var(--line);color:var(--cyan-deep);font-weight:600;font-size:.82rem;
  padding:.35rem .8rem;border-radius:999px;box-shadow:var(--shadow-soft)}
.note{background:var(--foam);border:1px dashed var(--aqua);border-radius:16px;padding:14px 18px;color:var(--ink-soft);font-size:.92rem;margin-top:1rem}

/* generic content blocks */
.lede{font-size:1.18rem;color:var(--ink-soft);max-width:60ch}
.cols2{display:grid;grid-template-columns:1fr 1fr;gap:30px;margin-top:30px}
.info-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:28px;box-shadow:var(--shadow-soft)}
.info-card h3{margin-bottom:.5rem;display:flex;align-items:center;gap:.5rem}
.info-card p{color:var(--ink-soft);margin:0}
.info-card .em{color:var(--cyan)}

/* contact */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:30px}
.contact-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:30px;box-shadow:var(--shadow-soft)}
.contact-card h3{margin-bottom:.7rem}
.contact-card a.phone{font-family:"Poppins",sans-serif;font-weight:700;font-size:1.6rem;color:var(--cyan-deep)}
.loc-list{display:grid;gap:.5rem;margin-top:.6rem;color:var(--ink-soft)}
.loc-list b{color:var(--ink)}
.hours{color:var(--ink-soft);margin-top:.8rem;font-size:.95rem}

/* ---------- footer ---------- */
.site-footer{background:#062f3b;color:#cbeef4;padding:64px 0 28px;position:relative;overflow:hidden}
.site-footer::before{content:"";position:absolute;top:-60px;right:-40px;width:240px;height:240px;border-radius:50%;
  background:radial-gradient(circle,rgba(0,188,212,.25),transparent 70%)}
.foot-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:30px;position:relative;z-index:2}
.foot-brand .brand{color:#fff;margin-bottom:.7rem}
.foot-brand p{color:#9fd4de;max-width:34ch}
.foot-col h4{font-size:.82rem;text-transform:uppercase;letter-spacing:.1em;color:#6fc4d4;margin-bottom:.9rem}
.foot-col a{display:block;color:#cbeef4;padding:.22rem 0;font-size:.95rem;transition:color .15s}
.foot-col a:hover{color:#fff}
.foot-bottom{display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;
  border-top:1px solid rgba(255,255,255,.12);margin-top:40px;padding-top:22px;font-size:.85rem;color:#7fb9c6;position:relative;z-index:2}

/* ---------- checkout modal ---------- */
.modal{position:fixed;inset:0;z-index:120;display:none}
.modal.open{display:block}
.modal-overlay{position:absolute;inset:0;background:rgba(6,47,59,.55);backdrop-filter:blur(4px)}
.modal-panel{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:min(560px,94vw);max-height:92vh;background:#fff;border-radius:var(--radius-lg);overflow:hidden;
  box-shadow:0 30px 80px -20px rgba(6,47,59,.6);display:flex;flex-direction:column;
  animation:pop .22s ease;
}
@keyframes pop{from{opacity:0;transform:translate(-50%,-46%) scale(.97)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}
.modal-top{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;
  background:var(--grad-cta);color:#fff}
.mt-title{display:flex;align-items:center;gap:.5rem;font-family:"Poppins",sans-serif;font-weight:700}
.mt-title .dot{width:9px;height:9px;border-radius:50%;background:#fff;box-shadow:0 0 0 4px rgba(255,255,255,.25)}
.secure{font-size:.82rem;opacity:.95;font-weight:600}
.modal-close{background:rgba(255,255,255,.2);border:0;color:#fff;width:32px;height:32px;border-radius:50%;
  font-size:1.4rem;line-height:1;cursor:pointer;transition:background .15s}
.modal-close:hover{background:rgba(255,255,255,.35)}
.modal-frame{position:relative;flex:1;min-height:62vh;background:var(--foam)}
.modal-frame iframe{width:100%;height:100%;min-height:62vh;border:0;display:block}
.modal-loading{position:absolute;inset:0;display:grid;place-items:center;background:var(--foam);color:var(--cyan-deep);text-align:center;font-weight:600}
.spin{width:42px;height:42px;border-radius:50%;border:4px solid var(--line);border-top-color:var(--cyan);margin:0 auto;animation:spin 1s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.modal-foot{padding:13px 20px;font-size:.86rem;color:var(--ink-soft);background:#fff;border-top:1px solid var(--line);text-align:center}
.modal-foot a{color:var(--cyan-deep);font-weight:700}

/* ---------- progressive enhancement reveal ---------- */
.js .reveal{opacity:0;transform:translateY(22px);transition:opacity .6s ease, transform .6s ease}
.js .reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){
  .js .reveal{opacity:1;transform:none;transition:none}
  .strip-track,.bead,.spark,.hero-art .glass::before,.cta-final::before,.cta-final::after{animation:none !important}
  html{scroll-behavior:auto}
}

/* ---------- responsive ---------- */
@media (max-width:900px){
  .hero-grid,.split,.pd,.contact-grid,.cols2{grid-template-columns:1fr}
  .props{grid-template-columns:1fr}
  .prod-grid{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr 1fr}
  .hero-art{order:-1;max-width:420px;margin:0 auto}
  section{padding:62px 0}
  .nav-links{
    position:absolute;top:74px;left:0;right:0;background:#fff;flex-direction:column;align-items:flex-start;
    gap:0;padding:10px 22px 18px;box-shadow:0 18px 30px -18px rgba(0,151,184,.5);
    border-bottom:1px solid var(--line);display:none;
  }
  .nav-links.show{display:flex}
  .nav-links a{width:100%;padding:.7rem 0;border-bottom:1px solid var(--foam-2)}
  .menu-toggle{display:flex}
}
@media (max-width:560px){
  .foot-grid{grid-template-columns:1fr}
  .hero-badge.h1b{left:-6px}
  .hero-badge.h2b{right:-4px}
  .nav-cta .btn.ghost{display:none}
}
