/*
Theme Name: SkinShift
Theme URI: https://nakuitahata.lt
Author: Gaudenis + Claude
Description: Lightweight custom WooCommerce theme for SkinShift — "Color is Information". Ported faithfully from the SkinShift prototype. Anton + Sora typography, CSS-drawn bottles, slide-out cart wired to WooCommerce AJAX.
Version: 1.0.0
Requires at least: 6.5
Tested up to: 7.0
Requires PHP: 8.0
Text Domain: skinshift
Tags: ecommerce, woocommerce, custom
*/

/* ============================================================
   SKIN SHIFT — brand system
   ============================================================ */
:root{
  --orange:#FF5A1E;
  --green:#A6E83C;
  --blue:#A9BBFF;
  --pink:#FF9FD0;
  --black:#141414;
  --ink:#1c1c1c;
  --cream:#F4F1EA;
  --paper:#FBFAF6;
  --white:#ffffff;
  --line:rgba(20,20,20,.12);
  --radius:22px;
  --radius-sm:14px;
  --shadow:0 18px 40px -18px rgba(20,20,20,.35);
  --shadow-soft:0 10px 30px -16px rgba(20,20,20,.30);
  --maxw:1240px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:'Sora',system-ui,-apple-system,sans-serif;
  color:var(--ink);
  background:var(--paper);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;display:block;height:auto}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none}
.anton{font-family:'Anton',sans-serif;font-weight:400;letter-spacing:.5px}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
section{position:relative}

/* Display headings */
.display{
  font-family:'Anton',sans-serif;
  text-transform:uppercase;
  line-height:.92;
  letter-spacing:.5px;
}
.eyebrow{
  font-size:12px;font-weight:700;letter-spacing:.28em;text-transform:uppercase;
  display:inline-flex;align-items:center;gap:8px;
}
.eyebrow::before{content:"";width:26px;height:2px;background:currentColor;display:inline-block}

/* Buttons */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  font-weight:700;font-size:14px;letter-spacing:.04em;text-transform:uppercase;
  padding:15px 28px;border-radius:100px;transition:.2s transform,.2s box-shadow,.2s background,.2s color;
  white-space:nowrap;
}
.btn:active{transform:translateY(1px) scale(.99)}
.btn--dark{background:var(--black);color:#fff}
.btn--dark:hover{box-shadow:0 12px 24px -10px rgba(0,0,0,.5);transform:translateY(-2px)}
.btn--light{background:#fff;color:var(--black);border:2px solid var(--black)}
.btn--light:hover{background:var(--black);color:#fff}
.btn--orange{background:var(--orange);color:#fff}
.btn--orange:hover{filter:brightness(1.05);transform:translateY(-2px)}
.btn--ghost{border:2px solid currentColor}
.btn--block{width:100%}
.btn--sm{padding:11px 20px;font-size:12px}
.btn.loading{opacity:.7;pointer-events:none}
.btn.loading::after{content:"";width:14px;height:14px;border:2px solid currentColor;border-top-color:transparent;border-radius:50%;animation:spin .6s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

/* Pills / tags */
.pill{
  display:inline-flex;align-items:center;gap:8px;
  padding:8px 16px;border-radius:100px;font-size:12.5px;font-weight:600;
  background:#fff;border:1.5px solid var(--black);
}

/* ============================================================
   ANNOUNCEMENT MARQUEE
   ============================================================ */
.topbar{background:var(--black);color:#fff;overflow:hidden;white-space:nowrap;font-family:'Anton',sans-serif;letter-spacing:1px}
.topbar .track{display:inline-flex;gap:40px;padding:9px 0;animation:scroll 32s linear infinite;font-size:13px;text-transform:uppercase}
.topbar .track span{display:inline-flex;align-items:center;gap:40px;color:#fff}
.topbar .dot{width:7px;height:7px;border-radius:50%;background:var(--orange)}
@keyframes scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ============================================================
   HEADER / NAV
   ============================================================ */
header.site{
  position:sticky;top:0;z-index:60;background:rgba(251,250,246,.85);
  backdrop-filter:blur(14px);border-bottom:1px solid var(--line);
}
.nav{display:flex;align-items:center;justify-content:space-between;height:72px}
.brand{font-family:'Anton',sans-serif;font-size:26px;line-height:.8;letter-spacing:.5px;text-transform:uppercase}
.brand span{display:block;font-size:13px;letter-spacing:3px}
.nav-links{display:flex;gap:30px;align-items:center}
.nav-links a{font-size:14px;font-weight:600;position:relative;padding:4px 0}
.nav-links a::after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:2px;background:var(--orange);transition:.25s}
.nav-links a:hover::after{width:100%}
.nav-actions{display:flex;align-items:center;gap:14px}
.icon-btn{width:42px;height:42px;border-radius:50%;display:grid;place-items:center;border:1.5px solid var(--black);transition:.2s;color:var(--black)}
.icon-btn:hover{background:var(--black);color:#fff}
.cart-btn{position:relative}
.cart-count{
  position:absolute;top:-6px;right:-6px;background:var(--orange);color:#fff;
  font-size:11px;font-weight:800;min-width:20px;height:20px;border-radius:50%;
  display:grid;place-items:center;padding:0 5px;border:2px solid var(--paper);
  transform:scale(0);transition:.2s;
}
.cart-count.show{transform:scale(1)}
.burger{display:none;flex-direction:column;gap:5px;width:42px;height:42px;border-radius:50%;border:1.5px solid var(--black);place-items:center;padding:0}
.burger span{width:18px;height:2px;background:var(--black);display:block}

/* ============================================================
   HERO
   ============================================================ */
.hero{background:var(--orange);color:var(--black);overflow:hidden;position:relative}
.hero .wrap{display:grid;grid-template-columns:1.05fr .95fr;gap:40px;align-items:center;padding-top:64px;padding-bottom:64px;position:relative;z-index:2}
.hero h1{font-size:clamp(56px,9vw,128px);color:var(--black)}
.hero .sub{font-size:18px;max-width:430px;margin:22px 0 30px;font-weight:500}
.hero .cta-row{display:flex;gap:14px;flex-wrap:wrap;align-items:center}
.hero .tm{font-size:14px;vertical-align:super;font-family:'Sora';font-weight:700}
.hero-tag{display:inline-flex;align-items:center;gap:8px;background:var(--black);color:#fff;padding:8px 16px;border-radius:100px;font-size:12px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;margin-bottom:24px}
.hero-tag .blink{width:8px;height:8px;border-radius:50%;background:var(--green);animation:blink 1.4s infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.25}}

.hero-visual{position:relative;height:540px;display:grid;place-items:center}
.hero-photo{
  width:100%;height:100%;border-radius:var(--radius);object-fit:cover;
  box-shadow:var(--shadow);filter:saturate(1.05);
}
.hero-photo-wrap{position:relative;width:88%;height:92%;border-radius:var(--radius);overflow:hidden}
.hero-photo-wrap::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 40%,rgba(255,90,30,.25))}

/* floating bubbles */
.bubble{position:absolute;border-radius:50%;background:radial-gradient(circle at 30% 30%,rgba(255,255,255,.9),rgba(255,255,255,.15));border:1px solid rgba(255,255,255,.5);pointer-events:none}
.b1{width:90px;height:90px;top:6%;right:2%;animation:float 7s ease-in-out infinite}
.b2{width:46px;height:46px;bottom:14%;left:-2%;animation:float 5.5s ease-in-out infinite .6s}
.b3{width:24px;height:24px;top:42%;right:-3%;animation:float 6s ease-in-out infinite .3s}
.b4{width:130px;height:130px;bottom:-5%;right:18%;opacity:.55;animation:float 9s ease-in-out infinite}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-18px)}}

.hero-strip{background:var(--black);color:#fff;position:relative;z-index:2}
.hero-strip .wrap{display:flex;justify-content:space-around;gap:18px;flex-wrap:wrap;padding:18px 24px}
.hero-strip .item{display:flex;align-items:center;gap:10px;font-size:13px;font-weight:600;letter-spacing:.02em}
.hero-strip svg{flex:0 0 auto}

/* ============================================================
   FEATURES (4 icons)
   ============================================================ */
.features{padding:84px 0}
.sec-head{max-width:680px;margin-bottom:50px}
.sec-head h2{font-size:clamp(34px,5vw,62px);margin:14px 0}
.feature-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.feature{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:30px 26px;transition:.25s;position:relative;overflow:hidden}
.feature:hover{transform:translateY(-6px);box-shadow:var(--shadow-soft)}
.feature .ic{width:58px;height:58px;border-radius:16px;display:grid;place-items:center;margin-bottom:18px;background:var(--cream)}
.feature:nth-child(1) .ic{background:var(--blue)}
.feature:nth-child(2) .ic{background:var(--green)}
.feature:nth-child(3) .ic{background:var(--pink)}
.feature:nth-child(4) .ic{background:var(--orange)}
.feature h3{font-family:'Anton';font-size:21px;text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px}
.feature p{font-size:14px;color:#555}

/* ============================================================
   PRODUCTS
   ============================================================ */
.products{padding:40px 0 90px}
.prod-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.card{
  border-radius:var(--radius);overflow:hidden;background:#fff;border:1px solid var(--line);
  display:flex;flex-direction:column;transition:.25s;
}
.card:hover{transform:translateY(-8px);box-shadow:var(--shadow)}
.card .visual{position:relative;aspect-ratio:1/1.02;display:grid;place-items:center;overflow:hidden}
.card[data-variant="hydrate"] .visual{background:var(--blue)}
.card[data-variant="balance"] .visual{background:var(--green)}
.card[data-variant="clear"]   .visual{background:var(--pink)}
.card .variant-label{position:absolute;top:18px;left:18px;font-family:'Anton';font-size:28px;text-transform:uppercase;color:var(--black);line-height:.85}
.card .variant-label small{display:block;font-family:'Sora';font-size:11px;font-weight:700;letter-spacing:.18em;margin-top:6px}
.card .price-badge{position:absolute;top:18px;right:18px;background:var(--black);color:#fff;font-weight:800;font-size:14px;padding:7px 14px;border-radius:100px}

/* CSS pump bottle */
.bottle{position:relative;width:118px;height:240px;filter:drop-shadow(0 16px 18px rgba(0,0,0,.18));transition:.4s}
.card:hover .bottle{transform:translateY(-6px) rotate(-2deg)}
.bottle .pump{position:absolute;top:0;left:50%;transform:translateX(-50%);width:30px;height:26px;background:#fff;border-radius:8px 8px 4px 4px}
.bottle .pump::before{content:"";position:absolute;top:9px;left:-12px;width:16px;height:8px;background:#fff;border-radius:4px}
.bottle .pump::after{content:"";position:absolute;top:-7px;left:50%;transform:translateX(-50%);width:14px;height:10px;background:#f0efe9;border-radius:4px 4px 0 0}
.bottle .collar{position:absolute;top:24px;left:50%;transform:translateX(-50%);width:34px;height:14px;background:#efede6;border-radius:4px}
.bottle .body{
  position:absolute;top:36px;left:50%;transform:translateX(-50%);width:100px;height:200px;
  background:linear-gradient(100deg,#fff 0%,#fff 55%,#ececff 100%);
  border-radius:16px;border:1px solid rgba(0,0,0,.06);
  display:flex;flex-direction:column;align-items:center;padding:26px 12px 16px;
}
.bottle .body::after{content:"";position:absolute;top:8px;left:10px;width:14px;height:80%;border-radius:8px;background:linear-gradient(180deg,rgba(255,255,255,.9),rgba(255,255,255,0))}
.bottle .b-brand{font-family:'Anton';font-size:19px;line-height:.82;text-align:center;color:var(--black);text-transform:uppercase}
.bottle .b-variant{font-size:8.5px;font-weight:800;letter-spacing:.12em;margin-top:8px;color:#333;text-transform:uppercase}
.bottle .b-sub{font-size:6.5px;font-weight:600;letter-spacing:.1em;color:#888;margin-top:2px;text-transform:uppercase}
.bottle .b-dot{width:18px;height:18px;border-radius:50%;margin-top:auto}
.bottle[data-c="hydrate"] .b-dot{background:var(--blue)}
.bottle[data-c="balance"] .b-dot{background:var(--green)}
.bottle[data-c="clear"]   .b-dot{background:var(--pink)}
.bottle[data-c="clean"]   .b-dot{background:var(--orange)}
.bottle .b-vol{font-size:6.5px;font-weight:700;letter-spacing:.1em;color:#999;margin-top:7px}

.card .info{padding:22px 22px 24px;display:flex;flex-direction:column;gap:12px;flex:1}
.card .info h3{font-family:'Anton';font-size:23px;text-transform:uppercase}
.card .stars{color:var(--orange);font-size:13px;letter-spacing:2px}
.card .desc{font-size:13.5px;color:#555;flex:1}
.card .ingredients{display:flex;gap:6px;flex-wrap:wrap}
.tag-sm{font-size:10.5px;font-weight:600;padding:5px 10px;border-radius:100px;background:var(--cream);color:#444}
.card .buy{display:flex;align-items:center;gap:10px;margin-top:6px}
.card .buy .price{font-family:'Anton';font-size:24px}
.card .buy .btn{flex:1}

/* mini bubbles inside cards */
.card .visual .mini{position:absolute;border-radius:50%;background:rgba(255,255,255,.5);border:1px solid rgba(255,255,255,.6)}
.card .m1{width:54px;height:54px;bottom:12%;right:8%}
.card .m2{width:22px;height:22px;top:24%;right:14%}
.card .m3{width:34px;height:34px;bottom:30%;left:8%}

/* ============================================================
   HOW IT WORKS / THE SCIENCE
   ============================================================ */
.science{background:var(--black);color:#fff;padding:96px 0;overflow:hidden}
.science .wrap{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.science h2{font-size:clamp(38px,5.5vw,68px);margin:16px 0 22px}
.science .lead{color:#cfcfcf;font-size:17px;max-width:480px;margin-bottom:34px}
.steps{display:flex;flex-direction:column;gap:18px}
.step{display:flex;gap:18px;align-items:flex-start;padding:18px;border:1px solid rgba(255,255,255,.14);border-radius:var(--radius-sm);transition:.2s}
.step:hover{background:rgba(255,255,255,.04)}
.step .n{font-family:'Anton';font-size:34px;line-height:1;color:var(--orange);min-width:46px}
.step h4{font-family:'Anton';font-size:18px;text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px}
.step p{font-size:14px;color:#bdbdbd}
.color-demo{position:relative;border-radius:var(--radius);overflow:hidden;aspect-ratio:1/1.05;background:#0f0f0f;display:grid;place-items:center}
.color-demo .ring{position:absolute;border-radius:50%;mix-blend-mode:screen;filter:blur(8px);animation:morph 8s ease-in-out infinite}
.cr1{width:320px;height:320px;background:var(--blue);animation-delay:0s}
.cr2{width:240px;height:240px;background:var(--green);animation-delay:-2.6s}
.cr3{width:180px;height:180px;background:var(--pink);animation-delay:-5.2s}
@keyframes morph{0%,100%{transform:translate(0,0) scale(1)}33%{transform:translate(40px,-30px) scale(1.15)}66%{transform:translate(-30px,30px) scale(.9)}}
.color-demo .demo-label{position:relative;z-index:2;text-align:center}
.color-demo .demo-label .anton{font-size:46px;color:#fff}
.color-demo .demo-label p{font-size:12px;letter-spacing:.3em;text-transform:uppercase;color:#fff;margin-top:6px}

/* ============================================================
   FEATURED PRODUCT
   ============================================================ */
.featured{padding:96px 0}
.featured .wrap{display:grid;grid-template-columns:1fr 1.1fr;gap:56px;align-items:center}
.featured .pic{background:var(--blue);border-radius:var(--radius);aspect-ratio:1/1;display:grid;place-items:center;position:relative;overflow:hidden}
.featured .pic .swatches{position:absolute;bottom:22px;left:50%;transform:translateX(-50%);display:flex;gap:10px}
.featured .pic .sw{width:34px;height:34px;border-radius:50%;border:3px solid #fff;cursor:pointer;transition:.2s}
.featured .pic .sw:hover{transform:scale(1.12)}
.featured .pic .sw[data-set="hydrate"]{background:var(--blue)}
.featured .pic .sw[data-set="balance"]{background:var(--green)}
.featured .pic .sw[data-set="clear"]{background:var(--pink)}
.featured .pic .sw.active{box-shadow:0 0 0 3px var(--black)}
.featured h2{font-size:clamp(36px,5vw,64px);margin:14px 0 8px}
.featured .price-line{display:flex;align-items:baseline;gap:14px;margin:10px 0 18px}
.featured .price-line .now{font-family:'Anton';font-size:40px}
.featured .price-line .was{font-size:18px;color:#999;text-decoration:line-through}
.featured .price-line .save{background:var(--green);color:var(--black);font-weight:800;font-size:12px;padding:5px 12px;border-radius:100px}
.featured .lead{color:#555;margin-bottom:22px;max-width:520px}
.benefit-list{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:26px}
.benefit-list li{list-style:none;display:flex;gap:10px;align-items:center;font-size:14px;font-weight:500}
.benefit-list .ck{width:22px;height:22px;border-radius:50%;background:var(--green);display:grid;place-items:center;flex:0 0 auto}
.qty{display:inline-flex;align-items:center;border:2px solid var(--black);border-radius:100px;overflow:hidden}
.qty button{width:44px;height:48px;font-size:20px;font-weight:700}
.qty button:hover{background:var(--black);color:#fff}
.qty input{width:40px;text-align:center;border:none;font-weight:700;font-size:16px;background:transparent;-moz-appearance:textfield}
.qty input::-webkit-outer-spin-button,.qty input::-webkit-inner-spin-button{-webkit-appearance:none}
.buy-row{display:flex;gap:14px;align-items:stretch;flex-wrap:wrap}
.buy-row .btn{flex:1;min-width:200px}

/* ============================================================
   MOOD GALLERY
   ============================================================ */
.mood{padding:30px 0 96px}
.mood-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:200px;gap:14px}
.mood-grid figure{position:relative;border-radius:var(--radius-sm);overflow:hidden;background:var(--cream)}
.mood-grid img{width:100%;height:100%;object-fit:cover;transition:.5s}
.mood-grid figure:hover img{transform:scale(1.07)}
.mood-grid .tall{grid-row:span 2}
.mood-grid .wide{grid-column:span 2}
.mood-grid figure.note{display:grid;place-items:center;padding:24px;text-align:center}
.mood-grid figure.note.o{background:var(--orange)}
.mood-grid figure.note.g{background:var(--green)}
.mood-grid figure.note .anton{font-size:30px;color:var(--black);line-height:.9}

/* ============================================================
   TRUST / ICONOGRAPHY
   ============================================================ */
.trust{background:var(--cream);padding:90px 0}
.trust-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:46px}
.trust-card{background:#fff;border-radius:var(--radius);padding:34px;display:flex;gap:20px;align-items:flex-start;transition:.2s}
.trust-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-soft)}
.trust-card .ic{width:54px;height:54px;border-radius:14px;background:var(--black);color:#fff;display:grid;place-items:center;flex:0 0 auto}
.trust-card h4{font-family:'Anton';font-size:19px;text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px}
.trust-card p{font-size:13.5px;color:#555}

/* ============================================================
   REVIEWS
   ============================================================ */
.reviews{padding:96px 0}
.rev-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:46px}
.rev{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:30px}
.rev .stars{color:var(--orange);letter-spacing:3px;margin-bottom:14px}
.rev p{font-size:15px;margin-bottom:20px}
.rev .who{display:flex;align-items:center;gap:12px}
.rev .who img{width:46px;height:46px;border-radius:50%;object-fit:cover}
.rev .who b{font-size:14px;display:block}
.rev .who span{font-size:12px;color:#888}

/* ============================================================
   FAQ
   ============================================================ */
.faq{padding:30px 0 96px}
.faq-list{display:flex;flex-direction:column;gap:12px;max-width:860px}
.faq-item{background:#fff;border:1px solid var(--line);border-radius:var(--radius-sm);padding:0 22px;overflow:hidden}
.faq-item summary{list-style:none;cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:20px 0;font-weight:600;font-size:16px}
.faq-item summary::-webkit-details-marker{display:none}
.faq-plus{font-family:'Anton';font-size:26px;color:var(--orange);transition:.25s;line-height:1}
.faq-item[open] .faq-plus{transform:rotate(45deg)}
.faq-a{padding:0 0 22px;color:#555;font-size:14.5px;max-width:680px}

/* ============================================================
   BRAND VOICE BANNER
   ============================================================ */
.voice{background:var(--orange);padding:90px 0;text-align:center;overflow:hidden}
.voice h2{font-size:clamp(40px,7vw,96px);color:var(--black)}
.voice .tags{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-top:34px}
.voice .tags .pill{background:var(--black);color:#fff;border-color:var(--black);font-weight:700;letter-spacing:.06em}

/* ============================================================
   NEWSLETTER
   ============================================================ */
.news{background:var(--black);color:#fff;padding:84px 0}
.news .wrap{display:grid;grid-template-columns:1fr 1fr;gap:50px;align-items:center}
.news h2{font-size:clamp(34px,4.4vw,56px);margin-bottom:14px}
.news p{color:#bbb;max-width:420px}
.news form{display:flex;gap:12px;flex-wrap:wrap}
.news input{flex:1;min-width:240px;padding:16px 22px;border-radius:100px;border:none;font-family:inherit;font-size:15px}
.news .fine{font-size:12px;color:#888;margin-top:14px}

/* ============================================================
   FOOTER
   ============================================================ */
footer.site{background:#0c0c0c;color:#ddd;padding:70px 0 30px}
.foot-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:40px}
.foot-brand .brand{color:#fff;margin-bottom:16px}
.foot-brand p{color:#999;font-size:14px;max-width:300px}
.foot-col h5{font-family:'Anton';font-size:15px;letter-spacing:.5px;text-transform:uppercase;color:#fff;margin-bottom:18px}
.foot-col a{display:block;color:#aaa;font-size:14px;padding:6px 0;transition:.2s}
.foot-col a:hover{color:var(--orange)}
.socials{display:flex;gap:10px;margin-top:18px}
.socials a{width:40px;height:40px;border-radius:50%;border:1px solid #333;display:grid;place-items:center;transition:.2s}
.socials a:hover{background:var(--orange);border-color:var(--orange);color:#000}
.foot-bottom{border-top:1px solid #222;margin-top:50px;padding-top:24px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;font-size:13px;color:#777}

/* ============================================================
   CART DRAWER
   ============================================================ */
.overlay{position:fixed;inset:0;background:rgba(0,0,0,.5);opacity:0;visibility:hidden;transition:.3s;z-index:90}
.overlay.open{opacity:1;visibility:visible}
.drawer{
  position:fixed;top:0;right:0;height:100%;width:420px;max-width:92vw;background:var(--paper);
  z-index:100;transform:translateX(100%);transition:transform .35s cubic-bezier(.4,0,.1,1);
  display:flex;flex-direction:column;box-shadow:-20px 0 60px rgba(0,0,0,.25);
}
.drawer.open{transform:translateX(0)}
.drawer-head{display:flex;align-items:center;justify-content:space-between;padding:24px;border-bottom:1px solid var(--line)}
.drawer-head h3{font-family:'Anton';font-size:24px;text-transform:uppercase}
.drawer-head .close{width:40px;height:40px;border-radius:50%;border:1.5px solid var(--black);display:grid;place-items:center;font-size:20px}
.drawer-head .close:hover{background:var(--black);color:#fff}
.drawer-body{flex:1;overflow-y:auto;padding:16px 24px}
.cart-empty{text-align:center;padding:60px 20px;color:#888}
.cart-empty .anton{font-size:26px;color:var(--black);display:block;margin:16px 0 6px}
.cart-item{display:flex;gap:14px;padding:16px 0;border-bottom:1px solid var(--line)}
.cart-item .thumb{width:64px;height:64px;border-radius:12px;flex:0 0 auto;display:grid;place-items:center;font-family:'Anton';color:var(--black);font-size:13px;text-align:center;line-height:.9;overflow:hidden}
.cart-item .thumb img{width:100%;height:100%;object-fit:cover}
.cart-item .thumb[data-c="hydrate"]{background:var(--blue)}
.cart-item .thumb[data-c="balance"]{background:var(--green)}
.cart-item .thumb[data-c="clear"]{background:var(--pink)}
.cart-item .thumb[data-c="trio"]{background:var(--orange)}
.cart-item .ci-info{flex:1;min-width:0}
.cart-item .ci-info b{font-size:14px;display:block}
.cart-item .ci-info .ci-sub{font-size:12px;color:#888}
.cart-item .ci-bottom{display:flex;align-items:center;justify-content:space-between;margin-top:8px}
.mini-qty{display:inline-flex;align-items:center;border:1.5px solid var(--black);border-radius:100px}
.mini-qty button{width:28px;height:28px;font-weight:700}
.mini-qty span{width:30px;text-align:center;font-size:13px;font-weight:700}
.cart-item .remove{font-size:12px;color:#c00;font-weight:600}
.cart-item .ci-price{font-weight:800;font-size:14px}
.drawer-foot{padding:22px 24px;border-top:1px solid var(--line);background:#fff}
.subtotal{display:flex;justify-content:space-between;font-weight:800;font-size:18px;margin-bottom:6px}
.subtotal .anton{font-size:24px}
.drawer-foot .ship{font-size:12px;color:#777;margin-bottom:16px}
.toast{
  position:fixed;bottom:26px;left:50%;transform:translateX(-50%) translateY(120px);
  background:var(--black);color:#fff;padding:14px 24px;border-radius:100px;font-weight:600;font-size:14px;
  z-index:120;transition:.35s;display:flex;align-items:center;gap:10px;box-shadow:var(--shadow);
}
.toast.show{transform:translateX(-50%) translateY(0)}
.toast .tdot{width:8px;height:8px;border-radius:50%;background:var(--green)}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media(max-width:1024px){
  .feature-grid{grid-template-columns:repeat(2,1fr)}
  .mood-grid{grid-template-columns:repeat(2,1fr)}
  .foot-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:860px){
  .nav-links{display:none}
  .burger{display:grid}
  .hero .wrap,.science .wrap,.featured .wrap,.news .wrap{grid-template-columns:1fr}
  .hero-visual{height:420px;order:-1}
  .prod-grid,.trust-grid,.rev-grid{grid-template-columns:1fr}
  .science .wrap{gap:36px}
  .benefit-list{grid-template-columns:1fr}
}
@media(max-width:560px){
  .feature-grid{grid-template-columns:1fr}
  .mood-grid{grid-template-columns:1fr;grid-auto-rows:220px}
  .foot-grid{grid-template-columns:1fr}
  .hero .cta-row{flex-direction:column;align-items:stretch}
}

/* mobile menu */
.mobile-menu{position:fixed;inset:0;background:var(--paper);z-index:80;transform:translateY(-100%);transition:.35s;padding:90px 30px;display:flex;flex-direction:column;gap:4px}
.mobile-menu.open{transform:translateY(0)}
.mobile-menu a{font-family:'Anton';font-size:32px;text-transform:uppercase;padding:12px 0;border-bottom:1px solid var(--line)}
.mobile-menu .mclose{position:absolute;top:24px;right:24px;font-size:30px}

/* ============================================================
   WooCommerce single-product + shop (themed to match)
   ============================================================ */
.woocommerce-page .wrap-narrow{max-width:var(--maxw);margin:0 auto;padding:48px 24px 80px}
.sk-shop{padding:60px 0 90px}
.sk-shop ul.products{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;list-style:none;margin:0;padding:0}
@media(max-width:860px){.sk-shop ul.products{grid-template-columns:1fr}}
.woocommerce-message,.woocommerce-info,.woocommerce-error{border-radius:var(--radius-sm);border:1px solid var(--line);background:#fff;padding:16px 20px;list-style:none;font-size:14px;margin-bottom:20px}
.woocommerce-error{border-color:#f3c2b6}
.single-product div.product{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start}
@media(max-width:860px){.single-product div.product{grid-template-columns:1fr}}
.single-product .product_title{font-family:'Anton';text-transform:uppercase;font-size:clamp(32px,5vw,56px);line-height:.95}
.single-product .price{font-family:'Anton';font-size:34px}
.single-product .single_add_to_cart_button,.sk-shop .button{background:var(--black)!important;color:#fff!important;border-radius:100px!important;text-transform:uppercase;font-weight:700!important;padding:15px 28px!important;letter-spacing:.04em}
.single-product .single_add_to_cart_button:hover,.sk-shop .button:hover{background:var(--orange)!important}
.skin-content{max-width:760px;margin:0 auto;padding:60px 24px 90px}
.skin-content h1{font-family:'Anton';text-transform:uppercase;font-size:clamp(34px,5vw,58px);margin-bottom:24px;line-height:.95}
.skin-content h2{font-family:'Anton';text-transform:uppercase;margin:32px 0 12px}
.skin-content p{margin-bottom:16px}
.skin-content ul{margin:0 0 16px 22px}
.skin-content li{margin-bottom:8px}
.skin-content a{color:var(--orange);text-decoration:underline}

/* product card link behaviour */
.card .visual{cursor:pointer}
.card .info h3 a{color:inherit}
.card .info h3 a:hover{color:var(--orange)}
.card .buy{flex-wrap:wrap}
.card .buy .btn--sm{flex:0 0 auto}

/* review avatar (CSS initials) */
.rev .who .avatar{width:46px;height:46px;border-radius:50%;display:grid;place-items:center;font-family:'Anton';font-size:20px;color:var(--black);flex:0 0 auto}

/* ============================================================
   MINI-CART UPSELL
   ============================================================ */
.upsell{display:flex;align-items:center;gap:12px;margin-top:18px;padding:14px;border:1.5px dashed var(--orange);border-radius:var(--radius-sm);background:#fff7f3;position:relative}
.upsell .thumb{width:48px;height:48px;border-radius:10px;display:grid;place-items:center;font-family:'Anton';font-size:11px;line-height:.9;color:var(--black);flex:0 0 auto}
.upsell .up-info{flex:1;min-width:0}
.upsell .up-info b{font-size:13.5px;display:block}
.upsell .up-sub{font-size:11px;color:#888;display:block;margin:2px 0 4px}
.upsell .up-price .was{text-decoration:line-through;color:#999;font-size:12px}
.upsell .up-price .now{font-weight:800;color:var(--orange);font-size:14px}
.upsell-badge{position:absolute;top:-10px;left:12px;background:var(--orange);color:#fff;font-weight:800;font-size:11px;padding:3px 9px;border-radius:100px}

/* ============================================================
   SINGLE PRODUCT LANDING
   ============================================================ */
.sp{padding:34px 24px 90px}
.sp-back{display:inline-block;margin-bottom:22px;font-weight:600;font-size:14px}
.sp-back:hover{color:var(--orange)}
.sp-hero{display:grid;grid-template-columns:1fr 1.05fr;gap:48px;align-items:center;margin-bottom:50px}
.sp-hero .pic{border-radius:var(--radius);aspect-ratio:1/1;display:grid;place-items:center;position:relative;overflow:hidden;transition:background .3s}
.sp-hero .swatches{position:absolute;bottom:22px;left:50%;transform:translateX(-50%);display:flex;gap:10px}
.sp-hero .sw{width:34px;height:34px;border-radius:50%;border:3px solid #fff;cursor:pointer;transition:.2s}
.sp-hero .sw[data-set="hydrate"]{background:var(--blue)}
.sp-hero .sw[data-set="balance"]{background:var(--green)}
.sp-hero .sw[data-set="clear"]{background:var(--pink)}
.sp-hero .sw.active{box-shadow:0 0 0 3px var(--black)}
.sp-summary h1{font-size:clamp(34px,5vw,60px);margin:10px 0 6px}
.sp-summary .price-line{display:flex;align-items:baseline;gap:14px;margin:8px 0 16px}
.sp-summary .price-line .now{font-family:'Anton';font-size:38px}
.sp-summary .price-line .was{font-size:18px;color:#999;text-decoration:line-through}
.sp-summary .price-line .save{background:var(--green);color:var(--black);font-weight:800;font-size:12px;padding:5px 12px;border-radius:100px}
.sp-summary .lead{color:#555;margin-bottom:22px}
.sp-assure{display:flex;gap:18px;flex-wrap:wrap;margin-top:20px;font-size:13px;color:#666}
.sp-details{display:grid;gap:34px;max-width:900px}
.sp-block h2{font-size:clamp(26px,3.4vw,40px);margin-bottom:18px}
.sp-rte p{margin-bottom:14px;color:#444}
.steps.light .step{border-color:var(--line)}
.steps.light .step h4{color:var(--black)}
.steps.light .step p{color:#666}

/* ============================================================
   WOOCOMMERCE CART / CHECKOUT (blocks + classic) — brand styling
   ============================================================ */
.woocommerce-page{min-height:50vh}
.wc-block-components-button,.wp-block-button__link,
.woocommerce a.button,.woocommerce button.button,.woocommerce input.button,
.woocommerce #respond input#submit{
  background:var(--black)!important;color:#fff!important;border-radius:100px!important;
  font-weight:700!important;text-transform:uppercase;letter-spacing:.04em;padding:14px 26px!important;border:none!important;
}
.wc-block-components-button:hover,.woocommerce a.button:hover,.woocommerce button.button:hover{background:var(--orange)!important}
.wc-block-checkout__actions .wc-block-components-checkout-place-order-button{background:var(--orange)!important;font-size:16px!important}
.wc-block-components-text-input input,.woocommerce form .form-row input.input-text,.woocommerce form .form-row textarea,.select2-container .select2-selection{
  border:1.5px solid var(--line)!important;border-radius:12px!important;padding:12px 14px!important;font-family:inherit!important;
}
.wc-block-components-text-input input:focus,.woocommerce form .form-row input.input-text:focus{border-color:var(--black)!important;outline:none!important}
.woocommerce-cart table.cart,.woocommerce-checkout .shop_table{border-radius:var(--radius-sm);overflow:hidden}
.wc-block-cart-items__row,.cart_item{font-size:14px}
.wc-block-components-totals-item__value,.order-total .amount{font-weight:800}
.woocommerce-cart .wc-proceed-to-checkout a.checkout-button{background:var(--orange)!important;font-size:16px!important}
h1.entry-title,.wc-block-components-title{font-family:'Anton';text-transform:uppercase}

/* ============================================================
   ACCESSIBILITY
   ============================================================ */
.skip-link{position:absolute;left:-9999px;top:0;z-index:1000;background:var(--black);color:#fff;padding:12px 20px;border-radius:0 0 10px 0;font-weight:700}
.skip-link:focus{left:0}
a:focus-visible,button:focus-visible,input:focus-visible,summary:focus-visible,[tabindex]:focus-visible,.sw:focus-visible{
  outline:3px solid var(--orange);outline-offset:2px;border-radius:6px;
}
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto!important}
  .topbar .track{animation:none}
}

/* ============================================================
   MOBILE / RESPONSIVE refinements
   ============================================================ */
@media(max-width:860px){
  .sp-hero{grid-template-columns:1fr;gap:28px}
  .sp-hero .pic{max-width:420px;margin:0 auto;width:100%}
}
@media(max-width:560px){
  .wrap{padding:0 18px}
  .nav{height:64px}
  .brand{font-size:22px}
  .hero .wrap{padding-top:40px;padding-bottom:40px}
  .hero .sub{font-size:16px}
  .features,.reviews,.trust{padding:56px 0}
  .products{padding:30px 0 60px}
  .btn{padding:14px 22px}
  /* comfortable tap targets */
  .nav-actions .icon-btn,.burger{width:46px;height:46px}
  .qty button{width:48px;height:50px}
  .mini-qty button{width:34px;height:34px}
  .faq-item summary{padding:18px 0;font-size:15px}
  .sp-summary .price-line .now{font-size:32px}
  .drawer{width:100%;max-width:100%}
  .buy-row .btn{min-width:0}
  .card .buy{gap:8px}
}
/* prevent iOS zoom on input focus */
@media(max-width:560px){
  input,select,textarea{font-size:16px!important}
}
