/**
 * Reboot Theme — Main Stylesheet
 * Fonts loaded via wp_enqueue_style (functions.php)
 *
 * @package Reboot
 */

/* ══════════════════════════════════════
   Design Tokens
   ══════════════════════════════════════ */

:root{
  --bg:#0c0c0a;--bg2:#141412;--bg3:#1a1a18;
  --text:#eeeeea;--text2:#9a9a94;--text3:#5c5c58;
  --accent:#d4a853;--accent-dim:rgba(212,168,83,.1);--accent-hover:#e0b96a;
  --green:#2ecc71;--green-dim:rgba(46,204,113,.1);
  --red:#e74c3c;--orange:#f39c12;
  --border:#1e1e1c;--radius:10px;--rs:8px;
  --font:'Inter',-apple-system,sans-serif;--mono:'JetBrains Mono',monospace;
  --nav:52px;
}

/* ══════════════════════════════════════
   Reset / Base
   ══════════════════════════════════════ */

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{font-size:16px;scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{background:var(--bg);color:var(--text);font-family:var(--font);line-height:1.5;-webkit-font-smoothing:antialiased;overflow-x:hidden;display:flex;flex-direction:column;min-height:100vh}
.footer{margin-top:auto;flex-shrink:0}
::-webkit-scrollbar{width:0;height:0}
::selection{background:var(--accent-dim);color:var(--accent)}
img{max-width:100%;display:block}a{color:inherit;text-decoration:none}button{font-family:var(--font)}

/* ══════════════════════════════════════
   Layout
   ══════════════════════════════════════ */

.container{max-width:1200px;margin:0 auto;padding:0 .85rem}
.section{padding:2.5rem 0}
.section-label{font-family:var(--mono);font-size:.6rem;font-weight:500;color:var(--accent);letter-spacing:.08em;text-transform:uppercase;display:inline-block;margin-bottom:.4rem}
.section-title{font-size:1.35rem;font-weight:700;letter-spacing:-.03em;line-height:1.15;margin-bottom:.35rem}
.section-title em{font-style:normal;color:var(--accent)}
.woocommerce-cart .page-top{display:none}
.woocommerce-cart .section{padding:0}

/* Account: hide page.php outer wrappers, let my-account.php handle layout */
.woocommerce-account .page-top{display:none}
.woocommerce-account .page-body .page-top{display:block}
.woocommerce-account .section{padding:0}
.woocommerce-account .page-body{font-size:inherit;color:inherit;line-height:inherit;width:100%;max-width:none}
.section-desc{font-size:.82rem;color:var(--text2);line-height:1.6;max-width:440px}
.section-header{margin-bottom:1.2rem}
.section-row{display:flex;align-items:center;justify-content:space-between;gap:.5rem;margin-bottom:1rem}

/* ══════════════════════════════════════
   Buttons
   ══════════════════════════════════════ */

.btn{display:inline-flex;align-items:center;justify-content:center;gap:.35rem;font-family:var(--font);font-weight:600;font-size:.82rem;padding:.7rem 1.2rem;border-radius:var(--rs);border:none;cursor:pointer;transition:all .15s;text-decoration:none;min-height:48px;-webkit-tap-highlight-color:transparent}
.btn-primary{background:var(--accent);color:#0c0c0a}
.btn-primary:active{background:var(--accent-hover);transform:scale(.97)}
.btn-ghost{background:none;color:var(--text2);border:1px solid var(--border)}
.btn-ghost:active{border-color:var(--accent);color:var(--accent)}
.btn-danger{background:none;color:var(--red);border:1px solid rgba(231,76,60,.25);font-size:.75rem;min-height:36px;padding:.4rem .8rem}
.btn-sm{padding:.4rem .75rem;font-size:.72rem;min-height:34px;font-weight:500}
.btn-full{width:100%}
.btn-lg{padding:.85rem 1.5rem;font-size:.88rem}

/* ══════════════════════════════════════
   Top Bar
   ══════════════════════════════════════ */

.topbar{position:fixed;top:0;left:0;right:0;z-index:1000;height:var(--nav);display:flex;align-items:center;padding:0 .85rem;background:rgba(12,12,10,.92);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--border)}
.topbar-inner{width:100%;max-width:1200px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:.4rem}
.logo{display:flex;align-items:center;gap:.4rem;font-weight:700;font-size:1rem;letter-spacing:-.02em;flex-shrink:0}
.logo-ico{width:26px;height:26px;background:var(--accent);border-radius:6px;display:flex;align-items:center;justify-content:center;color:#0c0c0a;font-size:.72rem}
.logo-img{width:26px;height:26px;border-radius:6px;object-fit:contain;flex-shrink:0}
.desk-links{display:none;gap:.1rem;list-style:none;flex:1;justify-content:center}
.desk-links a{font-size:.8rem;font-weight:450;color:var(--text2);padding:.3rem .55rem;border-radius:6px;transition:all .15s}
.desk-links a:hover,.desk-links a.on{color:var(--accent);background:var(--accent-dim)}
.topbar-right{display:flex;align-items:center;gap:.3rem}
.t-icon{position:relative;width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:var(--bg2);border:1px solid var(--border);border-radius:var(--rs);font-size:.9rem;color:var(--text2);cursor:pointer;-webkit-tap-highlight-color:transparent;text-decoration:none}
.t-icon:active,.t-icon:hover{border-color:var(--accent);color:var(--accent)}
.t-badge{position:absolute;top:-4px;right:-4px;min-width:15px;height:15px;background:var(--accent);color:#0c0c0a;font-size:.5rem;font-weight:700;border-radius:99px;display:flex;align-items:center;justify-content:center;padding:0 3px}
.burger{display:flex}


/* ══════════════════════════════════════
   Mobile Menu
   ══════════════════════════════════════ */

.mmenu{position:fixed;inset:0;z-index:999;background:rgba(0,0,0,.5);opacity:0;pointer-events:none;transition:opacity .25s}
.mmenu.open{opacity:1;pointer-events:all}
.mmenu-panel{position:absolute;top:0;right:0;bottom:0;width:100%;max-width:300px;background:var(--bg);padding:calc(var(--nav) + .6rem) 1rem 2rem;transform:translateX(100%);transition:transform .25s cubic-bezier(.4,0,.2,1);border-left:1px solid var(--border);overflow-y:auto}
.mmenu.open .mmenu-panel{transform:translateX(0)}
.mmenu-close{position:absolute;top:.5rem;right:.5rem;background:var(--bg2);border:1px solid var(--border);width:34px;height:34px;border-radius:var(--rs);display:flex;align-items:center;justify-content:center;font-size:.9rem;color:var(--text2);cursor:pointer}
.mmenu-user{display:flex;align-items:center;gap:.6rem;padding:.8rem;background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:1rem}
.mmenu-avatar{width:38px;height:38px;background:var(--accent);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#0c0c0a;font-weight:700;font-size:.82rem;flex-shrink:0}
.mmenu-uname{font-size:.85rem;font-weight:600}
.mmenu-uemail{font-size:.62rem;color:var(--text3)}
.mmenu-links{list-style:none;margin-bottom:1rem}
.mmenu-links li{border-bottom:1px solid var(--border)}
.mmenu-links a{display:flex;align-items:center;gap:.45rem;padding:.7rem 0;font-size:.88rem;font-weight:500;color:var(--text)}
.mmenu-links a .ml-i{font-size:1rem;width:22px;text-align:center}

/* ══════════════════════════════════════
   Breadcrumb
   ══════════════════════════════════════ */

.crumb{display:flex;align-items:center;gap:.3rem;font-size:.65rem;color:var(--text3);flex-wrap:wrap;margin-bottom:.6rem}
.crumb a{color:var(--text3)}.crumb a:hover{color:var(--accent)}.crumb .sep{opacity:.4}

/* ══════════════════════════════════════
   Page Header
   ══════════════════════════════════════ */

.page-top{padding:calc(var(--nav) + 1rem) 0 .8rem}

/* ══════════════════════════════════════
   Hero (homepage)
   ══════════════════════════════════════ */

.hero{padding:calc(var(--nav) + 1.5rem) 0 1.5rem}
.hero-badge{display:inline-flex;align-items:center;gap:.35rem;font-family:var(--mono);font-size:.58rem;font-weight:500;color:var(--accent);background:var(--accent-dim);padding:.25rem .7rem;border-radius:100px;margin-bottom:.8rem}
.hero-badge .dot{width:5px;height:5px;background:var(--accent);border-radius:50%;animation:pulse 2s ease infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.3}}
.hero-title{font-size:clamp(1.8rem,7vw,2.8rem);font-weight:800;letter-spacing:-.04em;line-height:1.05;margin-bottom:.8rem}
.hero-title .hl{color:var(--accent)}
.hero-sub{font-size:.85rem;color:var(--text2);line-height:1.65;margin-bottom:1.2rem}
.hero-sub strong{color:var(--text);font-weight:600}
.hero-actions{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1.2rem}
.hero-trust{display:flex;gap:.8rem;flex-wrap:wrap}
.hero-trust span{font-size:.68rem;color:var(--text3);display:flex;align-items:center;gap:.2rem}

/* Hero animated background */
.hero-wrap{position:relative;overflow:hidden;padding:calc(var(--nav) + 1.5rem) 0 0}
.hero-bg{position:absolute;inset:0;z-index:0}
.hero-bg canvas{width:100%;height:100%}
.hero-glow{position:absolute;border-radius:50%;filter:blur(80px);opacity:.12;pointer-events:none}
.hero-glow-1{width:300px;height:300px;background:var(--accent);top:-50px;right:-80px;animation:gFloat 8s ease-in-out infinite}
.hero-glow-2{width:200px;height:200px;background:#d4a853;bottom:20%;left:-60px;animation:gFloat 10s ease-in-out infinite reverse}
.hero-glow-3{width:150px;height:150px;background:#e0b96a;top:40%;right:20%;animation:gFloat 12s ease-in-out infinite 2s}
@keyframes gFloat{0%,100%{transform:translate(0,0) scale(1)}25%{transform:translate(20px,-30px) scale(1.1)}50%{transform:translate(-15px,20px) scale(.9)}75%{transform:translate(25px,10px) scale(1.05)}}
.hero-content{position:relative;z-index:1}

/* Text reveal */
.reveal{opacity:0;transform:translateY(20px);animation:revealUp .7s cubic-bezier(.22,1,.36,1) forwards}
.reveal-d1{animation-delay:.1s}.reveal-d2{animation-delay:.25s}.reveal-d3{animation-delay:.4s}.reveal-d4{animation-delay:.55s}.reveal-d5{animation-delay:.7s}
@keyframes revealUp{to{opacity:1;transform:translateY(0)}}

/* Brand marquee */
.marquee-wrap{overflow:hidden;padding:1.5rem 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border);margin:1.5rem 0}
.marquee{display:flex;gap:2.5rem;animation:marqueeSlide 20s linear infinite;width:max-content}
.marquee-item{font-family:var(--mono);font-size:.72rem;font-weight:500;color:var(--text3);white-space:nowrap;display:flex;align-items:center;gap:.4rem;letter-spacing:.02em}
.marquee-item .mdot{width:4px;height:4px;background:var(--accent);border-radius:50%;opacity:.5}
@keyframes marqueeSlide{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* Stats */
.stats-row{display:grid;grid-template-columns:repeat(4,1fr);gap:.4rem;margin-bottom:1.5rem}
.stat-box{text-align:center;padding:.7rem .3rem;background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);transition:border-color .2s}
.stat-box:hover{border-color:var(--accent)}
.stat-num{font-size:1.3rem;font-weight:800;color:var(--accent);letter-spacing:-.03em;display:block;line-height:1.1}
.stat-label{font-size:.55rem;color:var(--text3);display:block;margin-top:.15rem}
@media(max-width:400px){.stat-num{font-size:1.05rem}.stats-row{gap:.3rem}}

/* Hero CTA */
.hero-cta-row{display:flex;gap:.5rem;flex-direction:column;margin-bottom:1.2rem}
.hero-cta-col{display:flex;flex-direction:column;gap:.8rem;max-width:420px;margin:0 auto 2.5rem}
.hero-cta-main{position:relative;overflow:hidden}
.hero-cta-main .btn{position:relative;z-index:1}
.cta-shimmer{position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.12),transparent);animation:shimmer 3s ease infinite}
@keyframes shimmer{0%{left:-100%}100%{left:100%}}

/* ══════════════════════════════════════
   Full-page Hero (v2)
   ══════════════════════════════════════ */

.hero-full{position:relative;overflow:hidden;min-height:100vh;min-height:100dvh;display:flex;flex-direction:column;justify-content:center;padding:calc(var(--nav) + 2rem) 0 3rem}
.hero-full .hero-bg{position:absolute;inset:0;z-index:0}
.hero-full .hero-bg canvas{width:100%;height:100%}
.hero-full .hero-content{position:relative;z-index:2;text-align:center;max-width:760px;margin:0 auto;padding:0 1.2rem}
.hero-full .hero-badge{margin:0 auto 1.2rem}
.hero-full .hero-title{font-size:clamp(2.4rem,9vw,4.2rem);margin-bottom:1.4rem;line-height:1.05}
.hero-full .hero-sub{max-width:540px;margin:0 auto 2rem;font-size:.95rem;line-height:1.7}
.hero-full .trust-line{justify-content:center;margin-bottom:2rem;gap:.6rem}
.hero-full .trust-tag{font-size:.7rem;padding:.3rem .65rem}
.hero-full .hero-cta-col{max-width:420px;margin:0 auto 2.5rem;padding:0 .5rem}
.hero-full .hero-cta-col .btn-lg{padding:1rem 1.5rem;font-size:.92rem}

/* Floating emojis */
.emoji-field{position:absolute;inset:0;z-index:1;pointer-events:none;overflow:hidden}
.float-emoji{position:absolute;font-size:2.8rem;opacity:0;will-change:transform,opacity;animation:emojiFloat var(--dur,12s) var(--delay,0s) ease-in-out infinite;filter:blur(0px);line-height:1}
.float-emoji.orbit-1{animation-name:emojiOrbit1}
.float-emoji.orbit-2{animation-name:emojiOrbit2}
.float-emoji.orbit-3{animation-name:emojiOrbit3}
.float-emoji.orbit-4{animation-name:emojiOrbit4}

@keyframes emojiOrbit1{0%{transform:translate(0,0) rotate(0deg) scale(.8);opacity:0}10%{opacity:.45}50%{transform:translate(80px,-120px) rotate(15deg) scale(1.05);opacity:.55}90%{opacity:.45}100%{transform:translate(0,0) rotate(0deg) scale(.8);opacity:0}}
@keyframes emojiOrbit2{0%{transform:translate(0,0) rotate(0deg) scale(.85);opacity:0}10%{opacity:.4}50%{transform:translate(-60px,-90px) rotate(-12deg) scale(1.1);opacity:.5}90%{opacity:.4}100%{transform:translate(0,0) rotate(0deg) scale(.85);opacity:0}}
@keyframes emojiOrbit3{0%{transform:translate(0,0) rotate(0deg) scale(.75);opacity:0}10%{opacity:.35}30%{transform:translate(100px,50px) rotate(8deg) scale(.95)}50%{transform:translate(40px,-80px) rotate(18deg) scale(1.05);opacity:.5}70%{transform:translate(-50px,-30px) rotate(-5deg) scale(.9)}90%{opacity:.35}100%{transform:translate(0,0) rotate(0deg) scale(.75);opacity:0}}
@keyframes emojiOrbit4{0%{transform:translate(0,0) rotate(0deg) scale(.9);opacity:0}15%{opacity:.4}35%{transform:translate(-40px,-100px) rotate(-10deg) scale(1)}65%{transform:translate(60px,-50px) rotate(12deg) scale(1.08);opacity:.55}85%{opacity:.4}100%{transform:translate(0,0) rotate(0deg) scale(.9);opacity:0}}

.float-emoji::after{content:'';position:absolute;inset:-15px;background:var(--accent);border-radius:50%;filter:blur(25px);opacity:.08;z-index:-1}

.emoji-field[data-depth="far"] .float-emoji{font-size:2rem;filter:blur(0.5px);opacity:0}
.emoji-field[data-depth="mid"] .float-emoji{font-size:2.8rem;filter:blur(0px);opacity:0}
.emoji-field[data-depth="near"] .float-emoji{font-size:3.5rem;filter:blur(0px);opacity:0}

/* Hero stat pills */
.hero-stats{display:flex;flex-wrap:wrap;justify-content:center;gap:.5rem;max-width:600px;margin:0 auto}
.hero-stat-pill{display:flex;align-items:center;gap:.5rem;padding:.55rem 1rem;background:var(--bg2);border:1px solid var(--border);border-radius:100px;transition:border-color .2s;white-space:nowrap;flex-shrink:0}
.hero-stat-pill:hover{border-color:var(--accent)}
.hero-stat-pill .hsp-icon{font-size:1.1rem;line-height:1}
.hero-stat-pill .hsp-num{font-size:.95rem;font-weight:800;color:var(--accent);letter-spacing:-.02em;min-width:2.5ch;text-align:right;font-variant-numeric:tabular-nums}
.hero-stat-pill .hsp-label{font-size:.68rem;color:var(--text3);font-weight:500}

/* Scroll hint */
.scroll-hint{position:absolute;bottom:1.5rem;left:50%;transform:translateX(-50%);z-index:2;display:flex;flex-direction:column;align-items:center;gap:.3rem;animation:scrollBounce 2s ease-in-out infinite}
.scroll-hint-text{font-family:var(--mono);font-size:.55rem;color:var(--text3);letter-spacing:.1em;text-transform:uppercase}
.scroll-hint-arrow{width:20px;height:20px;border-right:1.5px solid var(--text3);border-bottom:1.5px solid var(--text3);transform:rotate(45deg);opacity:.4}
@keyframes scrollBounce{0%,100%{transform:translateX(-50%) translateY(0);opacity:.6}50%{transform:translateX(-50%) translateY(8px);opacity:1}}

/* Hero-full responsive */
@media(max-width:639px){
  .hero-full{padding:calc(var(--nav) + 1.5rem) 0 3rem}
  .hero-full .hero-content{padding:0 1rem}
  .hero-full .hero-title{font-size:clamp(1.8rem,8vw,2.6rem);margin-bottom:1rem}
  .hero-full .hero-sub{font-size:.85rem;margin-bottom:1.5rem}
  .hero-full .hero-cta-col{padding:0 .3rem;margin-bottom:1.8rem;gap:.6rem}
  .hero-full .hero-cta-col .btn-lg{padding:.75rem .6rem;font-size:.78rem}
  .hero-full .trust-line{gap:.4rem;margin-bottom:1.5rem}
  .hero-full .trust-tag{font-size:.6rem;padding:.22rem .5rem}
  .hero-stats{gap:.4rem}
  .hero-stat-pill{padding:.4rem .7rem;gap:.35rem}
  .hero-stat-pill .hsp-num{font-size:.8rem}
  .hero-stat-pill .hsp-label{font-size:.58rem}
  .hero-stat-pill .hsp-icon{font-size:.9rem}
  .emoji-field[data-depth="far"] .float-emoji{font-size:1.5rem}
  .emoji-field[data-depth="mid"] .float-emoji{font-size:2rem}
  .emoji-field[data-depth="near"] .float-emoji{font-size:2.5rem}
}
@media(min-width:640px){
  .emoji-field[data-depth="far"] .float-emoji{font-size:2.5rem}
  .emoji-field[data-depth="mid"] .float-emoji{font-size:3.5rem}
  .emoji-field[data-depth="near"] .float-emoji{font-size:4.5rem}
}
@media(min-width:900px){
  .hero-full .hero-title{font-size:4.2rem}
  .hero-full .hero-sub{font-size:1.05rem;max-width:560px}
  .hero-full .hero-content{max-width:800px}
  .emoji-field[data-depth="far"] .float-emoji{font-size:3rem}
  .emoji-field[data-depth="mid"] .float-emoji{font-size:4rem}
  .emoji-field[data-depth="near"] .float-emoji{font-size:5rem}
  .hero-stat-pill{padding:.6rem 1.2rem;gap:.6rem}
}

/* Categories grid */
.cat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:.4rem}
.cat-card{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.3rem;padding:.8rem .3rem;background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);text-decoration:none;color:var(--text);transition:all .2s;position:relative;overflow:hidden}
.cat-card:active{border-color:var(--accent);background:var(--accent-dim)}
.cat-card-glow{position:absolute;width:60px;height:60px;background:var(--accent);border-radius:50%;filter:blur(30px);opacity:0;transition:opacity .3s;pointer-events:none}
.cat-card:hover .cat-card-glow{opacity:.08}
.cat-card-emoji{font-size:1.6rem;line-height:1;transition:transform .2s}
.cat-card:active .cat-card-emoji{transform:scale(1.15)}
.cat-card-name{font-size:.62rem;font-weight:600;white-space:nowrap}
.cat-card-count{font-family:var(--mono);font-size:.5rem;color:var(--text3)}
@media(min-width:640px){.cat-grid{grid-template-columns:repeat(7,1fr)}.hero-cta-row{flex-direction:row}.stats-row{max-width:500px}}

/* Trust line */
.trust-line{display:flex;gap:.5rem;flex-wrap:wrap;margin-bottom:.8rem}
.trust-tag{display:flex;align-items:center;gap:.25rem;font-size:.65rem;color:var(--text3);background:var(--bg2);border:1px solid var(--border);padding:.25rem .55rem;border-radius:100px}
.trust-tag .tt-dot{width:6px;height:6px;border-radius:50%;background:var(--green);display:inline-block}

/* ══════════════════════════════════════
   Products Grid
   ══════════════════════════════════════ */

.products-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.85rem}
.p-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;position:relative;text-decoration:none;color:var(--text);transition:border-color .15s}
.p-card:active{border-color:var(--accent)}
.p-badges{position:absolute;top:.4rem;left:.4rem;z-index:2;display:flex;gap:.2rem}
.p-badge{font-family:var(--mono);font-size:.5rem;font-weight:500;padding:.12rem .35rem;border-radius:3px}
.p-badge-g{background:var(--text);color:var(--bg)}.p-badge-p{background:var(--red);color:#fff}.p-badge-e{background:var(--green);color:#fff}
.p-img{aspect-ratio:1;overflow:hidden;background:var(--bg3)}.p-img img{width:100%;height:100%;object-fit:cover}
.p-body{padding:.55rem .65rem .65rem}
.p-brand{font-family:var(--mono);font-size:.5rem;color:var(--text3);text-transform:uppercase;letter-spacing:.03em;display:block;margin-bottom:.1rem}
.p-body h4{font-size:.78rem;font-weight:600;margin-bottom:.1rem;line-height:1.25}
.p-specs{font-size:.62rem;color:var(--text3);margin-bottom:.35rem}
.p-pricing{display:flex;align-items:baseline;gap:.3rem;flex-wrap:wrap}
.p-price{font-size:1rem;font-weight:700;letter-spacing:-.02em}
.p-old{font-size:.62rem;color:var(--text3);text-decoration:line-through}
.p-save{font-family:var(--mono);font-size:.5rem;font-weight:500;color:var(--green);background:var(--green-dim);padding:.08rem .3rem;border-radius:3px}

/* ══════════════════════════════════════
   Product Detail — v3
   ══════════════════════════════════════ */

/* Gallery */
.gal{position:relative;border-radius:var(--radius);overflow:hidden;background:var(--bg2);border:1px solid var(--border);margin-bottom:.5rem;aspect-ratio:4/3}
.gal img{width:100%;height:100%;object-fit:cover}
.gal-tags{position:absolute;top:.55rem;left:.55rem;display:flex;gap:.2rem}
.gal-tag{font-family:var(--mono);font-size:.55rem;font-weight:600;padding:.15rem .45rem;border-radius:4px}
.tag-grade{background:var(--accent);color:#0c0c0a}
.tag-save{background:var(--red);color:#fff}
.gal-nav{position:absolute;bottom:.55rem;right:.55rem;font-family:var(--mono);font-size:.58rem;color:#fff;background:rgba(0,0,0,.55);padding:.15rem .45rem;border-radius:4px}
.gal-thumbs{display:flex;gap:.3rem;overflow-x:auto;padding:.1rem 0;-webkit-overflow-scrolling:touch}.gal-thumbs::-webkit-scrollbar{display:none}
.gal-th{width:52px;height:52px;border-radius:6px;border:2px solid var(--border);overflow:hidden;cursor:pointer;flex-shrink:0;opacity:.5;transition:all .15s}
.gal-th.on{border-color:var(--accent);opacity:1}
.gal-th img{width:100%;height:100%;object-fit:cover}

/* Product info */
.pd-brand{font-family:var(--mono);font-size:.58rem;color:var(--accent);text-transform:uppercase;letter-spacing:.06em;margin:.8rem 0 .15rem}
.pd-title{font-size:1.25rem;font-weight:700;letter-spacing:-.03em;line-height:1.2;margin-bottom:.25rem}
.pd-sub{font-size:.78rem;color:var(--text2);margin-bottom:.8rem}

/* Price Hero */
.price-hero{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:.9rem 1rem;margin-bottom:.8rem;position:relative;overflow:hidden}
.price-hero::before{content:'';position:absolute;top:0;right:0;width:120px;height:120px;background:radial-gradient(circle,rgba(212,168,83,.08) 0%,transparent 70%);pointer-events:none}
.ph-row{display:flex;align-items:baseline;gap:.45rem;flex-wrap:wrap}
.ph-price{font-size:1.7rem;font-weight:700;letter-spacing:-.03em}
.ph-old{font-size:.8rem;color:var(--text3);text-decoration:line-through}
.ph-save{font-family:var(--mono);font-size:.55rem;font-weight:600;color:var(--green);background:rgba(52,211,153,.12);padding:.12rem .4rem;border-radius:4px}
.ph-note{font-size:.65rem;color:var(--text3);margin-top:.2rem}
.ph-split{font-size:.7rem;color:var(--accent);font-weight:500;margin-top:.25rem}

/* Grade Tabs */
.grade-tabs{display:flex;background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:3px;margin-bottom:.7rem;gap:3px}
.grade-tab{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:.55rem .3rem;border-radius:calc(var(--radius) - 2px);cursor:pointer;transition:all .2s;border:1.5px solid transparent;position:relative;-webkit-tap-highlight-color:transparent;background:none;font-family:var(--font);color:var(--text)}
.grade-tab:active,.grade-tab.on{background:var(--accent-dim);border-color:var(--accent)}
.grade-tab .gt-letter{font-size:1.25rem;font-weight:700;color:var(--text3);transition:color .2s;line-height:1}
.grade-tab.on .gt-letter{color:var(--accent)}
.grade-tab .gt-name{font-size:.55rem;font-weight:500;color:var(--text3);margin-top:.1rem;transition:color .2s}
.grade-tab.on .gt-name{color:var(--text)}
.grade-tab .gt-from{font-family:var(--mono);font-size:.5rem;color:var(--text3);margin-top:.1rem}
.grade-tab.on .gt-from{color:var(--accent)}
.grade-tab .gt-count{position:absolute;top:4px;right:4px;font-family:var(--mono);font-size:.42rem;font-weight:600;background:var(--bg3);color:var(--text3);padding:.05rem .25rem;border-radius:3px}
.grade-tab.on .gt-count{background:rgba(212,168,83,.18);color:var(--accent)}

/* Unit Cards */
.units-title{font-size:.72rem;font-weight:600;margin-bottom:.4rem;display:flex;align-items:center;gap:.3rem;color:var(--text2)}
.units-title em{color:var(--accent);font-style:normal}
.u-list{display:flex;flex-direction:column;gap:.35rem;margin-bottom:.7rem}
.u-card{display:grid;grid-template-columns:auto 1fr auto;gap:.55rem;align-items:center;padding:.65rem .7rem;background:var(--bg2);border:1.5px solid var(--border);border-radius:var(--radius);cursor:pointer;transition:all .2s;-webkit-tap-highlight-color:transparent;position:relative}
.u-card:active,.u-card.on{border-color:var(--accent);background:var(--accent-dim)}
.u-card.oos{opacity:.4;pointer-events:none}
.u-radio{width:18px;height:18px;border-radius:50%;border:2px solid var(--border);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .2s}
.u-card.on .u-radio{border-color:var(--accent)}
.u-radio-dot{width:8px;height:8px;border-radius:50%;background:var(--accent);opacity:0;transition:opacity .15s;transform:scale(.5)}
.u-card.on .u-radio-dot{opacity:1;transform:scale(1)}
.u-info{min-width:0}
.u-specs-line{font-size:.75rem;font-weight:600;margin-bottom:.1rem;display:flex;align-items:center;gap:.3rem}
.u-specs-line .u-tag{font-family:var(--mono);font-size:.45rem;font-weight:600;background:var(--bg3);color:var(--text3);padding:.08rem .3rem;border-radius:3px}
.u-card.on .u-tag{background:rgba(212,168,83,.18);color:var(--accent)}
.u-detail{font-size:.6rem;color:var(--text3);display:flex;gap:.4rem;flex-wrap:wrap}
.u-detail span{display:flex;align-items:center;gap:.15rem}
.u-price{text-align:right;flex-shrink:0}
.u-price-val{font-size:1.05rem;font-weight:700;letter-spacing:-.02em}
.u-price-old{font-size:.55rem;color:var(--text3);text-decoration:line-through}

/* Health Report */
.health{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;margin-bottom:.7rem}
.health-header{display:flex;align-items:center;justify-content:space-between;padding:.7rem .8rem;border-bottom:1px solid var(--border)}
.health-title{font-size:.78rem;font-weight:600;display:flex;align-items:center;gap:.3rem}
.health-score{display:flex;align-items:center;gap:.3rem;font-family:var(--mono);font-size:.72rem;font-weight:600;padding:.2rem .55rem;border-radius:6px}
.health-score.excellent{color:var(--green);background:rgba(52,211,153,.12)}
.health-score.good{color:var(--orange);background:rgba(245,158,11,.12)}
.health-score.fair{color:var(--red);background:rgba(239,68,68,.12)}
.health-grid{padding:.5rem}
.health-item{display:grid;grid-template-columns:28px 1fr auto;gap:.45rem;align-items:center;padding:.5rem .3rem;border-bottom:1px solid var(--border)}
.health-item:last-child{border:none}
.hi-icon{width:28px;height:28px;border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:.85rem;background:var(--bg3);flex-shrink:0}
.hi-info{min-width:0}
.hi-label{font-size:.72rem;font-weight:600;margin-bottom:.05rem}
.hi-detail{font-size:.6rem;color:var(--text2);line-height:1.4}
.hi-status{display:flex;flex-direction:column;align-items:flex-end;gap:.2rem;flex-shrink:0}
.hi-badge{font-family:var(--mono);font-size:.52rem;font-weight:600;padding:.1rem .35rem;border-radius:3px;white-space:nowrap}
.hi-badge.ok{color:var(--green);background:rgba(52,211,153,.12)}
.hi-badge.mid{color:var(--orange);background:rgba(245,158,11,.12)}
.hi-badge.bad{color:var(--red);background:rgba(239,68,68,.12)}
.hi-bar{width:42px;height:4px;background:var(--bg3);border-radius:2px;overflow:hidden}
.hi-bar-fill{height:100%;border-radius:2px;transition:width .4s ease}
.hi-bar-fill.ok{background:var(--green)}
.hi-bar-fill.mid{background:var(--orange)}
.hi-bar-fill.bad{background:var(--red)}

/* Specs */
.specs-wrap{margin-bottom:.7rem}
.spec-btn{width:100%;display:flex;align-items:center;justify-content:space-between;padding:.65rem .8rem;background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);font-size:.78rem;font-weight:600;color:var(--text);cursor:pointer;font-family:var(--font)}
.spec-btn .arr{color:var(--accent);transition:transform .2s;font-size:.7rem}
.spec-btn.open{border-radius:var(--radius) var(--radius) 0 0}
.spec-btn.open .arr{transform:rotate(180deg)}
.spec-tbl{display:none;border:1px solid var(--border);border-top:0;border-radius:0 0 var(--radius) var(--radius);overflow:hidden}
.spec-tbl.open{display:block}
.sp-row{display:flex;padding:.4rem .8rem;font-size:.7rem;border-bottom:1px solid var(--border)}
.sp-row:last-child{border:0}.sp-row:nth-child(even){background:var(--bg2)}.sp-row:nth-child(odd){background:var(--bg)}
.sp-l{width:38%;color:var(--text3);flex-shrink:0}.sp-v{flex:1;font-weight:500}

/* Guarantees */
.guar{display:grid;grid-template-columns:1fr 1fr;gap:.3rem;margin-bottom:.8rem}
.guar-i{display:flex;align-items:center;gap:.25rem;font-size:.62rem;color:var(--text2);padding:.45rem .5rem;background:var(--bg2);border:1px solid var(--border);border-radius:6px}

/* Sticky Buy (mobile) */
.sticky-buy{position:fixed;bottom:0;left:0;right:0;z-index:800;padding:.5rem .85rem;background:rgba(12,12,10,.96);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-top:1px solid var(--border);display:flex;align-items:center;gap:.5rem}
.stk-info{flex:1;min-width:0}
.stk-name{font-size:.58rem;color:var(--text3);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.stk-price{font-size:1.1rem;font-weight:700}
.sticky-buy .btn{flex-shrink:0}

/* Desktop buy */
.desk-buy{display:none;gap:.5rem;margin-bottom:.8rem}


/* Animations */
@keyframes fadeUp{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
.anim{animation:fadeUp .35s ease both}
.anim-d1{animation-delay:.05s}.anim-d2{animation-delay:.1s}.anim-d3{animation-delay:.15s}

/* ══════════════════════════════════════
   Steps / Repair / Values / Testimonials
   ══════════════════════════════════════ */

.steps-col{display:flex;flex-direction:column;gap:.5rem}
.step-item{display:flex;align-items:flex-start;gap:.65rem;padding:.8rem;background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius)}
.step-num{font-family:var(--mono);font-size:.6rem;font-weight:500;color:var(--accent);background:var(--accent-dim);width:26px;height:26px;border-radius:6px;flex-shrink:0;display:flex;align-items:center;justify-content:center}
.step-item h4{font-size:.82rem;font-weight:600;margin-bottom:.1rem}.step-item p{font-size:.72rem;color:var(--text2);line-height:1.45}
.repair-list{display:flex;flex-direction:column;gap:.5rem}
.repair-card{display:flex;align-items:flex-start;gap:.65rem;padding:.8rem;background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius)}
.rep-ico{font-size:1.3rem;flex-shrink:0;margin-top:.1rem}.repair-card h4{font-size:.82rem;font-weight:600;margin-bottom:.05rem}.repair-card p{font-size:.72rem;color:var(--text2);line-height:1.45;margin-bottom:.2rem}
.rep-price{font-family:var(--mono);font-size:.62rem;font-weight:500;color:var(--accent)}
.vals-scroll{display:flex;gap:.4rem;overflow-x:auto;-webkit-overflow-scrolling:touch;padding:.1rem 0 .5rem}.vals-scroll::-webkit-scrollbar{display:none}
.val-pill{flex-shrink:0;width:105px;display:flex;flex-direction:column;align-items:center;gap:.2rem;padding:.65rem .4rem;background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);text-align:center}
.val-pill .vi{font-size:1.1rem}.val-pill strong{font-size:.68rem;font-weight:600}.val-pill span{font-size:.58rem;color:var(--text3)}
.testi-scroll{display:flex;gap:.5rem;overflow-x:auto;-webkit-overflow-scrolling:touch}.testi-scroll::-webkit-scrollbar{display:none}
.testi-card{flex-shrink:0;width:260px;padding:1rem;background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);display:flex;flex-direction:column;gap:.6rem}
.t-stars{color:#facc15;font-size:.7rem}.testi-card blockquote{font-size:.78rem;color:var(--text2);line-height:1.55;font-style:italic;flex:1}
.t-author{display:flex;align-items:center;gap:.4rem}
.t-av{width:28px;height:28px;background:var(--accent-dim);border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--mono);font-size:.5rem;font-weight:600;color:var(--accent)}
.t-author strong{font-size:.72rem;font-weight:500;display:block}.t-author span{font-size:.58rem;color:var(--text3)}
.cta-box{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:1.2rem;text-align:center}
.cta-box h3{font-size:1rem;font-weight:700;margin-bottom:.2rem}.cta-box p{font-size:.78rem;color:var(--text2);margin-bottom:.8rem}
.grades-row{display:grid;grid-template-columns:repeat(3,1fr);gap:.4rem}
.gr-pill{text-align:center;padding:.8rem .3rem;background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius)}
.gr-pill strong{display:block;font-size:1.4rem;font-weight:800;color:var(--accent);margin-bottom:.15rem}
.gr-pill span{font-size:.68rem;color:var(--text2);display:block}.gr-pill small{font-size:.58rem;color:var(--text3)}

/* ══════════════════════════════════════
   Contact / Forms
   ══════════════════════════════════════ */

.contact-layout{display:flex;flex-direction:column;gap:1.5rem}
.c-info-list{display:flex;flex-direction:column;gap:.4rem}
.c-info-item{display:flex;align-items:center;gap:.6rem;padding:.7rem;background:var(--bg2);border:1px solid var(--border);border-radius:var(--rs);text-decoration:none;color:var(--text)}
.c-ico{width:34px;height:34px;background:var(--accent-dim);border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:.85rem;flex-shrink:0}
.c-lbl{font-size:.55rem;font-family:var(--mono);color:var(--text3);text-transform:uppercase;letter-spacing:.04em;display:block}
.c-val{font-size:.82rem}.c-val a{color:var(--accent);font-weight:500}
.form-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:1rem}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:.5rem}
.form-group{display:flex;flex-direction:column;gap:.2rem;margin-bottom:.6rem}
.form-group label{font-size:.68rem;font-weight:500;color:var(--text2)}
.form-group input,.form-group select,.form-group textarea{font-family:var(--font);font-size:.88rem;color:var(--text);background:var(--bg);border:1px solid var(--border);padding:.6rem .7rem;border-radius:var(--rs);outline:none;transition:border-color .15s;appearance:none;min-height:48px}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--accent)}
.form-group input::placeholder,.form-group textarea::placeholder{color:var(--text3)}
.form-group textarea{resize:vertical;min-height:80px}
.form-ok{text-align:center;padding:2rem 1rem;border:1px solid var(--accent);border-radius:var(--radius);background:var(--accent-dim)}
.form-ok-icon{width:48px;height:48px;border-radius:50%;background:var(--accent);color:#0c0c0a;font-size:1.4rem;font-weight:700;display:flex;align-items:center;justify-content:center;margin:0 auto .8rem}
.form-ok h3{font-size:1.1rem;color:var(--accent);margin-bottom:.3rem}.form-ok p{font-size:.82rem;color:var(--text2);margin:0}
.form-msg{margin-top:.5rem;padding:.5rem .65rem;border-radius:var(--rs);font-size:.78rem;text-align:center}
.form-msg-error{background:rgba(231,76,60,.1);border:1px solid var(--red);color:var(--red)}

/* Select arrow for acc-field selects */
.acc-field select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6' fill='%235c5c58'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .6rem center;padding-right:1.5rem}
/* Textarea in acc-field */
.acc-field textarea{resize:vertical;min-height:70px}

/* ══════════════════════════════════════
   Cart — v2
   ══════════════════════════════════════ */

.page-title{font-size:1.3rem;font-weight:700;letter-spacing:-.03em;margin-bottom:.1rem;display:flex;align-items:center;gap:.4rem}
.page-title em{font-style:normal;color:var(--accent)}
.page-sub{font-size:.75rem;color:var(--text3);margin-bottom:1rem}

.cart-layout{display:flex;flex-direction:column;gap:1.2rem}

/* Cart item */
.cart-item{display:flex;gap:.65rem;padding:.75rem;background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);position:relative;transition:border-color .2s}
.cart-item:hover{border-color:rgba(30,30,28,.6)}
.ci-img{width:80px;height:80px;border-radius:8px;overflow:hidden;flex-shrink:0;background:var(--bg3);border:1px solid var(--border)}
.ci-img img,.ci-img .attachment-woocommerce_thumbnail{width:100%;height:100%;object-fit:cover}
.ci-body{flex:1;min-width:0;display:flex;flex-direction:column;justify-content:space-between}
.ci-top{display:flex;justify-content:space-between;gap:.4rem;align-items:flex-start}
.ci-info{min-width:0;flex:1}
.ci-name{font-size:.8rem;font-weight:600;line-height:1.3;margin-bottom:.15rem;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.ci-name a{color:var(--text);text-decoration:none}.ci-name a:hover{color:var(--accent)}

/* Cart item tags */
.ci-tags{display:flex;gap:.25rem;flex-wrap:wrap;margin-bottom:.25rem}
.ci-tag{font-size:.52rem;font-weight:600;padding:.1rem .35rem;border-radius:4px;display:inline-flex;align-items:center;gap:.15rem}
.ci-tag-grade{background:rgba(212,168,83,.18);color:var(--accent)}
.ci-tag-spec{background:var(--bg3);color:var(--text3);border:1px solid var(--border)}
.ci-tag-score{background:rgba(52,211,153,.1);color:var(--green)}

/* Cart item price */
.ci-price{text-align:right;flex-shrink:0}
.ci-price-val{font-size:1.05rem;font-weight:700;letter-spacing:-.02em}
.ci-price-old{font-size:.55rem;color:var(--text3);text-decoration:line-through}
.ci-price-save{font-family:var(--mono);font-size:.48rem;color:var(--green);background:rgba(52,211,153,.1);padding:.06rem .25rem;border-radius:3px;display:inline-block;margin-top:.1rem}

/* Cart item bottom */
.ci-bottom{display:flex;align-items:center;justify-content:space-between;margin-top:.3rem}
.ci-remove{font-size:.62rem;color:var(--red);background:none;border:none;padding:.15rem .3rem;border-radius:4px;cursor:pointer;opacity:.6;transition:opacity .15s;text-decoration:none}
.ci-remove:hover{opacity:1}
.ci-qty{display:flex;align-items:center;gap:.2rem}
.ci-qty button,.ci-qty .qty-minus,.ci-qty .qty-plus{width:26px;height:26px;border-radius:6px;border:1px solid var(--border);background:var(--bg3);color:var(--text2);font-size:.82rem;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s}
.ci-qty button:hover,.ci-qty .qty-minus:hover,.ci-qty .qty-plus:hover{border-color:var(--accent);color:var(--accent)}

/* Cart summary sidebar */
.cart-summary{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:1rem;position:sticky;top:calc(var(--nav) + 1rem)}
.cs-title{font-size:.88rem;font-weight:600;margin-bottom:.8rem;display:flex;align-items:center;gap:.3rem}
.cs-row{display:flex;justify-content:space-between;padding:.3rem 0;font-size:.82rem}
.cs-row .lbl{color:var(--text2)}.cs-row .val{font-weight:500}
.cs-row.total{border-top:1px solid var(--border);margin-top:.5rem;padding-top:.6rem;font-weight:700;font-size:1.05rem}
.cs-split{font-size:.68rem;color:var(--accent);margin-top:.25rem;text-align:right}

/* Coupon */
.cs-coupon{margin-top:.8rem}
.cs-coupon-label{font-size:.72rem;color:var(--text2);font-weight:500;margin-bottom:.4rem}
.cs-coupon-form{display:flex;gap:.3rem}
.cs-coupon-form input{flex:1;font-family:var(--font);font-size:.78rem;color:var(--text);background:var(--bg);border:1px solid var(--border);padding:.5rem .65rem;border-radius:var(--rs);outline:none;min-height:40px}
.cs-coupon-form input:focus{border-color:var(--accent)}
.cs-coupon-form input::placeholder{color:var(--text3)}
.cs-coupon-form button{padding:.5rem .7rem;background:var(--bg3);border:1px solid var(--border);border-radius:var(--rs);color:var(--text2);font-size:.72rem;font-weight:600;font-family:var(--font);min-height:40px;cursor:pointer}
.cs-coupon-form button:hover{border-color:var(--accent);color:var(--accent)}

/* CTA */
.cs-cta{margin-top:.8rem}
.cs-cta .btn{position:relative;overflow:hidden}
.cs-cta .shimmer,.shimmer{position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.1),transparent);animation:shimmer 3s ease infinite;pointer-events:none}
@keyframes shimmer{0%{left:-100%}100%{left:100%}}
.cs-secure{display:flex;align-items:center;justify-content:center;gap:.2rem;font-size:.58rem;color:var(--text3);margin-top:.5rem}
.cs-trust{display:flex;gap:.3rem;flex-wrap:wrap;justify-content:center;margin-top:.6rem}
.cs-trust span{font-size:.55rem;color:var(--text3);display:flex;align-items:center;gap:.12rem}
.cs-continue{display:block;text-align:center;margin-top:.6rem;font-size:.72rem;color:var(--text3);text-decoration:none}
.cs-continue:hover{color:var(--accent)}

/* Sticky mobile cart CTA */
.sticky-cart{position:fixed;bottom:0;left:0;right:0;z-index:800;padding:.5rem .85rem;background:rgba(12,12,10,.96);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-top:1px solid var(--border);display:flex;align-items:center;gap:.5rem}
.sc-info{flex:1}.sc-count{font-size:.58rem;color:var(--text3)}.sc-total{font-size:1.1rem;font-weight:700}
.sticky-cart .btn{flex-shrink:0}

/* Empty cart */
.cart-empty{text-align:center;padding:3rem 1rem}
.cart-empty-icon{font-size:3rem;margin-bottom:.6rem;display:block;opacity:.3}
.cart-empty h3{font-size:1.1rem;font-weight:700;margin-bottom:.3rem}
.cart-empty p{font-size:.82rem;color:var(--text2);margin-bottom:1.2rem;max-width:280px;margin-left:auto;margin-right:auto}

/* ══════════════════════════════════════
   Account
   ══════════════════════════════════════ */

.auth-tabs{display:flex;border-bottom:1px solid var(--border);margin-bottom:1.2rem}
.auth-tab{flex:1;text-align:center;padding:.7rem;font-size:.85rem;font-weight:500;color:var(--text3);cursor:pointer;border-bottom:2px solid transparent;transition:all .15s}
.auth-tab.on{color:var(--accent);border-bottom-color:var(--accent)}
.auth-panel{display:none}.auth-panel.on{display:block}

/* Register form */
.reg-header{display:flex;align-items:center;gap:.7rem;margin-bottom:1rem;padding-bottom:.8rem;border-bottom:1px solid var(--border)}
.reg-header-icon{width:40px;height:40px;border-radius:50%;background:var(--accent-dim);border:1px solid rgba(212,168,83,.2);display:flex;align-items:center;justify-content:center;font-size:1.1rem;font-weight:700;color:var(--accent);flex-shrink:0}
.reg-header-title{font-size:.88rem;font-weight:700}
.reg-header-desc{font-size:.68rem;color:var(--text3);line-height:1.4;margin-top:.1rem}
.reg-auto-pass{font-size:.68rem;color:var(--text3);background:var(--bg3);border:1px solid var(--border);border-radius:var(--rs);padding:.5rem .65rem;margin-bottom:.6rem;line-height:1.4}
.reg-trust{display:flex;gap:.4rem;flex-wrap:wrap;justify-content:center;margin-top:.8rem;padding-top:.6rem;border-top:1px solid var(--border)}
.reg-trust span{font-size:.55rem;color:var(--text3);display:flex;align-items:center;gap:.15rem}

/* Register form uses acc-field for inputs */
#panelRegister .acc-field{margin-bottom:.6rem}
#panelRegister .acc-form-grid{margin-bottom:.3rem}
.acc-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:1rem;margin-bottom:.6rem}
.acc-card h3{font-size:.92rem;font-weight:600;margin-bottom:.6rem;display:flex;align-items:center;gap:.3rem}
.acc-avatar{width:48px;height:48px;background:var(--accent);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#0c0c0a;font-size:1.1rem;font-weight:700;flex-shrink:0}
.acc-header{display:flex;align-items:center;gap:.8rem;margin-bottom:0}
.acc-name{font-size:1rem;font-weight:700}.acc-email{font-size:.72rem;color:var(--text3)}
.acc-links{display:flex;flex-direction:column;gap:.3rem}
.acc-link{display:flex;align-items:center;justify-content:space-between;padding:.7rem;background:var(--bg3);border:1px solid var(--border);border-radius:var(--rs);font-size:.82rem;font-weight:500;cursor:pointer;text-decoration:none;color:var(--text);transition:border-color .15s}
.acc-link:hover{border-color:rgba(212,168,83,.3)}
.acc-link:active{border-color:var(--accent)}.acc-link .al-i{font-size:1rem;margin-right:.4rem}.acc-link .al-a{color:var(--text3);font-size:.7rem}

/* Back link (for edit-address sub-page) */
.acc-back{display:inline-flex;align-items:center;font-size:.75rem;color:var(--text3);text-decoration:none;margin-bottom:.8rem;transition:color .15s}
.acc-back:hover{color:var(--accent)}

/* Account badge (count in header) */
.acc-badge{font-family:var(--mono);font-size:.58rem;color:var(--text3);background:var(--bg3);padding:.1rem .4rem;border-radius:4px;margin-left:auto}

/* Subsection titles inside a ck-body */
.acc-sub-title{font-size:.72rem;font-weight:600;color:var(--text);margin-bottom:.5rem;padding-bottom:.35rem;border-bottom:1px solid var(--border)}

/* Account cart items */
.acc-cart-items{display:flex;flex-direction:column;gap:.4rem}
.acc-cart-item{display:flex;align-items:center;gap:.5rem;padding:.4rem 0;border-bottom:1px solid var(--border)}
.acc-cart-item:last-child{border-bottom:none}
.acc-cart-img{width:44px;height:44px;border-radius:6px;overflow:hidden;flex-shrink:0;border:1px solid var(--border)}
.acc-cart-img img{width:100%;height:100%;object-fit:cover}
.acc-cart-info{flex:1;min-width:0}
.acc-cart-name{font-size:.72rem;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.acc-cart-meta{font-size:.55rem;color:var(--text3)}
.acc-cart-price{font-size:.78rem;font-weight:600;flex-shrink:0}

/* Address block inside accordion */
.acc-addr-block{padding:.5rem 0;border-bottom:1px solid var(--border)}
.acc-addr-block:last-child{border-bottom:none}
.acc-addr-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:.3rem}
.acc-addr-label{font-size:.68rem;font-weight:600;color:var(--text);text-transform:uppercase;letter-spacing:.03em}

/* Form grid & fields inside account sections */
.acc-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:.5rem;margin-bottom:.5rem}
.acc-field{display:flex;flex-direction:column;gap:.15rem;margin-bottom:.45rem}
.acc-field label{font-size:.62rem;font-weight:500;color:var(--text2);text-transform:uppercase;letter-spacing:.03em}
.acc-field label .required{color:var(--accent)}
.acc-field input,.acc-field select,.acc-field textarea{
  width:100%;font-family:var(--font);font-size:.82rem;color:var(--text);
  background:var(--bg);border:1px solid var(--border);padding:.55rem .65rem;
  border-radius:var(--rs);outline:none;min-height:42px;transition:border-color .15s;
  -webkit-appearance:none;appearance:none;
}
.acc-field input:focus,.acc-field select:focus,.acc-field textarea:focus{border-color:var(--accent)}
.acc-field input::placeholder,.acc-field textarea::placeholder{color:var(--text3);font-size:.78rem}
.acc-field-hint{font-size:.58rem;color:var(--text3);font-style:italic}

/* Address grid inside account sections */
.acc-address-grid{display:grid;grid-template-columns:1fr 1fr;gap:.45rem}
.acc-address-grid .form-row{margin:0;padding:0;display:flex;flex-direction:column;gap:.15rem}
.acc-address-grid .form-row-wide{grid-column:1/-1}
.acc-address-grid .form-row label{font-size:.62rem;font-weight:500;color:var(--text2);text-transform:uppercase;letter-spacing:.03em}
.acc-address-grid .form-row label .required{color:var(--accent)}
.acc-address-grid .form-row input,
.acc-address-grid .form-row select,
.acc-address-grid .form-row textarea{
  width:100%;font-family:var(--font);font-size:.82rem;color:var(--text);
  background:var(--bg);border:1px solid var(--border);padding:.55rem .65rem;
  border-radius:var(--rs);outline:none;min-height:42px;transition:border-color .15s;
  -webkit-appearance:none;appearance:none;
}
.acc-address-grid .form-row input:focus,
.acc-address-grid .form-row select:focus{border-color:var(--accent)}
.acc-address-grid .form-row input::placeholder{color:var(--text3);font-size:.78rem}
.acc-address-grid .form-row select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6' fill='%235c5c58'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .6rem center;padding-right:1.5rem}

/* Address cards (my-address.php) */
.acc-addr-edit{font-size:.68rem;color:var(--accent);text-decoration:none;font-weight:500;margin-left:auto}
.acc-addr-edit:hover{text-decoration:underline}
.acc-addr-text{font-style:normal;font-size:.82rem;color:var(--text2);line-height:1.6}
.acc-addr-empty{font-size:.82rem;color:var(--text3);margin:0}

/* Orders count badge */
.acc-orders-count{font-size:.62rem;color:var(--text3);font-family:var(--mono);margin-left:auto}

/* Responsive: single column on mobile */
@media(max-width:599px){
  .acc-form-grid,.acc-address-grid{grid-template-columns:1fr}
  .acc-address-grid .form-row-wide{grid-column:auto}
}

/* ══════════════════════════════════════
   Orders
   ══════════════════════════════════════ */

/* Legacy order-card kept for compat */
.order-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:.8rem;margin-bottom:.5rem}

/* New order cards inside ck-section */
.order-card-v2{display:block;padding:.75rem;border-bottom:1px solid var(--border);text-decoration:none;color:var(--text);transition:background .15s}
.order-card-v2:hover{background:var(--bg3)}
.order-card-v2:last-child{border-bottom:none}
.order-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}
.order-id{font-family:var(--mono);font-size:.62rem;color:var(--text3)}
.order-st{font-family:var(--mono);font-size:.58rem;font-weight:500;padding:.15rem .4rem;border-radius:4px}
.order-st.del{background:var(--green-dim);color:var(--green)}.order-st.ship{background:var(--accent-dim);color:var(--accent)}.order-st.proc{background:rgba(52,152,219,.1);color:#3498db}.order-st.draft{background:rgba(155,155,150,.1);color:var(--text3)}
.order-items{display:flex;gap:.4rem;margin-bottom:.5rem;overflow-x:auto;-webkit-overflow-scrolling:touch}.order-items::-webkit-scrollbar{display:none}
.order-th{width:48px;height:48px;border-radius:6px;border:1px solid var(--border);overflow:hidden;flex-shrink:0}.order-th img{width:100%;height:100%;object-fit:cover}
.order-foot{display:flex;justify-content:space-between;align-items:center;font-size:.75rem}
.order-date{color:var(--text3)}.order-tot{font-weight:700}

/* ══════════════════════════════════════
   View Order
   ══════════════════════════════════════ */

/* Header bar */
.vo-header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.3rem;margin-bottom:.6rem;padding:.6rem .75rem;background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius)}
.vo-header-left{display:flex;align-items:center;gap:.5rem}
.vo-order-num{font-size:.88rem;font-weight:700}
.vo-date{font-size:.62rem;color:var(--text3);font-family:var(--mono)}

/* Items list */
.vo-item{display:flex;align-items:center;gap:.6rem;padding:.65rem .75rem;border-bottom:1px solid var(--border)}
.vo-item:last-child{border-bottom:none}
.vo-item-img{width:56px;height:56px;border-radius:8px;overflow:hidden;flex-shrink:0;border:1px solid var(--border);background:var(--bg3)}
.vo-item-img img{width:100%;height:100%;object-fit:cover}
.vo-item-img a{display:block;width:100%;height:100%}
.vo-item-info{flex:1;min-width:0}
.vo-item-name{font-size:.78rem;font-weight:500;line-height:1.3}
.vo-item-name a{color:var(--text);text-decoration:none}.vo-item-name a:hover{color:var(--accent)}
.vo-item-meta{font-size:.55rem;color:var(--text3);margin-top:.1rem}
.vo-item-price{font-size:.82rem;font-weight:600;flex-shrink:0;white-space:nowrap}
.vo-item .wc-item-meta{list-style:none;margin:.2rem 0 0;padding:0}
.vo-item .wc-item-meta li{font-size:.55rem;color:var(--text3)}
.vo-item .wc-item-meta li strong{font-weight:500;color:var(--text2)}

/* Totals */
.vo-total-row{display:flex;justify-content:space-between;align-items:center;padding:.3rem 0;font-size:.78rem;color:var(--text2)}
.vo-total-row:not(:last-child){border-bottom:1px solid var(--border)}
.vo-total-final{font-weight:700;font-size:.92rem;color:var(--text);padding-top:.5rem;margin-top:.2rem;border-top:1px solid var(--border)}
.vo-total-final .vo-total-value{color:var(--accent)}
.vo-total-label{color:var(--text3)}

/* Customer note */
.vo-note{margin-top:.5rem;padding-top:.4rem;border-top:1px solid var(--border);font-size:.72rem;color:var(--text2);line-height:1.5}
.vo-note-label{font-weight:600;color:var(--text)}

/* Addresses grid */
.vo-addresses{display:grid;gap:.6rem}
.vo-addresses--two{grid-template-columns:1fr 1fr}
.vo-addr-title{font-size:.62rem;font-weight:600;color:var(--text);text-transform:uppercase;letter-spacing:.03em;margin-bottom:.25rem}

/* Order notes / tracking */
.vo-note-item{padding:.6rem .75rem;border-bottom:1px solid var(--border)}
.vo-note-item:last-child{border-bottom:none}
.vo-note-date{font-family:var(--mono);font-size:.55rem;color:var(--text3);margin-bottom:.2rem}
.vo-note-text{font-size:.78rem;color:var(--text2);line-height:1.5}
.vo-note-text p{margin:0}

/* Hide any WC leftovers in view-order context */
.woocommerce-MyAccount-content .woocommerce-order-details,.woocommerce-MyAccount-content .woocommerce-customer-details{display:none}

/* Responsive */
@media(max-width:599px){
  .vo-addresses--two{grid-template-columns:1fr}
}

/* ══════════════════════════════════════
   Footer
   ══════════════════════════════════════ */

.footer{background:var(--bg2);border-top:1px solid var(--border);padding:1.5rem 0 1rem}
.footer-cols{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1rem}
.footer-brand{grid-column:span 2}.footer-brand p{font-size:.72rem;color:var(--text3);margin-top:.35rem;line-height:1.5}
.footer h4{font-size:.58rem;font-family:var(--mono);font-weight:500;color:var(--text3);text-transform:uppercase;letter-spacing:.06em;margin-bottom:.4rem}
.footer ul{list-style:none}.footer ul li{margin-bottom:.2rem}.footer ul a{font-size:.78rem;color:var(--text2)}
.footer-bottom{padding-top:.8rem;border-top:1px solid var(--border);font-size:.62rem;color:var(--text3);text-align:center}

/* ══════════════════════════════════════
   Responsive
   ══════════════════════════════════════ */

@media(min-width:640px){
  .products-grid{grid-template-columns:repeat(3,1fr)}
  .hero-actions{flex-direction:row}
  .section{padding:3rem 0}
}

@media(min-width:900px){
  .container{padding:0 2rem}
  .topbar{padding:0 2rem}
  .desk-links{display:flex!important}
  .burger{display:none!important}
  .sticky-buy{display:none!important}
  .sticky-cart{display:none!important}
  .sticky-ck{display:none!important}
  .ck-layout{flex-direction:row;gap:2rem;align-items:flex-start}
  .ck-main{flex:1.5;min-width:0}
  .ck-side{flex:1;min-width:320px}
  .desk-buy{display:flex!important}
  .footer{padding:1.5rem 0}
  .products-grid{grid-template-columns:repeat(4,1fr);gap:1rem}
  .repair-list{display:grid;grid-template-columns:repeat(3,1fr)}
  .steps-col{display:grid;grid-template-columns:repeat(4,1fr)}
  .contact-layout{display:grid;grid-template-columns:1fr 1.2fr;gap:2.5rem;align-items:start}
  .pd-layout{display:grid;grid-template-columns:1.15fr 1fr;gap:2.5rem;align-items:start}
  .pd-right{position:sticky;top:calc(var(--nav) + 1rem)}
  .cart-layout{flex-direction:row;gap:2rem;align-items:flex-start}
  .cart-main{flex:1.5;min-width:0}
  .cart-side{flex:1;min-width:320px}
  .footer-cols{grid-template-columns:2fr 1fr 1fr;gap:2rem}
  .footer-brand{grid-column:span 1}
  .section{padding:4rem 0}
  .hero-title{font-size:clamp(2.2rem,3.5vw,3rem)}
}

@media(max-width:599px){
  .form-row{grid-template-columns:1fr}
}

/* ══════════════════════════════════════
   WordPress Admin Bar offset
   ══════════════════════════════════════ */

.admin-bar .topbar{top:32px}
.admin-bar .hero-wrap{padding-top:calc(var(--nav) + 32px + 1.5rem)}
.admin-bar .page-top{padding-top:calc(var(--nav) + 32px + 1rem)}
.admin-bar .mmenu-panel{padding-top:calc(var(--nav) + 32px + .6rem)}

@media(max-width:782px){
  .admin-bar .topbar{top:46px}
  .admin-bar .hero-wrap{padding-top:calc(var(--nav) + 46px + 1.5rem)}
  .admin-bar .page-top{padding-top:calc(var(--nav) + 46px + 1rem)}
  .admin-bar .mmenu-panel{padding-top:calc(var(--nav) + 46px + .6rem)}
}

/* ══════════════════════════════════════
   WooCommerce Overrides
   ══════════════════════════════════════ */

/* WC price output — strip WC wrappers to match design */
.p-price .woocommerce-Price-amount,
.p-old .woocommerce-Price-amount,
.ph-price .woocommerce-Price-amount,
.ph-old .woocommerce-Price-amount,
.ci-price-val .woocommerce-Price-amount,
.ci-price-old .woocommerce-Price-amount,
.stk-price .woocommerce-Price-amount,
.sc-total .woocommerce-Price-amount,
.gt-from .woocommerce-Price-amount,
.u-price-val .woocommerce-Price-amount,
.u-price-old .woocommerce-Price-amount,
.cart-summary .woocommerce-Price-amount,
.cs-split .woocommerce-Price-amount,
.order-tot .woocommerce-Price-amount{font:inherit;color:inherit}
.woocommerce-Price-currencySymbol{font:inherit}

/* Quantity input — match design */
.qty-input{width:36px;height:28px;text-align:center;font-family:var(--font);font-size:.82rem;font-weight:600;color:var(--text);background:transparent;border:none;outline:none;appearance:none;-moz-appearance:textfield;padding:0}
.qty-input::-webkit-inner-spin-button,.qty-input::-webkit-outer-spin-button{appearance:none;margin:0}
.qty-btn{width:28px;height:28px;border-radius:6px;border:1px solid var(--border);background:var(--bg3);color:var(--text);font-size:.85rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:border-color .15s}
.qty-btn:active{border-color:var(--accent);color:var(--accent)}
.qty-val{font-size:.82rem;font-weight:600;min-width:20px;text-align:center}

/* Add-to-cart form on single product */
.desk-buy .single_add_to_cart_button{display:inline-flex;align-items:center;justify-content:center;gap:.35rem;font-family:var(--font);font-weight:600;font-size:.88rem;padding:.85rem 1.5rem;border-radius:var(--rs);border:none;cursor:pointer;transition:all .15s;min-height:48px;background:var(--accent);color:#0c0c0a;flex:1}
.desk-buy .single_add_to_cart_button:active{background:var(--accent-hover);transform:scale(.97)}
.desk-buy form.cart{display:flex;gap:.5rem;flex:1}
.desk-buy form.cart .quantity{display:none}

/* WC notices */
.woocommerce-message,.woocommerce-info{background:var(--accent-dim);border:1px solid var(--accent);color:var(--accent);padding:.7rem 1rem;border-radius:var(--rs);font-size:.82rem;margin-bottom:1rem}
.woocommerce-error{background:rgba(231,76,60,.1);border:1px solid var(--red);color:var(--red);padding:.7rem 1rem;border-radius:var(--rs);font-size:.82rem;margin-bottom:1rem;list-style:none}
.woocommerce-message a,.woocommerce-info a{color:var(--accent);font-weight:600}
.woocommerce-error a{color:var(--red);font-weight:600}

/* WC pagination */
.woocommerce-pagination{display:flex;justify-content:center;gap:.3rem;margin-top:1.5rem}
.woocommerce-pagination .page-numbers{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:var(--rs);border:1px solid var(--border);background:var(--bg2);font-size:.82rem;font-weight:500;color:var(--text2);text-decoration:none;transition:all .15s}
.woocommerce-pagination .page-numbers.current,.woocommerce-pagination .page-numbers:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-dim)}
.woocommerce-pagination .page-numbers.dots{border:none;background:none}

/* Cart-specific WC overrides */
.woocommerce-cart-form .cart-item{display:flex;gap:.65rem;padding:.75rem;background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius)}

/* WC account — endpoint content styling */
.woocommerce-MyAccount-content{margin-top:0}
.woocommerce-MyAccount-content h2,.woocommerce-MyAccount-content h3{font-size:1rem;font-weight:700;margin-bottom:.6rem}
.woocommerce-MyAccount-content p{font-size:.82rem;color:var(--text2);line-height:1.6;margin-bottom:.6rem}
.woocommerce-MyAccount-content a{color:var(--accent)}

/* Hide default WC account navigation — we use custom links */
.woocommerce-MyAccount-navigation{display:none}

/* WC address fields (inside acc-section cards) */
.woocommerce-address-fields .form-row{margin-bottom:.6rem}
.woocommerce-address-fields label{font-size:.62rem;font-weight:500;color:var(--text2);display:block;margin-bottom:.2rem;text-transform:uppercase;letter-spacing:.03em}
.woocommerce-address-fields label .required{color:var(--accent)}
.woocommerce-address-fields input,.woocommerce-address-fields select{font-family:var(--font);font-size:.82rem;color:var(--text);background:var(--bg);border:1px solid var(--border);padding:.55rem .65rem;border-radius:var(--rs);outline:none;width:100%;min-height:42px;transition:border-color .15s;-webkit-appearance:none;appearance:none}
.woocommerce-address-fields input:focus,.woocommerce-address-fields select:focus{border-color:var(--accent)}
.woocommerce-address-fields input::placeholder{color:var(--text3);font-size:.78rem}
.woocommerce-address-fields select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6' fill='%235c5c58'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .6rem center;padding-right:1.5rem}

/* WC edit-account form (inside acc-section cards) */
.woocommerce-EditAccountForm .form-row{margin-bottom:.6rem}
.woocommerce-EditAccountForm label{font-size:.62rem;font-weight:500;color:var(--text2);display:block;margin-bottom:.2rem;text-transform:uppercase;letter-spacing:.03em}
.woocommerce-EditAccountForm label .required{color:var(--accent)}
.woocommerce-EditAccountForm input{font-family:var(--font);font-size:.82rem;color:var(--text);background:var(--bg);border:1px solid var(--border);padding:.55rem .65rem;border-radius:var(--rs);outline:none;width:100%;min-height:42px;transition:border-color .15s;-webkit-appearance:none;appearance:none}
.woocommerce-EditAccountForm input:focus{border-color:var(--accent)}
.woocommerce-EditAccountForm input::placeholder{color:var(--text3);font-size:.78rem}
.woocommerce-EditAccountForm fieldset{border:none;padding:0;margin:0}
.woocommerce-EditAccountForm fieldset legend{display:none}
.woocommerce-EditAccountForm button[type="submit"].button{display:none}
.woocommerce-EditAccountForm .clear{display:none}
.woocommerce-EditAccountForm #account_display_name_description{display:none}

/* ══════════════════════════════════════
   Checkout v2
   ══════════════════════════════════════ */

/* Remove page.php wrappers on checkout & cart */
.woocommerce-checkout .page-top,.woocommerce-cart .page-top{display:none}
.woocommerce-checkout .section,.woocommerce-cart .section{padding:0}
.woocommerce-checkout .section>.container,.woocommerce-cart .section>.container{max-width:none;padding:0}
.woocommerce-checkout .page-body,.woocommerce-cart .page-body{font-size:inherit;color:inherit;line-height:inherit;width:100%;max-width:none}

/* Progress Steps */
.steps{display:flex;align-items:center;justify-content:center;gap:0;padding:.8rem 0 .6rem;margin-bottom:.8rem}
.step{display:flex;align-items:center;gap:.3rem;font-size:.62rem;font-weight:500;color:var(--text3)}
.step-num{width:22px;height:22px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.52rem;font-weight:700;border:1.5px solid var(--border);background:var(--bg2);color:var(--text3);flex-shrink:0;transition:all .2s}
.step.done .step-num{background:var(--accent);border-color:var(--accent);color:#0c0c0a}
.step.active .step-num{border-color:var(--accent);color:var(--accent);background:var(--accent-dim)}
.step.done .step-label,.step.active .step-label{color:var(--text)}
.step-line{width:28px;height:1.5px;background:var(--border);margin:0 .35rem;flex-shrink:0}
.step-line.done{background:var(--accent)}

/* Layout */
.woocommerce-checkout form.checkout{width:100%}
.ck-layout{display:flex;flex-direction:column;gap:1.2rem}
.ck-main{min-width:0}

/* Section cards */
.ck-section{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}
.ck-header{display:flex;align-items:center;gap:.4rem;padding:.65rem .75rem;border-bottom:1px solid var(--border);cursor:pointer;-webkit-tap-highlight-color:transparent}
.ck-header-num{width:22px;height:22px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.55rem;font-weight:700;background:rgba(212,168,83,.18);color:var(--accent);flex-shrink:0}
.ck-header-title{font-size:.82rem;font-weight:600;flex:1}
.ck-header-arrow{font-size:.55rem;color:var(--text3);transition:transform .2s}
.ck-body{padding:.75rem}
.ck-section.collapsed .ck-body{display:none}
.ck-section.collapsed .ck-header-arrow{transform:rotate(-90deg)}
.ck-section.collapsed .ck-header{border-bottom:none}

/* WC billing/shipping fields inside ck-section */
.woocommerce-checkout .woocommerce-billing-fields__field-wrapper,
.woocommerce-checkout .woocommerce-shipping-fields__field-wrapper{display:grid;grid-template-columns:1fr 1fr;gap:.45rem}
.woocommerce-checkout .form-row-wide{grid-column:1/-1}
.woocommerce-checkout .form-row{margin:0;padding:0;display:flex;flex-direction:column;gap:.15rem}
.woocommerce-checkout .form-row label{font-size:.62rem;font-weight:500;color:var(--text2);text-transform:uppercase;letter-spacing:.03em}
.woocommerce-checkout .form-row label .required{color:var(--accent)}
.woocommerce-checkout .form-row input,.woocommerce-checkout .form-row select,.woocommerce-checkout .form-row textarea{
  width:100%;font-family:var(--font);font-size:.82rem;color:var(--text);
  background:var(--bg);border:1px solid var(--border);padding:.55rem .65rem;
  border-radius:var(--rs);outline:none;min-height:42px;transition:border-color .15s;
  -webkit-appearance:none;appearance:none;
}
.woocommerce-checkout .form-row input:focus,.woocommerce-checkout .form-row select:focus,.woocommerce-checkout .form-row textarea:focus{border-color:var(--accent)}
.woocommerce-checkout .form-row input::placeholder,.woocommerce-checkout .form-row textarea::placeholder{color:var(--text3);font-size:.78rem}
.woocommerce-checkout .form-row select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6' fill='%235c5c58'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .6rem center;padding-right:1.5rem}
.woocommerce-checkout .form-row textarea{resize:vertical;min-height:60px}
.woocommerce-checkout h3{font-size:.82rem;font-weight:600;margin-bottom:.5rem;color:var(--text)}
.woocommerce-checkout #ship-to-different-address{margin:0 0 .5rem}
.woocommerce-checkout #ship-to-different-address label{font-size:.78rem;display:flex;align-items:center;gap:.3rem;cursor:pointer}
.woocommerce-checkout #ship-to-different-address input[type="checkbox"]{width:16px;height:16px;accent-color:var(--accent)}

/* Hide default col2-set wrapper — we use ck-section instead */
.woocommerce-checkout .col2-set{display:contents}
.woocommerce-checkout .col-1,.woocommerce-checkout .col-2{display:contents}

/* Order notes textarea in ck-section */
.ck-section .form-group textarea{width:100%;font-family:var(--font);font-size:.82rem;color:var(--text);background:var(--bg);border:1px solid var(--border);padding:.55rem .65rem;border-radius:var(--rs);outline:none;min-height:60px;resize:vertical}
.ck-section .form-group textarea:focus{border-color:var(--accent)}
.ck-section .form-group textarea::placeholder{color:var(--text3);font-size:.78rem}

/* Order Summary sidebar */
.ck-summary{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:1rem;position:sticky;top:calc(var(--nav) + 1rem)}
.cs-item{display:flex;gap:.5rem;padding:.45rem 0;border-bottom:1px solid var(--border)}
.cs-item:last-of-type{border-bottom:none}
.cs-item-img{width:50px;height:50px;border-radius:6px;overflow:hidden;flex-shrink:0;background:var(--bg3);border:1px solid var(--border)}
.cs-item-img img{width:100%;height:100%;object-fit:cover}
.cs-item-info{flex:1;min-width:0}
.cs-item-name{font-size:.68rem;font-weight:500;line-height:1.25;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.cs-item-meta{font-size:.52rem;color:var(--text3)}
.cs-item-price{font-size:.78rem;font-weight:600;flex-shrink:0}
.cs-divider{height:1px;background:var(--border);margin:.5rem 0}
.cs-edit{display:block;text-align:center;margin-top:.5rem;font-size:.68rem;color:var(--text3)}
.cs-edit:hover{color:var(--accent)}

/* Shipping methods — card style */
.ck-shipping-methods .woocommerce-shipping-methods{list-style:none;margin:0;padding:0}
.ck-shipping-methods .woocommerce-shipping-methods li{margin-bottom:.35rem}
.ck-shipping-methods .woocommerce-shipping-methods li label{
  display:flex;align-items:center;gap:.55rem;padding:.6rem .65rem;
  background:var(--bg);border:1px solid var(--border);border-radius:var(--rs);
  cursor:pointer;transition:all .15s;font-size:.78rem;font-weight:600;
}
.ck-shipping-methods .woocommerce-shipping-methods li label:hover{border-color:rgba(212,168,83,.3)}
.ck-shipping-methods .woocommerce-shipping-methods li input[type="radio"]{accent-color:var(--accent);width:16px;height:16px;flex-shrink:0}
.ck-shipping-methods .woocommerce-shipping-methods li input[type="radio"]:checked + label,
.ck-shipping-methods .woocommerce-shipping-methods li.active label{border-color:var(--accent);background:var(--accent-dim)}
.ck-shipping-methods .shipping-method-description{font-size:.58rem;color:var(--text3);margin-top:.1rem}
.ck-shipping-methods .woocommerce-shipping-totals td,.ck-shipping-methods .woocommerce-shipping-totals th{display:none}
.ck-shipping-methods table{border:none;width:100%}
.ck-shipping-methods table td{padding:0;border:none}

/* Payment section — card style */
.ck-payment-wrap #payment{background:none;border:none;border-radius:0;padding:0}
.ck-payment-wrap .wc_payment_methods{list-style:none;margin:0;padding:0}
.ck-payment-wrap .wc_payment_method{margin-bottom:.35rem}
.ck-payment-wrap .wc_payment_method label{
  display:flex;align-items:center;gap:.55rem;padding:.6rem .65rem;
  background:var(--bg);border:1px solid var(--border);border-radius:var(--rs);
  cursor:pointer;transition:all .15s;font-size:.78rem;font-weight:600;
}
.ck-payment-wrap .wc_payment_method label:hover{border-color:rgba(212,168,83,.3)}
.ck-payment-wrap .wc_payment_method input[type="radio"]{accent-color:var(--accent);width:16px;height:16px;flex-shrink:0}
.ck-payment-wrap .wc_payment_method input[type="radio"]:checked ~ label,
.ck-payment-wrap .wc_payment_method.active label{border-color:var(--accent);background:var(--accent-dim)}
.ck-payment-wrap .payment_box{padding:.55rem .65rem;font-size:.72rem;color:var(--text2);background:var(--bg);border:1px solid var(--border);border-top:none;border-radius:0 0 var(--rs) var(--rs);margin-top:-1px;margin-bottom:.35rem}
.ck-payment-wrap .payment_box::before{display:none}
.ck-payment-wrap .payment_box p{margin:0}

/* Place order button */
#place_order{display:inline-flex;align-items:center;justify-content:center;font-family:var(--font);font-weight:600;font-size:.88rem;padding:.85rem 1.5rem;border-radius:var(--rs);border:none;cursor:pointer;background:var(--accent);color:#0c0c0a;width:100%;min-height:48px;margin-top:.5rem;position:relative;overflow:hidden}
.ck-payment-wrap .place-order{margin:0;padding:0}
.woocommerce-terms-and-conditions-wrapper{margin-top:.3rem}
.woocommerce-terms-and-conditions-wrapper .woocommerce-privacy-policy-text{font-size:.58rem;color:var(--text3)}
.woocommerce-terms-and-conditions-wrapper .woocommerce-privacy-policy-text a{color:var(--accent)}

/* Privacy note */
.privacy-note{font-size:.58rem;color:var(--text3);line-height:1.5}
.privacy-note a{color:var(--accent);text-decoration:underline}

/* Sticky mobile CTA */
.sticky-ck{position:fixed;bottom:0;left:0;right:0;z-index:80;padding:.5rem .85rem;background:rgba(12,12,10,.96);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-top:1px solid var(--border);display:flex;align-items:center;gap:.5rem}
.sk-info{flex:1}
.sk-label{font-size:.55rem;color:var(--text3)}
.sk-total{font-size:1.1rem;font-weight:700}
.sticky-ck .btn{flex-shrink:0}

/* WC notices on checkout */
.woocommerce-checkout .woocommerce-NoticeGroup{margin-bottom:.8rem}
.woocommerce-checkout .woocommerce-error,.woocommerce-checkout .woocommerce-message,.woocommerce-checkout .woocommerce-info{background:var(--bg2);border:1px solid var(--border);border-radius:var(--rs);padding:.6rem .75rem;font-size:.78rem;color:var(--text2);list-style:none;margin-bottom:.4rem}
.woocommerce-checkout .woocommerce-error{border-color:rgba(231,76,60,.3);color:var(--red)}

/* Hide default order review table — we built our own summary */
.woocommerce-checkout .woocommerce-checkout-review-order-table{display:none}
.woocommerce-checkout #order_review_heading{display:none}

/* Login/coupon toggles */
.woocommerce-checkout .woocommerce-form-login-toggle,.woocommerce-checkout .woocommerce-form-coupon-toggle{margin-bottom:.5rem}
.woocommerce-checkout .woocommerce-form-login-toggle .woocommerce-info,
.woocommerce-checkout .woocommerce-form-coupon-toggle .woocommerce-info{background:var(--accent-dim);border:1px solid rgba(212,168,83,.15);border-radius:var(--rs);padding:.45rem .65rem;font-size:.72rem;color:var(--text2)}
.woocommerce-checkout .woocommerce-form-login-toggle .woocommerce-info a,
.woocommerce-checkout .woocommerce-form-coupon-toggle .woocommerce-info a{color:var(--accent);font-weight:500}
.woocommerce-checkout .woocommerce-form-login,.woocommerce-checkout .checkout_coupon{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:.75rem;margin-bottom:.8rem}
.woocommerce-checkout .checkout_coupon .form-row{display:flex;gap:.3rem;flex-direction:row;align-items:center}
.woocommerce-checkout .checkout_coupon .form-row input{flex:1}
.woocommerce-checkout .checkout_coupon .form-row button{padding:.55rem .7rem;background:var(--bg3);border:1px solid var(--border);border-radius:var(--rs);color:var(--text2);font-size:.72rem;font-weight:600;font-family:var(--font);min-height:42px;cursor:pointer}
.woocommerce-checkout .checkout_coupon .form-row button:hover{border-color:var(--accent);color:var(--accent)}

/* Cancel status for orders */
.order-st.canc{background:rgba(231,76,60,.1);color:var(--red)}

/* WC product images in templates */
.p-img .attachment-woocommerce_thumbnail{width:100%;height:100%;object-fit:cover}
.order-th .attachment-woocommerce_gallery_thumbnail{width:100%;height:100%;object-fit:cover}
.cart-img .attachment-woocommerce_thumbnail{width:100%;height:100%;object-fit:cover}

/* WC filters-bar link style */
.filters-bar{display:flex;gap:.3rem;overflow-x:auto;-webkit-overflow-scrolling:touch;padding:.1rem 0 .5rem}.filters-bar::-webkit-scrollbar{display:none}
.filter-chip{flex-shrink:0;font-family:var(--font);font-size:.72rem;font-weight:500;color:var(--text2);background:var(--bg2);border:1px solid var(--border);padding:.35rem .65rem;border-radius:100px;cursor:pointer;white-space:nowrap;transition:all .15s;text-decoration:none}
.filter-chip:active,.filter-chip.active{color:var(--accent);background:var(--accent-dim);border-color:var(--accent)}
.sub-filters{display:flex;gap:.2rem;flex-wrap:wrap;margin-bottom:.5rem}
.sub-chip{font-family:var(--font);font-size:.62rem;color:var(--text3);background:var(--bg3);border:1px solid transparent;padding:.2rem .45rem;border-radius:4px;cursor:pointer;transition:all .15s}
.sub-chip:active,.sub-chip.active{border-color:var(--accent);color:var(--accent);background:var(--accent-dim)}
.results-count{display:block;font-size:.72rem;color:var(--text3);margin-bottom:.6rem}

/* Hide default WC elements we don't need */
.woocommerce-result-count,.woocommerce-ordering{display:none}

/* Hide WC default variation dropdown — we use grade tabs instead */
.variations_form .variations{display:none!important}
.variations_form .woocommerce-variation.single_variation{display:none!important}
.variations_form .woocommerce-variation-add-to-cart .quantity{display:none}

/* "à partir de" label on product cards */
.p-from{font-size:.55rem;color:var(--text3);display:block;line-height:1;margin-bottom:.05rem}

/* Old v2 compat — kept for archive cards */
.g-oos{font-family:var(--mono);font-size:.55rem;color:var(--red);display:block;margin-top:.1rem}
