@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800;900&display=swap');

:root{
  --turquoise:#12d6d6;
  --turquoise-dark:#08aeb1;
  --turquoise-soft:#e8ffff;
  --ink:#111820;
  --muted:#6c7a86;
  --gray:#f3f6f8;
  --line:#e4eaee;
  --white:#ffffff;
  --shadow:0 22px 60px rgba(17,24,32,.12);
  --radius:26px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:Inter,system-ui,sans-serif;
  background:var(--white);
  color:var(--ink);
  overflow-x:hidden;
}
a{text-decoration:none;color:inherit}
button,input,textarea,select{font-family:inherit}

.site-header{
  width:min(1180px, calc(100% - 32px));
  position:fixed;
  top:18px;
  left:50%;
  transform:translateX(-50%);
  z-index:20;
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:13px 16px;
  border:1px solid rgba(255,255,255,.55);
  background:rgba(255,255,255,.78);
  backdrop-filter:blur(18px);
  border-radius:999px;
  box-shadow:0 10px 40px rgba(20,30,40,.08);
}
.site-header.solid{position:sticky;top:14px;margin:14px auto 0;transform:none;left:auto}
.brand{display:flex;align-items:center;gap:10px;font-weight:900;letter-spacing:-.03em}
.brand img{width:42px;height:42px;border-radius:50%;object-fit:cover}
.brand span{font-size:1.1rem}
.nav{display:flex;align-items:center;gap:8px}
.nav a{
  padding:11px 15px;
  border-radius:999px;
  font-size:.94rem;
  font-weight:700;
  color:#2d3842;
  transition:.25s;
}
.nav a:hover{background:var(--turquoise-soft);color:#05777b}
.cart-link{background:#101820!important;color:white!important}
.cart-link strong{
  background:var(--turquoise);
  color:#061012;
  padding:2px 8px;
  border-radius:999px;
  margin-left:4px;
}
.menu-toggle{display:none;background:none;border:0;width:42px;height:42px}
.menu-toggle span{display:block;width:24px;height:2px;background:#111;margin:5px auto;border-radius:20px}

.hero{
  min-height:100vh;
  padding:140px max(22px,calc((100vw - 1180px)/2)) 70px;
  position:relative;
  display:grid;
  grid-template-columns:1.03fr .97fr;
  align-items:center;
  gap:50px;
  overflow:hidden;
}
.hero:before{
  content:"";
  position:absolute;
  inset:0;
  background:
    radial-gradient(circle at 18% 25%, rgba(18,214,214,.16), transparent 28%),
    radial-gradient(circle at 90% 20%, rgba(18,214,214,.20), transparent 31%),
    linear-gradient(180deg,#fff 0%,#f8fbfc 100%);
  z-index:-3;
}
.hero-bg-shape{position:absolute;border-radius:50%;filter:blur(2px);z-index:-2}
.shape-one{width:500px;height:500px;background:#e8ffff;right:-110px;top:120px}
.shape-two{width:250px;height:250px;background:#f0f4f5;left:8%;bottom:10%}
.eyebrow{
  display:inline-flex;
  align-items:center;
  gap:8px;
  color:#067f83;
  background:var(--turquoise-soft);
  border:1px solid rgba(18,214,214,.35);
  padding:9px 14px;
  border-radius:999px;
  font-weight:900;
  margin-bottom:22px;
}
.hero h1{
  font-size:clamp(3rem,6vw,6.4rem);
  line-height:.92;
  letter-spacing:-.075em;
  max-width:760px;
}
.hero p{
  font-size:1.13rem;
  line-height:1.75;
  color:var(--muted);
  max-width:620px;
  margin:25px 0 34px;
}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap}
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:50px;
  padding:0 22px;
  border-radius:999px;
  font-weight:900;
  border:1px solid transparent;
  cursor:pointer;
  transition:.25s;
}
.btn-primary{
  background:linear-gradient(135deg,var(--turquoise),#40ffff);
  color:#061012;
  box-shadow:0 16px 36px rgba(18,214,214,.32);
}
.btn-primary:hover{transform:translateY(-3px);box-shadow:0 20px 44px rgba(18,214,214,.42)}
.btn-ghost{background:#fff;color:#111;border-color:var(--line)}
.btn-ghost:hover{background:#f5fbfb}
.full{width:100%}

.hero-product{
  min-height:560px;
  display:grid;
  place-items:center;
  position:relative;
}
.product-orbit{
  width:min(460px,90vw);
  height:min(460px,90vw);
  border-radius:50%;
  background:linear-gradient(145deg,var(--turquoise),#dfffff);
  box-shadow:inset 0 0 80px rgba(255,255,255,.5), var(--shadow);
  position:absolute;
  animation:float 5s ease-in-out infinite;
}
.hero-logo-wrap{
  position:relative;
  z-index:2;
  display:flex;
  align-items:center;
  justify-content:center;
}

.hero-logo{
  width:340px;
  max-width:80%;
  height:auto;
  display:block;
  filter:
    drop-shadow(0 25px 45px rgba(0,0,0,.18));
}

@keyframes float{
  50%{
    transform:translateY(-16px) scale(1.02);
  }
}

.hero-mobile{display:none}

section{padding:80px max(22px,calc((100vw - 1180px)/2))}
.section-title{margin-bottom:28px}
.section-title span{
  color:#087e82;
  font-weight:900;
  text-transform:uppercase;
  font-size:.78rem;
  letter-spacing:.12em;
}
.section-title h2{
  margin-top:9px;
  font-size:clamp(2rem,3.5vw,3.6rem);
  line-height:1;
  letter-spacing:-.055em;
}
.row-title{display:flex;align-items:end;justify-content:space-between;gap:20px}
.mini-link{font-weight:900;color:#07868a}

.category-grid,.products-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:18px;
}
.category-card{
  padding:28px;
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius);
  box-shadow:0 12px 34px rgba(10,20,25,.05);
  transition:.28s;
}
.category-card:hover{transform:translateY(-7px);border-color:rgba(18,214,214,.45);box-shadow:var(--shadow)}
.cat-icon{font-size:2.5rem;margin-bottom:18px}
.category-card h3{font-size:1.35rem;margin-bottom:8px}
.category-card p{color:var(--muted);line-height:1.55}

.products-section{background:linear-gradient(180deg,#fff,#f8fbfc)}
.filters{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:26px}
.filter-btn{
  border:1px solid var(--line);
  background:#fff;
  padding:11px 16px;
  border-radius:999px;
  cursor:pointer;
  font-weight:900;
  transition:.22s;
}
.filter-btn.active,.filter-btn:hover{background:#101820;color:#fff;border-color:#101820}

.products-grid{grid-template-columns:repeat(3,1fr)}
.product-card{
  position:relative;
  background:#fff;
  border:1px solid var(--line);
  border-radius:30px;
  overflow:hidden;
  box-shadow:0 16px 40px rgba(10,20,25,.06);
  transition:.3s;
}
.product-card:hover{transform:translateY(-8px);box-shadow:var(--shadow)}
.badge{
  position:absolute;
  top:18px;left:18px;
  z-index:2;
  background:#111820;
  color:#fff;
  padding:8px 12px;
  border-radius:999px;
  font-size:.78rem;
  font-weight:900;
}

@media (max-width:900px){

  .badge{
    top:10px;
    left:10px;

    padding:6px 10px;

    font-size:.65rem;
    line-height:1;

    transform:scale(.9);
  }

}
.product-visual{
  height:320px;
  display:flex;
  align-items:center;
  justify-content:center;
  overflow:hidden;
  padding:0;
  cursor:zoom-in;
  background:
    radial-gradient(circle at 50% 50%, rgba(18,214,214,.24), transparent 42%),
    linear-gradient(135deg,#f7fbfc,#eaffff);
}

.product-visual img{
  width:100%;
  height:100%;
  display:block;
  object-fit:contain;
  object-position:center;
  transition:transform .3s ease;
}

.product-card:hover .product-visual img{
  transform:scale(1.08);
}

.product-info{
  padding:24px;
}

.category-name,
.product-category{
  color:#0b8d90;
  text-transform:uppercase;
  font-size:.73rem;
  font-weight:900;
  letter-spacing:.12em;
}

.product-info h3{
  font-size:1.35rem;
  margin:8px 0 10px;
  line-height:1.15;
  letter-spacing:-.02em;
}

.product-info p{
  color:var(--muted);
  line-height:1.55;
  min-height:74px;
}

.product-meta{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  margin:18px 0;
}

.product-meta strong{
  font-size:1.25rem;
  font-weight:900;
}

.product-meta span{
  background:var(--gray);
  padding:7px 10px;
  border-radius:999px;
  color:#52616d;
  font-size:.84rem;
  font-weight:800;
  white-space:nowrap;
}

.add-btn{
  width:100%;
  height:48px;
  border:0;
  border-radius:16px;
  background:var(--turquoise);
  color:#061012;
  cursor:pointer;
  font-weight:950;
  transition:.22s;
}

.add-btn:hover{
  background:#101820;
  color:#fff;
}

.image-modal{
  position:fixed;
  inset:0;
  z-index:9999;
  display:none;
  align-items:center;
  justify-content:center;
  padding:28px;
  background:rgba(7,16,20,.82);
  backdrop-filter:blur(10px);
}

.image-modal.active{
  display:flex;
}

.image-modal img{
  max-width:92vw;
  max-height:88vh;
  object-fit:contain;
  background:#fff;
  border-radius:26px;
  padding:20px;
  box-shadow:0 30px 90px rgba(0,0,0,.35);
}

.image-modal-close{
  position:absolute;
  top:22px;
  right:24px;
  width:46px;
  height:46px;
  border:0;
  border-radius:50%;
  background:#fff;
  color:#111820;
  font-size:32px;
  line-height:1;
  cursor:pointer;
  font-weight:700;
}

.benefits{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:16px;
}
.benefit{
  background:#101820;
  color:#fff;
  padding:28px;
  border-radius:24px;
}
.benefit strong{display:block;font-size:1.3rem;margin-bottom:6px}
.benefit span{color:#b8c4ca}

.footer{
  padding:45px max(22px,calc((100vw - 1180px)/2));
  background:#071014;
  color:#fff;
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:30px;
}
.footer img{width:55px;border-radius:50%;display:block;margin-bottom:12px}
.footer p{color:#b8c4ca;margin-top:8px}

.floating-cart{
  position:fixed;
  right:22px;
  bottom:22px;
  z-index:30;
  background:#101820;
  color:#fff;
  min-width:62px;
  height:56px;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:7px;
  border-radius:999px;
  box-shadow:var(--shadow);
  font-weight:900;
}
.floating-cart span{background:var(--turquoise);color:#071014;border-radius:999px;padding:2px 7px}

.toast{
  position:fixed;
  left:50%;
  bottom:25px;
  transform:translate(-50%,30px);
  background:#101820;
  color:#fff;
  padding:14px 18px;
  border-radius:999px;
  z-index:50;
  opacity:0;
  transition:.25s;
  font-weight:800;
}
.toast.show{opacity:1;transform:translate(-50%,0)}

.cart-page{padding-top:20px}
.cart-hero{
  padding-top:80px;
  text-align:center;
  background:linear-gradient(180deg,#fff,#f7fbfc);
}
.cart-hero span{color:#087e82;font-weight:900;text-transform:uppercase;letter-spacing:.12em}
.cart-hero h1{font-size:clamp(2.7rem,6vw,5rem);letter-spacing:-.06em;margin-top:10px}
.cart-hero p{color:var(--muted);max-width:660px;margin:14px auto 0;line-height:1.7}
.cart-layout{
  display:grid;
  grid-template-columns:1fr 380px;
  gap:24px;
  align-items:start;
}
.cart-box,.summary-box{
  background:#fff;
  border:1px solid var(--line);
  border-radius:30px;
  box-shadow:0 16px 42px rgba(10,20,25,.06);
  padding:24px;
}
.cart-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}
.clear-btn,.remove-btn{
  background:#fff0f0;
  color:#c93636;
  border:0;
  border-radius:999px;
  padding:10px 14px;
  cursor:pointer;
  font-weight:900;
}
.cart-items{display:flex;flex-direction:column;gap:14px}
.cart-item{
  display:grid;
  grid-template-columns:90px 1fr auto auto;
  gap:16px;
  align-items:center;
  padding:15px;
  border:1px solid var(--line);
  border-radius:22px;
}
.cart-visual{
  width:90px;
  height:90px;
  border-radius:20px;
  display:flex;
  align-items:center;
  justify-content:center;
  overflow:hidden;
  background:#fff;
  border:1px solid var(--line);
  cursor:zoom-in;
}

.cart-visual img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
.cart-detail h3{margin-bottom:6px}
.cart-detail p{color:var(--muted);font-size:.92rem;line-height:1.45;margin-bottom:10px}
.cart-options label{font-size:.82rem;color:#60717c;font-weight:900}
.cart-options select{margin-left:8px;border:1px solid var(--line);border-radius:10px;padding:7px}
.qty-box{display:flex;align-items:center;gap:8px;background:#f4f7f8;border-radius:999px;padding:6px}
.qty-box button{width:32px;height:32px;border:0;border-radius:50%;background:#fff;cursor:pointer;font-weight:900}
.qty-box span{min-width:22px;text-align:center;font-weight:900}
.summary-box{position:sticky;top:105px}
.summary-box h2{margin-bottom:18px}
.summary-box label{display:block;color:#51616d;font-size:.86rem;font-weight:900;margin-bottom:14px}
.summary-box input,.summary-box textarea{
  width:100%;
  margin-top:7px;
  border:1px solid var(--line);
  border-radius:16px;
  padding:13px 14px;
  outline:none;
}
.summary-box textarea{min-height:92px;resize:vertical}
.summary-line{
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding:18px 0;
  border-top:1px solid var(--line);
  margin-top:8px;
}
.summary-line strong{font-size:1.5rem}
.summary-box .btn{margin-top:10px}
.empty-cart{text-align:center;padding:60px 20px}
.empty-cart p{color:var(--muted);margin:10px 0 20px}

@media (max-width:900px){
  .site-header{top:10px;width:calc(100% - 20px);border-radius:22px}
  .menu-toggle{display:block}
  .nav{
    position:absolute;
    left:0;right:0;top:72px;
    background:#fff;
    border:1px solid var(--line);
    border-radius:22px;
    padding:12px;
    display:none;
    flex-direction:column;
    box-shadow:var(--shadow);
  }
  .nav.open{display:flex}
  .nav a{width:100%;text-align:center}
  .visible-desktop{display:none!important}

  .hero-desktop{display:none}
  .hero-mobile{
    display:block;
    padding:0;
    min-height:auto;
    background:none;
}

.hero-mobile-image{
    width:100%;
    display:block;
    object-fit:cover;
}

.mobile-overlay{
    display:flex;
    justify-content:center;
    margin-top:-70px;
    position:relative;
    z-index:2;
    padding-bottom:25px;
}

.mobile-overlay .btn{
    min-width:220px;
    box-shadow:0 15px 35px rgba(18,214,214,.35);
}

section{
    padding:58px 18px;
}

.category-grid{
    grid-template-columns:repeat(2,1fr);
    gap:12px;
}

.products-grid{
    grid-template-columns:repeat(2,1fr);
    gap:12px;
}

.benefits{
    grid-template-columns:1fr;
}

.row-title{
    align-items:flex-start;
    flex-direction:column;
}

.product-visual{
    height:170px;
}

.product-info{
    padding:14px;
}

.product-info h3{
    font-size:1rem;
    line-height:1.2;
}

.product-info p{
    display:none;
}

.product-meta{
    flex-direction:column;
    align-items:flex-start;
    gap:6px;
}

.product-meta strong{
    font-size:1rem;
}

.product-meta span{
    font-size:.7rem;
    padding:5px 8px;
}

.add-btn{
    height:42px;
    font-size:.82rem;
}

.footer{
    flex-direction:column;
}

.floating-cart{
    right:15px;
    bottom:15px;
}

.cart-layout{
    grid-template-columns:1fr;
    padding:40px 18px;
}

.cart-item{
    grid-template-columns:74px 1fr;
    align-items:start;
}

.cart-visual{
    width:74px;
    height:74px;
}

.qty-box,
.remove-btn{
    grid-column:2;
}

.summary-box{
    position:static;
}
}

/* =========================
   HERO DESKTOP
========================= */

.hero-desktop{
    padding:0;
    display:block;
    position:relative;
    overflow:hidden;
    background:none;
}

.hero-desktop-banner{
    width:100%;
    height:auto;
    display:block;
}

/* LOGO SOBRE HERO */

.hero-desktop::after{
    content:"";
    position:absolute;

    top:120px;
    left:60px;

    width:180px;
    height:180px;

    background:url("../assets/img/logo.png") center center / contain no-repeat;

    z-index:10;

    filter:drop-shadow(0 10px 25px rgba(0,0,0,.25));
}

/* =========================
   CARD PRODUCTO
========================= */

.product-visual{
    position:relative;
}

/* ELIMINAMOS FLECHAS DEL CARD */

.img-arrow,
.img-prev,
.img-next{
    display:none !important;
}

/* =========================
   ZOOM MODAL
========================= */

.image-modal{
    position:fixed;
    inset:0;
    background:rgba(0,0,0,.82);
    backdrop-filter:blur(8px);
    display:flex;
    align-items:center;
    justify-content:center;
    z-index:99999;
    opacity:0;
    pointer-events:none;
    transition:.25s;
}

.image-modal.active{
    opacity:1;
    pointer-events:auto;
}

.image-modal img{
    max-width:min(85vw,900px);
    max-height:85vh;
    object-fit:contain;
    border-radius:20px;
    background:#fff;
    padding:10px;
    box-shadow:0 20px 60px rgba(0,0,0,.45);
}

/* CERRAR */

.image-modal-close{
    position:absolute;
    top:25px;
    right:25px;
    width:54px;
    height:54px;
    border:none;
    border-radius:50%;
    background:#fff;
    color:#111;
    font-size:34px;
    font-weight:700;
    cursor:pointer;
    z-index:100001;
}

/* FLECHAS GRANDES */

.zoom-prev,
.zoom-next{
    position:absolute;
    top:50%;
    transform:translateY(-50%);
    width:70px;
    height:70px;
    border:none;
    border-radius:50%;
    background:rgba(255,255,255,.92);
    color:#111;
    font-size:44px;
    font-weight:700;
    cursor:pointer;
    z-index:100000;
    transition:.2s;
}

.zoom-prev:hover,
.zoom-next:hover{
    transform:translateY(-50%) scale(1.08);
}

.zoom-prev{
    left:40px;
}

.zoom-next{
    right:40px;
}

/* INDICADORES */

.zoom-dots{
    position:absolute;
    bottom:35px;
    left:50%;
    transform:translateX(-50%);
    display:flex;
    gap:12px;
    z-index:100000;
}

.zoom-dots span{
    width:14px;
    height:14px;
    border-radius:50%;
    background:rgba(255,255,255,.35);
}

.zoom-dots span.active{
    background:#fff;
}

/* =========================
   SMART PRODUCT CARDS
========================= */

.smart-product-card{
    border-radius:28px;
    border:1px solid rgba(228,234,238,.95);
    background:#fff;
    box-shadow:0 12px 35px rgba(10,20,25,.08);
    overflow:hidden;
    transition:.25s;
}

.smart-product-card:hover{
    transform:translateY(-6px);
    box-shadow:0 20px 50px rgba(10,20,25,.12);
}

.smart-badge{
    top:14px;
    right:14px;
    left:auto;
    background:#101820;
    color:#fff;
    font-size:.75rem;
    padding:8px 14px;
    border-radius:999px;
    z-index:5;
}

.smart-visual{
    height:240px;
    display:flex;
    align-items:center;
    justify-content:center;
    background:
    radial-gradient(circle at center,
    rgba(18,214,214,.12),
    transparent 55%);
}

.smart-visual img{
    width:100%;
    height:100%;
    object-fit:contain;
    padding:12px;
}

.smart-info{
    padding:18px;
}

.smart-topline{
    display:flex;
    justify-content:space-between;
    align-items:center;
    gap:10px;
    margin-bottom:8px;
}

.smart-topline .category-name{
    font-size:.72rem;
    letter-spacing:.12em;
    text-transform:uppercase;
    font-weight:900;
    color:#07868a;
}

.smart-topline strong{
    font-size:2rem;
    font-weight:900;
    color:#101820;
    white-space:nowrap;
}

.smart-info h3{
    font-size:1.25rem;
    line-height:1.2;
    margin:0 0 10px;
}

.smart-info p{
    display:block !important;
    overflow:visible !important;
    min-height:auto !important;
    max-height:none !important;
}

.smart-option-block{
    margin-top:14px;
}

.smart-option-head{
    display:flex;
    justify-content:space-between;
    align-items:center;
    margin-bottom:8px;
}

.smart-option-head span{
    font-size:.72rem;
    letter-spacing:.15em;
    text-transform:uppercase;
    font-weight:900;
    color:#4c5b66;
}

.smart-option-head small{
    color:#07868a;
    font-weight:800;
    font-size:.75rem;
}

.variant-chips{
    display:flex;
    flex-wrap:wrap;
    gap:6px;
}

.variant-chip{
    border:1px solid #d9e4e8;
    background:#fff;
    color:#26323a;
    border-radius:999px;
    padding:6px 12px;
    font-size:.72rem;
    font-weight:800;
    cursor:pointer;
    transition:.2s;
}

.variant-chip:hover{
    background:#eaffff;
    border-color:#12d6d6;
}

.variant-chip.active{
    background:#101820;
    border-color:#101820;
    color:#fff;
}

.smart-select{
    width:100%;
    height:48px;
    border-radius:14px;
    border:1px solid #d9e4e8;
    padding:0 14px;
    font-size:.9rem;
    background:#fff;
}

.hidden-variant-select{
    display:none !important;
}

.smart-add-btn{
    width:100%;
    height:50px;
    margin-top:14px;
    border-radius:14px;
    font-size:.95rem;
    font-weight:900;
    background:linear-gradient(
        135deg,
        #12d6d6,
        #53ffff
    );
    box-shadow:0 12px 24px rgba(18,214,214,.22);
}

.smart-add-btn:hover{
    background:#101820;
    color:#fff;
}

.smart-description{
    display:block !important;
    margin:12px 0 18px;
    color:#5f6b75;
    font-size:.92rem;
    line-height:1.5;
}

/* Talles */

.sizes-section{
padding:80px 20px;
max-width:1200px;
margin:auto;
text-align:center;
}

.sizes-buttons{
display:flex;
justify-content:center;
gap:20px;
margin-top:40px;
flex-wrap:wrap;
}

.size-btn{
border:none;
padding:18px 35px;
border-radius:60px;
background:#19d3dc;
color:#07131f;
font-weight:700;
font-size:16px;
cursor:pointer;
transition:.25s;
}

.size-btn:hover{
transform:translateY(-4px);
box-shadow:0 15px 30px rgba(25,211,220,.25);
}

.size-modal{
position:fixed;
inset:0;
z-index:99999;
display:none;
align-items:center;
justify-content:center;
padding:30px;
}

.size-modal.active{
display:flex;
}

.size-modal-overlay{
position:absolute;
inset:0;
background:rgba(0,0,0,.75);
backdrop-filter:blur(8px);
}

.size-modal-content{
position:relative;
z-index:2;
max-width:1000px;
width:100%;
background:#fff;
border-radius:20px;
padding:20px;
box-shadow:0 30px 80px rgba(0,0,0,.3);
animation:sizeZoom .25s ease;
}

.size-modal-content img{
display:block;
width:100%;
max-height:80vh;
object-fit:contain;
border-radius:12px;
}

.size-modal-close{
position:absolute;
top:-15px;
right:-15px;
width:45px;
height:45px;
border:none;
border-radius:50%;
background:#07131f;
color:#fff;
font-size:28px;
cursor:pointer;
}

@keyframes sizeZoom{
from{
opacity:0;
transform:scale(.9);
}
to{
opacity:1;
transform:scale(1);
}
}

/* =========================
   MOBILE
========================= */

@media(max-width:900px){

    .smart-product-card{
        border-radius:22px;
    }

    .smart-visual{
        height:240px;
    }

    .smart-visual img{
        padding:8px;
        object-fit:contain;
    }

    .smart-info{
        padding:14px;
    }

    .smart-topline{
        flex-direction:column;
        align-items:flex-start;
        gap:4px;
    }

    .smart-topline strong{
        font-size:1.5rem;
    }

    .smart-info h3{
        font-size:1.1rem;
    }

    .variant-chip{
        padding:5px 10px;
        font-size:.65rem;
    }

    .smart-option-head{
        flex-direction:column;
        align-items:flex-start;
        gap:3px;
    }

    .smart-option-head span,
    .smart-option-head small{
        font-size:.65rem;
    }

    .smart-select{
        height:42px;
        font-size:.8rem;
    }

    .smart-add-btn{
        height:44px;
        font-size:.8rem;
    }

    .smart-description{
        font-size:.82rem;
        line-height:1.4;
        min-height:58px;
        max-height:58px;
    }

    .smart-info p{
        display:none;
    }

    /* HERO */

    .hero-desktop{
        display:none !important;
    }

    .hero-desktop-banner{
        display:none !important;
    }

    .hero-mobile{
        display:block !important;
        margin:0;
        padding:0;
    }

    .hero-mobile-image{
        display:block !important;
        width:100%;
        height:auto;
    }

    .hero-logo{
        display:none !important;
    }

    /* MEJORAS VISUALES */

    .smart-option{
        margin-top:10px;
    }

    .smart-option-head{
        margin-bottom:6px;
    }

    /* SCROLL HORIZONTAL PARA CHIPS */

    .variant-chips,
    .variant-list,
    .design-list{
        display:flex;
        gap:8px;
        overflow-x:auto;
        flex-wrap:nowrap;
        padding-bottom:6px;
        scrollbar-width:none;
    }

    .variant-chips::-webkit-scrollbar,
    .variant-list::-webkit-scrollbar,
    .design-list::-webkit-scrollbar{
        display:none;
    }

    .variant-chip{
        white-space:nowrap;
        flex-shrink:0;
    }

    /* CATEGORIAS */

    .category-grid{
        display:grid;
        grid-template-columns:1fr 1fr;
        gap:12px;
    }

    .category-card{
        min-height:90px;
        padding:16px 10px;
        display:flex;
        align-items:center;
        justify-content:center;
        text-align:center;
    }

    .category-card h3{
        margin:0;
        font-size:1rem;
        line-height:1.2;
    }

    .category-card p,
    .category-content p,
    .cat-card p{
        display:none !important;
    }

    /* TALLES */

    .sizes-section{
        padding:60px 20px;
    }

    .sizes-buttons{
        flex-direction:column;
    }

    .size-btn{
        width:100%;
    }

    .size-modal{
        padding:15px;
    }

}