@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,400;0,600;0,700;1,400;1,600&family=Outfit:wght@300;400;500;600&display=swap');
*{margin:0;padding:0;box-sizing:border-box}
:root{
  --p50:#f5f0ff;--p100:#ede5ff;--p200:#d8c8ff;--p300:#bfa3ff;
  --p400:#9d6fff;--p500:#7c3aed;--p600:#6221d0;--p700:#4c1aa3;--p900:#1e0a4a;
  --rose:#e040fb;--dark:#12082e;--mid:#3a2660;--muted:#8872b0;
}
body{font-family:'Outfit',sans-serif;background:#f7f3ff;color:var(--dark);overflow-x:hidden}

/* PROMO */
.promo-banner{background:linear-gradient(90deg,var(--p600),var(--rose));color:white;text-align:center;padding:10px 1rem;font-size:13px;font-weight:500;position:relative}
.promo-close{position:absolute;right:1rem;top:50%;transform:translateY(-50%);background:none;border:none;color:white;font-size:16px;cursor:pointer;opacity:.7}
.promo-close:hover{opacity:1}

/* NAV */
.navbar{position:sticky;top:0;z-index:300;background:rgba(255,255,255,.95);backdrop-filter:blur(14px);border-bottom:1px solid var(--p200);padding:0 2rem;display:flex;align-items:center;justify-content:space-between;height:68px;gap:1rem}
.navbar-left{display:flex;align-items:center;gap:12px;flex-shrink:0}
.logo-ring{width:44px;height:44px;border-radius:50%;border:2px solid var(--p500);display:flex;align-items:center;justify-content:center;background:white;text-decoration:none}
.brand-name{font-family:'Cormorant Garamond',serif;font-size:18px;font-weight:700;color:var(--p700);line-height:1}
.brand-tag{font-size:9px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);font-weight:500}
.search-wrap{flex:1;max-width:340px;position:relative}
.search-wrap input{width:100%;padding:9px 14px 9px 38px;border:1.5px solid var(--p200);border-radius:50px;font-family:'Outfit',sans-serif;font-size:13px;background:var(--p50);color:var(--dark);outline:none;transition:border .2s}
.search-wrap input:focus{border-color:var(--p500);background:white}
.search-wrap input::placeholder{color:var(--muted)}
.s-icon{position:absolute;left:13px;top:50%;transform:translateY(-50%);color:var(--muted);font-size:14px;pointer-events:none}
.navbar-right{display:flex;align-items:center;gap:8px;flex-shrink:0}
.nav-link{background:none;border:none;color:var(--mid);font-family:'Outfit',sans-serif;font-size:13px;font-weight:500;cursor:pointer;padding:6px 10px;border-radius:50px;transition:background .15s;text-decoration:none;display:inline-block}
.nav-link:hover{background:var(--p50);color:var(--p600)}
.btn-wsp-nav{background:none;border:1.5px solid #25d366;color:#25d366;border-radius:50px;padding:7px 13px;font-family:'Outfit',sans-serif;font-size:12px;font-weight:500;cursor:pointer;display:flex;align-items:center;gap:5px;transition:background .2s,color .2s;text-decoration:none}
.btn-wsp-nav:hover{background:#25d366;color:white}
.btn-cart{background:var(--p500);color:white;border:none;border-radius:50px;padding:8px 16px;font-family:'Outfit',sans-serif;font-size:12px;font-weight:500;cursor:pointer;display:flex;align-items:center;gap:6px}
.btn-cart:hover{background:var(--p600)}
.cart-badge{background:var(--rose);color:white;border-radius:50%;width:18px;height:18px;font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center}

/* HERO */
.hero{position:relative;overflow:hidden;background:var(--p900);padding:4.5rem 2rem 4rem;display:flex;align-items:center;justify-content:center}
.hero-bg{position:absolute;inset:0;pointer-events:none;background:radial-gradient(ellipse 60% 60% at 75% 20%,rgba(160,80,255,.35) 0%,transparent 60%),radial-gradient(ellipse 50% 50% at 20% 80%,rgba(224,64,251,.2) 0%,transparent 60%)}
.hero-dots{position:absolute;inset:0;background-image:radial-gradient(rgba(255,255,255,.07) 1px,transparent 1px);background-size:26px 26px;pointer-events:none}
.hero-content{position:relative;text-align:center;max-width:600px}
.hero-eyebrow{display:inline-flex;align-items:center;gap:8px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.18);border-radius:50px;padding:5px 14px;font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.75);font-weight:500;margin-bottom:1.2rem}
.hero h1{font-family:'Cormorant Garamond',serif;font-size:54px;font-weight:600;line-height:1.05;color:white;margin-bottom:1rem}
.hero h1 em{font-style:italic;color:#d4a8ff}
.hero p{font-size:16px;font-weight:300;color:rgba(255,255,255,.7);line-height:1.7;margin-bottom:2rem}
.hero-actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
.cta-primary{background:white;color:var(--p700);border:none;border-radius:50px;padding:13px 28px;font-family:'Outfit',sans-serif;font-size:14px;font-weight:600;cursor:pointer;text-decoration:none;display:inline-block}
.cta-ghost{background:rgba(255,255,255,.08);color:white;border:1.5px solid rgba(255,255,255,.28);border-radius:50px;padding:13px 22px;font-family:'Outfit',sans-serif;font-size:14px;cursor:pointer;text-decoration:none;display:inline-block}

/* STATS */
.stats-strip{background:white;border-bottom:1px solid var(--p100);display:flex;justify-content:center;padding:.8rem 2rem;gap:2rem;flex-wrap:wrap}
.stat{display:flex;align-items:center;gap:8px}
.stat-icon{font-size:18px}
.stat-text{font-size:12px;color:var(--muted)}
.stat-text strong{color:var(--dark);font-weight:600;display:block;font-size:13px}

/* SECTIONS */
.section-wrap{max-width:1040px;margin:0 auto;padding:3rem 1.5rem}
.section-label{font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--p500);font-weight:600;margin-bottom:.3rem}
.section-title{font-family:'Cormorant Garamond',serif;font-size:34px;font-weight:700;color:var(--p900);line-height:1;margin-bottom:1.6rem}

/* NOSOTROS */
.nosotros-grid{display:grid;grid-template-columns:1fr 1fr;gap:2.5rem;align-items:center}
@media(max-width:620px){.nosotros-grid{grid-template-columns:1fr}}
.nosotros-img{border-radius:20px;background:linear-gradient(140deg,#ede5ff,#d8c8ff);height:260px;display:flex;align-items:center;justify-content:center;font-size:80px}
.chips{display:flex;gap:8px;flex-wrap:wrap;margin-top:1rem}
.chip{background:var(--p50);border:1px solid var(--p200);border-radius:50px;padding:5px 14px;font-size:12px;color:var(--p600);font-weight:500}

/* CATALOG */
.catalog-top{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:1.4rem;gap:1rem;flex-wrap:wrap}
.filters{display:flex;gap:7px;flex-wrap:wrap}
.pill{background:white;border:1.5px solid var(--p200);color:var(--mid);border-radius:50px;padding:6px 14px;font-size:12px;font-family:'Outfit',sans-serif;font-weight:500;cursor:pointer;transition:all .18s}
.pill.active,.pill:hover{background:var(--p500);border-color:var(--p500);color:white}
.search-note{font-size:12px;color:var(--muted);margin-bottom:1rem;min-height:16px}
.cat-group{margin-bottom:2.2rem}
.cat-header{display:flex;align-items:center;gap:10px;margin-bottom:1rem}
.cat-emoji{font-size:20px}
.cat-title{font-family:'Cormorant Garamond',serif;font-size:22px;font-weight:700;color:var(--p700)}
.cat-line{flex:1;height:1px;background:var(--p200)}
.cat-count{font-size:11px;color:var(--muted)}
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:14px}
.card{background:white;border-radius:18px;border:1px solid var(--p100);overflow:hidden;cursor:pointer;transition:transform .22s cubic-bezier(.34,1.56,.64,1)}
.card:hover{transform:translateY(-5px)}
.card-img{height:155px;overflow:hidden;position:relative;background:var(--p50);display:flex;align-items:center;justify-content:center;font-size:46px}
.card-img img{width:100%;height:100%;object-fit:cover;display:block}
.card-badge{position:absolute;top:9px;right:9px;background:var(--p500);color:white;font-size:9px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;padding:3px 8px;border-radius:50px}
.card-badge.new{background:var(--rose)}
.card-badge.magic{background:#f97316}
.card-body{padding:12px 14px 14px}
.card-sub{font-size:10px;letter-spacing:.09em;text-transform:uppercase;color:var(--p400);font-weight:600;margin-bottom:3px}
.card-name{font-family:'Cormorant Garamond',serif;font-size:16px;font-weight:700;color:var(--p900);margin-bottom:4px;line-height:1.2}
.card-detail{font-size:11px;color:var(--muted);margin-bottom:10px;line-height:1.4;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;}
.card-footer{display:flex;align-items:center;justify-content:space-between;gap:5px;flex-wrap:nowrap;min-height:34px}
.card-price{font-size:11px;color:var(--muted);font-style:italic;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:50%}
.btn-consult{background:none;border:1.5px solid var(--p300);color:var(--p600);border-radius:50px;padding:5px 11px;font-family:'Outfit',sans-serif;font-size:11px;font-weight:500;cursor:pointer;white-space:nowrap}
.btn-consult:hover{background:var(--p500);color:white;border-color:var(--p500)}
.no-results{grid-column:1/-1;text-align:center;padding:2.5rem 1rem;color:var(--muted);font-size:14px}

/* HOW */
.how-section{background:var(--p900);padding:3.5rem 2rem;position:relative;overflow:hidden}
.how-bg{position:absolute;top:-80px;right:-80px;width:300px;height:300px;border-radius:50%;background:radial-gradient(circle,rgba(160,80,255,.22),transparent 70%);pointer-events:none}
.how-inner{max-width:900px;margin:0 auto}
.how-section .section-label{color:var(--p300)}
.how-section .section-title{color:white}
.steps{display:grid;grid-template-columns:repeat(auto-fit,minmax(165px,1fr));gap:14px}
.step{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);border-radius:14px;padding:1.2rem 1rem}
.step-num{font-family:'Cormorant Garamond',serif;font-size:36px;font-weight:700;color:var(--p300);line-height:1;margin-bottom:.4rem}
.step-title{font-size:13.5px;font-weight:600;color:white;margin-bottom:.3rem}
.step-desc{font-size:11.5px;color:rgba(255,255,255,.5);line-height:1.5}

/* IG */
.ig-section{background:white;border-top:1px solid var(--p100);border-bottom:1px solid var(--p100)}
.ig-inner{max-width:1040px;margin:0 auto;padding:2.5rem 1.5rem}
.ig-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem}
.ig-handle{display:flex;align-items:center;gap:10px}
.ig-avatar{width:44px;height:44px;border-radius:50%;background:linear-gradient(135deg,#f9a825,#e040fb,#7c3aed);display:flex;align-items:center;justify-content:center;font-size:20px}
.ig-name{font-weight:600;font-size:14px;color:var(--dark)}
.ig-sub{font-size:11.5px;color:var(--muted)}
.ig-follow{background:var(--p500);color:white;border:none;border-radius:50px;padding:7px 18px;font-family:'Outfit',sans-serif;font-size:12.5px;font-weight:500;cursor:pointer;text-decoration:none;display:inline-block}
.ig-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}
.ig-post{border-radius:12px;aspect-ratio:1;overflow:hidden;cursor:pointer;background:linear-gradient(140deg,#f0e8ff,#ddd5f9);display:flex;align-items:center;justify-content:center;font-size:30px;text-decoration:none}

/* FORM */
.form-section{background:var(--p50);border-top:1px solid var(--p100)}
.form-inner{max-width:680px;margin:0 auto;padding:3rem 1.5rem}
.form-card{background:white;border-radius:20px;border:1px solid var(--p200);padding:2rem}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.form-grid .full{grid-column:1/-1}
.field-label{font-size:12px;font-weight:500;color:var(--mid);margin-bottom:5px;display:block}
.field-input,.field-select,.field-textarea{width:100%;padding:10px 14px;border:1.5px solid var(--p200);border-radius:10px;font-family:'Outfit',sans-serif;font-size:13px;color:var(--dark);background:var(--p50);outline:none;transition:border .2s}
.field-input:focus,.field-select:focus,.field-textarea:focus{border-color:var(--p500);background:white}
.field-textarea{resize:vertical;min-height:90px}
.field-select{cursor:pointer;appearance:none}
.btn-submit{width:100%;background:var(--p500);color:white;border:none;border-radius:50px;padding:14px;font-family:'Outfit',sans-serif;font-size:15px;font-weight:600;cursor:pointer;margin-top:1.2rem;display:flex;align-items:center;justify-content:center;gap:8px}
.btn-submit:hover{background:var(--p600)}
.form-success{display:none;text-align:center;padding:2rem;color:var(--p700)}
.form-success .fs-icon{font-size:48px;margin-bottom:.8rem}
.form-success h3{font-family:'Cormorant Garamond',serif;font-size:24px;font-weight:700;margin-bottom:.5rem}

/* FAQ */
.faq-section{background:white;border-top:1px solid var(--p100)}
.faq-inner{max-width:680px;margin:0 auto;padding:3rem 1.5rem}
.faq-list{display:flex;flex-direction:column;gap:10px}
.faq-item{border:1px solid var(--p200);border-radius:14px;overflow:hidden}
.faq-q{width:100%;background:none;border:none;padding:16px 18px;display:flex;justify-content:space-between;align-items:center;cursor:pointer;font-family:'Outfit',sans-serif;font-size:14px;font-weight:500;color:var(--dark);text-align:left;gap:1rem}
.faq-q:hover{background:var(--p50)}
.faq-q.open{background:var(--p50);color:var(--p600)}
.faq-chevron{flex-shrink:0;font-size:16px;color:var(--muted);transition:transform .25s}
.faq-q.open .faq-chevron{transform:rotate(180deg);color:var(--p500)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .3s ease,padding .3s ease;font-size:13.5px;color:var(--mid);line-height:1.7;padding:0 18px}
.faq-a.open{max-height:200px;padding:0 18px 16px}

/* CART */
.cart-overlay{display:none;position:fixed;inset:0;background:rgba(10,4,30,.45);z-index:400}
.cart-overlay.open{display:block}
.cart-drawer{position:fixed;right:0;top:0;bottom:0;width:340px;background:white;z-index:401;display:flex;flex-direction:column;transform:translateX(100%);transition:transform .3s cubic-bezier(.4,0,.2,1)}
.cart-overlay.open .cart-drawer{transform:translateX(0)}
.cart-head{padding:1.2rem 1.3rem .9rem;border-bottom:1px solid var(--p100);display:flex;align-items:center;justify-content:space-between}
.cart-head h3{font-family:'Cormorant Garamond',serif;font-size:20px;color:var(--p700)}
.close-btn{background:var(--p50);border:none;width:30px;height:30px;border-radius:50%;cursor:pointer;font-size:14px;color:var(--mid)}
.cart-body{flex:1;overflow-y:auto;padding:.9rem 1.3rem}
.empty-cart{text-align:center;padding:2.5rem 1rem;color:var(--muted);font-size:13px}
.empty-cart span{display:block;font-size:42px;margin-bottom:.7rem}
.cart-line{display:flex;align-items:center;gap:9px;padding:10px 0;border-bottom:1px solid var(--p50)}
.cart-line-thumb{width:38px;height:38px;border-radius:9px;background:var(--p50);display:flex;align-items:center;justify-content:center;font-size:19px;flex-shrink:0;overflow:hidden}
.cart-line-thumb img{width:100%;height:100%;object-fit:cover}
.cart-line-info{flex:1}
.cart-line-name{font-size:13px;font-weight:500;color:var(--dark);line-height:1.2}
.cart-line-price{font-size:12px;color:var(--p500);font-weight:600;margin-top:2px}
.cart-line-rm{background:none;border:none;color:#ccc;cursor:pointer;font-size:14px;padding:3px}
.cart-line-rm:hover{color:#e94848}
.cart-foot{padding:1rem 1.3rem;border-top:1px solid var(--p100);display:flex;flex-direction:column;gap:9px}
.cart-total-row{display:flex;justify-content:space-between;align-items:center}
.cart-total-label{font-size:12px;color:var(--muted)}
.cart-total-val{font-size:20px;font-weight:700;color:var(--p700);font-family:'Cormorant Garamond',serif}
.btn-send-wsp{background:#25d366;color:white;border:none;border-radius:50px;padding:12px;font-family:'Outfit',sans-serif;font-size:14px;font-weight:600;cursor:pointer;width:100%;display:flex;align-items:center;justify-content:center;gap:7px}
.btn-send-wsp:hover{background:#1ebe5a}

/* FLOAT */
.wsp-float{position:fixed;bottom:1.8rem;right:1.8rem;z-index:350}
.wsp-btn{width:56px;height:56px;border-radius:50%;background:#25d366;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:26px;box-shadow:0 4px 20px rgba(37,211,102,.4)}

/* TOAST */
.toast{position:fixed;bottom:5.5rem;left:50%;transform:translateX(-50%) translateY(60px);background:var(--p700);color:white;padding:10px 22px;border-radius:50px;font-size:13px;font-weight:500;z-index:500;pointer-events:none;transition:transform .3s cubic-bezier(.34,1.56,.64,1);white-space:nowrap}
.toast.show{transform:translateX(-50%) translateY(0)}

/* FOOTER */
footer{background:var(--dark);color:rgba(255,255,255,.5);padding:2.2rem 2rem;text-align:center}
.footer-brand{font-family:'Cormorant Garamond',serif;font-size:21px;font-weight:700;color:white;margin-bottom:.2rem}
.footer-divider{width:36px;height:2px;background:var(--p500);border-radius:2px;margin:.8rem auto}
.footer-links{display:flex;justify-content:center;gap:1.5rem;flex-wrap:wrap;margin-bottom:.8rem}
.footer-link{color:var(--p300);font-size:12.5px;cursor:pointer;text-decoration:none}
.footer-link:hover{color:white}
.footer-contact{font-size:12px;color:var(--p300)}
.footer-copy{font-size:10.5px;color:rgba(255,255,255,.2);margin-top:.6rem}

/* ═══════════════════════════════════════
   MOBILE — hasta 768px
   ═══════════════════════════════════════ */
@media (max-width: 768px) {

  /* NAV MÓVIL */
  .navbar { padding: 0 1rem; height: 60px; gap: .5rem; }
  .brand-tag { display: none; }
  .brand-name { font-size: 16px; }
  .logo-ring { width: 38px; height: 38px; }
  .search-wrap { display: none; } /* se mueve abajo */
  .nav-link { display: none; }
  .btn-wsp-nav { display: none; }
  .btn-cart { padding: 7px 13px; font-size: 11px; }

  /* HAMBURGER */
  .hamburger {
    display: flex;
    flex-direction: column;
    gap: 5px;
    background: none;
    border: none;
    cursor: pointer;
    padding: 6px;
    border-radius: 8px;
  }
  .hamburger span {
    display: block;
    width: 22px;
    height: 2px;
    background: var(--p600);
    border-radius: 2px;
    transition: all .25s;
  }
  .hamburger.open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
  .hamburger.open span:nth-child(2) { opacity: 0; }
  .hamburger.open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

  /* MOBILE MENU DRAWER */
  .mobile-menu {
    display: none;
    position: fixed;
    inset: 60px 0 0 0;
    background: white;
    z-index: 299;
    flex-direction: column;
    padding: 1.5rem 1.5rem 2rem;
    gap: 0;
    border-top: 1px solid var(--p100);
    overflow-y: auto;
  }
  .mobile-menu.open { display: flex; }

  /* buscador dentro del menu móvil */
  .mobile-search {
    position: relative;
    margin-bottom: 1.2rem;
  }
  .mobile-search input {
    width: 100%;
    padding: 11px 14px 11px 40px;
    border: 1.5px solid var(--p200);
    border-radius: 50px;
    font-family: 'Outfit', sans-serif;
    font-size: 14px;
    background: var(--p50);
    color: var(--dark);
    outline: none;
  }
  .mobile-search input:focus { border-color: var(--p500); background: white; }
  .mobile-search .s-icon { position: absolute; left: 14px; top: 50%; transform: translateY(-50%); color: var(--muted); font-size: 15px; pointer-events: none; }

  .mobile-nav-link {
    display: flex;
    align-items: center;
    padding: 14px 4px;
    border-bottom: 1px solid var(--p50);
    font-size: 15px;
    font-weight: 500;
    color: var(--mid);
    text-decoration: none;
    gap: 10px;
  }
  .mobile-nav-link:last-of-type { border-bottom: none; }
  .mobile-nav-link .mn-icon { font-size: 18px; }

  .mobile-wsp-btn {
    margin-top: 1.2rem;
    width: 100%;
    background: #25d366;
    color: white;
    border: none;
    border-radius: 50px;
    padding: 14px;
    font-family: 'Outfit', sans-serif;
    font-size: 15px;
    font-weight: 600;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    text-decoration: none;
  }

  /* HERO */
  .hero { padding: 3rem 1.2rem 2.5rem; }
  .hero h1 { font-size: 36px; }
  .hero p { font-size: 14px; }
  .hero-eyebrow { font-size: 10px; padding: 4px 12px; }
  .cta-primary, .cta-ghost { padding: 11px 20px; font-size: 13px; }

  /* STATS */
  .stats-strip { gap: 1rem; padding: .8rem 1rem; justify-content: flex-start; overflow-x: auto; flex-wrap: nowrap; }
  .stat { flex-shrink: 0; }
  .stat-text { font-size: 11px; }
  .stat-text strong { font-size: 12px; }

  /* SECTION WRAP */
  .section-wrap { padding: 2rem 1rem; }
  .section-title { font-size: 26px; }

  /* NOSOTROS */
  .nosotros-img { height: 180px; font-size: 56px; }

  /* CATÁLOGO */
  .catalog-top { flex-direction: column; align-items: flex-start; gap: .8rem; }
  .filters { gap: 6px; }
  .pill { padding: 5px 12px; font-size: 11.5px; }
  .grid { grid-template-columns: repeat(2, 1fr); gap: 10px; }
  .card-img { height: 130px; font-size: 38px; }
  .card-body { padding: 10px 11px 12px; }
  .card-name { font-size: 14px; }
  .card-detail { font-size: 10.5px; margin-bottom: 8px; }
  .btn-consult { font-size: 10px; padding: 5px 9px; }
  .cat-title { font-size: 19px; }

  /* HOW */
  .how-section { padding: 2.5rem 1rem; }
  .steps { grid-template-columns: 1fr 1fr; gap: 10px; }
  .step { padding: 1rem .9rem; }
  .step-num { font-size: 28px; }
  .step-title { font-size: 12.5px; }
  .step-desc { font-size: 11px; }

  /* IG */
  .ig-inner { padding: 1.8rem 1rem; }
  .ig-sub { display: none; }
  .ig-grid { grid-template-columns: repeat(4,1fr); gap: 6px; }

  /* FORM */
  .form-inner { padding: 2rem 1rem; }
  .form-card { padding: 1.5rem 1.2rem; }
  .form-grid { grid-template-columns: 1fr; }
  .form-grid .full { grid-column: 1; }

  /* FAQ */
  .faq-inner { padding: 2rem 1rem; }
  .faq-q { font-size: 13px; padding: 14px 14px; }

  /* CARRITO */
  .cart-drawer { width: 100%; }

  /* FLOAT WSP — más arriba para no tapar el teclado */
  .wsp-float { bottom: 1.2rem; right: 1rem; }
  .wsp-btn { width: 50px; height: 50px; font-size: 22px; }

  /* FOOTER */
  footer { padding: 2rem 1rem; }
  .footer-links { gap: 1rem; }
}

/* ═══════════════════════════════════════
   TABLET — 769px a 1024px
   ═══════════════════════════════════════ */
@media (min-width: 769px) and (max-width: 1024px) {
  .navbar { padding: 0 1.2rem; }
  .search-wrap { max-width: 240px; }
  .nav-link { padding: 6px 7px; font-size: 12px; }
  .hero h1 { font-size: 44px; }
  .grid { grid-template-columns: repeat(auto-fill, minmax(160px, 1fr)); }
  .steps { grid-template-columns: repeat(2, 1fr); }
  .nosotros-img { height: 220px; }
}

/* Ocultar hamburger en desktop */
@media (min-width: 769px) {
  .hamburger { display: none; }
  .mobile-menu { display: none !important; }
}

/* ═══════════════════════════════════════
   POLISH — Diseño profesional
   ═══════════════════════════════════════ */

/* Logo real */
.logo-ring {
  width: 46px;
  height: 46px;
  border-radius: 50%;
  border: none;
  overflow: hidden;
  background: white;
  box-shadow: 0 2px 8px rgba(124,58,237,.15);
  flex-shrink: 0;
}
.logo-ring img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* Navbar refinado */
.navbar {
  box-shadow: 0 1px 0 var(--p100), 0 4px 20px rgba(124,58,237,.06);
}

/* Hero — texto más refinado */
.hero h1 {
  letter-spacing: -.5px;
}
.hero-eyebrow {
  backdrop-filter: blur(8px);
}

/* Cards — sombra sutil */
.card {
  box-shadow: 0 2px 12px rgba(124,58,237,.06);
}
.card:hover {
  box-shadow: 0 8px 32px rgba(124,58,237,.15);
}

/* Botones — más pulidos */
.btn-consult {
  transition: all .18s cubic-bezier(.34,1.56,.64,1);
}
.cta-primary {
  box-shadow: 0 4px 20px rgba(255,255,255,.25);
  transition: transform .15s, box-shadow .15s;
}
.cta-primary:hover {
  box-shadow: 0 8px 32px rgba(255,255,255,.3);
}

/* Steps — borde izquierdo de acento */
.step {
  border-left: 3px solid var(--p500);
  border-top: 1px solid rgba(255,255,255,.1);
  border-right: 1px solid rgba(255,255,255,.1);
  border-bottom: 1px solid rgba(255,255,255,.1);
}

/* Form inputs — más cuidados */
.field-input, .field-select, .field-textarea {
  font-size: 14px;
  transition: border .2s, box-shadow .2s, background .2s;
}
.field-input:focus, .field-select:focus, .field-textarea:focus {
  box-shadow: 0 0 0 3px rgba(124,58,237,.12);
}

/* FAQ — hover más suave */
.faq-item {
  transition: box-shadow .2s;
}
.faq-item:hover {
  box-shadow: 0 2px 16px rgba(124,58,237,.08);
}

/* Cart drawer — sombra */
.cart-drawer {
  box-shadow: -8px 0 40px rgba(10,4,30,.18);
}

/* Section label — línea decorativa */
.section-label::before {
  content: '✦ ';
  color: var(--p400);
}

/* Footer — borde superior */
footer {
  border-top: 3px solid var(--p600);
}

/* Scrollbar personalizado */
::-webkit-scrollbar { width: 6px; }
::-webkit-scrollbar-track { background: var(--p50); }
::-webkit-scrollbar-thumb { background: var(--p300); border-radius: 3px; }
::-webkit-scrollbar-thumb:hover { background: var(--p400); }

/* Selección de texto */
::selection { background: var(--p200); color: var(--p900); }


/* ═══════════════════════════════════════
   HERO CARRUSEL
   ═══════════════════════════════════════ */
.hero-carousel {
  position: relative;
  overflow: hidden;
  height: 560px;
}

@media (max-width: 768px) {
  .hero-carousel { height: 500px; }
}

.hero-slide {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(135deg, var(--g1) 0%, var(--g2) 55%, var(--g3) 100%);
  opacity: 0;
  transform: scale(1.03);
  transition: opacity .9s ease, transform .9s ease;
  pointer-events: none;
  padding: 3rem 2rem;
}

.hero-slide.active {
  opacity: 1;
  transform: scale(1);
  pointer-events: auto;
  z-index: 1;
}

.hero-slide.leaving {
  opacity: 0;
  transform: scale(.97);
  z-index: 0;
}

/* reutiliza el hero-dots ya definido */
.hero-slide .hero-dots {
  position: absolute;
  inset: 0;
  background-image: radial-gradient(rgba(255,255,255,.07) 1px, transparent 1px);
  background-size: 26px 26px;
  pointer-events: none;
}

/* Progress bar */
.hero-progress {
  position: absolute;
  bottom: 0;
  left: 0;
  height: 3px;
  background: rgba(255,255,255,.35);
  z-index: 10;
  width: 0%;
  transition: width linear;
}

/* ═══════════════════════════════════════
   REDES SOCIALES
   ═══════════════════════════════════════ */
.social-section {
  background: var(--p900);
  border-top: 1px solid rgba(255,255,255,.08);
  border-bottom: 1px solid rgba(255,255,255,.08);
}
.social-inner {
  max-width: 800px;
  margin: 0 auto;
  padding: 3rem 1.5rem;
}
.social-inner .section-label { color: var(--p300); }
.social-inner .section-title { color: white; }

.social-cards {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.social-card {
  display: flex;
  align-items: center;
  gap: 16px;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 16px;
  padding: 1.1rem 1.4rem;
  text-decoration: none;
  transition: background .2s, transform .18s, border-color .2s;
}
.social-card:hover {
  background: rgba(255,255,255,.12);
  border-color: rgba(255,255,255,.25);
  transform: translateX(4px);
}

.social-icon {
  width: 52px;
  height: 52px;
  border-radius: 14px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.ig-icon  { background: linear-gradient(135deg, #f9a825, #e040fb, #7c3aed); }
.fb-icon  { background: #1877f2; }
.wsp-icon { background: #25d366; }

.social-info { flex: 1; }
.social-name   { font-size: 15px; font-weight: 600; color: white; margin-bottom: 2px; }
.social-handle { font-size: 12.5px; color: var(--p300); margin-bottom: 2px; }
.social-desc   { font-size: 12px; color: rgba(255,255,255,.45); }

.social-arrow {
  font-size: 18px;
  color: rgba(255,255,255,.3);
  transition: color .2s, transform .2s;
}
.social-card:hover .social-arrow {
  color: white;
  transform: translateX(4px);
}

@media (max-width: 768px) {
  .social-inner { padding: 2rem 1rem; }
  .social-card { padding: .9rem 1rem; gap: 12px; }
  .social-icon { width: 44px; height: 44px; border-radius: 12px; }
  .social-name { font-size: 14px; }
}

/* ═══════════════════════════════════════
   BOTONES COMPRAR / CONSULTAR EN CARDS
   ═══════════════════════════════════════ */
.btn-buy-card {
  background: var(--p500);
  color: white;
  border: none;
  border-radius: 50px;
  padding: 6px 14px;
  font-family: 'Outfit', sans-serif;
  font-size: 11.5px;
  font-weight: 600;
  cursor: pointer;
  white-space: nowrap;
  transition: background .15s, transform .1s;
  display: flex;
  align-items: center;
  gap: 4px;
}
.btn-buy-card:hover { background: var(--p600); }
.btn-buy-card:active { transform: scale(.95); }

.btn-wsp-card {
  background: none;
  border: 1.5px solid #25d366;
  color: #25d366;
  border-radius: 50px;
  padding: 5px 12px;
  font-family: 'Outfit', sans-serif;
  font-size: 11px;
  font-weight: 500;
  cursor: pointer;
  white-space: nowrap;
  transition: all .15s;
}
.btn-wsp-card:hover { background: #25d366; color: white; }

/* Botones en página de detalle de producto */
.btn-buy-prod {
  background: var(--p500);
  color: white;
  border: none;
  border-radius: 50px;
  padding: 15px 28px;
  font-family: 'Outfit', sans-serif;
  font-size: 15px;
  font-weight: 600;
  cursor: pointer;
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 9px;
  transition: background .2s, transform .1s;
  box-shadow: 0 4px 20px rgba(124,58,237,.25);
}
.btn-buy-prod:hover { background: var(--p600); }
.btn-buy-prod:active { transform: scale(.98); }

/* ═══════════════════════════════════════
   CARRUSEL — soporte para fotos de fondo
   ═══════════════════════════════════════ */
.hero-slide.has-img {
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}
.hero-slide.has-img::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(
    135deg,
    rgba(30, 10, 74, 0.82) 0%,
    rgba(76, 26, 163, 0.65) 50%,
    rgba(124, 58, 237, 0.45) 100%
  );
  z-index: 0;
}
.hero-slide.has-img .hero-content {
  position: relative;
  z-index: 1;
}
