/* ============================================================
   PURISAKI™ — puurisaki.com — css/style.css
   Theme  : Powder Blue (#A8C8DE) + Royal Blue (#1E3D7A) + Coral (#E84530)
   Font   : Noto Sans (clean, clinical, Japanese compatible — never used)
   Design : Clean minimal wellness — all new class names
   ============================================================ */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
  --pb:    #A8C8DE; /* powder blue — packaging background */
  --pb2:   #C0D8E8;
  --pbp:   #EEF5FA;
  --rb:    #1E3D7A; /* royal blue — patch ring */
  --rb2:   #2A4D8A;
  --rbp:   #EEF1F8;
  --cor:   #E84530; /* coral red — patch center */
  --cor2:  #F05540;
  --corp:  #FEF1EF;
  --silver:#8AAABB; /* metallic badges */
  --white: #FFFFFF;
  --snow:  #F5F9FC;
  --cloud: #EDF4F8;
  --dark:  #0A1828;
  --navy:  #14284A;
  --muted: #5A7285;
  --bds:   #C8D8E8;
  --r: 8px; --pill: 50px
}

.pod{max-width:1160px;margin:0 auto;padding:0 20px}

html{scroll-behavior:smooth}
body{font-family:'Noto Sans',system-ui,-apple-system,sans-serif;font-size:17px;color:var(--dark);background:var(--snow);overflow-x:hidden;line-height:1.73}

/* ── NAV ── */
nav{position:sticky;top:0;z-index:100;background:var(--white);height:64px;padding:0;border-bottom:2px solid var(--bds);transition:box-shadow .3s}
.nav-pod{height:100%;display:flex;align-items:center;justify-content:space-between;gap:20px}
.site-name{font-size:1.3rem;font-weight:800;color:var(--rb);text-decoration:none;display:flex;align-items:center;gap:2px;flex-shrink:0;letter-spacing:.2px}
.sn-u{color:var(--cor);font-size:1.4rem}
.nav-menu{display:flex;align-items:center;gap:16px;list-style:none}
.nav-menu a{color:var(--muted);text-decoration:none;font-size:.84rem;font-weight:600;transition:color .2s;white-space:nowrap}
.nav-menu a:hover{color:var(--rb)}
.nav-pill{background:var(--cor)!important;color:var(--white)!important;padding:9px 20px;border-radius:var(--pill);font-weight:700!important;font-size:.82rem!important;transition:background .2s,transform .15s!important}
.nav-pill:hover{background:var(--cor2)!important;transform:translateY(-1px)}
.burger-btn{display:none;flex-direction:column;gap:5px;cursor:pointer;background:none;border:none;padding:4px}
.burger-btn span{width:24px;height:2px;background:var(--rb);display:block;border-radius:2px}
.pull-menu{display:none;flex-direction:column;background:var(--white);border-bottom:2px solid var(--bds);padding:20px;gap:12px;position:absolute;top:64px;left:0;right:0;z-index:99;box-shadow:0 8px 20px rgba(10,24,40,.08)}
.pull-menu.open{display:flex}
.pull-menu a{color:var(--muted);text-decoration:none;font-size:1rem;font-weight:600;padding:6px 0;border-bottom:1px solid var(--bds)}
.pull-menu a:hover{color:var(--rb)}
.pull-order{background:var(--cor);color:var(--white)!important;text-align:center;padding:13px;border-radius:var(--pill);font-weight:700;margin-top:6px;border-bottom:none!important}

/* ── BUTTON ── */
.btn-coral{display:inline-block;background:var(--cor);color:var(--white);font-weight:700;font-size:.95rem;padding:13px 30px;border-radius:var(--pill);text-decoration:none;transition:background .2s,transform .15s;box-shadow:0 3px 14px rgba(232,69,48,.26)}
.btn-coral:hover{background:var(--cor2);transform:translateY(-2px);box-shadow:0 5px 20px rgba(232,69,48,.36)}
.btn-xl{font-size:1.05rem;padding:15px 40px}

/* ── SECTION BANNERS ── */
.section-banner{background:linear-gradient(135deg,var(--rb) 0%,var(--rb2) 100%);padding:46px 20px 38px;text-align:center}
.section-banner h2,.section-banner h3{font-size:1.85rem;font-weight:800;color:var(--white);line-height:1.22;margin-bottom:8px}
.section-banner p{font-size:.94rem;color:rgba(255,255,255,.55);margin-top:6px}
.section-banner-dark{background:linear-gradient(135deg,var(--dark) 0%,var(--navy) 100%)}

/* ── HERO ── */
.hero-section{background:linear-gradient(160deg,var(--pbp) 0%,var(--cloud) 60%,var(--white) 100%);padding:64px 0}
.hero-pod{display:grid;grid-template-columns:440px 1fr;align-items:center;gap:52px}
.hero-product{display:flex;flex-direction:column;align-items:center;gap:16px}
.hero-product a img{max-width:100%;filter:drop-shadow(0 12px 32px rgba(30,61,122,.15));transition:transform .4s;display:block}
.hero-product a:hover img{transform:scale(1.04)}
.hero-patch-ring{display:flex;gap:8px;justify-content:center;flex-wrap:wrap}
.hero-patch-ring span{font-size:.8rem;font-weight:700;color:var(--rb);background:var(--white);border:1px solid var(--bds);padding:5px 14px;border-radius:var(--pill)}
.hero-label-row{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:16px}
.hl-blue{background:var(--rb);color:var(--white);padding:5px 14px;border-radius:var(--pill);font-size:.77rem;font-weight:700;text-transform:uppercase;letter-spacing:.4px}
.hl-coral{background:var(--cor);color:var(--white);padding:5px 14px;border-radius:var(--pill);font-size:.77rem;font-weight:700}
.hero-words h1{font-size:2.2rem;font-weight:800;line-height:1.1;color:var(--dark);margin-bottom:16px}
.hero-para{font-size:1.02rem;line-height:1.8;color:var(--muted);margin-bottom:20px}
.hero-claims-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:20px;background:var(--white);border:1px solid var(--bds);border-radius:var(--r);padding:14px 16px}
.hcg-item{display:flex;align-items:center;gap:8px}
.hcg-ico{color:var(--rb);font-weight:800;font-size:1rem;flex-shrink:0}
.hcg-item p{font-size:.84rem;font-weight:600;color:var(--dark)}
.hero-price-chip{display:flex;align-items:flex-end;gap:6px;margin-bottom:20px;background:var(--pbp);border:1px solid var(--bds);border-radius:var(--r);padding:12px 16px}
.hpc-from{font-size:.88rem;color:var(--muted);padding-bottom:2px}
.hpc-price{font-size:2rem;font-weight:800;color:var(--rb);line-height:1}
.hpc-pack{font-size:.85rem;color:var(--muted);padding-bottom:2px}
.hero-trust{display:flex;flex-wrap:wrap;gap:8px 20px;margin-top:14px}
.hero-trust span{font-size:.82rem;font-weight:600;color:var(--muted)}
.hero-legal-note{font-size:.72rem;color:#8AA0B0;margin-top:10px;font-style:italic;line-height:1.5}

/* ── PRICE SECTION ── */
.price-section{background:var(--dark);padding:40px 20px;text-align:center}
.price-section a{display:inline-block}
.price-section a img{max-width:960px;width:100%;height:auto;border-radius:var(--r);transition:transform .3s;box-shadow:0 4px 24px rgba(0,0,0,.4)}
.price-section a:hover img{transform:scale(1.01)}

/* ── WHY SECTION ── */
.why-section{background:var(--snow);padding:60px 0}
.why-pod{display:grid;grid-template-columns:1fr 420px;gap:52px;align-items:start}
.why-text p{font-size:1.01rem;line-height:1.82;color:var(--muted);margin-bottom:14px}
.why-legal{font-size:.78rem!important;color:#8AA0B0;font-style:italic;background:var(--pbp);border:1px solid var(--bds);border-radius:var(--r);padding:10px 14px}
.why-compare{display:flex;flex-direction:column;gap:14px}
.wc-col{background:var(--white);border:1px solid var(--bds);border-radius:var(--r);padding:18px 16px}
.wc-pills{border-top:3px solid #FCA5A5}
.wc-patch{border-top:3px solid var(--rb)}
.wc-col h3{font-size:.88rem;font-weight:800;text-transform:uppercase;letter-spacing:.4px;margin-bottom:14px;color:var(--dark)}
.wci{display:flex;gap:10px;align-items:flex-start;padding:8px 0;border-bottom:1px solid var(--bds)}
.wci:last-child{border-bottom:none}
.wci-ico{font-size:1.2rem;flex-shrink:0}
.wci strong{display:block;font-size:.86rem;font-weight:700;color:var(--dark);margin-bottom:3px}
.wci p{font-size:.8rem;line-height:1.5;color:var(--muted)}

/* ── ABOUT ── */
.about-section{background:var(--white);padding:60px 0}
.about-pod{display:grid;grid-template-columns:1fr 400px;align-items:center;gap:52px}
.about-text p{font-size:1.01rem;line-height:1.82;color:var(--muted);margin-bottom:14px}
.about-img img{max-width:100%;filter:drop-shadow(0 8px 24px rgba(30,61,122,.12));border-radius:var(--r)}

/* ── INGREDIENTS ── */
.ing-section{background:var(--pbp);padding:60px 0}
.ing-feature-row{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-bottom:20px}
.ifr-card{background:var(--white);border:1px solid var(--bds);border-radius:var(--r);border-top:3px solid var(--rb);padding:22px 18px;transition:box-shadow .3s,transform .3s}
.ifr-card:hover{box-shadow:0 6px 18px rgba(30,61,122,.1);transform:translateY(-3px)}
.ifr-ico{font-size:2rem;display:block;margin-bottom:10px}
.ifr-card h3{font-size:.95rem;font-weight:700;color:var(--dark);margin-bottom:4px}
.ifr-role{display:block;font-size:.73rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--rb);margin-bottom:10px}
.ifr-card p{font-size:.88rem;line-height:1.72;color:var(--muted)}
.ifr-main{position:relative}
.ing-secondary-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:20px}
.isg-item{background:var(--white);border:1px solid var(--bds);border-radius:var(--r);padding:18px 16px;text-align:center;transition:box-shadow .3s}
.isg-item:hover{box-shadow:0 4px 14px rgba(30,61,122,.08)}
.isg-ico{font-size:1.8rem;display:block;margin-bottom:8px}
.isg-item h4{font-size:.88rem;font-weight:700;color:var(--dark);margin-bottom:6px}
.isg-item p{font-size:.82rem;line-height:1.6;color:var(--muted)}
.ing-disclaimer{font-size:.78rem;color:#5A7285;font-style:italic;text-align:center;padding:14px 18px;background:var(--white);border:1px solid var(--bds);border-radius:var(--r)}

/* ── LAYERS ── */
.layers-section{background:var(--white);padding:60px 0}
.layers-pod{display:grid;grid-template-columns:380px 1fr;gap:52px;align-items:start}
.layers-visual img{max-width:100%;filter:drop-shadow(0 6px 20px rgba(30,61,122,.12));border-radius:var(--r)}
.layers-content{display:flex;flex-direction:column;gap:16px}
.layer-card{background:var(--snow);border:1px solid var(--bds);border-radius:var(--r);padding:18px 18px}
.lc-1{border-left:4px solid var(--pb)}
.lc-2{border-left:4px solid var(--silver)}
.lc-3{border-left:4px solid var(--rb)}
.lc-num{font-size:.72rem;font-weight:800;text-transform:uppercase;letter-spacing:.7px;color:var(--rb);margin-bottom:4px}
.layer-card h3{font-size:.95rem;font-weight:700;color:var(--dark);margin-bottom:8px}
.layer-card p{font-size:.9rem;line-height:1.74;color:var(--muted)}

/* ── USE STEPS ── */
.use-section{background:var(--cloud);padding:60px 0}
.use-steps{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-bottom:20px}
.use-step{background:var(--white);border:1px solid var(--bds);border-radius:var(--r);border-top:3px solid var(--cor);padding:26px 22px;text-align:center;position:relative}
.us-num{position:absolute;top:10px;right:14px;font-size:2.8rem;font-weight:800;color:rgba(232,69,48,.07);line-height:1}
.us-ico{font-size:2.2rem;display:block;margin-bottom:12px}
.use-step h3{font-size:.95rem;font-weight:700;color:var(--dark);margin-bottom:8px;text-transform:uppercase;letter-spacing:.3px}
.use-step p{font-size:.9rem;line-height:1.72;color:var(--muted)}
.use-legal{font-size:.78rem;color:#8AA0B0;font-style:italic;text-align:center;line-height:1.6;padding:12px 16px;background:var(--white);border:1px solid var(--bds);border-radius:var(--r)}

/* ── 30-DAY JOURNEY ── */
.journey-section{background:var(--white);padding:60px 0}
.journey-timeline{max-width:900px;margin:0 auto;display:flex;flex-direction:column;gap:0}
.jt-item{display:flex;gap:22px;align-items:flex-start;padding:26px 0;border-bottom:1px solid var(--bds)}
.jt-item:last-child{border-bottom:none}
.jt-marker{background:linear-gradient(135deg,var(--rb) 0%,var(--pb) 100%);color:var(--white);font-size:.78rem;font-weight:700;padding:8px 14px;border-radius:var(--r);white-space:nowrap;flex-shrink:0;text-align:center;min-width:78px;line-height:1.3}
.jt-marker small{display:block;font-size:.69rem;font-weight:400;opacity:.8;margin-top:3px}
.jt-body h3{font-size:1rem;font-weight:700;color:var(--dark);margin-bottom:8px}
.jt-body p{font-size:.93rem;line-height:1.78;color:var(--muted);margin-bottom:8px}
.jt-legal{font-size:.77rem!important;color:#8AA0B0;font-style:italic;background:var(--pbp);border-radius:var(--r);padding:6px 10px}

/* ── REVIEWS ── */
.reviews-section{background:var(--cloud);padding:60px 0}
.reviews-banner-img{text-align:center;margin-bottom:24px}
.reviews-banner-img a img{max-width:960px;width:100%;height:auto;border-radius:var(--r);box-shadow:0 3px 16px rgba(30,61,122,.08);transition:transform .3s}
.reviews-banner-img a:hover img{transform:scale(1.01)}
.reviews-grid{display:flex;flex-direction:column;gap:18px;margin-bottom:14px}
.rv-box{background:var(--white);border:1px solid var(--bds);border-radius:var(--r);border-left:4px solid var(--pb);padding:24px 22px;transition:box-shadow .3s}
.rv-box:hover{box-shadow:0 4px 16px rgba(168,200,222,.2)}
.rv-stars{font-size:1.05rem;color:#E5A80C;letter-spacing:3px;margin-bottom:8px}
.rv-verify{font-size:.77rem;font-weight:700;color:var(--rb);text-transform:uppercase;letter-spacing:.3px;display:block;margin-bottom:14px}
.rv-quote{font-size:.92rem;line-height:1.76;color:var(--muted);font-style:italic;margin-bottom:18px}
.rv-author{display:flex;align-items:center;gap:12px;border-top:1px solid var(--bds);padding-top:14px}
.rv-photo{width:52px;height:52px;border-radius:50%;object-fit:cover;border:2px solid var(--rb);flex-shrink:0}
.rv-name{font-weight:700;color:var(--dark);font-size:.9rem}
.rv-loc{font-size:.78rem;color:var(--muted)}
.reviews-legal{font-size:.77rem;color:#8AA0B0;text-align:center;font-style:italic;line-height:1.6}

/* ── GUARANTEE ── */
.guar-section{background:var(--white);padding:60px 0}
.guar-pod{display:grid;grid-template-columns:230px 1fr;align-items:center;gap:48px}
.gp-img img{max-width:100%;filter:drop-shadow(0 4px 14px rgba(30,61,122,.12))}
.gp-text h3{font-size:1.3rem;font-weight:700;color:var(--dark);margin-bottom:14px;line-height:1.25}
.gp-text p{font-size:1rem;line-height:1.8;color:var(--muted);margin-bottom:12px}

/* ── FAQ ── */
.faq-section{background:var(--pbp);padding:60px 0}
.faq-list{display:flex;flex-direction:column;gap:10px}
.faq-unit{background:var(--white);border:1px solid var(--bds);border-radius:var(--r);overflow:hidden;transition:border-color .2s}
.faq-unit.open{border-color:var(--rb)}
.faq-q-btn{width:100%;background:none;border:none;text-align:left;padding:17px 20px;font-family:'Noto Sans',system-ui,sans-serif;font-size:.94rem;font-weight:700;color:var(--dark);cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:12px;transition:background .2s;line-height:1.4}
.faq-q-btn:hover{background:var(--pbp)}
.faq-unit.open .faq-q-btn{background:var(--pbp);color:var(--rb)}
.faq-chevron{font-size:.88rem;transition:transform .3s;color:var(--rb);flex-shrink:0}
.faq-answer{display:none;padding:14px 20px 18px;font-size:.92rem;line-height:1.78;color:var(--muted);border-top:1px solid var(--bds)}
.faq-unit.open .faq-answer{display:block}
.faq-unit.open .faq-chevron{transform:rotate(180deg)}

/* ── ORDER ── */
.order-section{background:var(--snow);padding:60px 0}
.order-copy{font-size:1rem;line-height:1.8;color:var(--muted);margin-bottom:24px}
.order-img{text-align:center}
.order-img a img{max-width:960px;width:100%;height:auto;border-radius:var(--r);box-shadow:0 3px 16px rgba(0,0,0,.07);transition:transform .3s}
.order-img a:hover img{transform:scale(1.01)}

/* ── FINAL CTA ── */
.cta-section{background:linear-gradient(150deg,var(--dark) 0%,var(--rb) 100%);padding:64px 0;text-align:center}
.cta-pod{display:flex;flex-direction:column;align-items:center}
.cta-section h2{font-size:1.95rem;font-weight:800;color:var(--white);margin-bottom:10px;line-height:1.22}
.cta-copy{font-size:.97rem;color:rgba(255,255,255,.6);margin-bottom:24px;max-width:700px;line-height:1.75}
.cta-ing-list{display:flex;flex-wrap:wrap;justify-content:center;gap:8px;margin-bottom:24px;padding:16px 20px;background:rgba(255,255,255,.06);border-radius:var(--r);border:1px solid rgba(255,255,255,.1);max-width:700px;width:100%}
.cta-ing-list span{font-size:.81rem;font-weight:600;color:rgba(255,255,255,.8)}
.cta-features{display:flex;flex-wrap:wrap;justify-content:center;gap:8px 20px;margin-bottom:28px;max-width:700px}
.cta-features span{font-size:.86rem;font-weight:600;color:rgba(255,255,255,.78)}
.cta-legal{font-size:.72rem;color:rgba(255,255,255,.35);margin-top:14px;font-style:italic;line-height:1.65;max-width:700px}

/* ── FOOTER ── */
footer{background:#05101E;padding:44px 20px 24px}
.ft-top{text-align:center;margin-bottom:16px}
.ft-logo{font-size:1.4rem;font-weight:800;color:var(--pb2);letter-spacing:.3px;margin-bottom:4px}
.ft-u{color:var(--cor2)}
.ft-tagline{font-size:.82rem;color:rgba(255,255,255,.28)}
.ft-ql{text-align:center;font-size:.7rem;font-weight:700;color:var(--pb);text-transform:uppercase;letter-spacing:1.5px;margin:16px 0 10px}
.ft-nav{display:flex;flex-wrap:wrap;justify-content:center;background:rgba(255,255,255,.05);border-radius:var(--r);padding:14px 16px;margin-bottom:24px;gap:4px}
.ft-nav a{color:#FFFFFF;text-decoration:none;font-size:.86rem;font-weight:500;padding:5px 14px;border-right:1px solid rgba(255,255,255,.12);transition:color .2s,background .2s,border-radius .2s;white-space:nowrap}
.ft-nav a:last-child{border-right:none}
.ft-nav a:hover{color:#05101E;background:var(--pb2);border-radius:20px;border-right:1px solid transparent}
.ft-legal-section{max-width:1000px;margin:0 auto;border-top:1px solid rgba(255,255,255,.07);padding-top:20px}
.ft-fda-block{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.1);border-radius:var(--r);padding:16px 20px;margin-bottom:16px}
.ft-fda-block strong{font-size:.82rem;color:var(--pb2);display:block;margin-bottom:8px}
.ft-fda-block p{font-size:.77rem;line-height:1.7;color:rgba(255,255,255,.3);margin-bottom:8px}
.ft-fda-block p:last-child{margin-bottom:0}
.ft-legal-section>p{font-size:.77rem;line-height:1.7;color:rgba(255,255,255,.22);margin-bottom:10px}
.ft-policy{text-align:center;margin-bottom:14px;display:flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:6px}
.ft-policy a{color:rgba(255,255,255,.5);text-decoration:none;font-size:.82rem;font-weight:500;transition:color .2s}
.ft-policy a:hover{color:var(--pb2);text-decoration:underline}
.ft-policy span{color:rgba(255,255,255,.15)}
.ft-copy{text-align:center;font-size:.78rem;color:rgba(255,255,255,.2)}
.ft-copy a{color:rgba(255,255,255,.35);text-decoration:none;transition:color .2s}
.ft-copy a:hover{color:var(--pb2)}

/* ── LIFT — new class name ── */
.lift{opacity:0;transform:translateY(20px);transition:opacity .56s ease,transform .56s ease}
.lift.lifted{opacity:1;transform:translateY(0)}

/* ── RESPONSIVE ── */
@media(max-width:1040px){
  .hero-section{padding:44px 0}
  .hero-pod{grid-template-columns:1fr;gap:36px;padding:0 20px}
  .hero-product a img{max-width:300px;margin:0 auto;display:block}
  .hero-words h1{font-size:2rem}
  .hero-claims-grid{grid-template-columns:1fr}
  .why-pod{grid-template-columns:1fr}
  .about-pod{grid-template-columns:1fr}
  .about-img img{max-width:300px;margin:0 auto;display:block}
  .layers-pod{grid-template-columns:1fr}
  .layers-visual img{max-width:300px;margin:0 auto;display:block}
  .ing-feature-row{grid-template-columns:1fr}
  .ing-secondary-grid{grid-template-columns:repeat(2,1fr)}
  .use-steps{grid-template-columns:1fr}
  .guar-pod{grid-template-columns:1fr;text-align:center}
}
@media(max-width:700px){
  nav{padding:0}
  .pod.nav-pod{padding:0 16px}
  .nav-menu{display:none}
  .burger-btn{display:flex}
  .section-banner{padding:36px 16px 28px}
  .section-banner h2,.section-banner h3{font-size:1.52rem}
  .ing-secondary-grid{grid-template-columns:1fr}
  .jt-item{flex-direction:column;gap:10px}
  .why-section,.about-section,.ing-section,.layers-section,
  .use-section,.journey-section,.reviews-section,.guar-section,
  .faq-section,.order-section{padding:44px 0}
  .price-section{padding:24px 16px}
  .cta-section{padding:48px 16px}
  .cta-section h2{font-size:1.58rem}
  .cta-features{flex-direction:column;align-items:center;gap:8px}
  footer{padding:36px 16px 20px}
  .ft-nav a{border-right:none;padding:5px 10px}
}