@font-face{
  font-family:'SignHandwriting';
  src:url('sign-handwriting.ttf') format('truetype');
  font-weight:normal;font-style:normal;
}
@font-face{
  font-family:'Normiyola';
  src:url('normiyola.otf') format('opentype');
  font-weight:normal;font-style:normal;
}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{
  --teal:#62CAE3;--teal-dark:#4ab8d4;--pink:#e91e8c;
  --gold:#c9a84c;--amber:#e07820;
  --bg:#0d1b3e;--bg2:#142751;--bg3:#0f1d3a;--bg4:#1a2d56;
  --border:#1a2d56;--border2:#1e3560;
  --white-1:#f0ebe0;   /* blanco hueso primario — títulos */
  --white-2:#c8c2b6;   /* blanco hueso secundario — cuerpo/apoyo */
  --text:#f0ebe0;--muted:#8a9aaa;--subtle:#2d4055;
  --card:rgba(8,15,24,0.72);
  --r:14px;
  --sans:'Inter',sans-serif;
  --serif:'Cormorant Garamond',serif;
  --script:'Dancing Script',cursive;
  --cream:#f0e8d8;--cream2:#e6ddd0;
}
html{scroll-behavior:smooth}
body{background:#142751;color:var(--text);font-family:var(--sans);line-height:1.6;overflow-x:hidden}

a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}

/* ── NAVBAR TRANSPARENTE — logotipo grande centrado, olas desde extremos ── */
body{padding-top:0}
nav{
  position:fixed;top:0;left:0;right:0;z-index:200;
  background:transparent;
}

/* ── BARRA SUPERIOR ── */
.nav-topbar{
  position:absolute;top:0;left:0;right:0;z-index:10;
  display:flex;align-items:center;
  padding:.5rem 2vw;
  gap:1.8vw;
}
/* Isotipo izquierda */
.ntb-iso{
  height:clamp(48px,6vw,85px);width:auto;
  filter:brightness(0) invert(1) opacity(0.55);
  flex-shrink:0;
}
/* Links izquierda */
.ntb-link{
  font-size:clamp(.48rem,1vw,.68rem);
  letter-spacing:clamp(.8px,.22vw,2.5px);
  text-transform:uppercase;font-weight:500;
  color:rgba(240,235,224,.65);transition:color .2s;
  white-space:nowrap;
}
.ntb-link:hover{color:var(--white-1)}
/* Botones — tamaño proporcional */
.nav-topbar .nav-wa,
.nav-topbar .nav-reserva{
  font-size:clamp(.48rem,1vw,.68rem);
  letter-spacing:clamp(.8px,.22vw,2.5px);
  padding:.3rem clamp(.5rem,.8vw,1rem);
  white-space:nowrap;
}
/* Links empujan botones a la derecha */
.ntb-iso{ margin-left:0; }
.nav-topbar .nav-wa{ margin-left:auto; background:rgba(255,255,255,.55); }
.nav-topbar .nav-reserva{ margin-left:0; }

/* Navbar top: olas + logo centrado */
.nav-top{
  display:flex;
  align-items:flex-start;
  height:170px;
  overflow:visible;
}
.nav-wave-left,.nav-wave-right{
  flex:1;min-width:0;
  height:170px;
  display:flex;align-items:center;
}
.nav-wave-left svg,.nav-wave-right svg{
  display:block;width:100%;height:170px;overflow:visible;
}
.nav-wordmark{
  flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
  z-index:5;pointer-events:none;
}
.nav-wordmark img{
  height:160px;width:auto;display:block;
  filter:brightness(0) invert(1) opacity(0.93);
}
@media(max-width:900px){
  .nav-wordmark img{height:80px}
  .nav-top{height:100px}
  .nav-wave-left svg,.nav-wave-right svg{height:100px}
}

/* Botones pill (fuera del topbar también) */
.nav-wa{
  display:flex;align-items:center;gap:.4rem;
  border:1.5px solid rgba(240,235,224,.5);color:rgba(240,235,224,.88);
  font-size:.68rem;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;
  padding:.32rem 1rem;border-radius:999px;
  background:rgba(255,255,255,.06);transition:all .2s;white-space:nowrap;
}
.nav-wa:hover{background:rgba(255,255,255,.14);border-color:var(--white-1);color:var(--white-1)}
.nav-reserva{
  display:flex;align-items:center;gap:.4rem;
  border:1.5px solid rgba(240,235,224,.5);color:rgba(240,235,224,.88);
  font-size:.68rem;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;
  padding:.32rem 1rem;border-radius:999px;
  background:transparent;transition:all .2s;white-space:nowrap;
}
.nav-reserva:hover{background:rgba(255,255,255,.14);border-color:var(--white-1);color:var(--white-1)}

/* Mobile menu — oculto por defecto */
.mobile-menu-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:300}
.mobile-menu-overlay.open{display:block}
.mobile-menu{display:none;position:fixed;top:0;left:0;bottom:0;width:280px;background:var(--bg2);z-index:400;flex-direction:column;padding:2rem 1.5rem;gap:1.5rem}
.mobile-menu.open{display:flex}
.mobile-menu a{color:var(--text);font-size:1rem;text-transform:uppercase;letter-spacing:2px}

/* Hamburger */
.nav-hamburger{
  background:none;border:none;color:rgba(240,235,224,.65);
  cursor:pointer;padding:.2rem;display:flex;align-items:center;transition:color .2s;
}
.nav-hamburger:hover{color:var(--white-1)}

/* Search */
.search-btn{color:rgba(240,235,224,.6)}
.search-btn:hover{color:var(--teal)}

/* ── SEARCH ── */
.search-wrap{position:relative;display:flex;align-items:center}
.search-btn{background:none;border:none;color:var(--muted);cursor:pointer;padding:.4rem;display:flex;align-items:center;transition:color .2s}
.search-btn:hover{color:var(--teal)}
.search-box{display:none;align-items:center;gap:.4rem;background:var(--bg3);border:1px solid var(--border2);border-radius:999px;padding:.3rem .4rem .3rem .9rem}
.search-box.open{display:flex}
.search-box input{background:none;border:none;color:var(--text);font-size:.88rem;outline:none;width:180px}
.search-box input::placeholder{color:var(--muted)}
.search-close{background:none;border:none;color:var(--muted);cursor:pointer;font-size:1.3rem;line-height:1;padding:0 .3rem}
.search-results{position:absolute;top:calc(100% + .6rem);right:0;width:320px;background:var(--bg3);border:1px solid var(--border2);border-radius:14px;display:none;z-index:400;max-height:380px;overflow-y:auto;box-shadow:0 8px 32px rgba(0,0,0,.5)}
.search-results.open{display:block}
.search-result-item{padding:.7rem 1rem;cursor:pointer;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;gap:.5rem;transition:background .15s}
.search-result-item:hover{background:var(--bg4)}
.search-result-item:last-child{border-bottom:none}
.search-result-name{font-size:.88rem;color:var(--text)}
.search-result-cat{font-size:.73rem;color:var(--muted);margin-top:.15rem}
.search-result-price{font-size:.88rem;color:var(--teal);font-weight:600;white-space:nowrap}
.search-no-results{padding:1.2rem;text-align:center;color:var(--muted);font-size:.85rem}
@media(max-width:700px){.search-box input{width:130px}}

/* ── WAVE SEPARATOR — contorno real UMI + línea blanca ── */
.wave-sep{position:absolute;bottom:-2px;left:0;right:0;line-height:0;pointer-events:none;z-index:2}
.wave-sep svg{display:block;width:100%;height:120px}
.wave-sep-top{position:absolute;top:-2px;left:0;right:0;line-height:0;pointer-events:none;z-index:2}
.wave-sep-top svg{display:block;width:100%;height:90px}
/* Divisor de sección full-width (no absolute) */
.sec-divider{position:relative;line-height:0;margin:0;padding:0;display:block}
.sec-divider svg{display:block;width:100%;height:120px}

/* ── HERO SECTION — alineado a la izquierda como en la referencia ── */
.hero-sec{
  min-height:100vh;
  background:url('fondo-umi.jpg') center top/cover no-repeat;
  display:flex;align-items:flex-end;justify-content:flex-start;
  text-align:left;padding:190px 5vw 12rem;
  position:relative;overflow:hidden;
}
.hero-sec::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(105deg,
    rgba(4,7,9,.82) 0%,
    rgba(4,7,9,.55) 45%,
    rgba(4,7,9,.12) 100%);
  pointer-events:none;
}
.hero-content{position:relative;z-index:1;max-width:560px}
.hero-eyebrow{
  display:block;font-size:.72rem;letter-spacing:5px;text-transform:uppercase;
  color:rgba(240,235,224,.75);font-weight:400;margin-bottom:.5rem;
}
.hero-title{
  font-family:var(--sans);
  font-size:clamp(4rem,9vw,7rem);
  font-weight:900;line-height:.88;letter-spacing:-3px;
  color:var(--white-1);margin-bottom:.3rem;text-transform:uppercase;
}
.hero-sub{
  font-size:.95rem;color:rgba(240,235,224,.70);
  max-width:400px;margin:0 0 .4rem;font-weight:300;line-height:1.65;
}
.hero-script-line{
  display:flex;align-items:baseline;gap:.6rem;
  margin-bottom:1.8rem;flex-wrap:nowrap;
}
.hero-exp{
  font-size:clamp(.85rem,1.6vw,1.1rem);
  color:rgba(240,235,224,.70);font-weight:300;
  white-space:nowrap;letter-spacing:.5px;
}
.hero-script{
  font-family:'SignHandwriting', var(--script);
  font-size:clamp(1.8rem,4vw,3rem);
  color:var(--teal);font-style:normal;font-weight:normal;
  line-height:1;letter-spacing:1px;white-space:nowrap;
}
.hero-btns{display:flex;gap:1rem;flex-wrap:wrap}
.btn-hero-primary{
  display:inline-flex;align-items:center;gap:.5rem;
  background:var(--teal);color:#000;font-weight:700;
  font-size:.8rem;letter-spacing:2px;text-transform:uppercase;
  padding:.85rem 2.2rem;border-radius:999px;
  transition:transform .25s,box-shadow .25s;
  box-shadow:0 0 24px rgba(98,202,227,.35);white-space:nowrap;
}
.btn-hero-primary:hover{transform:translateY(-2px);box-shadow:0 8px 30px rgba(98,202,227,.5)}
.btn-hero-secondary{
  display:inline-flex;align-items:center;gap:.5rem;
  background:transparent;color:var(--white-1);font-weight:700;
  font-size:.8rem;letter-spacing:2px;text-transform:uppercase;
  padding:.85rem 2.2rem;border-radius:999px;
  border:1.5px solid rgba(240,235,224,.55);
  transition:all .25s;white-space:nowrap;
}
.btn-hero-secondary:hover{background:rgba(255,255,255,.1);border-color:var(--white-1)}
/* Badge circular / sello en el hero */
.hero-badge{
  position:absolute;bottom:10rem;right:4vw;z-index:2;
  width:110px;height:110px;
  border-radius:50%;
  border:1.5px solid rgba(255,255,255,.4);
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;gap:.2rem;
  background:rgba(4,7,9,.4);backdrop-filter:blur(8px);
}
.hero-badge-top{
  font-size:.52rem;letter-spacing:3px;text-transform:uppercase;
  color:rgba(240,235,224,.75);font-weight:600;
}
.hero-badge-icon{font-size:1.5rem;line-height:1}
.hero-badge-bot{
  font-size:.5rem;letter-spacing:2.5px;text-transform:uppercase;
  color:rgba(240,235,224,.6);font-weight:500;
}
/* Alias viejo — no romper nada existente */
.btn-hero{
  display:inline-block;
  background:var(--teal);color:#000;font-weight:700;
  font-size:.9rem;letter-spacing:1.5px;text-transform:uppercase;
  padding:1rem 2.6rem;border-radius:999px;
  transition:transform .25s,box-shadow .25s;
  box-shadow:0 0 30px rgba(98,202,227,.3);
}
.btn-hero:hover{transform:translateY(-3px);box-shadow:0 8px 40px rgba(98,202,227,.5)}

/* ── SECCIÓN CREAM — Nuestra Historia + Más Pedidos ── */
.cream-sec{
  background:var(--cream);
  padding:0 0 0;
  position:relative;
  overflow:hidden;
}
.cream-inner{
  max-width:1240px;margin:0 auto;
  padding:5rem 2rem 5rem;
  display:grid;
  grid-template-columns:1fr 380px 1fr;
  gap:3.5rem;
  align-items:start;
}
/* Historia — columna izquierda */
.cream-historia{}
.cream-label{
  display:block;font-size:.65rem;letter-spacing:4px;text-transform:uppercase;
  color:var(--teal);font-weight:700;margin-bottom:.8rem;
}
.cream-title{
  font-family:var(--serif);
  font-size:clamp(2.2rem,4vw,3rem);
  font-weight:700;color:#0a0a0a;
  line-height:1.05;letter-spacing:-1px;margin-bottom:.4rem;
}
.cream-title em{
  font-family:'SignHandwriting', var(--script);font-style:normal;
  font-size:clamp(2rem,3.5vw,2.6rem);color:#222;font-weight:400;
}
.cream-desc{
  font-size:.88rem;color:#444;line-height:1.75;
  margin-bottom:1.5rem;max-width:340px;
}
.cream-link{
  font-size:.75rem;letter-spacing:2px;text-transform:uppercase;
  color:#0a0a0a;font-weight:700;
  border-bottom:1.5px solid #0a0a0a;
  padding-bottom:.15rem;transition:color .2s;
}
.cream-link:hover{color:var(--teal);border-color:var(--teal)}
/* Foto central */
.cream-photo{border-radius:18px;overflow:hidden}
.cream-photo img{width:100%;height:360px;object-fit:cover;display:block}
/* Más Pedidos — columna derecha */
.cream-pedidos{}
.cream-pedidos-grid{
  display:grid;grid-template-columns:1fr 1fr;
  gap:1.2rem;margin-top:1.5rem;
}
.pedido-item{display:flex;flex-direction:column;align-items:center;gap:.5rem;cursor:pointer}
.pedido-circle{
  width:120px;height:120px;border-radius:50%;overflow:hidden;
  border:3px solid var(--cream2);transition:border-color .2s,transform .2s;
}
.pedido-circle:hover{border-color:var(--teal);transform:scale(1.05)}
.pedido-circle img{width:100%;height:100%;object-fit:cover}
.pedido-name{
  font-size:.72rem;letter-spacing:1px;text-transform:uppercase;
  color:#111;font-weight:700;text-align:center;
}
.pedido-price{font-size:.8rem;color:var(--teal);font-weight:700}
.cream-menu-link{
  display:block;margin-top:1.5rem;
  font-size:.75rem;letter-spacing:2px;text-transform:uppercase;
  color:#0a0a0a;font-weight:700;
  border-bottom:1.5px solid #0a0a0a;
  padding-bottom:.15rem;width:fit-content;transition:color .2s;
}
.cream-menu-link:hover{color:var(--teal);border-color:var(--teal)}
/* Transición cream → oscuro */
.cream-wave-bottom{position:relative;line-height:0;background:var(--cream)}
.cream-wave-bottom svg{display:block;width:100%;height:120px}
@media(max-width:1000px){
  .cream-inner{grid-template-columns:1fr 1fr;gap:2rem}
  .cream-photo{display:none}
}
@media(max-width:640px){
  .cream-inner{grid-template-columns:1fr;gap:2.5rem}
  .hero-badge{display:none}
  .hero-sec{padding:190px 1.5rem 10rem}
  .cream-pedidos-grid{grid-template-columns:repeat(2,1fr)}
}

/* ── FOOTER REDISEÑADO ── */
footer{
  background:#0a0a0a;
  padding:0;
  border-top:1px solid rgba(255,255,255,.06);
}
.footer-inner{
  max-width:1240px;margin:0 auto;
  display:grid;
  grid-template-columns:260px 1fr 1fr 1fr 1fr;
  gap:3rem;padding:4rem 2rem;
  align-items:start;
}
.footer-brand{}
.footer-brand-logos{display:flex;align-items:center;gap:.8rem;margin-bottom:.6rem}
.footer-brand-iso svg{opacity:.85}
.footer-brand-name{
  font-size:.6rem;letter-spacing:3.5px;text-transform:uppercase;
  color:rgba(240,235,224,.45);font-weight:500;margin-top:.25rem;
}
.footer-col-title{
  font-size:.62rem;letter-spacing:3px;text-transform:uppercase;
  color:rgba(240,235,224,.45);font-weight:600;margin-bottom:1rem;display:block;
}
.footer-links{list-style:none;display:flex;flex-direction:column;gap:.6rem}
.footer-links li a{
  font-size:.82rem;color:rgba(240,235,224,.6);transition:color .2s;
}
.footer-links li a:hover{color:var(--white-1)}
.footer-info{font-size:.82rem;color:rgba(240,235,224,.6);line-height:1.8}
.footer-info strong{color:rgba(240,235,224,.85)}
.footer-social{display:flex;gap:.8rem;margin-top:.5rem;flex-wrap:wrap}
.footer-social a{
  width:36px;height:36px;border-radius:50%;
  border:1px solid rgba(240,235,224,.2);
  display:flex;align-items:center;justify-content:center;
  color:rgba(240,235,224,.5);font-size:.8rem;transition:all .2s;
}
.footer-social a:hover{border-color:var(--teal);color:var(--teal)}
.footer-bottom{
  border-top:1px solid rgba(255,255,255,.06);
  padding:1.2rem 2rem;max-width:1240px;margin:0 auto;
  display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap;
}
.footer-copy{font-size:.72rem;color:rgba(240,235,224,.3);letter-spacing:.5px}
@media(max-width:900px){
  .footer-inner{grid-template-columns:1fr 1fr;gap:2rem}
  .footer-brand{grid-column:1/-1}
}

/* ── MENU SECTION ── */
.menu-sec{
  background:var(--teal);
  padding:5rem 0 0;   /* sin padding inferior — termina en la ola */
  position:relative;
}
.menu-sec-inner{max-width:1440px;margin:0 auto;text-align:center;padding:0 1rem}

/* ── ZONA TEAL: texto oscuro sobre fondo teal ── */
.menu-sec .sec-label{color:rgba(4,7,9,.78)}
.menu-sec .menu-big-title{color:#0d1e40}
.menu-sec .menu-sec-sub{color:rgba(4,7,9,.58)}
.menu-sec .cat-circ-label{color:rgba(4,7,9,.65)}
.menu-sec .cat-circ.on .cat-circ-label{color:#0d1e40;font-weight:700}
.menu-sec .cat-circ-ring text{fill:rgba(4,7,9,.82)}
.menu-sec .cat-circ-ring circle:first-child{stroke:rgba(4,7,9,.18) !important}
.menu-sec .cat-circ-ring circle:not(:first-child){fill:rgba(4,7,9,.38) !important}
.menu-sec .cat-circ.on .cat-circ-inner{
  border:none;background:transparent;box-shadow:none;
}
.menu-sec .subcat-pill{background:rgba(4,7,9,.1);border-color:rgba(4,7,9,.22);color:#0d1e40}
.menu-sec .subcat-pill:hover,.menu-sec .subcat-pill.on{background:#0d1e40;border-color:#0d1e40;color:var(--teal)}

/* ── OLA INTERNA: curva inferior UMI — teal → oscuro ── */
.menu-wave-cut{
  position:relative;height:120px;line-height:0;
  margin-top:2rem;
}
.menu-wave-cut svg{display:block;width:100%;height:100%}

/* ── ZONA OSCURA: items del menú ── */
.menu-dark-area{
  background:#142751;
  padding:3rem 0 5rem;
  position:relative;
}
.menu-dark-area > div{padding:0 2rem}
.menu-dark-area .cat-heading{
  font-family:var(--serif);font-size:1.8rem;color:var(--white-1);
  margin-bottom:1.8rem;padding-bottom:.9rem;
  border-bottom:1px solid var(--border);
  display:flex;align-items:center;gap:.6rem;
}

/* ── OLA INFERIOR DEL MENÚ: oscuro → siguiente sección ── */
.menu-bottom-wave{
  position:relative;height:120px;line-height:0;
  background:transparent;z-index:3;margin-bottom:-120px;
}
.menu-bottom-wave svg{display:block;width:100%;height:100%}

/* ── FEATURED SECTION (Más Pedido) ── */
.featured-sec{
  min-height:58vh;
  background:url('saito-roll-h.jpg') 60% center/cover no-repeat;
  position:relative;
  display:flex;align-items:center;justify-content:center;
  text-align:center;padding:7rem 2rem 10rem;
  overflow:hidden;
}
.featured-sec::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(to bottom,
    rgba(6,14,28,.80) 0%,
    rgba(4,7,9,.20) 40%,
    rgba(4,7,9,.30) 70%,
    rgba(6,14,28,.88) 100%);
}
.featured-content{position:relative}
.featured-label{
  display:inline-block;font-size:.7rem;letter-spacing:4px;text-transform:uppercase;
  color:#c8a87a;margin-bottom:.9rem;font-weight:600;
}
.featured-title{
  font-family:var(--serif);
  font-size:clamp(3.5rem,10vw,7.5rem);
  font-weight:700;color:#c8b89a;
  line-height:.9;letter-spacing:-2px;margin-bottom:1.2rem;
}
.featured-sub{color:rgba(210,195,170,.75);font-weight:300;font-size:1rem;margin-bottom:2rem}
.btn-featured{
  display:inline-block;border:1.5px solid #c8a87a;color:#c8a87a;
  font-size:.82rem;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;
  padding:.8rem 2rem;border-radius:999px;
  transition:background .2s,color .2s;
}
.btn-featured:hover{background:#c8a87a;color:#000}

/* ── VIDEOS SECTION ── */
.videos-sec{
  background:#142751;
  padding:5rem 2rem 6rem;
  position:relative;
}
.videos-inner{
  max-width:1400px;margin:0 auto;
  display:grid;grid-template-columns:160px 1fr;
  gap:2rem;align-items:center;
}
.videos-left{padding-top:0}
.videos-left-label{
  font-size:.6rem;letter-spacing:2.5px;text-transform:uppercase;
  color:var(--teal);font-weight:600;margin-bottom:.6rem;display:block;
}
.videos-title{
  font-family:var(--serif);
  font-size:clamp(1.4rem,2.5vw,2rem);
  font-weight:700;color:var(--white-1);
  line-height:.95;letter-spacing:-1px;margin-bottom:.7rem;
}
.videos-left p{color:var(--muted);font-size:.78rem;margin-bottom:1rem;font-weight:300;line-height:1.6}
.btn-reels{
  display:inline-block;
  background:var(--teal);color:#000;font-weight:700;
  font-size:.78rem;letter-spacing:1px;text-transform:uppercase;
  padding:.75rem 1.8rem;border-radius:999px;
  transition:opacity .2s;
}
.btn-reels:hover{opacity:.85}
.reels-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;
}
.reel-card{
  border-radius:20px;overflow:hidden;
  background:rgba(98,202,227,.03);
  border:1px solid rgba(98,202,227,.15);
  aspect-ratio:9/16;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  cursor:pointer;transition:border-color .3s,transform .3s;
  position:relative;
}
.reel-card:hover{border-color:rgba(98,202,227,.5);transform:translateY(-6px)}
/* Reel card con video autoplay muted */
.reel-embed-card{ cursor:pointer; padding:0; overflow:hidden; }
.reel-preview{ display:none; }
.reel-video{
  position:absolute; inset:0;
  width:100%; height:100%;
  object-fit:cover; display:block;
  background:#000;
}
.reel-play-btn{
  position:absolute; inset:0;
  display:flex; align-items:center; justify-content:center;
  background:rgba(0,0,0,.25);
  transition:background .2s; pointer-events:none;
}
.reel-play-btn svg{ filter:drop-shadow(0 2px 8px rgba(0,0,0,.6)); }
.reel-embed-card:hover .reel-play-btn{ background:rgba(0,0,0,.1); }
.reel-play-btn.hidden{ display:none; }
.reel-sound-btn{
  position:absolute; bottom:.7rem; right:.7rem; z-index:10;
  background:rgba(0,0,0,.6); border:1px solid rgba(255,255,255,.3);
  color:#fff; border-radius:50%;
  width:36px; height:36px;
  display:none; align-items:center; justify-content:center;
  cursor:pointer; transition:all .2s; backdrop-filter:blur(4px);
}
.reel-sound-btn.visible{ display:flex; }
.reel-sound-btn:hover{ background:rgba(98,202,227,.7); border-color:var(--teal); }
.reel-sound-btn.muted{ color:rgba(255,255,255,.6); }
.reel-sound-btn:not(.muted){ color:var(--teal); border-color:var(--teal); }
.reel-icon{font-size:2rem;color:rgba(98,202,227,.3);margin-bottom:.7rem}
.reel-coming{
  font-size:.62rem;letter-spacing:2px;text-transform:uppercase;
  color:rgba(98,202,227,.25);font-weight:600;text-align:center;padding:0 .6rem;
}
@media(max-width:900px){
  .videos-inner{grid-template-columns:1fr;gap:2.5rem}
  .reels-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:600px){
  .reels-grid{grid-template-columns:repeat(2,1fr)}
}

/* ── SECTION WRAPPER ── */
.section{padding:6rem 2rem;max-width:1200px;margin:0 auto}
.sec-label{display:block;font-size:.7rem;letter-spacing:3px;text-transform:uppercase;color:var(--teal);margin-bottom:.8rem}
.sec-title{font-family:var(--serif);font-size:clamp(2.2rem,5vw,3.5rem);color:var(--white-1);line-height:1.1;margin-bottom:.8rem}
.sec-sub{color:var(--muted);font-weight:300;max-width:500px}

/* ── MENU ── */
/* Efecto interleaving: E y Ú pasan delante del logo del navbar */
.ml-behind{
  position:relative;
  z-index:190;
  display:inline-block;
}
.ml-front{
  position:relative;
  z-index:210;
  display:inline-block;
}
.menu-big-title{
  font-family:var(--serif);
  font-size:clamp(5rem,14vw,9rem);
  font-weight:700;color:var(--white-1);
  line-height:.88;letter-spacing:-3px;
  text-align:center;margin-bottom:.6rem;
}
.menu-sec-sub{color:var(--muted);font-size:1rem;text-align:center;margin:0 auto .5rem;display:block}
/* Círculos principales con texto SVG rotatorio */
.cat-circles{display:flex;gap:0;flex-wrap:wrap;justify-content:center;margin:3rem 0 0;padding:0 1rem;overflow:visible}
.cat-circ{
  display:flex;flex-direction:column;align-items:center;gap:.55rem;
  cursor:pointer;transition:transform .35s cubic-bezier(.34,1.56,.64,1);
  -webkit-tap-highlight-color:transparent;user-select:none;
}
.cat-circ:hover{transform:translateY(-8px) scale(1.06)}
.cat-circ-wrap{position:relative;width:200px;height:200px;margin:0 -18px;flex-shrink:0}
/* SVG del anillo rotatorio — encima del círculo interior (z-index mayor por orden DOM) */
.cat-circ-ring{
  position:absolute;inset:0;width:100%;height:100%;
  transform-origin:50% 50%;
  pointer-events:none;
}
/* Ocultar círculo exterior y puntos */
.cat-circ-ring > circle{ display:none; }
/* Gira lento */
.cat-circ .cat-circ-ring{animation:spin-text 18s linear infinite}
.cat-circ:hover .cat-circ-ring{animation:spin-text 14s linear infinite}
.cat-circ.on .cat-circ-ring{animation:spin-text 18s linear infinite}
@keyframes spin-text{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}
/* Círculo interior — debajo del SVG (z-index menor por orden DOM) */
.cat-circ-inner{
  position:absolute;inset:32px;border-radius:50%;
  background:transparent;
  border:none;
  display:flex;align-items:center;justify-content:center;
  font-size:3rem;
  transition:border-color .3s,box-shadow .3s,background .3s;
  backdrop-filter:blur(14px);
  pointer-events:none;
}
.cat-circ.on .cat-circ-inner{
  background:transparent;
  border:none;
  box-shadow:none;
}
.cat-circ-label{
  font-size:.65rem;letter-spacing:2.5px;text-transform:uppercase;
  color:var(--muted);font-weight:600;text-align:center;max-width:140px;
  transition:color .3s;line-height:1.3;
}
.cat-circ.on .cat-circ-label{color:var(--teal)}
/* Subcategorías — pills elegantes bajo los círculos */
.subcat-row{
  display:none;flex-wrap:wrap;gap:.5rem;justify-content:center;
  padding:1.8rem 0 .5rem;
  animation:sub-fadein .35s ease;
}
.subcat-row.open{display:flex}
@keyframes sub-fadein{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
.subcat-pill{
  background:var(--bg3);border:1px solid var(--border);
  color:var(--muted);padding:.38rem 1.1rem;border-radius:999px;
  font-size:.76rem;font-weight:500;letter-spacing:.5px;cursor:pointer;
  transition:all .2s;white-space:nowrap;
}
.subcat-pill:hover,.subcat-pill.on{background:var(--teal);border-color:var(--teal);color:#000;font-weight:700}
.cat-block{display:none}
.cat-block.show{display:block}
.cat-heading{
  font-family:var(--serif);font-size:1.8rem;color:var(--white-1);
  margin-bottom:1.8rem;padding-bottom:.9rem;
  border-bottom:1px solid var(--border);
  display:flex;align-items:center;gap:.6rem;
}
.items-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(300px,1fr));
  gap:1.1rem;
}
/* Card with image */
.item{
  background:var(--card);border:1px solid var(--border);border-radius:var(--r);
  overflow:hidden;display:flex;flex-direction:column;
  transition:transform .25s,border-color .25s,box-shadow .25s;
  cursor:pointer;
}
.item:hover{
  transform:translateY(-4px);border-color:var(--teal);
  box-shadow:0 12px 40px rgba(98,202,227,.12);
}
.item-img{
  width:100%;height:185px;object-fit:cover;
  background:var(--bg3);flex-shrink:0;
}
.item-img-placeholder{
  width:100%;height:185px;background:var(--bg3);
  display:flex;align-items:center;justify-content:center;
  font-size:3.5rem;flex-shrink:0;
  border-bottom:1px solid var(--border);
}
.item-body{padding:1rem 1.2rem 1.2rem;display:flex;flex-direction:column;flex:1}
.item-name{font-weight:600;font-size:.95rem;color:var(--text);margin-bottom:.3rem;line-height:1.3}
.item-desc{font-size:.78rem;color:var(--muted);line-height:1.45;flex:1;margin-bottom:.9rem}
.item-footer{display:flex;align-items:center;justify-content:space-between;margin-top:auto}
.item-price{font-family:var(--serif);font-size:1.3rem;font-weight:700;color:var(--teal)}

/* ── ABOUT ── */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center;margin-top:4rem}
@media(max-width:768px){.about-grid{grid-template-columns:1fr;gap:3rem}}
.about-copy p{color:var(--muted);margin-bottom:1.2rem;font-weight:300;line-height:1.8}
.about-tags{display:flex;gap:.5rem;flex-wrap:wrap;margin-top:1.8rem}
.tag{
  border:1px solid var(--border2);color:var(--muted);
  padding:.3rem .85rem;border-radius:999px;font-size:.75rem;font-weight:500;
}
.about-visual{
  background:linear-gradient(145deg,var(--bg3),var(--bg2));
  border:1px solid var(--border);border-radius:24px;
  padding:3.5rem 2.5rem;text-align:center;position:relative;overflow:hidden;
}
.about-visual::before{
  content:'';position:absolute;top:-30%;left:50%;transform:translateX(-50%);
  width:200px;height:200px;border-radius:50%;
  background:radial-gradient(var(--teal),transparent 70%);
  opacity:.15;pointer-events:none;
}
.av-symbol{font-size:5rem;display:block;margin-bottom:1rem}
.av-name{font-family:var(--serif);font-size:3rem;color:var(--white-1);letter-spacing:4px}
.av-tagline{color:var(--teal);font-size:.85rem;letter-spacing:2px;text-transform:uppercase;margin-top:.5rem}
.av-addr{color:var(--muted);font-size:.82rem;margin-top:1.5rem;line-height:1.7}

/* ── CTA ── */
.cta-wrap{padding:0 2rem 6rem}
.cta-box{
  max-width:900px;margin:0 auto;
  background:linear-gradient(135deg,rgba(98,202,227,.1) 0%,rgba(233,30,140,.08) 100%);
  border:1px solid rgba(98,202,227,.2);border-radius:24px;
  padding:5rem 2rem;text-align:center;position:relative;overflow:hidden;
}
.cta-box::before{
  content:'';position:absolute;top:0;left:0;right:0;bottom:0;
  background:radial-gradient(ellipse 60% 50% at 50% 0%,rgba(98,202,227,.08),transparent);
  pointer-events:none;
}
.cta-box h2{font-family:var(--serif);font-size:clamp(2rem,5vw,3.2rem);color:var(--white-1);margin-bottom:1rem}
.cta-box p{color:var(--muted);margin-bottom:2.5rem;font-weight:300}
.btn-wa{
  display:inline-flex;align-items:center;gap:.65rem;
  background:#25D366;color:#fff;font-weight:700;font-size:1rem;
  letter-spacing:.5px;padding:1.1rem 2.5rem;border-radius:999px;
  box-shadow:0 8px 30px rgba(37,211,102,.3);
  transition:transform .25s,box-shadow .25s;
}
.btn-wa:hover{transform:translateY(-3px);box-shadow:0 14px 40px rgba(37,211,102,.45)}
.btn-wa svg{width:22px;height:22px;fill:#fff;flex-shrink:0}

/* ── CONTACT ── */
.contact-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-top:3rem}
.contact-card{
  background:var(--card);border:1px solid var(--border);border-radius:var(--r);
  padding:1.6rem;display:flex;flex-direction:column;gap:.4rem;
}
.cc-icon{font-size:1.5rem}
.cc-label{font-size:.68rem;letter-spacing:2px;text-transform:uppercase;color:var(--subtle)}
.cc-val{font-size:.92rem;font-weight:500;color:var(--text);line-height:1.5}
.cc-val a{color:var(--teal)}
.cc-val a:hover{text-decoration:underline}

/* ── REVIEWS MARQUEE ── */
.reviews-sec{
  padding:4rem 0 3.5rem;
  overflow:hidden;
  background:rgba(4,7,9,.50);
  backdrop-filter:blur(8px);
  border-top:1px solid rgba(98,202,227,.13);
  border-bottom:1px solid rgba(98,202,227,.13);
}
.reviews-head{text-align:center;padding:0 2rem 2.8rem}
.reviews-head .sec-label{display:inline-block;font-size:.68rem;letter-spacing:3px;text-transform:uppercase;color:var(--teal);margin-bottom:.6rem}
.reviews-head h2{font-family:var(--serif);font-size:clamp(1.8rem,4vw,2.8rem);font-weight:600;color:var(--text);line-height:1.2}
.reviews-head p{margin-top:.5rem;color:var(--muted);font-size:.88rem}
.reviews-badge{display:inline-flex;align-items:center;gap:.5rem;background:rgba(201,168,76,.1);border:1px solid rgba(201,168,76,.3);border-radius:999px;padding:.35rem 1rem .35rem .6rem;margin-top:1rem}
.reviews-badge svg{width:18px;height:18px}
.reviews-badge span{font-size:.8rem;font-weight:600;color:var(--gold);letter-spacing:.5px}

.reviews-track-wrap{overflow:hidden;position:relative;padding:.5rem 0}
.reviews-track-wrap::before,.reviews-track-wrap::after{
  content:'';position:absolute;top:0;bottom:0;width:140px;z-index:2;pointer-events:none;
}
.reviews-track-wrap::before{left:0;background:linear-gradient(to right,rgba(4,7,9,.92) 0%,transparent 100%)}
.reviews-track-wrap::after{right:0;background:linear-gradient(to left,rgba(4,7,9,.92) 0%,transparent 100%)}

.reviews-track{
  display:flex;gap:1.4rem;
  animation:scroll-rev 50s linear infinite;
  width:max-content;
}
.reviews-track:hover{animation-play-state:paused}
@keyframes scroll-rev{
  0%{transform:translateX(0)}
  100%{transform:translateX(-50%)}
}

.rev-card{
  background:rgba(8,15,24,.82);
  border:1px solid rgba(98,202,227,.13);
  border-radius:16px;
  padding:1.6rem 1.8rem;
  width:290px;
  flex-shrink:0;
  backdrop-filter:blur(10px);
  transition:border-color .3s;
}
.rev-card:hover{border-color:rgba(98,202,227,.35)}
.rev-stars{display:flex;gap:.18rem;margin-bottom:.9rem}
.rev-stars svg{width:.95rem;height:.95rem;fill:#c9a84c;flex-shrink:0}
.rev-text{font-size:.86rem;color:var(--text);line-height:1.65;margin-bottom:1.1rem;font-style:italic;opacity:.92}
#longRev{max-height:5.4em;overflow:hidden;transition:max-height .4s ease;margin-bottom:.4rem;}
#longRev.expanded{max-height:600px;}
.rev-more{font-size:.72rem;font-weight:700;color:var(--teal);cursor:pointer;
  background:none;border:none;padding:0;margin-bottom:1rem;display:none;letter-spacing:.5px;}
.rev-more.visible{display:inline-block;}
.rev-more:hover{opacity:.7;}
.rev-text::before{content:'\201C';color:var(--teal);font-size:1.3rem;line-height:0;vertical-align:-.3em;margin-right:.15rem;opacity:.7}
.rev-author{display:flex;align-items:center;gap:.7rem}
.rev-av{
  width:34px;height:34px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:.82rem;font-weight:700;color:#f0ebe0;flex-shrink:0;
  background:linear-gradient(135deg,var(--teal),var(--teal-dark));
}
.rev-info{}
.rev-name{font-size:.8rem;font-weight:600;color:var(--teal);line-height:1.2}
.rev-src{font-size:.7rem;color:var(--muted);margin-top:.1rem;display:flex;align-items:center;gap:.3rem}
.rev-src svg{width:10px;height:10px;fill:var(--muted)}

/* ── FOOTER ── */
footer{
  border-top:1px solid var(--border);
  padding:2.5rem 2rem;text-align:center;
  color:var(--muted);font-size:.8rem;letter-spacing:.5px;
}
footer strong{color:var(--teal)}

/* ── FAB ── */
/* ── SIDE TABS (pestañas cuaderno, solapadas) ── */
.side-tabs{
  position:fixed;right:0;top:50%;transform:translateY(-50%);
  z-index:999;display:flex;flex-direction:column;
}
.side-tab{
  display:flex;align-items:center;gap:12px;
  padding:0 0 0 18px;height:92px;width:168px;
  border-radius:16px 0 0 16px;
  transform:translateX(152px); /* muestra solo 16px del borde */
  transition:transform .28s cubic-bezier(.4,0,.2,1);
  cursor:pointer;border:none;text-decoration:none;
  white-space:nowrap;position:relative;
  box-shadow:-4px 2px 16px rgba(0,0,0,.28);
  font-family:'Inter',sans-serif;
  margin-top:-22px; /* solapamiento */
}
.side-tab:first-child{ margin-top:0; }
/* z-index por defecto: la de arriba tapa a la siguiente */
.side-tab:nth-child(1){ z-index:4; }
.side-tab:nth-child(2){ z-index:3; }
.side-tab:nth-child(3){ z-index:2; }
.side-tab:nth-child(4){ z-index:1; }
.side-tab:hover{ transform:translateX(0); z-index:10; }

.side-tab-icon{
  flex-shrink:0;display:flex;align-items:center;justify-content:center;
}
.side-tab-label{
  font-size:.74rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase;
}

.side-tab--cart  { background:#b2ddd9; }
.side-tab--cart  .side-tab-icon svg{ width:20px;height:20px;fill:#1d4e4a; }
.side-tab--cart  .side-tab-label{ color:#1d4e4a; }

.side-tab--wa    { background:#b4e0c0; }
.side-tab--wa    .side-tab-icon svg{ width:20px;height:20px;fill:#1a4a2c; }
.side-tab--wa    .side-tab-label{ color:#1a4a2c; }

.side-tab--google{ background:#b4cfe8; }
.side-tab--google .side-tab-icon svg{ width:20px;height:20px; }
.side-tab--google .side-tab-label{ color:#1a2e4a; }

.side-tab--ta    { background:#b2dcc8; }
.side-tab--ta    .side-tab-icon svg{ width:20px;height:20px;fill:#1a3c2e; }
.side-tab--ta    .side-tab-label{ color:#1a3c2e; }

.cart-fab-badge{
  position:absolute;top:14px;left:28px;
  background:#e03050;color:#fff;font-size:.6rem;font-weight:700;
  width:18px;height:18px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  border:2px solid #fff;pointer-events:none;
}
.cart-fab-badge.hidden{display:none}
.cart-fab{ display:none; }
.fab{ display:none; }

/* ── ITEM ADD BUTTON ── */
.item-wa{
  font-size:.7rem;font-weight:700;letter-spacing:1px;text-transform:uppercase;
  color:var(--teal);border:1px solid rgba(98,202,227,.35);
  padding:.3rem .8rem;border-radius:999px;
  transition:background .2s,color .2s;cursor:pointer;
  background:transparent;
}
.item:hover .item-wa{background:var(--teal);color:#000}
.item.added{border-color:var(--teal);animation:addpop .35s ease}
@keyframes addpop{0%{transform:scale(1)}50%{transform:scale(1.04)}100%{transform:scale(1)}}

/* ── CART OVERLAY ── */
.cart-overlay{
  position:fixed;inset:0;background:rgba(0,0,0,.65);z-index:1000;
  opacity:0;pointer-events:none;transition:opacity .3s;
  backdrop-filter:blur(4px);
}
.cart-overlay.open{opacity:1;pointer-events:all}

/* ── CART DRAWER ── */
.cart-drawer{
  position:fixed;top:0;right:0;bottom:0;width:min(420px,100vw);
  background:var(--bg2);border-left:1px solid var(--border);
  z-index:1001;display:flex;flex-direction:column;
  transform:translateX(100%);transition:transform .35s cubic-bezier(.4,0,.2,1);
}
.cart-drawer.open{transform:translateX(0)}
.cart-header{
  display:flex;align-items:center;justify-content:space-between;
  padding:1.3rem 1.5rem;border-bottom:1px solid var(--border);
  flex-shrink:0;
}
.cart-header h3{font-family:var(--serif);font-size:1.4rem;color:var(--white-1)}
.cart-close{
  background:var(--bg3);border:1px solid var(--border);color:var(--muted);
  width:34px;height:34px;border-radius:50%;font-size:1.2rem;cursor:pointer;
  display:flex;align-items:center;justify-content:center;transition:color .2s;
}
.cart-close:hover{color:var(--white-1)}
.cart-items{flex:1;overflow-y:auto;padding:1rem 1.5rem;display:flex;flex-direction:column;gap:.8rem}
.cart-empty{
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  height:100%;color:var(--muted);text-align:center;gap:.8rem;
}
.cart-empty span{font-size:3rem}
.cart-empty p{font-size:.85rem}
.cart-row{
  display:flex;align-items:center;gap:.85rem;
  background:var(--card);border:1px solid var(--border);border-radius:10px;
  padding:.8rem 1rem;
}
.cart-row-emoji{font-size:1.6rem;flex-shrink:0;width:2.6rem;text-align:center}
.cart-row-thumb{width:2.6rem;height:2.6rem;border-radius:.5rem;object-fit:cover;flex-shrink:0;background:var(--bg3)}

/* ── Address autocomplete dropdown ── */
.addr-wrap{position:relative}
.addr-suggestions{
  position:absolute;top:calc(100% + 4px);left:0;right:0;z-index:999;
  background:var(--bg3);border:1px solid var(--border2);border-radius:.6rem;
  overflow:hidden;box-shadow:0 8px 24px rgba(0,0,0,.5);max-height:220px;overflow-y:auto;
}
.addr-sug-item{
  padding:.65rem .9rem;font-size:.84rem;color:var(--text);cursor:pointer;
  border-bottom:1px solid var(--border);display:flex;align-items:center;gap:.5rem;
  transition:background .15s;
}
.addr-sug-item:last-child{border-bottom:none}
.addr-sug-item:hover,.addr-sug-item.active{background:var(--bg4)}
.addr-sug-icon{font-size:1rem;flex-shrink:0}
.addr-sug-main{font-weight:500}
.addr-sug-sub{font-size:.76rem;color:var(--muted);margin-top:.1rem}
.cart-row-info{flex:1;min-width:0}
.cart-row-name{font-size:.85rem;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cart-row-price{font-size:.78rem;color:var(--teal);margin-top:.15rem}
.cart-qty{display:flex;align-items:center;gap:.4rem;flex-shrink:0}
.qty-btn{
  background:var(--bg3);border:1px solid var(--border);color:var(--text);
  width:28px;height:28px;border-radius:50%;font-size:1rem;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  transition:background .2s;line-height:1;
}
.qty-btn:hover{background:var(--teal);color:#000;border-color:var(--teal)}
.qty-num{font-size:.9rem;font-weight:700;min-width:18px;text-align:center}
.cart-row-del{
  background:none;border:none;color:var(--subtle);font-size:1rem;
  cursor:pointer;padding:.2rem;transition:color .2s;flex-shrink:0;
}
.cart-row-del:hover{color:#ef4444}
.cart-footer{
  padding:1.2rem 1.5rem;border-top:1px solid var(--border);flex-shrink:0;
}
.cart-total-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}
.cart-total-label{color:var(--muted);font-size:.82rem;text-transform:uppercase;letter-spacing:1px}
.cart-total-val{font-family:var(--serif);font-size:1.6rem;color:var(--teal);font-weight:700}
.btn-checkout{
  width:100%;padding:1rem;border-radius:999px;border:none;cursor:pointer;
  background:var(--teal);color:#000;font-weight:700;font-size:.95rem;
  letter-spacing:.5px;transition:opacity .2s;
}
.btn-checkout:hover{opacity:.88}
.btn-checkout:disabled{background:var(--subtle);color:var(--muted);cursor:not-allowed}

/* ── CHECKOUT MODAL ── */
.checkout-modal{
  position:fixed;inset:0;z-index:1100;
  display:flex;align-items:center;justify-content:center;padding:1rem;
  opacity:0;pointer-events:none;transition:opacity .3s;
}
.checkout-modal.open{opacity:1;pointer-events:all}
.checkout-modal-bg{position:absolute;inset:0;background:rgba(0,0,0,.75);backdrop-filter:blur(6px)}
.checkout-box{
  position:relative;width:100%;max-width:480px;max-height:90vh;overflow-y:auto;
  background:var(--bg2);border:1px solid var(--border2);border-radius:20px;
  padding:2rem;z-index:1;
}
.checkout-box h3{font-family:var(--serif);font-size:1.6rem;color:var(--white-1);margin-bottom:1.5rem}
.field{display:flex;flex-direction:column;gap:.4rem;margin-bottom:1rem}
.field label{font-size:.75rem;color:var(--muted);letter-spacing:1px;text-transform:uppercase}
.field input,.field textarea,.field select{
  background:var(--bg3);border:1px solid var(--border2);border-radius:8px;
  color:var(--text);font-size:.9rem;padding:.7rem .9rem;outline:none;
  font-family:var(--sans);transition:border-color .2s;width:100%;
}
.field input:focus,.field textarea:focus,.field select:focus{border-color:var(--teal)}
.field select option{background:var(--bg3)}
.field textarea{resize:vertical;min-height:70px}
.radio-group{display:flex;gap:.6rem;flex-wrap:wrap}
.radio-opt{
  flex:1;min-width:100px;border:1px solid var(--border2);border-radius:8px;
  padding:.65rem .9rem;cursor:pointer;font-size:.83rem;color:var(--muted);
  text-align:center;transition:all .2s;
}
.radio-opt.selected{border-color:var(--teal);color:var(--teal);background:rgba(98,202,227,.08)}
.checkout-summary{
  background:var(--bg3);border:1px solid var(--border);border-radius:10px;
  padding:1rem;margin-bottom:1.2rem;font-size:.82rem;
}
.checkout-summary-title{color:var(--muted);font-size:.72rem;text-transform:uppercase;letter-spacing:1px;margin-bottom:.6rem}
.checkout-summary-item{display:flex;justify-content:space-between;color:var(--text);padding:.2rem 0}
.checkout-summary-total{
  display:flex;justify-content:space-between;
  border-top:1px solid var(--border);margin-top:.5rem;padding-top:.5rem;
  font-weight:700;color:var(--teal);font-family:var(--serif);font-size:1.1rem;
}
.checkout-actions{display:flex;gap:.8rem;margin-top:1.2rem}
.btn-back{
  flex:1;padding:.9rem;border-radius:999px;border:1px solid var(--border2);
  background:transparent;color:var(--muted);font-size:.85rem;cursor:pointer;
  transition:border-color .2s,color .2s;
}
.btn-back:hover{border-color:var(--teal);color:var(--teal)}
.btn-send{
  flex:2;padding:.9rem;border-radius:999px;border:none;cursor:pointer;
  background:#25D366;color:#fff;font-weight:700;font-size:.9rem;
  transition:opacity .2s;
}
.btn-send:hover{opacity:.88}
