
:root{
  --bg:#0b0a0c;--panel:#131216;--marble:#f4f1ec;
  --gold:#e6b543;--gold-l:#f0d088;--gold-d:#c99a2f;
  --cream:#f6f1e7;--muted:#cdc4b4;--line:rgba(230,181,67,.22);
  --maxw:1240px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;overflow-x:hidden}
body{background:var(--bg);color:var(--cream);font-family:'Outfit',sans-serif;font-weight:300;line-height:1.7;overflow-x:hidden;-webkit-font-smoothing:antialiased}
h1,h2,h3,.disp{font-family:'Fraunces',serif;font-weight:300;line-height:1.06;letter-spacing:-.01em}
a{color:inherit;text-decoration:none}img{display:block;max-width:100%}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 32px}
.eyebrow{font-size:.68rem;letter-spacing:.4em;text-transform:uppercase;color:var(--gold);font-weight:500}
.gold-grad{background:linear-gradient(120deg,var(--gold-l),var(--gold),var(--gold-l));-webkit-background-clip:text;background-clip:text;color:transparent}

/* ---- NAV ---- */
header{position:sticky;top:0;inset:auto;z-index:300;transition:.4s;border-bottom:1px solid transparent}header.sc{border-color:transparent}
header.sc{background:rgba(11,10,12,.86);backdrop-filter:blur(14px);border-color:var(--line)}
nav{display:flex;align-items:center;justify-content:space-between;height:140px;max-width:var(--maxw);margin:0 auto;padding:0 32px}
.brand{display:flex;align-items:center;gap:13px}
.brand img{height:110px;width:auto}
.brand .txt{font-family:'Fraunces';font-size:1.15rem;letter-spacing:.06em;line-height:1.05}
.brand .txt b{display:block;font-weight:500}
.brand .txt span{font-size:.62rem;letter-spacing:.34em;text-transform:uppercase;color:var(--gold);font-weight:400}
.nl{display:flex;gap:32px;align-items:center}
.nl a{font-size:.76rem;letter-spacing:.14em;text-transform:uppercase;color:#f6f1e7;transition:.3s;position:relative}
.nl a.btn-g,.nl a.btn-g:hover{color:#000}
.nl a:hover{color:var(--gold-l)}
.btn{padding:13px 26px;font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;font-weight:500;transition:.35s;display:inline-flex;align-items:center;gap:8px;border:1px solid transparent;cursor:pointer}
.btn-g{background:linear-gradient(120deg,var(--gold),var(--gold-l));color:#000;font-weight:600}
.btn-g:hover{color:#000}
.btn-g:hover{transform:translateY(-2px);box-shadow:0 14px 34px -12px rgba(230,181,67,.55)}
.btn-o{border-color:var(--line);color:var(--cream)}
.btn-o:hover{border-color:var(--gold);color:var(--gold-l)}
.burger{display:none;font-size:1.4rem;background:none;border:0;color:var(--cream);cursor:pointer}

/* ---- HERO ---- */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;overflow:hidden;padding:158px 0 40px !important}
.hero-bg{position:absolute;inset:0;z-index:0;overflow:hidden}
.hero-slide{position:absolute;inset:0;background-size:cover;background-position:right -80px center;background-repeat:no-repeat;opacity:0;transition:opacity 1.2s ease;filter:brightness(1.05) contrast(1.0)}
.hero-slide:nth-child(2){background-position:right -280px center}
.hero-slide:nth-child(3){background-position:right -280px center}
.hero-slide.active{opacity:.92}
.hero-glow{position:absolute;z-index:1;width:680px;height:680px;border-radius:50%;background:radial-gradient(circle,rgba(230,181,67,.18),transparent 68%);right:14%;top:38%;transform:translateY(-50%);filter:blur(24px);pointer-events:none}
.hero-shade{position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(11,10,12,.95) 0%,rgba(11,10,12,.45) 12%,transparent 28%,transparent 68%,var(--bg) 100%),linear-gradient(90deg,rgba(11,10,12,.95) 0%,rgba(11,10,12,.88) 18%,rgba(11,10,12,.72) 36%,rgba(11,10,12,.5) 54%,rgba(11,10,12,.28) 72%,rgba(11,10,12,.08) 90%,transparent 100%);pointer-events:none}
.hero .wrap{position:relative;z-index:2;width:100%;display:grid;grid-template-columns:1.2fr .8fr;gap:48px;align-items:center}
.hero-inner{max-width:640px}
.hero h1{font-size:clamp(2.7rem,6.5vw,5.6rem);margin:0 0 24px;opacity:0;animation:fadeUp .9s .2s forwards}
.hero h1 em{font-style:italic;color:var(--gold)}
.hero .eyebrow{opacity:0;animation:fadeUp .9s .05s forwards}
.hero p{font-size:1.15rem;color:var(--cream);max-width:480px;margin-bottom:36px;opacity:0;animation:fadeUp .9s .35s forwards}
.hbtns{display:flex;gap:16px;flex-wrap:wrap;margin-bottom:48px;opacity:0;animation:fadeUp .9s .5s forwards}
.badges{display:flex;gap:24px;flex-wrap:nowrap;opacity:0;animation:fadeUp .9s .65s forwards}
.badges-row2{display:none}
.badge{border-left:1px solid var(--line);padding-left:16px}
.badge b{font-family:'Fraunces';font-size:1.85rem;display:block;line-height:1}
.badge span{font-size:.64rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}

/* signature ring */
.ring-stage{position:relative;display:flex;align-items:center;justify-content:center;aspect-ratio:1;opacity:0;animation:fadeIn 1.4s .6s forwards}
.ring-stage svg{width:100%;max-width:400px;overflow:visible}
.rot{transform-origin:center;animation:spin 40s linear infinite}
.rot2{transform-origin:center;animation:spin 28s linear infinite reverse}
.ring-core{position:absolute;text-align:center}
.ring-core .deg{font-family:'Fraunces';font-size:3.4rem;color:var(--gold-l);line-height:1}
.ring-core .deg small{font-size:1.2rem;vertical-align:super;color:var(--gold)}
.ring-core .cap{font-size:.66rem;letter-spacing:.28em;text-transform:uppercase;color:var(--cream);margin-top:8px;opacity:.8}

@keyframes spin{to{transform:rotate(360deg)}}
@keyframes fadeUp{from{opacity:0;transform:translateY(26px)}to{opacity:1;transform:none}}
@keyframes fadeIn{to{opacity:1}}

/* ---- AWARDS BAR ---- */
.awards{background:var(--panel);border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:22px 0;overflow:hidden;white-space:nowrap}
.aw-track{display:inline-flex;gap:50px;align-items:center;animation:slide 34s linear infinite;font-family:'Fraunces';font-style:italic;font-size:1.05rem;color:var(--muted)}
.aw-track span{display:inline-flex;align-items:center;gap:50px}
.aw-track b{color:var(--gold);font-style:normal}
@keyframes slide{to{transform:translateX(-50%)}}

/* ---- SECTIONS ---- */
section{padding:64px 0;position:relative}
.sh{max-width:660px;margin-bottom:36px}
.sh h2{font-size:clamp(2.1rem,4.5vw,3.6rem);margin-top:14px}
.sh h2 em{font-style:italic;color:var(--gold)}
.sh p{color:var(--muted);margin-top:14px;font-size:1.05rem}

/* treatments */
.treatments{background:var(--panel)}
.tg{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line)}
.tc{background:var(--panel);transition:.45s;position:relative;overflow:hidden;display:flex;flex-direction:column}
.tc::before{content:"";position:absolute;left:0;top:0;height:2px;width:0;background:linear-gradient(90deg,var(--gold),var(--gold-l));transition:.45s;z-index:3}
.tc:hover{background:var(--bg)}
.tc:hover::before{width:100%}
.tc .tcimg{position:relative;aspect-ratio:16/10;overflow:hidden;background:#1a140c}
.tc .tcimg img{width:100%;height:100%;object-fit:cover;transition:.6s}
.tc:hover .tcimg img{transform:scale(1.06)}
.tc .tcimg .num{position:absolute;top:16px;left:18px;font-family:'Fraunces';font-style:italic;color:var(--gold);font-size:1.05rem;z-index:2;text-shadow:0 2px 8px rgba(0,0,0,.8)}
.tc .tcbody{padding:30px 30px 36px;display:flex;flex-direction:column;flex:1}
.tc .ic{width:42px;height:42px;color:var(--gold);margin-bottom:16px}
.tc h3{font-size:1.4rem;margin-bottom:10px}
.tc p{color:var(--muted);font-size:.92rem;margin-bottom:20px;flex:1}
.tc a{font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--gold);display:inline-flex;gap:8px;transition:.3s}
.tc:hover a{gap:14px}

/* productos destacados */
.featured{background:var(--panel)}
.pg{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.pcard{background:var(--bg);border:1px solid var(--line);border-radius:4px;overflow:hidden;transition:.4s;display:flex;flex-direction:column}
.pcard:hover{transform:translateY(-6px);box-shadow:0 26px 56px -28px rgba(0,0,0,.7);border-color:var(--gold)}
.pcard .ph{position:relative;aspect-ratio:4/3;overflow:hidden;background:#1a1a1a}
.pcard .ph img{width:100%;height:100%;object-fit:cover;transition:.6s}
.pcard:hover .ph img{transform:scale(1.05)}
.pcard .tag{position:absolute;top:14px;left:14px;background:var(--gold);color:#000;font-size:.62rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;padding:6px 12px;border-radius:2px}
.pcard .body{padding:26px 24px 28px;display:flex;flex-direction:column;flex:1}
.pcard h3{font-size:1.3rem;margin-bottom:6px;line-height:1.15}
.pcard .cat{font-size:.66rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);margin-bottom:14px}
.pcard .price{display:flex;align-items:baseline;gap:10px;margin:auto 0 18px}
.pcard .price .now{font-family:'Fraunces';font-size:1.7rem;color:var(--cream)}
.pcard .price .was{font-size:.95rem;color:var(--muted);text-decoration:line-through}
.pcard .pbtn{display:inline-flex;align-items:center;justify-content:center;gap:8px;background:transparent;border:1px solid var(--gold);color:var(--gold);padding:12px 0;font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;font-weight:500;transition:.3s;border-radius:2px}
.pcard .pbtn:hover{background:var(--gold);color:#000}

/* method */
.method .wrap{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.method h2{font-size:clamp(2rem,4vw,3.2rem)}.method h2 em{font-style:italic;color:var(--gold)}
.mv{position:relative}
.mv img{aspect-ratio:4/5;object-fit:cover;filter:grayscale(.15) brightness(.95);width:100%}
.mv .seal{position:absolute;right:-22px;bottom:32px;width:124px;height:124px;border-radius:50%;background:linear-gradient(120deg,var(--gold),var(--gold-l));display:flex;align-items:center;justify-content:center;text-align:center;color:#1a1408;font-family:'Fraunces';font-size:.82rem;font-weight:500;line-height:1.25;padding:10px;box-shadow:0 18px 40px -16px rgba(230,181,67,.5)}
.ms{margin-top:32px}
.msx{display:flex;gap:20px;padding:24px 0;border-top:1px solid var(--line)}
.msx:last-child{border-bottom:1px solid var(--line)}
.msx .n{font-family:'Fraunces';font-style:italic;font-size:1.4rem;color:var(--gold);flex:none;width:34px}
.msx h4{font-weight:500;font-size:1.06rem;margin-bottom:3px}
.msx p{color:var(--muted);font-size:.9rem}

/* clinics */
.cg{display:grid;grid-template-columns:repeat(5,1fr);gap:14px}
.cc{border:1px solid var(--line);padding:30px 22px;transition:.4s}
.cc:hover{border-color:var(--gold);background:var(--panel);transform:translateY(-4px)}
.cc .pin{width:8px;height:8px;border-radius:50%;background:var(--gold);display:inline-block;margin-bottom:16px;box-shadow:0 0 0 5px rgba(230,181,67,.16)}
.cc .c{font-family:'Fraunces';font-size:1.35rem;margin-bottom:8px}
.cc .a{font-size:.82rem;color:var(--muted);line-height:1.55}
/* --- Nuevo diseño de clínicas --- */
.clin-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:30px}
.clin-card{background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:20px 22px;display:flex;gap:14px;align-items:flex-start;transition:.4s}
.clin-card:hover{border-color:var(--gold);transform:translateY(-4px)}
.clin-pin{width:24px;height:24px;color:var(--gold);flex-shrink:0;margin-top:2px}
.clin-name{font-family:'Fraunces';font-size:1.25rem;color:var(--cream);margin-bottom:4px}
.clin-addr{font-size:.82rem;color:var(--muted);line-height:1.5}
.clin-soon-label{text-align:center;margin:36px 0 18px}
.clin-soon-label span{display:inline-block;background:rgba(230,181,67,.12);color:var(--gold);font-size:.68rem;letter-spacing:.2em;padding:7px 18px;border-radius:20px;border:1px solid rgba(230,181,67,.3)}
.clin-soon-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}
.clin-soon{border:1px dashed rgba(230,181,67,.3);border-radius:10px;padding:16px 10px;text-align:center;transition:.4s}
.clin-soon:hover{border-color:var(--gold)}
.clin-pin-s{width:20px;height:20px;color:var(--gold);margin-bottom:6px}
.clin-name-s{font-size:.95rem;color:var(--cream)}
.clin-soon-txt{font-size:.7rem;color:var(--muted);margin-top:3px}

/* testimonials */
.testi{background:var(--panel);overflow:hidden}
.qg{display:flex;gap:22px;width:max-content;animation:qscroll 40s linear infinite}
.testi:hover .qg{animation-play-state:paused}
.q{border:1px solid var(--line);padding:38px 32px;background:var(--bg);flex:0 0 360px;width:360px}
@keyframes qscroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.q .s{color:var(--gold);letter-spacing:3px;margin-bottom:16px}
.q p{font-family:'Fraunces';font-style:italic;font-size:1.18rem;line-height:1.45;margin-bottom:18px;color:var(--cream)}
.q .w{font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}

/* closer */
.closer{text-align:center;padding:150px 0;position:relative;overflow:hidden}
.closer::before{content:"";position:absolute;inset:0;background:radial-gradient(60% 80% at 50% 28%,rgba(230,181,67,.13),transparent 70%)}
.closer .wrap{position:relative;z-index:2}
.closer img.cl-logo{height:90px;width:auto;margin:0 auto 30px;opacity:.95}
.closer h2{font-size:clamp(2.6rem,6vw,5rem)}.closer h2 em{font-style:italic;color:var(--gold)}
.closer p{color:var(--muted);max-width:480px;margin:18px auto 38px}

/* footer */
footer{border-top:1px solid var(--line);padding:64px 0 34px;background:var(--panel)}
.fg{display:grid;grid-template-columns:1.8fr 1.1fr 1.1fr 1.3fr 1fr;gap:30px;margin-bottom:44px}
.fg h5{font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);margin-bottom:18px}
.fg a,.fg p{display:block;color:var(--muted);font-size:.9rem;margin-bottom:10px;transition:.3s}
.fg a:hover{color:var(--cream)}
.foot-brand img{height:60px;margin-bottom:18px}
.foot-brand p{max-width:260px;color:var(--muted);font-size:.92rem}
.foot-icons{display:flex;gap:20px;align-items:center;margin-top:18px;font-size:1.4rem}
.foot-icons a{color:var(--cream);transition:.25s;position:relative;text-decoration:none}
.foot-icons a:hover{color:var(--gold)}
.foot-icons .cart-count{position:absolute;top:-8px;right:-10px;background:var(--gold);color:#000;font-size:.6rem;font-weight:600;width:16px;height:16px;border-radius:50%;display:flex;align-items:center;justify-content:center}
.fb{border-top:1px solid var(--line);padding-top:24px;display:flex;justify-content:space-between;font-size:.78rem;color:var(--muted);flex-wrap:wrap;gap:12px}

.reveal{opacity:0;transform:translateY(30px);transition:.9s cubic-bezier(.16,1,.3,1)}
.reveal.in{opacity:1;transform:none}

.wa{position:fixed;right:24px;bottom:24px;z-index:90;width:56px;height:56px;border-radius:50%;background:linear-gradient(120deg,var(--gold),var(--gold-l));color:#1a1408;display:flex;align-items:center;justify-content:center;box-shadow:0 12px 30px -8px rgba(230,181,67,.5);transition:.35s}
.wa:hover{transform:scale(1.08) translateY(-2px)}

@media(max-width:1100px){
  .fg{grid-template-columns:repeat(3,1fr)}
}
@media(max-width:980px){
  .hero .wrap{grid-template-columns:1fr;gap:30px}
  .ring-stage{order:-1;max-width:300px;margin:0 auto}
  .method .wrap{grid-template-columns:1fr;gap:40px}
  .pg{grid-template-columns:1fr}
  .tg,.qg{grid-template-columns:1fr}
  .cg{grid-template-columns:1fr 1fr}
  .fg{grid-template-columns:repeat(3,1fr)}
  .nl{display:none}.burger{display:block}
  .hero-shade{background:linear-gradient(180deg,transparent 0%,transparent 45%,var(--bg) 100%)}
}
@media(max-width:520px){.cg{grid-template-columns:1fr}.fg{grid-template-columns:1fr}.badges{gap:22px}.brand .txt{display:none}.clin-grid{grid-template-columns:1fr}.clin-soon-grid{grid-template-columns:1fr 1fr}}

/* ====== AJUSTES MÓVIL (celular) ====== */
@media(max-width:768px){
  /* Header transparente; fondo solo en cápsulas detrás del logo y la hamburguesa */
  .cgm-header{background:transparent !important;position:absolute !important;top:0;left:0;right:0;border-bottom:1px solid transparent !important}
  .cgm-header.sc{background:rgba(11,10,12,.96) !important;position:fixed !important;border-bottom:1px solid rgba(230,181,67,.22) !important}
  .cgm-header.sc .cgm-logo,.cgm-header.sc .cgm-burger{background:transparent !important;padding:0 !important;border-radius:0 !important}
  .cgm-header .cgm-bar{height:84px !important;padding:0 16px;justify-content:space-between}
  .cgm-logo{background:transparent;border:0;padding:0}
  .cgm-logo img{height:70px !important}
  .cgm-burger{background:rgba(11,10,12,.55);border-radius:12px;padding:6px 12px !important}
  .cgm-nav{top:84px !important}
  /* En móvil: solo hamburguesa a la derecha, ocultar iconos buscar/cuenta/carrito */
  .cgm-icons{display:none !important}
  .cgm-burger{display:block;margin-left:auto;order:3}
  /* Hero: foto fondo completo con texto encima (sin banner), foto alejada (zoom out) */
  .hero{min-height:auto;padding:110px 0 30px !important;display:flex;align-items:flex-start;background:var(--bg)}
  .hero-bg{position:absolute;inset:0;height:auto}
  .hero-slide{background-size:auto 70% !important;background-position:center top !important;background-repeat:no-repeat !important}
  .hero-slide:nth-child(3){background-size:auto 70% !important;background-position:center top !important}
  .hero-shade{background:linear-gradient(180deg,rgba(11,10,12,.92) 0%,rgba(11,10,12,.6) 12%,rgba(11,10,12,.3) 28%,transparent 55%,transparent 70%,var(--bg) 100%) !important}
  .hero-glow{display:none}
  /* Anillo de círculos arriba del texto, girando, sin el centro 360 */
  .ring-stage{display:flex !important;order:-1;max-width:240px;margin:0 auto 24px}
  .ring-stage svg{max-width:240px}
  .ring-core{display:none !important}
  /* Contenido del hero: una columna, texto sobre la foto */
  .hero .wrap{display:flex;flex-direction:column;padding:0 18px}
  .hero h1{font-size:clamp(2rem,8.5vw,2.8rem);margin:0 0 16px;word-break:break-word}
  .hero p{font-size:1rem}
  /* Botones en columna y full width */
  .hero .hbtns{flex-direction:column;align-items:stretch;gap:12px;margin-bottom:20px}
  .hero .btn{width:100%;text-align:center;justify-content:center;padding:13px 14px;font-size:.66rem;letter-spacing:.1em}
  /* Secciones con menos padding lateral */
  section{padding:48px 0}
  .treatments{padding:40px 0}
  .sh{margin-bottom:28px}
  .wrap{padding-left:18px;padding-right:18px}
  /* Footer en una columna */
  .fg{grid-template-columns:1fr !important;gap:26px}
  /* Badges/stats apilados */
  .badges{flex-direction:row;flex-wrap:wrap !important;align-items:flex-start;gap:14px 18px}
  .badge b{font-size:1.4rem}
  .badge span{font-size:.58rem}
  .badge-pc{display:none}
  .badges-row2{display:flex;margin-top:14px;animation-delay:.75s}
  .awards{padding:12px 0}
}
@media(prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}.reveal{opacity:1;transform:none}}

/* ====== HEADER CON MENÚS DESPLEGABLES (estilo Shopify) ====== */
header.cgm-header{position:absolute !important;top:0;left:0;right:0;inset:0 0 auto 0;z-index:300;background:transparent;border-bottom:1px solid transparent;transition:.4s}
header.cgm-header.sc{position:absolute !important;background:transparent;backdrop-filter:none;border-bottom:1px solid transparent}
/* Al hacer scroll, el header se encoge */
.cgm-header.sc .cgm-bar{height:158px}
.cgm-header.sc .cgm-logo img{height:110px}
.cgm-header .cgm-bar{max-width:1320px;margin:0 auto;padding:0 28px;display:flex;align-items:center;gap:20px;height:158px;justify-content:flex-start;align-items:center;overflow:visible;position:relative;left:-7.5px}
.cgm-logo{flex-shrink:0;display:flex;align-items:center}
.cgm-logo img{height:110px;width:auto;display:block;object-fit:contain;transition:height .35s ease}
.cgm-header .cgm-nav{display:flex;align-items:center;gap:4px;flex:1;justify-content:center;height:auto}
.cgm-item{position:relative}
.cgm-item > a{display:block;padding:14px 13px;font-family:'Outfit',sans-serif;font-size:.74rem;letter-spacing:.13em;text-transform:uppercase;color:var(--gold);font-weight:400;transition:.25s;white-space:nowrap}
.cgm-item > a:hover{color:var(--gold-l)}
.cgm-item.has-sub > a::after{content:"⌄";margin-left:5px;font-size:.7rem;color:#e6b543;opacity:.7}
.cgm-sub{position:absolute;top:100%;left:50%;transform:translateX(-50%) translateY(8px);min-width:250px;background:#131216;border:1px solid rgba(230,181,67,.25);padding:10px 0;opacity:0;visibility:hidden;transition:.28s;box-shadow:0 24px 50px -16px rgba(0,0,0,.7);z-index:210}
.cgm-item.has-sub:hover .cgm-sub{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
.cgm-sub a{display:block;padding:11px 22px;font-family:'Outfit',sans-serif;font-size:.82rem;color:#cdc4b4;letter-spacing:.02em;transition:.22s;white-space:nowrap}
.cgm-sub a:hover{background:rgba(230,181,67,.08);color:#f0d088;padding-left:27px}
.cgm-icons{display:flex;gap:18px;align-items:center;font-size:1.15rem;flex-shrink:0}
.cgm-icons a{color:#f6f1e7;transition:.25s;position:relative}
.cgm-icons a:hover{color:#e6b543}
.cgm-icons .cart-count{position:absolute;top:-8px;right:-10px;background:#e6b543;color:#000;font-size:.6rem;font-weight:600;width:16px;height:16px;border-radius:50%;display:flex;align-items:center;justify-content:center}
.cgm-burger{display:none;background:none;border:0;color:#f6f1e7;font-size:1.6rem;cursor:pointer}
@media(max-width:1100px){
  .cgm-header .cgm-nav{display:none;position:absolute;top:84px;left:0;right:0;background:#131216;flex-direction:column;align-items:stretch;padding:10px 0;border-bottom:1px solid rgba(230,181,67,.22);max-height:82vh;overflow-y:auto}
  .cgm-header.open .cgm-nav{display:flex}
  .cgm-item{border-bottom:1px solid rgba(230,181,67,.08)}
  .cgm-item > a{padding:16px 24px;font-size:.9rem}
  /* Submenús COLAPSADOS por defecto en móvil */
  .cgm-sub{position:static !important;left:auto !important;right:auto !important;transform:none !important;min-width:0;width:100%;border:0;box-shadow:none;background:#0e0c10;
           max-height:0;overflow:hidden;opacity:1;visibility:visible;padding:0;transition:max-height .3s ease}
  /* Se abren solo cuando la categoría tiene .open (al tocarla) */
  .cgm-item.open .cgm-sub{max-height:600px;padding:6px 0 12px}
  .cgm-item.has-sub:hover .cgm-sub{max-height:0;transform:none !important}
  .cgm-item.open.has-sub:hover .cgm-sub{max-height:600px;transform:none !important}
  .cgm-sub a{padding:11px 40px;font-size:.85rem}
  .cgm-burger{display:block}
}
