/*
Theme Name: KIMA Labs
Theme URI: https://kimalabx.com
Author: AJLabs
Author URI: https://ajlabs.io
Description: Custom WooCommerce theme for KIMA Labs — a clean, premium biotech storefront for peptide bioregulator supplements. Dark hero, light content pages, single accent blue.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.6
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: kimalabx
Tags: e-commerce, custom-logo, custom-menu, featured-images, threaded-comments, translation-ready
*/

/* ===================================================================
   KIMA Labs — design system
   Type: Switzer — one clean grotesk, headings + body
   =================================================================== */
:root{
  --bg:#F4F2EC;
  --bg-2:#ECE9DF;
  --tint:#E5F0F8;
  --white:#FFFFFF;
  --ink:#17191D;
  --ink-2:#5C616A;
  --line:#E3E0D5;
  --line-w:#ECE9DF;
  --blue:#2E9BDD;
  --blue-d:#1F86C6;
  --blue-2:#5AC4FA;
  --blue-soft:#E4F0F9;
  --muted:#8A8F98;
  --display:"Switzer",-apple-system,Arial,sans-serif;
  --body:"Switzer",-apple-system,Arial,sans-serif;
  --radius:18px;
  --shadow:0 24px 56px -24px rgba(23,40,66,.26);
  --shadow-sm:0 12px 30px -14px rgba(23,40,66,.22);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{background:var(--bg);color:var(--ink-2);
  font-family:var(--body);font-size:16px;line-height:1.65;
  -webkit-font-smoothing:antialiased;overflow-x:hidden}
img{max-width:100%;display:block;height:auto}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{font-family:var(--display);color:var(--ink);
  font-weight:600;line-height:1.08;letter-spacing:-.02em}
section[id]{scroll-margin-top:80px}
.wrap{max-width:1200px;margin:0 auto;padding:0 28px}
.wrap.narrow{max-width:860px}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;
  font-family:var(--body);font-size:15px;font-weight:600;
  padding:14px 26px;border-radius:999px;border:1.5px solid transparent;
  cursor:pointer;white-space:nowrap;
  transition:transform .16s ease,box-shadow .2s ease,background .2s ease,
    border-color .2s ease,color .2s ease}
.btn-dark{background:var(--ink);color:#fff}
.btn-dark:hover{transform:translateY(-2px);box-shadow:0 14px 30px -10px rgba(23,25,29,.6);color:#fff}
.btn-light{background:#fff;color:var(--ink);border-color:var(--line)}
.btn-light:hover{transform:translateY(-2px);box-shadow:var(--shadow-sm);color:var(--ink)}
.btn-primary{background:var(--blue);color:#fff}
.btn-primary:hover{background:var(--blue-d);color:#fff}
.btn-white{background:#fff;color:var(--ink)}
.btn-white:hover{transform:translateY(-2px);box-shadow:0 16px 34px -12px rgba(0,0,0,.55);color:var(--ink)}
.btn-lg{padding:17px 32px;font-size:16px}
.btn-sm{padding:10px 20px;font-size:14px}

/* ---------- sparkle ---------- */
.spark{width:15px;height:15px;flex:none;fill:var(--blue)}

/* ---------- topbar ---------- */
.topbar{display:flex;align-items:center;justify-content:center;gap:14px;
  padding:9px 16px;background:var(--ink);
  font-size:11.5px;font-weight:500;letter-spacing:.09em;text-transform:uppercase;
  color:rgba(255,255,255,.72)}
.topbar i{width:3px;height:3px;border-radius:50%;background:var(--blue)}

/* ---------- header ---------- */
#header{position:sticky;top:0;z-index:100;
  transition:background .25s ease,border-color .25s ease,box-shadow .25s ease;
  border-bottom:1px solid transparent}
#header.scrolled{background:rgba(244,242,236,.88);backdrop-filter:blur(14px);
  border-bottom-color:var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;height:72px}
.logo{display:flex;align-items:center;gap:10px}
.nav-links{display:flex;align-items:center;gap:30px;list-style:none;margin:0;padding:0}
.nav-links li{list-style:none}
.nav-links a{font-size:14.5px;font-weight:500;color:var(--ink-2);
  transition:color .15s ease}
.nav-links a:hover,
.nav-links li.current-menu-item > a,
.nav-links li.current_page_item > a,
.nav-links li.current-menu-parent > a,
.nav-links a.active{color:var(--ink)}
.nav-right{display:flex;align-items:center;gap:14px}
.cart-btn{position:relative;background:none;border:0;color:var(--ink);
  cursor:pointer;padding:6px;display:flex;text-decoration:none}
.cart-count{position:absolute;top:-3px;right:-4px;min-width:17px;height:17px;
  padding:0 4px;border-radius:9px;background:var(--blue);color:#fff;
  font-size:10.5px;font-weight:700;line-height:17px;text-align:center;
  transition:transform .25s cubic-bezier(.3,1.6,.5,1)}
.cart-count.bump{transform:scale(1.45)}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:0;
  cursor:pointer;padding:6px}
.burger span{width:22px;height:2px;background:var(--ink);border-radius:2px;
  transition:transform .25s ease,opacity .2s ease}
.burger.x span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.burger.x span:nth-child(2){opacity:0}
.burger.x span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ---------- hero ---------- */
.hero{position:relative;overflow:hidden;
  padding:clamp(40px,6vw,76px) 0 clamp(70px,8vw,108px)}
.hero-grid{position:relative;z-index:1;display:grid;
  grid-template-columns:1.04fr .96fr;gap:clamp(28px,5vw,68px);
  align-items:center}
.pill{display:inline-flex;align-items:center;gap:8px;
  background:#fff;border:1px solid var(--line);border-radius:999px;
  padding:8px 16px 8px 13px;font-size:12.5px;font-weight:600;
  letter-spacing:.04em;color:var(--ink);box-shadow:var(--shadow-sm)}
.hero h1{font-size:clamp(38px,4.4vw,60px);letter-spacing:-.03em;
  margin:22px 0 0;font-weight:600}
.lede{margin:24px 0 30px;font-size:clamp(15px,1.5vw,18px);max-width:30em}
.hero-cta{display:flex;align-items:center;gap:22px;flex-wrap:wrap}
.link-play{display:inline-flex;align-items:center;gap:10px;
  font-size:15px;font-weight:600;color:var(--ink)}
.play{width:38px;height:38px;border-radius:50%;background:#fff;
  border:1px solid var(--line);display:flex;align-items:center;
  justify-content:center;box-shadow:var(--shadow-sm);transition:transform .16s ease}
.play svg{width:16px;height:16px;color:var(--blue);margin-left:2px}
.link-play:hover .play{transform:scale(1.08)}
.hero-meta{display:flex;align-items:center;gap:8px;margin-top:26px;
  font-size:13.5px;color:var(--ink-2)}
.hero-meta b{color:var(--ink)}
.rstars{color:var(--blue);letter-spacing:1.5px}
.rstars.big{font-size:22px;letter-spacing:3px}

/* hero visual */
.hero-visual{position:relative;display:flex;align-items:center;
  justify-content:center;min-height:480px}
.hero-visual img{position:relative;z-index:2;max-height:520px;width:auto;
  filter:drop-shadow(0 40px 50px rgba(23,40,66,.32))}
.float{animation:float 6s ease-in-out infinite}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-15px)}}
.spark.s1,.spark.s2,.spark.s3,.spark.s4{position:absolute;z-index:3;
  animation:twinkle 3.4s ease-in-out infinite}
.s1{width:30px;height:30px;top:14%;right:16%;animation-delay:.2s}
.s2{width:20px;height:20px;bottom:20%;left:14%;animation-delay:1.4s}
@keyframes twinkle{0%,100%{transform:scale(1) rotate(0);opacity:.95}
  50%{transform:scale(.7) rotate(20deg);opacity:.5}}
.scroll-cue{position:absolute;left:50%;bottom:22px;transform:translateX(-50%);
  display:flex;flex-direction:column;align-items:center;gap:8px;z-index:1;
  font-size:10.5px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--ink-2)}
.scroll-cue i{width:1px;height:38px;background:var(--line);position:relative;
  overflow:hidden}
.scroll-cue i::after{content:"";position:absolute;left:0;top:0;width:1px;
  height:14px;background:var(--blue);animation:cue 1.8s ease-in-out infinite}
@keyframes cue{0%{transform:translateY(-16px)}100%{transform:translateY(38px)}}

/* ---------- section + heads ---------- */
.section{padding:clamp(64px,8vw,118px) 0}
.section-head{max-width:640px;margin:0 auto clamp(40px,5vw,60px);
  text-align:center}
.eyebrow{display:inline-flex;align-items:center;gap:8px;
  font-size:12px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;
  color:var(--blue-d);margin-bottom:18px;
  background:var(--blue-soft);padding:7px 14px;border-radius:999px}
.eyebrow.center{margin-left:auto;margin-right:auto}
.section-head h2{font-size:clamp(29px,3.7vw,48px)}
.section-sub{margin-top:15px;font-size:16px;color:var(--ink-2)}

/* ---------- benefit cards ---------- */
.cards{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.card{background:#fff;border:1px solid var(--line-w);border-radius:var(--radius);
  padding:30px 26px;box-shadow:var(--shadow-sm);
  transition:transform .22s ease,box-shadow .22s ease}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.card-ic{width:54px;height:54px;border-radius:15px;margin-bottom:22px;
  display:flex;align-items:center;justify-content:center}
.card-ic svg{width:27px;height:27px;fill:none;stroke-width:1.7;
  stroke-linecap:round;stroke-linejoin:round}
.ic-a{background:#E4F0F9}.ic-a svg{stroke:#2E9BDD}
.ic-b{background:#E3F3EC}.ic-b svg{stroke:#37A87E}
.ic-c{background:#FBEEDD}.ic-c svg{stroke:#D49334}
.ic-d{background:#EBE6F7}.ic-d svg{stroke:#7E68C4}
.card h3{font-size:19px;margin-bottom:9px;font-weight:600}
.card p{font-size:14.5px}

/* ---------- science ---------- */
.science{background:var(--white)}
.science-grid{display:grid;grid-template-columns:.95fr 1.05fr;
  gap:clamp(36px,5vw,84px);align-items:center}
.science-media{position:relative;padding:18px}
.disc-sm{position:absolute;width:96%;height:96%;top:2%;left:2%;
  transform:none;background:var(--tint);border-radius:24px}
.science-media img{position:relative;z-index:1;width:100%;
  aspect-ratio:4/3.6;object-fit:cover;border-radius:16px;
  box-shadow:var(--shadow)}
.science-badge{position:absolute;z-index:2;right:-6px;bottom:24px;
  background:#fff;border:1px solid var(--line);border-radius:14px;
  padding:14px 20px;display:flex;flex-direction:column;box-shadow:var(--shadow)}
.science-badge b{font-family:var(--display);font-size:21px;color:var(--blue);
  letter-spacing:.05em}
.science-badge span{font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;
  color:var(--ink-2)}
.spark.s3{top:6%;left:2%;width:26px;height:26px;animation-delay:.6s}
.science-copy h2{font-size:clamp(28px,3.5vw,44px);margin-bottom:18px}
.science-copy>p{font-size:15.5px;margin-bottom:22px}
.science-list{list-style:none;display:flex;flex-direction:column;gap:13px;
  margin-bottom:28px}
.science-list li{display:flex;align-items:center;gap:12px;font-size:15px;
  color:var(--ink);font-weight:500}
.science-list svg{width:20px;height:20px;flex:none;fill:none;stroke:#fff;
  stroke-width:2.6;stroke-linecap:round;stroke-linejoin:round;
  background:var(--blue);border-radius:50%;padding:4px}
.stat-chips{display:flex;gap:12px;flex-wrap:wrap}
.stat-chip{display:flex;flex-direction:column;background:var(--bg);
  border:1px solid var(--line);border-radius:13px;padding:13px 20px;
  font-size:11.5px;letter-spacing:.07em;text-transform:uppercase;
  color:var(--ink-2)}
.stat-chip b{font-family:var(--display);font-size:26px;color:var(--ink);
  line-height:1;text-transform:none;letter-spacing:0}
.stat-chip b i{font-style:normal;font-size:.5em;color:var(--blue)}

/* ---------- buy panel ---------- */
.buy-sec{background:var(--bg-2)}
.buy{display:grid;grid-template-columns:.9fr 1.1fr;
  gap:clamp(26px,3.5vw,58px);align-items:center;
  background:#fff;border:1px solid var(--line-w);border-radius:24px;
  padding:clamp(28px,3.6vw,52px);box-shadow:var(--shadow)}
.buy-media{position:relative;display:flex;align-items:center;
  justify-content:center;min-height:340px}
.disc-buy{position:absolute;width:330px;height:330px;border-radius:50%;
  background:var(--tint);top:50%;left:50%;transform:translate(-50%,-50%)}
.buy-media img{position:relative;z-index:1;max-height:420px;width:auto;
  filter:drop-shadow(0 30px 40px rgba(23,40,66,.3))}
.spark.s4{top:12%;right:14%;width:26px;height:26px;animation-delay:1s}
.stars{font-size:14px;color:var(--blue);letter-spacing:1.5px;margin-bottom:13px}
.stars span{color:var(--ink-2);font-size:12.5px;letter-spacing:.02em;margin-left:6px}
.buy-info h2{font-family:var(--display);font-size:clamp(30px,3.4vw,44px)}
.buy-tag{color:var(--blue-d);font-size:13.5px;font-weight:600;
  letter-spacing:.04em;margin:5px 0 16px}
.buy-desc{font-size:15px;margin-bottom:20px}
.buy-list{list-style:none;display:flex;flex-direction:column;gap:11px;
  margin-bottom:26px}
.buy-list li{display:flex;align-items:center;gap:11px;font-size:14px;
  color:var(--ink)}
.buy-list svg{width:19px;height:19px;flex:none;fill:none;stroke:#fff;
  stroke-width:2.6;stroke-linecap:round;stroke-linejoin:round;
  background:var(--blue);border-radius:50%;padding:4px}
.buy-bar{display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.qty{display:flex;align-items:center;border:1.5px solid var(--line);
  border-radius:999px;overflow:hidden}
.qty-btn{width:42px;height:48px;background:none;border:0;color:var(--ink);
  font-size:18px;cursor:pointer;transition:background .15s ease}
.qty-btn:hover{background:var(--bg)}
.qty input.qty-input,.qty span{width:40px;text-align:center;font-weight:600;color:var(--ink);
  border:0;background:transparent;font-family:var(--body);font-size:15px}
.qty input.qty-input:focus{outline:none}
.qty input.qty-input::-webkit-outer-spin-button,
.qty input.qty-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}
.qty input.qty-input{-moz-appearance:textfield}
.buy-bar .add-to-cart,.buy-bar button[type=submit]{flex:1;min-width:190px}
.buy-reassure{display:flex;align-items:center;gap:7px;margin-top:15px;
  font-size:12.5px;color:var(--ink-2)}
.buy-reassure svg{fill:none;stroke:var(--ink-2);stroke-width:1.7;
  stroke-linecap:round;stroke-linejoin:round;flex:none}

/* ---------- reviews ---------- */
.reviews-score{display:flex;flex-direction:column;align-items:center;gap:6px;
  margin-top:18px}
.reviews-score span{font-size:14px;color:var(--ink-2)}
.reviews-score b{color:var(--ink)}
.review-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.review{background:#fff;border:1px solid var(--line-w);border-radius:var(--radius);
  padding:26px 26px 22px;box-shadow:var(--shadow-sm)}
.r-stars{color:var(--blue);font-size:14px;letter-spacing:1.5px;margin-bottom:12px}
.review p{font-size:14.5px;color:var(--ink);margin-bottom:18px}
.review figcaption{display:flex;align-items:center;gap:10px;
  font-size:12px;color:var(--ink-2);flex-wrap:wrap}
.av{width:24px;height:24px;border-radius:50%;flex:none;
  background:var(--blue-soft);color:var(--blue-d);
  font-family:var(--display);font-weight:600;font-size:12px;
  display:flex;align-items:center;justify-content:center}
.review figcaption .av{width:34px;height:34px;font-size:14px}
.review figcaption b{font-family:var(--body);font-size:14px;color:var(--ink);
  margin-right:auto}

/* ---------- faq ---------- */
.faq-sec{background:var(--bg-2)}
.faq{display:flex;flex-direction:column;gap:12px}
.faq details{background:#fff;border:1px solid var(--line-w);border-radius:14px;
  box-shadow:var(--shadow-sm);transition:box-shadow .2s ease}
.faq summary{display:flex;align-items:center;justify-content:space-between;
  gap:16px;padding:20px 24px;cursor:pointer;list-style:none;
  font-family:var(--display);font-weight:600;font-size:16.5px;color:var(--ink)}
.faq summary::-webkit-details-marker{display:none}
.faq summary i{position:relative;width:14px;height:14px;flex:none}
.faq summary i::before,.faq summary i::after{content:"";position:absolute;
  background:var(--blue);border-radius:2px;transition:transform .25s ease}
.faq summary i::before{top:6px;left:0;width:14px;height:2px}
.faq summary i::after{left:6px;top:0;width:2px;height:14px}
.faq details[open] summary i::after{transform:scaleY(0)}
.faq details p{padding:0 24px 21px;font-size:14.5px;max-width:62ch}

/* ---------- cta band ---------- */
.cta-band{padding:0 0 clamp(64px,8vw,110px)}
.cta-in{position:relative;overflow:hidden;text-align:center;
  display:flex;flex-direction:column;align-items:center;
  background:linear-gradient(140deg,#3ba4e4 0%,#1f7cba 100%);
  border-radius:28px;padding:clamp(44px,5.5vw,80px) clamp(26px,4vw,60px)}
.cta-in .eyebrow{background:rgba(255,255,255,.18);color:#fff}
.cta-in .eyebrow .spark{fill:#fff}
.cta-in h2{color:#fff;font-size:clamp(28px,3.4vw,44px);margin-bottom:12px}
.cta-in p{color:rgba(255,255,255,.92);font-size:15.5px;max-width:48ch;
  margin-bottom:28px}
.cta-actions{display:flex;gap:13px;flex-wrap:wrap;justify-content:center}

/* ---------- footer ---------- */
.site-footer{background:var(--ink);color:rgba(255,255,255,.6);
  padding:clamp(54px,6vw,80px) 0 32px}
.footer-top{display:grid;grid-template-columns:1.7fr 1fr 1fr 1fr;gap:40px;
  padding-bottom:46px;border-bottom:1px solid rgba(255,255,255,.1)}
.footer-brand p{margin:16px 0 20px;font-size:14px;max-width:30em}
.signup{display:flex;gap:8px;max-width:340px}
.signup input{flex:1;background:rgba(255,255,255,.07);
  border:1px solid rgba(255,255,255,.16);border-radius:999px;
  padding:12px 18px;color:#fff;font-family:var(--body);font-size:14px}
.signup input::placeholder{color:rgba(255,255,255,.4)}
.signup input:focus{outline:none;border-color:var(--blue)}
.footer-col h4{font-family:var(--display);font-size:13px;letter-spacing:.05em;
  text-transform:uppercase;color:#fff;margin-bottom:16px;font-weight:600}
.footer-col ul{list-style:none;margin:0;padding:0}
.footer-col li{list-style:none}
.footer-col a{display:block;font-size:14px;color:rgba(255,255,255,.6);
  margin-bottom:11px;transition:color .15s ease}
.footer-col a:hover{color:var(--blue)}
.footer-bottom{display:flex;justify-content:space-between;gap:24px;
  flex-wrap:wrap;padding-top:26px}
.disclaimer{font-size:11.5px;color:rgba(255,255,255,.4);max-width:64ch;
  line-height:1.6}
.copyright{font-size:12.5px;color:rgba(255,255,255,.4);white-space:nowrap}

/* ---------- sticky buy bar ---------- */
.stickybar{position:fixed;left:0;right:0;bottom:0;z-index:90;background:#fff;
  border-top:1px solid var(--line);box-shadow:0 -10px 30px -16px rgba(23,40,66,.3);
  transform:translateY(110%);transition:transform .35s cubic-bezier(.2,.9,.3,1)}
.stickybar.show{transform:translateY(0)}
.stickybar-in{display:flex;align-items:center;justify-content:space-between;
  gap:20px;padding:11px 28px}
.sb-product{display:flex;align-items:center;gap:13px;min-width:0}
.sb-product img{height:46px;width:auto;flex:none}
.sb-product b{font-family:var(--display);font-size:16px;color:var(--ink);
  font-weight:600;display:block}
.sb-product span{font-size:12px;color:var(--ink-2)}

/* ---------- toast ---------- */
.toast{position:fixed;left:50%;bottom:88px;transform:translate(-50%,30px);
  background:var(--ink);color:#fff;font-size:14px;font-weight:600;
  padding:13px 24px;border-radius:999px;z-index:200;
  box-shadow:var(--shadow);opacity:0;
  transition:transform .35s cubic-bezier(.2,.9,.3,1),opacity .3s ease}
.toast.show{transform:translate(-50%,0);opacity:1}

/* ---------- reveal ---------- */
[data-reveal]{opacity:0;transform:translateY(28px);
  transition:opacity .7s ease,transform .7s ease}
[data-reveal].in{opacity:1;transform:none}
.cards .card:nth-child(2),.review-grid .review:nth-child(2){transition-delay:.08s}
.cards .card:nth-child(3),.review-grid .review:nth-child(3){transition-delay:.16s}
.cards .card:nth-child(4){transition-delay:.24s}
.review-grid .review:nth-child(5){transition-delay:.08s}
.review-grid .review:nth-child(6){transition-delay:.16s}

/* ---------- logo image ---------- */
/* High specificity so WooCommerce's `.woocommerce-page img{height:auto}` rule
   can't override us on shop / cart / checkout pages. */
#header .logo-img,
.site-footer .logo-img,
body .logo-img{height:44px;width:auto;display:block;
  filter:brightness(0);transition:filter .25s ease}
.site-footer .footer-logo,
.footer-brand .footer-logo,
body .footer-logo{height:40px;margin-bottom:18px;width:auto;
  filter:brightness(0) invert(1)}

/* ---------- hero orbital motif ---------- */
.orbit{position:relative;width:min(100%,440px);aspect-ratio:1;
  display:flex;align-items:center;justify-content:center;margin:0 auto}
.orbit-ring{position:absolute;border-radius:50%;border:2px dotted}
.orbit-ring.r1{inset:0;border-color:rgba(46,155,221,.45);
  animation:spin 46s linear infinite}
.orbit-ring.r2{inset:19%;border-color:rgba(46,155,221,.3);
  animation:spin 34s linear infinite reverse}
.orbit-disc{position:absolute;inset:29%;border-radius:50%;background:var(--tint)}
@keyframes spin{to{transform:rotate(360deg)}}
.orbit img{position:relative;z-index:2;max-height:362px;width:auto;
  filter:drop-shadow(0 36px 46px rgba(23,40,66,.32))}
.orbit-tag{position:absolute;bottom:9%;right:1%;z-index:4;background:#fff;
  border:1px solid var(--line);border-radius:14px;padding:12px 18px;
  box-shadow:var(--shadow);display:flex;flex-direction:column;
  font-size:11.5px;color:var(--ink-2)}
.orbit-tag b{font-family:var(--display);font-size:15px;color:var(--ink);
  font-weight:600}

/* ---------- featured product ---------- */
.feature{display:grid;grid-template-columns:1fr 1.05fr;
  gap:clamp(26px,3.6vw,58px);align-items:center;background:#fff;
  border:1px solid var(--line-w);border-radius:24px;
  padding:clamp(26px,3.6vw,50px);box-shadow:var(--shadow)}
.feature-media{position:relative;background:var(--tint);border-radius:18px;
  display:flex;align-items:center;justify-content:center;
  padding:clamp(26px,4vw,50px);aspect-ratio:1/.86}
.feature-media img{max-height:330px;width:auto;
  filter:drop-shadow(0 24px 32px rgba(23,40,66,.34))}
.feature-info h3{font-family:var(--display);font-size:clamp(28px,3.3vw,42px);
  margin:4px 0 0}
.feature-desc{font-size:15px;margin:14px 0 20px}
.feature-foot{display:flex;align-items:center;gap:18px;flex-wrap:wrap;
  margin-top:4px;padding-top:22px;border-top:1px solid var(--line)}
.feature-foot .btn{flex:1;min-width:190px}
.feature-foot .price-block{display:flex;flex-direction:column}
.feature-foot .price{font-family:var(--display);font-size:30px;color:var(--ink);font-weight:600;line-height:1}
.feature-foot .price-sub{font-size:12px;color:var(--ink-2);margin-top:4px}
.pc-tag{position:absolute;top:15px;left:15px;background:#fff;border-radius:999px;
  padding:6px 13px;font-size:11px;font-weight:600;letter-spacing:.03em;
  color:var(--blue-d);box-shadow:var(--shadow-sm)}

/* ===================================================================
   dark hero (brand homepage + product page + inner pages)
   =================================================================== */
.hero-dark{
  margin-top:-72px;
  padding-top:calc(72px + clamp(40px,5vw,78px));
  padding-bottom:clamp(78px,9vw,128px);
  color:rgba(255,255,255,.72);
  border-radius:0 0 38px 38px;
  background:
    radial-gradient(56% 48% at 73% 38%,rgba(46,140,206,.36),transparent 64%),
    radial-gradient(46% 40% at 14% 98%,rgba(55,170,233,.14),transparent 62%),
    linear-gradient(180deg,#0C1019 0%,#080A10 100%);
}
.hero-dark::before{content:"";position:absolute;inset:0;border-radius:inherit;
  pointer-events:none;opacity:.05;
  background-image:radial-gradient(rgba(255,255,255,.6) .8px,transparent .9px);
  background-size:30px 30px}
.hd-bg{position:absolute;inset:0;overflow:hidden;border-radius:inherit;
  pointer-events:none}
.hd-glow{position:absolute;border-radius:50%;filter:blur(46px)}
.hd-glow-1{top:2%;right:6%;width:540px;height:540px;
  background:radial-gradient(circle,rgba(55,170,233,.32),transparent 66%)}
.hd-glow-2{bottom:-14%;left:-8%;width:440px;height:440px;
  background:radial-gradient(circle,rgba(90,196,250,.13),transparent 66%)}

.crumb{display:flex;align-items:center;gap:9px;font-size:13px;
  color:rgba(255,255,255,.5);margin-bottom:clamp(20px,3.5vw,38px)}
.crumb a{transition:color .15s ease}
.crumb a:hover{color:#fff}
.crumb .sep{opacity:.4}
.crumb .here{color:#fff;font-weight:600}

.hero-dark h1{color:#fff}
.hero-dark .lede{color:rgba(255,255,255,.68)}
.hero-dark .pill{background:rgba(255,255,255,.07);
  border-color:rgba(255,255,255,.17);color:#fff;backdrop-filter:blur(8px);
  box-shadow:none}
.hero-dark .hero-meta{color:rgba(255,255,255,.7)}
.hero-dark .hero-meta b{color:#fff}
.hero-dark .link-play{color:#fff}
.hero-dark .play{background:rgba(255,255,255,.08);
  border-color:rgba(255,255,255,.18)}
.hero-dark .play svg{color:var(--blue-2)}
.hero-dark .scroll-cue{color:rgba(255,255,255,.5)}
.hero-dark .scroll-cue i{background:rgba(255,255,255,.16)}
.hero-dark .spark{fill:var(--blue-2);
  filter:drop-shadow(0 0 6px rgba(90,196,250,.85))}
.hero-dark .orbit-ring{border-width:2.5px;
  border-color:rgba(125,208,252,.7);
  filter:drop-shadow(0 0 6px rgba(55,170,233,.7))}
.orbit-glow{position:absolute;inset:8%;border-radius:50%;
  background:radial-gradient(circle,rgba(55,170,233,.72),transparent 66%);
  filter:blur(34px)}
.hero-dark .orbit img{filter:drop-shadow(0 32px 46px rgba(0,0,0,.62))
  drop-shadow(0 0 40px rgba(55,170,233,.3))}

/* nav over the dark hero */
body.dark-hero #header:not(.scrolled){border-bottom-color:transparent}
body.dark-hero #header:not(.scrolled) .logo-img{filter:brightness(0) invert(1)}
body.dark-hero #header:not(.scrolled) .nav-links a{color:rgba(255,255,255,.82)}
body.dark-hero #header:not(.scrolled) .nav-links a:hover,
body.dark-hero #header:not(.scrolled) .nav-links li.current-menu-item > a,
body.dark-hero #header:not(.scrolled) .nav-links li.current_page_item > a,
body.dark-hero #header:not(.scrolled) .nav-links a.active{color:#fff}
body.dark-hero #header:not(.scrolled) .cart-btn{color:#fff}
body.dark-hero #header:not(.scrolled) .burger span{background:#fff}
body.dark-hero #header:not(.scrolled) .btn-dark{background:#fff;color:var(--ink)}

/* centered hero (homepage) */
.hero-center{padding-bottom:clamp(98px,11vw,150px)}
.hero-center .hero-inner{position:relative;z-index:1;max-width:800px;
  margin:0 auto;text-align:center;
  display:flex;flex-direction:column;align-items:center}
.hero-center h1{font-size:clamp(40px,5.6vw,74px)}
.hero-center .lede{max-width:36em;margin-left:auto;margin-right:auto}
.hero-center .hero-cta{justify-content:center}
.hero-center .hero-meta{justify-content:center}
.hero-ring{position:absolute;left:50%;top:50%;
  transform:translate(-50%,-50%);border-radius:50%;pointer-events:none;
  border:1.5px dotted rgba(110,200,250,.2)}
.hero-ring.r-a{width:540px;height:540px;animation:spin 64s linear infinite}
.hero-ring.r-b{width:840px;height:840px;
  border-color:rgba(110,200,250,.11);animation:spin 88s linear infinite reverse}

/* ===================================================================
   inner page header
   =================================================================== */
.page-head{position:relative;overflow:hidden;text-align:center;
  margin-top:-72px;
  padding-top:calc(72px + clamp(46px,6vw,84px));
  padding-bottom:clamp(46px,6vw,82px);
  border-radius:0 0 38px 38px;
  background:
    radial-gradient(58% 74% at 50% 2%,rgba(46,140,206,.34),transparent 66%),
    linear-gradient(180deg,#0C1019,#080A10);}
.page-head::before{content:"";position:absolute;inset:0;border-radius:inherit;
  pointer-events:none;opacity:.05;
  background-image:radial-gradient(rgba(255,255,255,.6) .8px,transparent .9px);
  background-size:30px 30px}
.page-head .wrap{position:relative;z-index:1}
.page-head .crumb{justify-content:center;margin-bottom:18px}
.page-head h1{color:#fff;font-size:clamp(33px,4.5vw,56px);letter-spacing:-.03em}
.page-head .lead{color:rgba(255,255,255,.66);font-size:16px;
  margin:15px auto 0;max-width:50ch}
.page-wrap{padding:clamp(60px,8vw,108px) 0}

/* faq page footer prompt */
.faq-more{text-align:center;margin-top:40px}
.faq-more p{font-size:15px;color:var(--ink-2);margin-bottom:14px}

/* contact page */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;
  gap:clamp(34px,5vw,72px);align-items:center}
.contact-copy h2{font-size:clamp(27px,3.3vw,40px);margin-bottom:16px}
.contact-copy p{font-size:15.5px;margin-bottom:24px}
.contact-links{display:flex;flex-direction:column;gap:13px}
.contact-link{display:flex;align-items:center;gap:12px;font-size:15px;
  font-weight:500;color:var(--ink);transition:color .15s ease}
.contact-link:hover{color:var(--blue-d)}
.contact-link.static{cursor:default}
.contact-link.static:hover{color:var(--ink)}
.contact-link svg{width:20px;height:20px;flex:none;fill:none;stroke:var(--blue);
  stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round}
.contact-form{display:flex;flex-direction:column;gap:14px;background:#fff;
  border:1px solid var(--line-w);border-radius:var(--radius);
  padding:clamp(24px,3vw,38px);box-shadow:var(--shadow-sm)}
.field input,.field textarea{width:100%;background:var(--bg);
  border:1px solid var(--line);border-radius:11px;padding:13px 15px;
  color:var(--ink);font-family:var(--body);font-size:14.5px;resize:vertical;
  transition:border-color .18s ease}
.field input::placeholder,.field textarea::placeholder{color:var(--muted)}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--blue)}
.contact-form .form-msg{font-size:14px;padding:12px 14px;border-radius:10px}
.contact-form .form-msg.ok{background:#E3F3EC;color:#1f6e4f}
.contact-form .form-msg.err{background:#FDECEC;color:#a23030}

/* blog */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.post-card{display:flex;flex-direction:column;background:#fff;
  border:1px solid var(--line-w);border-radius:var(--radius);overflow:hidden;
  box-shadow:var(--shadow-sm);color:inherit;
  transition:transform .22s ease,box-shadow .22s ease}
.post-card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.post-media{aspect-ratio:16/10;display:flex;align-items:flex-start;padding:16px;
  background-size:cover;background-position:center}
.post-media.t1{background:linear-gradient(150deg,#d9e7f4,#eceae2)}
.post-media.t2{background:linear-gradient(150deg,#dfeee6,#eceae2)}
.post-media.t3{background:linear-gradient(150deg,#f1e7d6,#eceae2)}
.post-cat{font-size:10.5px;font-weight:600;letter-spacing:.06em;
  text-transform:uppercase;color:var(--blue-d);background:#fff;
  padding:5px 11px;border-radius:999px;box-shadow:var(--shadow-sm)}
.post-body{display:flex;flex-direction:column;flex:1;padding:22px 24px 24px}
.post-date{font-size:12px;color:var(--muted);margin-bottom:9px}
.post-body h3{font-family:var(--display);font-size:18.5px;font-weight:600;
  margin-bottom:8px;line-height:1.3}
.post-body p{font-size:14px;margin-bottom:18px}
.post-more{margin-top:auto;font-size:13.5px;font-weight:600;color:var(--blue-d);
  display:inline-flex;align-items:center;gap:6px}
.post-more svg{width:15px;height:15px;fill:none;stroke:currentColor;
  stroke-width:2;stroke-linecap:round;stroke-linejoin:round;
  transition:transform .18s ease}
.post-card:hover .post-more svg{transform:translateX(3px)}
.more-row{text-align:center;margin-top:clamp(36px,4vw,50px)}
.pagination-row{display:flex;justify-content:center;gap:6px;margin-top:48px}
.pagination-row a,.pagination-row span{padding:8px 14px;border-radius:10px;
  border:1px solid var(--line);color:var(--ink-2);font-size:14px;font-weight:600;
  background:#fff}
.pagination-row .current{background:var(--ink);color:#fff;border-color:var(--ink)}

/* single article */
.article{max-width:740px;margin:0 auto}
.back-link{display:inline-flex;align-items:center;gap:7px;font-size:14px;
  font-weight:600;color:var(--blue-d);margin-bottom:28px}
.back-link svg{width:16px;height:16px;fill:none;stroke:currentColor;
  stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.article-media{aspect-ratio:16/8;border-radius:var(--radius);
  margin-bottom:clamp(28px,4vw,44px);
  background:linear-gradient(150deg,#d9e7f4,#eceae2);
  background-size:cover;background-position:center;overflow:hidden}
.article-body p{font-size:16px;margin-bottom:18px}
.article-body h2{font-family:var(--display);font-size:clamp(22px,2.6vw,30px);
  font-weight:600;margin:36px 0 14px;letter-spacing:-.01em}
.article-body h3{font-family:var(--display);font-size:20px;font-weight:600;
  margin:28px 0 12px}
.article-body ul,.article-body ol{margin:0 0 18px 22px}
.article-body li{font-size:16px;margin-bottom:6px}
.article-body img{border-radius:var(--radius);margin:22px 0}
.article-body a{color:var(--blue-d);text-decoration:underline;text-underline-offset:3px}
.article-body blockquote{margin:28px 0;padding:6px 0 6px 24px;
  border-left:3px solid var(--blue);font-size:18px;line-height:1.55;
  color:var(--ink);font-weight:500}

/* ===================================================================
   WooCommerce block-based cart + checkout
   Targets the wp:woocommerce/cart and wp:woocommerce/checkout blocks
   used by Woo 8.0+ by default.
   =================================================================== */

/* page wrap — sit cart/checkout content inside our content frame */
.woocommerce-cart .site-main,
.woocommerce-checkout .site-main{padding:clamp(48px,6vw,84px) 0 clamp(60px,8vw,108px);
  background:var(--bg)}
.woocommerce-cart .site-main .wrap,
.woocommerce-checkout .site-main .wrap{max-width:1200px}

/* shared block-cart + block-checkout typography */
.wp-block-woocommerce-cart,
.wp-block-woocommerce-checkout{font-family:var(--body);color:var(--ink-2)}
.wp-block-woocommerce-cart h2,
.wp-block-woocommerce-checkout h2{font-family:var(--display);color:var(--ink);
  font-weight:600;letter-spacing:-.01em}

/* ---------- block cart ---------- */
.wc-block-cart{display:grid;grid-template-columns:1.5fr 1fr;gap:clamp(24px,3vw,44px);
  align-items:flex-start}
.wc-block-cart__main,
.wc-block-cart__sidebar{background:#fff;border:1px solid var(--line-w);
  border-radius:var(--radius);padding:clamp(20px,2.5vw,32px);box-shadow:var(--shadow-sm)}
.wc-block-cart-items{border-top:0 !important}
.wc-block-cart-items__header{font-family:var(--display);font-size:12px;
  letter-spacing:.09em;text-transform:uppercase;color:var(--ink-2);
  border-bottom:1px solid var(--line);padding-bottom:14px;margin-bottom:6px}
.wc-block-cart-items__header > th{font-weight:600 !important;color:var(--ink-2) !important;
  background:transparent !important;border:0 !important}
.wc-block-cart-items__row{border-bottom:1px solid var(--line-w) !important;
  padding:18px 0 !important}
.wc-block-cart-items__row:last-child{border-bottom:0 !important}
.wc-block-cart-item__image img,
.wc-block-components-product-image img{border-radius:12px;background:var(--tint);
  padding:8px;max-width:90px;height:auto}
.wc-block-cart-item__product-name,
.wc-block-components-product-name{font-family:var(--display) !important;
  font-size:16.5px !important;font-weight:600 !important;color:var(--ink) !important;
  text-decoration:none !important}
.wc-block-cart-item__product-name:hover,
.wc-block-components-product-name:hover{color:var(--blue-d) !important}
.wc-block-cart-item__product-metadata,
.wc-block-components-product-metadata{font-size:13px;color:var(--ink-2);margin-top:4px}
.wc-block-cart-item__total-price-and-sale-badge-wrapper,
.wc-block-components-product-price{font-family:var(--display);font-weight:600;
  color:var(--ink);font-size:16px}
.wc-block-components-product-price__value{color:var(--ink) !important}

/* qty selector inside cart */
.wc-block-components-quantity-selector{border:1.5px solid var(--line) !important;
  border-radius:999px !important;overflow:hidden;background:#fff;
  display:inline-flex !important;align-items:center;margin-top:8px}
.wc-block-components-quantity-selector__input{border:0 !important;background:transparent !important;
  text-align:center;font-family:var(--body) !important;font-weight:600 !important;
  color:var(--ink) !important;font-size:15px !important;width:40px !important}
.wc-block-components-quantity-selector__button{background:none !important;
  border:0 !important;color:var(--ink) !important;width:36px !important;height:42px !important;
  font-size:18px !important;cursor:pointer;transition:background .15s ease}
.wc-block-components-quantity-selector__button:hover{background:var(--bg) !important}

/* remove link */
.wc-block-cart-item__remove-link{font-size:12.5px !important;color:var(--ink-2) !important;
  text-decoration:underline !important;text-underline-offset:3px;
  transition:color .15s ease;margin-top:8px;display:inline-block}
.wc-block-cart-item__remove-link:hover{color:#cc3030 !important}

/* sidebar — totals */
.wc-block-cart__sidebar h2,
.wc-block-components-totals-wrapper h2{font-size:14px !important;
  letter-spacing:.1em;text-transform:uppercase;color:var(--ink-2) !important;
  font-weight:600;margin-bottom:18px;padding-bottom:14px;
  border-bottom:1px solid var(--line);font-family:var(--body) !important}
.wc-block-components-totals-item{display:flex;justify-content:space-between;
  padding:10px 0 !important;font-size:14.5px;color:var(--ink-2)}
.wc-block-components-totals-item__label{color:var(--ink-2) !important}
.wc-block-components-totals-item__value,
.wc-block-components-totals-footer-item-tax-value{color:var(--ink) !important;
  font-weight:600}
.wc-block-components-totals-footer-item{border-top:1px solid var(--line) !important;
  padding-top:16px !important;margin-top:12px !important;font-size:17px !important}
.wc-block-components-totals-footer-item .wc-block-components-totals-item__label{
  font-family:var(--display);color:var(--ink) !important;font-weight:600;font-size:17px}
.wc-block-components-totals-footer-item .wc-block-components-totals-item__value{
  font-family:var(--display);font-size:22px}

/* coupons accordion */
.wc-block-components-totals-coupon{border-top:1px solid var(--line) !important;
  padding-top:14px;margin-top:14px}
.wc-block-components-panel__button{color:var(--ink-2) !important;font-size:14px !important;
  font-weight:500 !important;background:transparent !important}
.wc-block-components-panel__button:hover{color:var(--ink) !important}

/* checkout button */
.wc-block-cart__submit-container{margin-top:22px}
.wc-block-cart__submit-button,
.wc-block-components-checkout-place-order-button{background:var(--ink) !important;
  color:#fff !important;font-family:var(--body) !important;font-size:16px !important;
  font-weight:600 !important;padding:17px 32px !important;border-radius:999px !important;
  border:0 !important;width:100%;cursor:pointer;
  transition:transform .16s ease,box-shadow .2s ease,background .2s ease;
  text-decoration:none !important;text-align:center;display:inline-flex !important;
  align-items:center;justify-content:center}
.wc-block-cart__submit-button:hover,
.wc-block-components-checkout-place-order-button:hover{transform:translateY(-2px);
  box-shadow:0 14px 30px -10px rgba(23,25,29,.6);color:#fff !important;background:var(--ink) !important}

/* ---------- block checkout ---------- */
.wc-block-checkout{display:grid;grid-template-columns:1.4fr 1fr;
  gap:clamp(24px,3vw,44px);align-items:flex-start}
.wc-block-checkout__main,
.wc-block-checkout__sidebar{background:#fff;border:1px solid var(--line-w);
  border-radius:var(--radius);padding:clamp(22px,2.6vw,34px);box-shadow:var(--shadow-sm)}
.wc-block-components-checkout-step{padding:22px 0 !important;
  border-top:1px solid var(--line-w) !important}
.wc-block-components-checkout-step:first-child,
.wc-block-components-checkout-step--with-step-number:first-of-type{
  border-top:0 !important;padding-top:0 !important}
.wc-block-components-checkout-step__title,
.wc-block-components-title{font-family:var(--display) !important;
  font-size:20px !important;font-weight:600 !important;color:var(--ink) !important;
  letter-spacing:-.01em !important;margin-bottom:6px !important}
.wc-block-components-checkout-step__description{font-size:14px !important;
  color:var(--ink-2) !important;margin-bottom:14px !important}

/* inputs */
.wc-block-components-text-input,
.wc-block-components-textarea{background:#fff !important;
  border:1px solid var(--line) !important;border-radius:11px !important;
  margin:8px 0 !important}
.wc-block-components-text-input input,
.wc-block-components-text-input input.wc-block-components-text-input,
.wc-block-components-textarea{background:var(--bg) !important;
  border:1px solid var(--line) !important;border-radius:11px !important;
  padding:14px 16px !important;color:var(--ink) !important;
  font-family:var(--body) !important;font-size:14.5px !important;
  box-shadow:none !important}
.wc-block-components-text-input input:focus,
.wc-block-components-textarea:focus{border-color:var(--blue) !important;
  outline:none !important;box-shadow:0 0 0 3px rgba(46,155,221,.18) !important}
.wc-block-components-text-input label,
.wc-block-components-form .wc-block-components-text-input label{
  font-size:13px !important;color:var(--ink-2) !important;
  font-weight:500 !important;background:var(--bg) !important;padding:0 4px !important}
.wc-block-components-text-input.is-active label{color:var(--blue-d) !important}

/* select */
.wc-block-components-combobox,
.wc-block-components-select{background:var(--bg) !important;
  border:1px solid var(--line) !important;border-radius:11px !important}
.wc-block-components-select .wc-block-components-select__select,
.wc-block-components-combobox-control input{background:var(--bg) !important;
  border:0 !important;padding:14px 16px !important;color:var(--ink) !important;
  font-family:var(--body) !important;font-size:14.5px !important;
  border-radius:11px !important}

/* checkbox */
.wc-block-components-checkbox__mark{border-color:var(--line) !important;
  border-radius:5px !important;background:#fff !important}
.wc-block-components-checkbox__input:checked + .wc-block-components-checkbox__mark{
  background:var(--blue) !important;border-color:var(--blue) !important}
.wc-block-components-checkbox__label{font-size:14px !important;color:var(--ink-2) !important}

/* shipping/payment radio cards */
.wc-block-components-radio-control__option,
.wc-block-components-radio-control-accordion-option{
  background:var(--bg) !important;border:1px solid var(--line) !important;
  border-radius:12px !important;padding:14px 16px !important;
  margin-bottom:10px !important;transition:border-color .15s ease}
.wc-block-components-radio-control__option-checked,
.wc-block-components-radio-control-accordion-option:has(input:checked){
  border-color:var(--blue) !important;background:var(--blue-soft) !important}
.wc-block-components-radio-control__input{accent-color:var(--blue)}
.wc-block-components-radio-control__label{font-size:14.5px !important;
  font-weight:600 !important;color:var(--ink) !important}
.wc-block-components-radio-control__description{font-size:13px !important;
  color:var(--ink-2) !important}

/* order summary sidebar */
.wc-block-components-order-summary{background:transparent;padding:0}
.wc-block-components-order-summary__title{font-family:var(--display);font-size:18px;
  color:var(--ink);font-weight:600;margin-bottom:14px}
.wc-block-components-order-summary-item{border-bottom:1px solid var(--line-w);
  padding:14px 0;font-size:14px;color:var(--ink-2);display:flex;gap:12px}
.wc-block-components-order-summary-item:last-child{border-bottom:0}
.wc-block-components-order-summary-item__image{flex:0 0 auto;width:60px;height:60px;
  background:var(--tint);border-radius:10px;overflow:hidden}
.wc-block-components-order-summary-item__image img{width:100%;height:100%;
  object-fit:contain;padding:6px}
.wc-block-components-order-summary-item__quantity{color:var(--blue-d);font-weight:700}
.wc-block-components-order-summary-item__description{font-size:12.5px;color:var(--ink-2);
  margin-top:4px;line-height:1.5}

/* notices */
.wc-block-components-notice-banner{background:#fff !important;
  border:1px solid var(--line) !important;border-left:3px solid var(--blue) !important;
  border-radius:12px !important;color:var(--ink) !important;
  font-size:14.5px !important;padding:14px 16px !important;font-family:var(--body) !important}
.wc-block-components-notice-banner.is-error{border-left-color:#cc3030 !important}
.wc-block-components-notice-banner.is-success{border-left-color:#37A87E !important}

/* place-order link/button */
.wc-block-components-checkout-place-order-button__text{color:#fff !important}

/* empty cart */
.wc-block-cart__empty-cart__title{font-family:var(--display);font-size:28px;
  font-weight:600;color:var(--ink);margin-bottom:12px}

/* responsive */
@media (max-width:900px){
	.wc-block-cart,
	.wc-block-checkout{grid-template-columns:1fr;gap:28px}
}

/* ===================================================================
   WooCommerce overrides (legacy shortcode cart/checkout, notices, my-account)
   =================================================================== */
.woocommerce-notices-wrapper:empty{display:none}
.woocommerce-message,.woocommerce-info,.woocommerce-error{
  background:#fff;border:1px solid var(--line);border-left:3px solid var(--blue);
  border-radius:12px;padding:14px 18px;margin-bottom:18px;font-size:14.5px;
  color:var(--ink);list-style:none}
.woocommerce-error{border-left-color:#cc3030}
.woocommerce-message a.button,.woocommerce-info a.button{
  background:var(--ink);color:#fff !important;padding:8px 16px;border-radius:999px;
  font-size:13px;font-weight:600;margin-left:14px;text-decoration:none}
.woocommerce .button,.woocommerce a.button,.woocommerce button.button,
.woocommerce-page .button,.woocommerce-page a.button,.woocommerce-page button.button,
.woocommerce input.button,.woocommerce-page input.button{
  background:var(--ink) !important;color:#fff !important;border:0 !important;
  border-radius:999px !important;padding:14px 26px !important;font-size:15px !important;
  font-weight:600 !important;font-family:var(--body) !important;
  text-transform:none !important;box-shadow:none !important;cursor:pointer;
  transition:transform .16s ease,box-shadow .2s ease}
.woocommerce .button:hover,.woocommerce a.button:hover,.woocommerce button.button:hover{
  transform:translateY(-2px);box-shadow:0 14px 30px -10px rgba(23,25,29,.6)}
.woocommerce .button.alt,.woocommerce button.button.alt,.woocommerce-page .button.alt{
  background:var(--blue) !important}
.woocommerce .button.alt:hover,.woocommerce button.button.alt:hover{
  background:var(--blue-d) !important}
.woocommerce form .form-row{display:flex;flex-direction:column;margin:0 0 14px}
.woocommerce form .form-row label{font-size:13px;color:var(--ink);font-weight:600;
  margin-bottom:6px}
.woocommerce form .form-row input.input-text,
.woocommerce form .form-row textarea,
.woocommerce form .form-row select{
  background:var(--bg);border:1px solid var(--line);border-radius:11px;
  padding:13px 15px;color:var(--ink);font-family:var(--body);font-size:14.5px}
.woocommerce form .form-row input.input-text:focus,
.woocommerce form .form-row textarea:focus{outline:none;border-color:var(--blue)}
.woocommerce table.shop_table{border:1px solid var(--line-w);border-radius:var(--radius);
  background:#fff;border-collapse:separate}
.woocommerce table.shop_table th,.woocommerce table.shop_table td{
  border-color:var(--line-w);padding:14px;font-size:14.5px;color:var(--ink)}
.woocommerce-cart-form,.woocommerce-checkout{font-family:var(--body)}
.woocommerce-cart .cart-collaterals .cart_totals{background:#fff;
  border:1px solid var(--line-w);border-radius:var(--radius);padding:24px;
  box-shadow:var(--shadow-sm)}
.woocommerce .quantity .qty{background:var(--bg);border:1px solid var(--line);
  border-radius:11px;padding:10px 12px;font-family:var(--body);font-size:14.5px;
  color:var(--ink);width:80px}

/* ===================================================================
   responsive
   =================================================================== */
@media (max-width:1000px){
  .hero-grid{grid-template-columns:1fr;gap:34px}
  .hero-visual{order:-1;min-height:380px}
  .hero-visual img{max-height:360px}
  .scroll-cue{display:none}
  .science-grid,.buy,.feature,.contact-grid{grid-template-columns:1fr;gap:40px}
  .science-media{order:-1}
  .buy-media{min-height:auto}
  .buy-media img{max-height:320px}
  .cards{grid-template-columns:repeat(2,1fr)}
  .review-grid,.blog-grid{grid-template-columns:repeat(2,1fr)}
  .footer-top{grid-template-columns:1fr 1fr 1fr 1fr;gap:32px}
  .footer-brand{grid-column:1/-1}
  .orbit{width:min(84%,360px)}
}
@media (max-width:860px){
  .nav-links{position:absolute;top:72px;left:0;right:0;flex-direction:column;
    align-items:stretch;gap:0;background:rgba(244,242,236,.98);
    backdrop-filter:blur(14px);border-bottom:1px solid var(--line);
    max-height:0;overflow:hidden;transition:max-height .3s ease}
  .nav-links.open{max-height:420px}
  .nav-links a{padding:15px 28px;border-top:1px solid var(--line);font-size:15px}
  .nav-links li:first-child a{border-top:0}
  .burger{display:flex}
}
@media (max-width:640px){
  .topbar span:nth-child(5),.topbar i:nth-child(4){display:none}
  .cards,.review-grid,.blog-grid{grid-template-columns:1fr}
  .footer-top{grid-template-columns:1fr 1fr}
  .footer-bottom{flex-direction:column;gap:14px}
  .buy-bar .add-to-cart{flex:1 1 100%}
  .cta-actions .btn{flex:1}
  .btn-sm{display:none}
  .sb-product span{display:none}
}
