/* ═══════════════════════════════════════════════
   TOKENS / VARIABLES
═══════════════════════════════════════════════ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --ink:#0a0a0f; --ink-2:#1a1a24; --ink-3:#2c2c3a;
  --mid:#6b6b80; --silver:#b0b0c0; --fog:#e8e8f0; --ghost:#f4f4f8; --white:#fff;
  --accent:#5b4fff; --accent-h:#4a3ddd; --accent-2:#ff4f7b; --accent-3:#00d4aa;
  --r-s:6px; --r-m:12px; --r-l:20px;
  --sh-s:0 2px 8px rgba(0,0,0,.07); --sh-m:0 8px 32px rgba(0,0,0,.10); --sh-l:0 20px 60px rgba(0,0,0,.14);
  --nav-h:68px; --ff-h:'Poppins',sans-serif; --ff-b:'Poppins',sans-serif; --t:.22s cubic-bezier(.4,0,.2,1);
}
html{scroll-behavior:smooth}
body{font-family:var(--ff-b);background:var(--ghost);color:var(--ink);line-height:1.65;min-height:100vh}
::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--ghost)}::-webkit-scrollbar-thumb{background:var(--accent);border-radius:3px}

/* ═══════════════════════════════════════════════
   NAV
═══════════════════════════════════════════════ */
#nav{position:sticky;top:0;z-index:1000;height:var(--nav-h);background:rgba(255,255,255,.9);backdrop-filter:blur(20px);border-bottom:1px solid var(--fog);display:flex;align-items:center;padding:0 clamp(16px,4vw,48px);gap:12px}
.nav-logo{font-family:var(--ff-h);font-size:1.25rem;font-weight:500;color:var(--ink);text-decoration:none;display:flex;align-items:center;gap:8px;margin-right:auto}
.nav-logo span{color:var(--accent)}
.nav-links{display:flex;gap:4px;list-style:none}
.nav-links a{font-size:.875rem;font-weight:500;color:var(--mid);text-decoration:none;padding:6px 14px;border-radius:var(--r-s);transition:color var(--t),background var(--t)}
.nav-links a:hover,.nav-links a.active{color:var(--accent);background:rgba(91,79,255,.08)}
.cart-btn{background:var(--accent);color:var(--white);border:none;border-radius:var(--r-m);padding:10px 20px;font-family:var(--ff-b);font-size:.875rem;font-weight:500;cursor:pointer;display:flex;align-items:center;gap:8px;transition:background var(--t),transform var(--t),box-shadow var(--t)}
.cart-btn:hover{background:var(--accent-h);transform:translateY(-1px);box-shadow:0 4px 16px rgba(91,79,255,.4)}
.cart-badge{background:var(--accent-2);color:white;border-radius:100px;font-size:.7rem;font-weight:500;padding:1px 6px;min-width:18px;text-align:center;display:none}
.cart-badge.show{display:inline-block}
.nav-toggle{display:none;background:none;border:none;cursor:pointer;color:var(--ink);font-size:1.4rem}
@media(max-width:768px){.nav-links{display:none;position:absolute;top:var(--nav-h);left:0;right:0;background:white;flex-direction:column;padding:16px;border-bottom:1px solid var(--fog);box-shadow:var(--sh-m);gap:4px}.nav-links.open{display:flex}.nav-toggle{display:block}}

/* ═══════════════════════════════════════════════
   LAYOUT HELPERS
═══════════════════════════════════════════════ */
.section{padding:clamp(60px,8vw,100px) clamp(16px,5vw,80px);max-width:1280px;margin:0 auto}
.section-label{font-size:.73rem;font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:var(--accent);margin-bottom:10px}
.section-header{margin-bottom:48px;text-align:center}
.section-header h2{font-family:var(--ff-h);font-size:clamp(1.6rem,3.5vw,2.4rem);font-weight:500;line-height:1.2;letter-spacing:-.02em}
.section-header p{margin-top:10px;color:var(--mid);max-width:520px;margin-left:auto;margin-right:auto}
@media(max-width:640px){.section-header{text-align:left}.section-header p{margin-left:0;margin-right:0}}

/* ═══════════════════════════════════════════════
   BUTTONS
═══════════════════════════════════════════════ */
.btn-primary{background:var(--accent);color:white;border:none;border-radius:var(--r-m);padding:14px 32px;font-family:var(--ff-b);font-size:1rem;font-weight:500;cursor:pointer;text-decoration:none;display:inline-block;transition:background var(--t),transform var(--t),box-shadow var(--t)}
.btn-primary:hover{background:var(--accent-h);transform:translateY(-2px);box-shadow:0 8px 24px rgba(91,79,255,.5)}
.btn-ghost{background:rgba(255,255,255,.08);color:white;border:1px solid rgba(255,255,255,.18);border-radius:var(--r-m);padding:14px 32px;font-family:var(--ff-b);font-size:1rem;font-weight:500;cursor:pointer;text-decoration:none;display:inline-block;transition:background var(--t),transform var(--t)}
.btn-ghost:hover{background:rgba(255,255,255,.15);transform:translateY(-2px)}
.btn-outline{background:transparent;color:var(--accent);border:1.5px solid var(--accent);border-radius:var(--r-m);padding:13px 30px;font-family:var(--ff-b);font-size:1rem;font-weight:500;cursor:pointer;text-decoration:none;display:inline-block;transition:all var(--t)}
.btn-outline:hover{background:var(--accent);color:white;transform:translateY(-1px)}

/* ═══════════════════════════════════════════════
   PRODUCT CARD
═══════════════════════════════════════════════ */
.product-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(100%,280px),1fr));gap:22px}
.product-card{background:var(--white);border:1px solid var(--fog);border-radius:var(--r-l);display:flex;flex-direction:column;transition:transform var(--t),box-shadow var(--t),border-color var(--t);position:relative;overflow:hidden;text-decoration:none;color:inherit}
.product-card::after{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--accent),var(--accent-2));transform:scaleX(0);transform-origin:left;transition:transform var(--t)}
.product-card:hover{transform:translateY(-4px);box-shadow:var(--sh-l);border-color:rgba(91,79,255,.2)}
.product-card:hover::after{transform:scaleX(1)}
.card-img{width:100%;aspect-ratio:16/9;overflow:hidden;position:relative;background:var(--ink-2)}
.card-img img{width:100%;height:100%;object-fit:unset!important;display:block;transition:transform .4s ease}
.product-card:hover .card-img img{transform:scale(1.04)}
.card-img-placeholder{width:100%;aspect-ratio:16/9;display:flex;align-items:center;justify-content:center;font-family:var(--ff-h);font-size:1.1rem;font-weight:500;color:rgba(255,255,255,.7);letter-spacing:.05em}
.card-badge{position:absolute;top:12px;right:12px;font-size:.68rem;font-weight:500;letter-spacing:.05em;text-transform:uppercase;background:var(--accent-2);color:white;border-radius:100px;padding:3px 10px;z-index:2}
.card-badge.sale{background:linear-gradient(135deg,#ff6b35,#f7c59f);color:var(--ink)}
.card-badge.new-b{background:var(--accent-3);color:var(--ink)}
.card-body{padding:22px 24px 24px;flex:1;display:flex;flex-direction:column}
.card-type-tag{font-size:.68rem;font-weight:500;letter-spacing:.1em;text-transform:uppercase;margin-bottom:5px}
.card-name{font-family:var(--ff-h);font-size:1.05rem;font-weight:500;margin-bottom:6px;line-height:1.3}
.card-tagline{font-size:.85rem;color:var(--mid);line-height:1.55;flex:1;margin-bottom:14px}
.card-feats{list-style:none;display:flex;flex-direction:column;gap:3px;margin-bottom:18px}
.card-feats li{font-size:.78rem;color:var(--mid);display:flex;align-items:center;gap:6px}
.card-feats li::before{content:'✓';color:var(--accent-3);font-weight:500}
.card-footer{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-top:auto}
.card-price{font-family:var(--ff-h);font-size:1.45rem;font-weight:500}
.card-price sup{font-size:.72rem;font-weight:500;vertical-align:top;margin-top:5px;display:inline-block}
.btn-add{background:var(--ink);color:white;border:none;border-radius:var(--r-s);padding:9px 16px;font-size:.82rem;font-weight:500;cursor:pointer;transition:background var(--t),transform var(--t);white-space:nowrap}
.btn-add:hover{background:var(--accent);transform:translateY(-1px)}
.btn-add.added{background:var(--accent-3);color:var(--ink)}

/* ═══════════════════════════════════════════════
   FILTER TABS
═══════════════════════════════════════════════ */
.filter-tabs{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:36px}
.filter-tab{background:var(--white);border:1px solid var(--fog);border-radius:100px;padding:7px 18px;font-size:.83rem;font-weight:500;cursor:pointer;transition:all var(--t);color:var(--mid)}
.filter-tab:hover{border-color:var(--accent);color:var(--accent)}
.filter-tab.active{background:var(--accent);border-color:var(--accent);color:white}

/* ═══════════════════════════════════════════════
   PAGE HERO
═══════════════════════════════════════════════ */
.page-hero{background:var(--ink);color:white;padding:clamp(60px,8vw,100px) clamp(16px,5vw,80px);position:relative;overflow:hidden;text-align:center}
.page-hero::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 80% 60% at 50% 50%,rgba(91,79,255,.35) 0%,transparent 70%)}
.page-hero-inner{position:relative;z-index:1;max-width:760px;margin:0 auto}
.page-eyebrow{font-size:.73rem;font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:var(--accent-3);margin-bottom:12px}
.page-hero h1{font-family:var(--ff-h);font-size:clamp(2rem,5vw,3.2rem);font-weight:500;line-height:1.1;letter-spacing:-.02em}
.page-hero p{margin-top:14px;color:rgba(255,255,255,.6);max-width:520px;margin-left:auto;margin-right:auto}

/* ═══════════════════════════════════════════════
   PROSE
═══════════════════════════════════════════════ */
.prose{max-width:780px;margin:0 auto;padding:clamp(48px,6vw,80px) clamp(16px,5vw,48px)}
.prose h2{font-family:var(--ff-h);font-size:1.4rem;font-weight:500;margin-top:40px;margin-bottom:10px}
.prose h3{font-family:var(--ff-h);font-size:1.1rem;font-weight:500;margin-top:28px;margin-bottom:8px}
.prose p{color:var(--mid);margin-bottom:16px}
.prose ul{color:var(--mid);padding-left:24px;margin-bottom:16px}
.prose ul li{margin-bottom:6px}
.prose a{color:var(--accent);text-decoration:none}
.prose a:hover{text-decoration:underline}
.prose .updated{font-size:.8rem;color:var(--silver);margin-bottom:32px}

/* ═══════════════════════════════════════════════
   CART SIDEBAR
═══════════════════════════════════════════════ */
#cart-overlay{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:1998;opacity:0;pointer-events:none;transition:opacity var(--t)}
#cart-overlay.open{opacity:1;pointer-events:all}
#cart-sidebar{position:fixed;top:0;right:0;bottom:0;width:min(420px,100vw);background:var(--white);z-index:1999;display:flex;flex-direction:column;transform:translateX(100%);transition:transform .3s cubic-bezier(.4,0,.2,1);box-shadow:-8px 0 40px rgba(0,0,0,.15)}
#cart-sidebar.open{transform:translateX(0)}
.cart-head{padding:24px;border-bottom:1px solid var(--fog);display:flex;align-items:center;justify-content:space-between}
.cart-head h3{font-family:var(--ff-h);font-size:1.2rem;font-weight:500}
.cart-close{background:var(--ghost);border:none;width:36px;height:36px;border-radius:50%;cursor:pointer;font-size:1.1rem;display:flex;align-items:center;justify-content:center;transition:background var(--t)}
.cart-close:hover{background:var(--fog)}
.cart-items{flex:1;overflow-y:auto;padding:20px 24px;display:flex;flex-direction:column;gap:16px}
.cart-empty-msg{text-align:center;padding:60px 20px;color:var(--silver)}
.cart-empty-msg .icon{font-size:3rem;margin-bottom:12px}
.cart-item{display:flex;gap:14px;align-items:flex-start;padding:14px;background:var(--ghost);border-radius:var(--r-m);border:1px solid var(--fog)}
.ci-thumb{width:52px;height:36px;border-radius:6px;overflow:hidden;flex-shrink:0;background:var(--ink-2)}
.ci-thumb img{width:100%;height:100%;object-fit:cover;display:block}
.ci-info{flex:1}
.ci-name{font-size:.875rem;font-weight:500;margin-bottom:2px}
.ci-price{font-size:.78rem;color:var(--mid)}
.ci-controls{display:flex;align-items:center;gap:8px;margin-top:7px}
.qty-btn{width:26px;height:26px;background:var(--white);border:1px solid var(--fog);border-radius:6px;cursor:pointer;font-size:.95rem;display:flex;align-items:center;justify-content:center;transition:border-color var(--t)}
.qty-btn:hover{border-color:var(--accent);color:var(--accent)}
.qty-val{font-size:.85rem;font-weight:500;min-width:20px;text-align:center}
.ci-remove{background:none;border:none;cursor:pointer;color:var(--silver);font-size:.85rem;margin-left:auto;transition:color var(--t)}
.ci-remove:hover{color:var(--accent-2)}
.cart-foot{padding:20px 24px;border-top:1px solid var(--fog)}
.cart-total-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}
.cart-total-row span{font-size:.9rem;color:var(--mid)}
.cart-total-row strong{font-family:var(--ff-h);font-size:1.5rem;font-weight:500}
.btn-stripe{width:100%;background:var(--accent);color:white;border:none;border-radius:var(--r-m);padding:16px;font-size:1rem;font-weight:500;cursor:pointer;transition:background var(--t),transform var(--t);display:flex;align-items:center;justify-content:center;gap:8px}
.btn-stripe:hover{background:var(--accent-h);transform:translateY(-1px)}
.stripe-note{text-align:center;font-size:.75rem;color:var(--silver);margin-top:10px}

/* ═══════════════════════════════════════════════
   TOAST
═══════════════════════════════════════════════ */
#toast-stack{position:fixed;top:24px;right:24px;display:flex;flex-direction:column;gap:10px;z-index:9999}
.toast{background:var(--ink);color:white;border-radius:var(--r-m);padding:14px 20px;font-size:.875rem;font-weight:500;display:flex;align-items:center;gap:10px;box-shadow:var(--sh-l);animation:slideIn .25s ease;max-width:320px}
.toast.success{border-left:3px solid var(--accent-3)}
.toast.error{border-left:3px solid var(--accent-2)}
@keyframes slideIn{from{opacity:0;transform:translateX(20px)}to{opacity:1;transform:none}}
@keyframes fadeUp{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}

/* ═══════════════════════════════════════════════
   TYPE COLOURS / BADGES
═══════════════════════════════════════════════ */
.type-micro{color:#ef4444}.type-theme{color:#8b5cf6}.type-addon{color:#0ea5e9}.type-uikit{color:#10b981}.type-bundle{color:#f59e0b}
.badge-micro{background:#ef4444}.badge-theme{background:#8b5cf6}.badge-addon{background:#0ea5e9}.badge-uikit{background:#10b981}.badge-bundle{background:#f59e0b}

/* ═══════════════════════════════════════════════
   HERO OVERLAYS / GRADIENTS
═══════════════════════════════════════════════ */
.hero-glow{position:absolute;inset:0;background:radial-gradient(ellipse 80% 60% at 50% -10%,rgba(91,79,255,.55) 0%,transparent 70%),radial-gradient(ellipse 60% 40% at 80% 80%,rgba(255,79,123,.3) 0%,transparent 60%)}
.animate-pulse-dot{animation:pulse 2s infinite}

/* ═══════════════════════════════════════════════
   BREADCRUMB
═══════════════════════════════════════════════ */
.breadcrumb-link{color:var(--mid);text-decoration:none;transition:color var(--t)}
.breadcrumb-link:hover{color:var(--accent)}

/* ═══════════════════════════════════════════════
   FOOTER LINKS
═══════════════════════════════════════════════ */
.footer-link{font-size:.875rem;color:rgba(255,255,255,.6);text-decoration:none;transition:color .2s}
.footer-link:hover{color:white}

/* ═══════════════════════════════════════════════
   NEWSLETTER BUTTON SPINNER
═══════════════════════════════════════════════ */
.btn-loading{position:relative;color:transparent!important;pointer-events:none}
.btn-loading::after{content:'';position:absolute;width:16px;height:16px;top:50%;left:50%;margin:-8px 0 0 -8px;border:2px solid rgba(255,255,255,.35);border-top-color:white;border-radius:50%;animation:btn-spin .6s linear infinite}
@keyframes btn-spin{to{transform:rotate(360deg)}}

/* ═══════════════════════════════════════════════
   AIRWALLEX PAYMENT MODAL
═══════════════════════════════════════════════ */
.aw-modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.55);backdrop-filter:blur(4px);z-index:2000;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .25s}
.aw-modal-overlay.open{opacity:1;pointer-events:auto}
.aw-modal{background:var(--white);border-radius:var(--r-l);padding:32px;width:min(520px,94vw);max-height:90vh;overflow-y:auto;box-shadow:var(--sh-l);transform:translateY(12px);transition:transform .25s}
.aw-modal-overlay.open .aw-modal{transform:translateY(0)}
.aw-modal-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}
.aw-modal-title{font-family:var(--ff-h);font-size:1.05rem;font-weight:500;color:var(--ink)}
.aw-modal-close{background:none;border:none;cursor:pointer;color:var(--mid);padding:4px;border-radius:var(--r-s);display:flex;align-items:center;justify-content:center;transition:color var(--t),background var(--t)}
.aw-modal-close:hover{color:var(--ink);background:var(--ghost)}
.aw-loading{display:flex;align-items:center;justify-content:center;min-height:180px}
.aw-spinner{width:32px;height:32px;border:3px solid var(--fog);border-top-color:var(--accent);border-radius:50%;animation:btn-spin .7s linear infinite}

/* ═══════════════════════════════════════════════
   SHOP FULFILLMENT STRIP
═══════════════════════════════════════════════ */
.shop-fulfillment-strip{display:flex;align-items:center;gap:8px;font-size:.8rem;color:var(--mid);background:var(--white);border:1px solid var(--fog);border-radius:var(--r-s);padding:10px 16px;margin-bottom:28px}
.shop-fulfillment-strip svg{flex-shrink:0;color:var(--accent);opacity:.75}

/* ═══════════════════════════════════════════════
   CHECKOUT REASSURANCE
═══════════════════════════════════════════════ */
.checkout-reassurance{list-style:none;display:flex;flex-direction:column;gap:7px;margin-top:14px;padding:14px 16px;background:var(--ghost);border:1px solid var(--fog);border-radius:var(--r-s)}
.checkout-reassurance li{display:flex;align-items:center;gap:7px;font-size:.76rem;color:var(--mid);line-height:1.4}
.checkout-reassurance svg{flex-shrink:0;color:var(--accent);opacity:.75}
.checkout-reassurance-link{color:var(--mid);text-decoration:underline;text-underline-offset:2px;transition:color var(--t)}
.checkout-reassurance-link:hover{color:var(--accent)}

/* ═══════════════════════════════════════════════
   CHECKOUT
═══════════════════════════════════════════════ */
.checkout-grid{display:grid;grid-template-columns:1fr 380px;gap:32px;align-items:start}
@media(max-width:720px){.checkout-grid{grid-template-columns:1fr}}
.checkout-input{width:100%;padding:11px 14px;border:1.5px solid var(--fog);border-radius:var(--r-s);font-family:var(--ff-b);font-size:.9rem;color:var(--ink);background:#fff;outline:none;transition:border-color var(--t)}
.checkout-input:focus{border-color:var(--accent)}

/* ═══════════════════════════════════════════════
   UTILS
═══════════════════════════════════════════════ */
.text-center{text-align:center}
.mt-8{margin-top:8px}.mt-16{margin-top:16px}.mt-24{margin-top:24px}.mt-32{margin-top:32px}
.text-mid{color:var(--mid)}
/* Token color utilities — defined here so Tailwind CDN ambiguity never matters */
.bg-ink{background-color:var(--ink)}.bg-ink-2{background-color:var(--ink-2)}.bg-ink-3{background-color:var(--ink-3)}
.text-ink{color:var(--ink)}.text-ink-2{color:var(--ink-2)}.text-ink-3{color:var(--ink-3)}
.bg-accent{background-color:var(--accent)}.bg-accent-2{background-color:var(--accent-2)}.bg-accent-3{background-color:var(--accent-3)}
.text-accent{color:var(--accent)}.text-accent-2{color:var(--accent-2)}.text-accent-3{color:var(--accent-3)}
.bg-fog{background-color:var(--fog)}.bg-ghost{background-color:var(--ghost)}.bg-white{background-color:var(--white)}
.border-fog{border-color:var(--fog)}.border-accent{border-color:var(--accent)}
@media(max-width:640px){.footer-grid{grid-template-columns:1fr!important;gap:32px!important}}

/* ═══════════════════════════════════════════════
   FAQ (home page)
═══════════════════════════════════════════════ */
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.3}}
.faq-list{max-width:720px;margin:0 auto}
.faq-item{border-bottom:1px solid var(--fog);padding:4px 0}
.faq-item:first-child{border-top:1px solid var(--fog)}
.faq-q{display:flex;justify-content:space-between;align-items:center;gap:16px;padding:20px 0;font-family:var(--ff-h);font-size:1rem;font-weight:500;cursor:pointer;list-style:none;user-select:none}
.faq-q::-webkit-details-marker{display:none}
.faq-icon{width:20px;height:20px;border-radius:50%;border:1.5px solid var(--fog);flex-shrink:0;position:relative;transition:border-color .2s}
.faq-icon::before,.faq-icon::after{content:'';position:absolute;background:var(--mid);border-radius:2px;transition:transform .25s,opacity .25s}
.faq-icon::before{width:8px;height:1.5px;top:50%;left:50%;transform:translate(-50%,-50%)}
.faq-icon::after{width:1.5px;height:8px;top:50%;left:50%;transform:translate(-50%,-50%)}
.faq-item[open] .faq-icon::after{transform:translate(-50%,-50%) rotate(90deg);opacity:0}
.faq-item[open] .faq-q{color:var(--accent)}
.faq-item[open] .faq-icon{border-color:var(--accent)}
.faq-item[open] .faq-icon::before{background:var(--accent)}
.faq-a{padding-bottom:20px}
.faq-a p{font-size:.925rem;color:var(--mid);line-height:1.75;margin:0}

/* ═══════════════════════════════════════════════
   HOME NEWSLETTER
═══════════════════════════════════════════════ */
.home-newsletter{background:var(--white);border:1px solid var(--fog);border-radius:var(--r-l);padding:clamp(32px,5vw,56px);display:grid;grid-template-columns:1fr 1fr;gap:clamp(24px,4vw,64px);align-items:center}
.home-newsletter-text .section-label{margin-bottom:10px}
.home-newsletter-text h2{font-family:var(--ff-h);font-size:clamp(1.3rem,2.5vw,1.8rem);font-weight:500;line-height:1.25;letter-spacing:-.02em;margin-bottom:10px}
.home-newsletter-text p{font-size:.9rem;color:var(--mid);line-height:1.7;margin:0}
.home-newsletter-form{display:flex;gap:10px}
.home-newsletter-form .checkout-input{flex:1}
@media(max-width:640px){.home-newsletter{grid-template-columns:1fr}.home-newsletter-form{flex-direction:column}}

/* ═══════════════════════════════════════════════
   CONTACT
═══════════════════════════════════════════════ */
.contact-icon-wrap{width:44px;height:44px;border-radius:50%;background:rgba(91,79,255,.08);color:var(--accent);display:flex;align-items:center;justify-content:center;margin-bottom:12px;flex-shrink:0}

/* ═══════════════════════════════════════════════
   ABOUT PAGE
═══════════════════════════════════════════════ */
.about-img-pair{display:grid;grid-template-columns:1fr 1fr;gap:3px;border-radius:var(--r-l);overflow:hidden}
.about-img-wrap{position:relative;overflow:hidden;background:linear-gradient(135deg,var(--ink-2),var(--ink-3))}
.about-img-wrap>img{width:100%;height:100%;object-fit:cover;display:block}
.about-img-overlay{position:absolute;inset:0;background:linear-gradient(to bottom,transparent 40%,rgba(0,0,0,.25) 100%)}
@media(max-width:540px){.about-img-pair{grid-template-columns:1fr;gap:3px}.about-img-wrap:first-child{border-radius:var(--r-l) var(--r-l) 0 0}.about-img-wrap:last-child{border-radius:0 0 var(--r-l) var(--r-l)}}
.about-stats-card{display:grid;grid-template-columns:1fr 1fr;background:var(--ink-2);border-radius:var(--r-l);overflow:hidden;aspect-ratio:4/3}
.about-stat{display:flex;flex-direction:column;justify-content:center;padding:28px;border-right:1px solid rgba(255,255,255,.07);border-bottom:1px solid rgba(255,255,255,.07)}
.about-stat:nth-child(2){border-right:none}
.about-stat:nth-child(3){border-bottom:none}
.about-stat:nth-child(4){border-right:none;border-bottom:none}
.about-stat strong{font-family:var(--ff-h);font-size:clamp(1.4rem,3vw,2rem);font-weight:500;color:white;margin-bottom:4px}
.about-stat span{font-size:.78rem;color:rgba(255,255,255,.45);text-transform:uppercase;letter-spacing:.07em;line-height:1.4}
.about-badges{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.about-badge{display:flex;flex-direction:column;align-items:center;text-align:center;padding:24px 16px;background:var(--white);border:1px solid var(--fog);border-radius:var(--r-m)}
.about-badge-icon{width:44px;height:44px;border-radius:50%;background:rgba(91,79,255,.08);color:var(--accent);display:flex;align-items:center;justify-content:center;margin-bottom:12px}
.about-badge strong{display:block;font-family:var(--ff-h);font-size:1.1rem;font-weight:500;color:var(--ink);margin-bottom:4px}
.about-badge span{font-size:.8rem;color:var(--mid)}
@media(max-width:540px){.about-badges{grid-template-columns:1fr}}
.about-block .section-label{margin-bottom:10px}
.about-block h2{font-family:var(--ff-h);font-size:clamp(1.4rem,3vw,1.9rem);font-weight:500;line-height:1.25;letter-spacing:-.02em;margin-bottom:20px}
.about-block p{font-size:.975rem;color:var(--mid);line-height:1.85;margin-bottom:16px}
.about-block p:last-child{margin-bottom:0}
.about-principles{display:flex;flex-direction:column;gap:16px;margin-top:28px}
.about-principle{display:grid;grid-template-columns:36px 1fr;gap:16px;align-items:start;padding:24px;background:var(--white);border:1px solid var(--fog);border-radius:var(--r-m)}
.about-principle-num{font-family:var(--ff-h);font-size:.75rem;font-weight:500;letter-spacing:.1em;color:var(--accent);padding-top:2px}
.about-principle h3{font-family:var(--ff-h);font-size:.95rem;font-weight:500;margin-bottom:6px}
.about-principle p{font-size:.875rem;color:var(--mid);line-height:1.8;margin:0}
.about-newsletter{background:var(--white);border:1px solid var(--fog);border-radius:var(--r-l);padding:36px}
.about-newsletter .section-label{margin-bottom:10px}
.about-newsletter h2{font-family:var(--ff-h);font-size:clamp(1.2rem,2.5vw,1.6rem);font-weight:500;line-height:1.25;letter-spacing:-.02em;margin-bottom:10px}
.about-newsletter p{font-size:.9rem;color:var(--mid);line-height:1.7;margin-bottom:24px}
.about-newsletter-form{display:flex;gap:10px}
.about-newsletter-form .checkout-input{flex:1}
@media(max-width:480px){.about-newsletter-form{flex-direction:column}}
.about-cta{position:relative;overflow:hidden;background:var(--ink-2);color:white;padding:clamp(56px,8vw,96px) clamp(16px,5vw,80px);border-top:1px solid rgba(255,255,255,.06)}
.about-cta-glow{position:absolute;inset:0;background:radial-gradient(ellipse 70% 80% at 20% 50%,rgba(91,79,255,.35) 0%,transparent 65%),radial-gradient(ellipse 50% 60% at 80% 50%,rgba(255,79,123,.2) 0%,transparent 60%);pointer-events:none}
.about-cta-inner{position:relative;z-index:1;max-width:1200px;margin:0 auto;display:grid;grid-template-columns:1fr auto;gap:48px;align-items:center}
.about-cta h2{font-family:var(--ff-h);font-size:clamp(1.6rem,3vw,2.2rem);font-weight:500;margin-bottom:12px}
.about-cta p{font-size:.975rem;color:rgba(255,255,255,.55);line-height:1.75;max-width:600px;margin:0}
.about-cta-actions{display:flex;flex-direction:column;gap:12px;flex-shrink:0}
@media(max-width:860px){.about-cta-inner{grid-template-columns:1fr}.about-cta-actions{flex-direction:row;flex-wrap:wrap}}

/* ═══════════════════════════════════════════════
   PRODUCT PAGE
═══════════════════════════════════════════════ */
.product-hero{background:var(--ink);color:white;padding:clamp(60px,8vw,100px) clamp(16px,5vw,80px)}
.product-hero-grid{display:grid;grid-template-columns:1fr 420px;gap:64px;max-width:1200px;margin:0 auto;align-items:start}
@media(max-width:900px){.product-hero-grid{grid-template-columns:1fr}}
.product-main-img{width:100%;border-radius:var(--r-l);overflow:hidden;aspect-ratio:16/9;position:relative}
.product-main-img img{width:100%;height:100%;display:block}
.buy-card{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);border-radius:var(--r-l);padding:32px;position:sticky;top:calc(var(--nav-h) + 24px)}
.buy-price{font-family:var(--ff-h);font-size:3rem;font-weight:500;line-height:1;margin-bottom:8px}
.buy-price sup{font-size:1.2rem;font-weight:500;vertical-align:top;margin-top:10px;display:inline-block}
.buy-tagline{font-size:.9rem;color:rgba(255,255,255,.55);margin-bottom:24px}
.btn-buy{width:100%;background:var(--accent);color:white;border:none;border-radius:var(--r-m);padding:18px;font-family:var(--ff-b);font-size:1.05rem;font-weight:500;cursor:pointer;transition:background var(--t),transform var(--t),box-shadow var(--t);margin-bottom:12px}
.btn-buy:hover{background:var(--accent-h);transform:translateY(-2px);box-shadow:0 8px 32px rgba(91,79,255,.5)}
.btn-buy.added{background:var(--accent-3);color:var(--ink)}
.btn-view-cart{width:100%;background:transparent;color:rgba(255,255,255,.7);border:1px solid rgba(255,255,255,.2);border-radius:var(--r-m);padding:14px;font-family:var(--ff-b);font-size:.9rem;font-weight:500;cursor:pointer;transition:all var(--t);display:none}
.btn-view-cart.show{display:block}
.btn-view-cart:hover{background:rgba(255,255,255,.1);color:white}
.buy-meta{margin-top:20px;display:flex;flex-direction:column;gap:10px}
.buy-meta-row{display:flex;align-items:center;gap:10px;font-size:.85rem;color:rgba(255,255,255,.5)}
.buy-meta-row span:first-child{font-size:1.1rem}
.product-info{padding:clamp(48px,6vw,80px) clamp(16px,5vw,80px)}
.product-info-grid{display:grid;grid-template-columns:1fr 380px;gap:64px;max-width:1200px;margin:0 auto;align-items:start}
@media(max-width:900px){.product-info-grid{grid-template-columns:1fr}}
.feat-list{list-style:none;display:flex;flex-direction:column;gap:10px;margin-top:20px}
.feat-list li{display:flex;align-items:flex-start;gap:12px;font-size:.95rem;color:var(--mid);padding:12px 16px;background:var(--white);border:1px solid var(--fog);border-radius:var(--r-s)}
.feat-list li::before{content:'✓';color:var(--accent-3);font-weight:500;font-size:1rem;flex-shrink:0;margin-top:1px}
.includes-list{list-style:none;display:flex;flex-direction:column;gap:8px;margin-top:16px}
.includes-list li{display:flex;align-items:center;gap:10px;font-size:.9rem;color:var(--mid);padding:10px 14px;background:rgba(91,79,255,.04);border:1px solid rgba(91,79,255,.1);border-radius:var(--r-s)}
.includes-list li::before{content:'📦';font-size:.9rem}
.related-section{background:var(--white);padding:clamp(60px,8vw,100px) clamp(16px,5vw,80px);border-top:1px solid var(--fog)}
.related-section .inner{max-width:1280px;margin:0 auto}
.files-list{list-style:none;display:flex;flex-direction:column;gap:6px;margin-top:12px}
.files-list li{font-size:.875rem;color:var(--mid);padding:8px 12px;background:var(--ghost);border:1px solid var(--fog);border-radius:var(--r-s);font-family:monospace;letter-spacing:.01em}
.licence-block{display:flex;align-items:flex-start;gap:10px;margin-top:16px;padding:14px 16px;background:rgba(91,79,255,.04);border:1px solid rgba(91,79,255,.12);border-radius:var(--r-s);color:var(--accent)}
.licence-block div{display:flex;flex-direction:column;gap:2px}
.licence-block strong{font-size:.78rem;font-weight:600;text-transform:uppercase;letter-spacing:.07em;color:var(--accent)}
.licence-block span{font-size:.85rem;color:var(--mid)}

iframe{outline:none}
