/* ========== CHANGARRITO MIX - STYLES ========== */

*{box-sizing:border-box;margin:0;padding:0}
body{font-family:'Outfit',sans-serif;background:#F5F0E1;color:#2D1117;-webkit-font-smoothing:antialiased;overflow-x:hidden}

/* PAPEL PICADO */
.papel-picado{
  width:100%;height:20px;
  background:repeating-linear-gradient(90deg,
    #E31837 0px,#E31837 25px,
    #FFD700 25px,#FFD700 50px,
    #1B8A2E 50px,#1B8A2E 75px,
    #FF6D00 75px,#FF6D00 100px,
    #E31837 100px,#E31837 125px,
    #1B8A2E 125px,#1B8A2E 150px
  );
  mask-image:url("data:image/svg+xml,%3Csvg width='25' height='20' viewBox='0 0 25 20' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M0 0h25v12c0 0-2.5 0-4-2.5S17.5 4 14.5 4s-4 2-5.5 5.5S5 12 5 12H0z' fill='white'/%3E%3Ccircle cx='12.5' cy='6' r='1.5' fill='black'/%3E%3C/svg%3E");
  -webkit-mask-image:url("data:image/svg+xml,%3Csvg width='25' height='20' viewBox='0 0 25 20' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M0 0h25v12c0 0-2.5 0-4-2.5S17.5 4 14.5 4s-4 2-5.5 5.5S5 12 5 12H0z' fill='white'/%3E%3Ccircle cx='12.5' cy='6' r='1.5' fill='black'/%3E%3C/svg%3E");
  mask-size:25px 20px;-webkit-mask-size:25px 20px;
  mask-repeat:repeat-x;-webkit-mask-repeat:repeat-x;
}

/* HEADER */
.header{background:#E31837;padding:18px 20px 22px;text-align:center;position:sticky;top:0;z-index:50;box-shadow:0 2px 8px rgba(0,0,0,0.15)}
.header-top{display:flex;align-items:center;justify-content:center;gap:12px}
.header-chile{font-size:28px}
.header-chile.green{transform:scaleX(-1)}
.header-name{font-size:clamp(24px,7vw,38px);font-weight:900;color:#fff;letter-spacing:1px}
.header-name span{color:#FFD700}
.header-tagline{font-size:12px;color:rgba(255,255,255,0.7);letter-spacing:2px;margin-top:2px}

/* HERO */
.hero{max-width:1100px;margin:12px auto 0;padding:0 16px}
.hero-inner{background:linear-gradient(135deg,#1a0a0e 0%,#2D1117 50%,#1a0a0e 100%);border-radius:12px;padding:14px 20px;text-align:center;border:1px solid #E31837;position:relative;overflow:hidden}
.hero-inner::before{content:'';position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle,rgba(227,24,55,0.1) 0%,transparent 70%);animation:heroPulse 4s ease-in-out infinite}
@keyframes heroPulse{0%,100%{opacity:0.3}50%{opacity:0.8}}
.hero-title{font-size:clamp(16px,4vw,22px);font-weight:900;color:#fff;line-height:1.2;margin-bottom:6px;position:relative}
.hero-sub{font-size:clamp(13px,3.5vw,16px);color:rgba(255,255,255,0.7);margin-bottom:16px;position:relative}
.hero-countdown{margin-bottom:4px;position:relative}
.hero-compact{padding:10px 16px !important}
.hero-compact .hero-title{font-size:clamp(15px,3.6vw,20px);margin-bottom:5px}
.hero-compact .hero-countdown{margin-bottom:4px}
.hero-hint{font-size:11px;color:rgba(255,255,255,0.6);margin-top:2px;position:relative}
.hero-hint b{color:#FFD700}
.countdown-label{display:inline-block;background:#E31837;color:#fff;padding:4px 14px;border-radius:16px;font-size:12px;font-weight:800;letter-spacing:0.5px}
.hero-proof{display:flex;justify-content:center;gap:24px;margin-bottom:16px;position:relative}
.hero-proof span{font-size:13px;color:rgba(255,255,255,0.6);font-weight:600}
.hero-proof b{color:#FFD700}
.hero-cta{display:inline-block;background:#FFD700;color:#2D1117;padding:14px 32px;border-radius:8px;font-size:16px;font-weight:900;text-decoration:none;position:relative;transition:transform 0.2s}
.hero-cta:hover{transform:scale(1.05)}

/* VIRAL SECTION */
.viral-section{max-width:1100px;margin:20px auto 0;padding:0 16px}
.viral-title{font-size:20px;font-weight:900;color:#E31837;text-align:center;margin-bottom:14px}
.viral-scroll{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;padding:4px 0 16px}
@media(min-width:640px){.viral-scroll{grid-template-columns:repeat(3,1fr)}}
@media(min-width:900px){.viral-scroll{grid-template-columns:repeat(4,1fr)}}
.viral-card{background:#fff;border-radius:14px;overflow:hidden;border:3px solid #FFD700;box-shadow:0 4px 16px rgba(227,24,55,0.1);position:relative}
.viral-card .card-img{width:100%;aspect-ratio:1;object-fit:contain;background:#fff;padding:8%}
.viral-card .card-info{padding:12px 14px 6px}
.viral-card .card-name{font-size:16px;font-weight:900}
.viral-card .card-tag{font-size:12px;color:#999;margin-top:2px}
.viral-card .card-price{font-size:18px;font-weight:900;color:#E31837;margin-top:6px}
.viral-card .card-amazon{font-size:12px;color:#999;text-decoration:line-through;margin-top:2px}
.viral-badge{position:absolute;top:12px;left:12px;background:#E31837;color:#fff;font-size:10px;font-weight:800;padding:4px 10px;border-radius:4px;z-index:2;letter-spacing:0.5px}
.viral-card .card-vote{padding:10px 14px 14px}

/* FILTERS */
.filters{display:flex;gap:8px;padding:18px 16px 12px;max-width:1100px;margin:0 auto;justify-content:center;flex-wrap:wrap}
.filter-btn{background:#fff;border:2px solid #ddd;color:#999;padding:10px 22px;border-radius:8px;font-size:14px;font-weight:700;cursor:pointer;font-family:'Outfit',sans-serif;transition:all 0.15s;min-height:44px}
.filter-btn.active,.filter-btn:hover{border-color:#E31837;color:#E31837;background:#fff}

/* STATS / SOCIAL PROOF */
.stats{display:flex;justify-content:center;align-items:center;gap:12px;padding:8px 16px 16px;flex-wrap:wrap}
.stats span{font-size:13px;color:#999;font-weight:600}
.stats span b{color:#E31837}
.stats-separator{color:#ddd;font-size:13px}
.stats-drop{color:#2E7D32!important}
.stats-drop b{color:#2E7D32!important}

/* GRID */
.grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;padding:0 16px 24px;max-width:1100px;margin:0 auto}
@media(min-width:640px){.grid{grid-template-columns:repeat(3,1fr)}}
@media(min-width:900px){.grid{grid-template-columns:repeat(4,1fr)}}
@media(min-width:1200px){.grid{grid-template-columns:repeat(5,1fr);max-width:1400px}}

/* CARD */
.card{background:#fff;border-radius:12px;overflow:hidden;border:2px solid #E8E2D0;transition:border-color 0.2s;display:flex;flex-direction:column;position:relative}
.card:hover{border-color:#E31837}
.card-img{width:100%;aspect-ratio:1;object-fit:contain;background:#fff;cursor:pointer;display:block;padding:8%}
/* Scale-up solo para productos que genuinamente se ven lejos */
.card-info{padding:10px 12px 4px;flex:1}
.card-name{font-size:14px;font-weight:800;color:#2D1117;line-height:1.25;overflow-wrap:break-word;word-break:break-word;min-height:2.5em;display:flex;align-items:flex-start}
.card-tag{font-size:11px;color:#999;margin-top:2px;line-height:1.3}
.card-price{font-size:16px;font-weight:900;color:#E31837;margin-top:4px}
.card-vote{padding:8px 12px 12px;margin-top:auto}

/* VOTE */
.vote-btn{width:100%;padding:12px 8px;border-radius:8px;font-size:13px;font-weight:800;cursor:pointer;font-family:'Outfit',sans-serif;transition:all 0.15s;border:2px solid #E31837;background:#fff;color:#E31837;text-align:center;min-height:44px;-webkit-tap-highlight-color:transparent}
.vote-btn:hover{background:#E31837;color:#fff;border-color:#E31837}
.vote-btn.voted{background:#2E7D32;color:#fff;border-color:#2E7D32}
.vote-count{font-size:11px;color:#BBB;text-align:center;margin-top:4px}
.vote-bar{height:3px;background:#E8E2D0;border-radius:3px;margin-top:4px;overflow:hidden}
.vote-bar-fill{height:100%;background:linear-gradient(90deg,#E53935,#F9E45B,#2E7D32);border-radius:3px;transition:width 0.4s}

/* DETAIL */
.detail{padding:10px 12px 4px}
.detail-hook{font-size:12px;color:#666;line-height:1.5;margin-bottom:6px}
.detail-why{font-size:12px;color:#2E7D32;background:#f0f8f0;padding:8px 10px;border-radius:6px;border-left:3px solid #2E7D32;margin-bottom:6px}

/* HOW */
.how-section{max-width:1100px;margin:0 auto 20px;padding:0 16px}
.how-card{background:#fff;border:2px solid #E8E2D0;border-radius:12px;padding:20px;text-align:center}
.how-title{font-size:20px;font-weight:900;color:#E31837;margin-bottom:14px}
.how-steps{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.step{background:#F5F0E1;border-radius:8px;padding:12px 10px}
.step-num{font-size:20px;font-weight:900;color:#E31837}
.step-text{font-size:12px;color:#666;margin-top:4px;line-height:1.4}

/* CTA */
.cta-section{max-width:1100px;margin:0 auto 20px;padding:0 16px}
.cta-card{background:#1B8A2E;border-radius:12px;padding:24px 20px;text-align:center}
.cta-title{font-size:18px;font-weight:900;color:#fff;margin-bottom:4px}
.cta-text{font-size:13px;color:rgba(255,255,255,0.8);margin-bottom:14px}
.cta-btn{display:inline-block;background:#fff;color:#1B8A2E;padding:14px 32px;border-radius:8px;font-size:15px;font-weight:800;text-decoration:none;border:none;cursor:pointer;min-height:48px;-webkit-tap-highlight-color:transparent}

/* FOOTER */
.footer{text-align:center;padding:16px;font-size:11px;color:#ccc;border-top:1px solid #E8E2D0}

/* TOAST */
.toast{position:fixed;bottom:20px;left:50%;transform:translateX(-50%) translateY(80px);background:#E31837;color:#fff;padding:10px 24px;border-radius:8px;font-size:13px;font-weight:700;z-index:100;transition:transform 0.3s;pointer-events:none;max-width:calc(100vw - 32px);text-align:center}
.toast.show{transform:translateX(-50%) translateY(0)}

/* ADD TO CART BUTTON */
.add-btn{width:100%;padding:10px 8px;border-radius:8px;font-size:13px;font-weight:800;cursor:pointer;font-family:'Outfit',sans-serif;border:2px solid #FFD700;background:#FFD700;color:#2D1117;text-align:center;min-height:40px;margin-bottom:6px;transition:all 0.15s}
.price-row{display:flex;align-items:center;justify-content:space-between;gap:6px;margin-top:4px}
.price-row .card-price{margin-top:0}
.card-number{display:inline-block;font-size:11px;font-weight:800;color:#2D1117;background:#f0e6d0;border:1px dashed #999;border-radius:4px;padding:2px 8px;letter-spacing:0.5px;flex-shrink:0}
.card-vote{display:flex;flex-direction:column}
.add-btn:active{transform:scale(0.97);background:#e6c200}
/* CART BADGE ON CARD */
.card-cart-badge{position:absolute;bottom:8px;right:8px;background:#E31837;color:#fff;font-size:14px;font-weight:900;width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;z-index:3;box-shadow:0 2px 6px rgba(0,0,0,0.3);font-family:'Outfit',sans-serif}

.cart-qty-row{display:flex;align-items:center;justify-content:center;gap:0;width:100%;margin-bottom:6px}
.qty-btn{width:40px;height:40px;border:2px solid #E31837;background:#fff;color:#E31837;font-size:18px;font-weight:900;cursor:pointer;font-family:'Outfit',sans-serif;transition:all 0.15s}
.qty-btn:first-child{border-radius:8px 0 0 8px}
.qty-btn:last-child{border-radius:0 8px 8px 0}
.qty-btn:active{background:#E31837;color:#fff}
.qty-count{min-width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:#E31837;color:#fff;font-size:16px;font-weight:900;font-family:'Outfit',sans-serif;border-top:2px solid #E31837;border-bottom:2px solid #E31837}

/* CART OVERLAY */
.cart-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,0.6);z-index:1000;display:none;justify-content:flex-end}
.cart-overlay.cart-open{display:flex}
.cart-drawer{width:100%;max-width:400px;background:#fff;height:100%;margin-left:auto;display:flex;flex-direction:column;overflow-y:auto}
.cart-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:2px solid #E8E2D0;position:sticky;top:0;background:#fff;z-index:1}
.cart-title{font-size:18px;font-weight:900;color:#2D1117}
.cart-close{background:none;border:none;font-size:20px;font-weight:900;cursor:pointer;color:#999;padding:8px}
.cart-items{padding:12px 16px}
.cart-item{display:flex;align-items:center;gap:12px;padding:12px 0;border-bottom:1px solid #E8E2D0}
.cart-item-img{width:50px;height:50px;border-radius:6px;object-fit:cover;background:#f9f6ee}
.cart-item-info{flex:1}
.cart-item-name{font-size:13px;font-weight:800;color:#2D1117}
.cart-item-price{font-size:12px;color:#E31837;font-weight:700;margin-top:2px}
.cart-item-remove{background:none;border:none;color:#999;font-size:16px;font-weight:900;cursor:pointer;padding:8px}
.cart-footer{padding:16px 20px;border-top:2px solid #E8E2D0;position:sticky;bottom:0;background:#fff}
.cart-subtotal{font-size:14px;color:#999;text-decoration:line-through}
.cart-discount{font-size:14px;font-weight:800;color:#2E7D32;margin-top:4px}
.cart-next-discount{font-size:12px;color:#E31837;font-weight:700;margin-top:4px;background:#fff5f5;padding:6px 10px;border-radius:6px;border:1px dashed #E31837}
.cart-total{font-size:18px;font-weight:900;color:#2D1117;margin-top:6px}
.cart-apartado{font-size:14px;font-weight:700;color:#2E7D32;margin-top:4px}
.cart-checkout-btn{width:100%;padding:14px;border-radius:8px;font-size:15px;font-weight:900;cursor:pointer;font-family:'Outfit',sans-serif;border:none;background:#25D366;color:#fff;margin-top:12px;min-height:48px}
.cart-checkout-btn:active{background:#1da851;transform:scale(0.98)}
.cart-negotiate-btn{width:100%;padding:12px;border-radius:8px;font-size:13px;font-weight:700;cursor:pointer;font-family:'Outfit',sans-serif;border:2px solid #E8E2D0;background:#fff;color:#666;margin-top:8px}
.cart-negotiate-btn:active{background:#f5f0e1;transform:scale(0.98)}

/* FOCUS */
.vote-btn:focus-visible,.filter-btn:focus-visible,.cta-btn:focus-visible,.add-btn:focus-visible{outline:2px solid #E31837;outline-offset:2px}

/* EMOJI FALLBACK */
.card-img-emoji{width:100%;aspect-ratio:1;display:flex;align-items:center;justify-content:center;font-size:56px;background:#f9f6ee;cursor:pointer}

/* TIER BADGE */
.tier-badge{position:absolute;top:8px;left:8px;color:#fff;font-size:9px;font-weight:800;padding:3px 8px;border-radius:4px;z-index:2;letter-spacing:0.5px}
.tier-S{background:#E31837}
.tier-A{background:#E31837}

/* Ocultar gramaje/tag en cards del landing */
.card .card-tag,
.viral-card .card-tag{display:none}

/* RICH METER (barra vertical ¿esta rico?) */
.rich-meter{position:absolute;top:6px;right:6px;z-index:4;display:flex;flex-direction:column;align-items:center;gap:2px;cursor:pointer;background:rgba(255,255,255,0.95);border:2px solid #E31837;border-radius:10px;padding:5px 6px;transition:transform .15s,box-shadow .15s;min-width:38px;box-shadow:0 2px 6px rgba(0,0,0,0.15)}
.rich-meter-icon{font-size:14px;font-weight:900;color:#E31837;line-height:1;min-height:16px;display:flex;align-items:center;justify-content:center}
.rich-meter.voted .rich-meter-icon{color:#2e7d32}
.rich-meter:hover{transform:scale(1.08);box-shadow:0 2px 8px rgba(227,24,55,0.4)}
.rich-meter.voted{background:#fff8e1;border-color:#FFD700}
.rich-meter-label{font-size:8px;font-weight:900;color:#E31837;text-align:center;line-height:1;letter-spacing:0.3px}
.rich-meter.voted .rich-meter-label{color:#c17a00}
.rich-meter-bar{width:10px;height:60px;background:#f5f5f5;border-radius:5px;overflow:hidden;display:flex;flex-direction:column-reverse;border:1px solid #ddd}
.rich-meter-fill{width:100%;background:linear-gradient(to top,#4caf50,#8bc34a,#cddc39);transition:height .4s ease;min-height:3%}
.rich-meter.voted .rich-meter-fill{background:linear-gradient(to top,#ff6b35,#ffa500,#FFD700)}
.rich-meter-count{font-size:11px;font-weight:900;color:#2D1117;line-height:1}
.rich-meter.voted .rich-meter-count{color:#E31837}

/* AGOTADO state */
.agotado-badge{position:absolute;top:8px;left:8px;background:#333;color:#fff;font-size:10px;font-weight:900;padding:4px 10px;border-radius:4px;z-index:3;letter-spacing:1px;border:2px solid #FFD700}
.viral-card .agotado-badge{top:12px;left:12px;font-size:11px}
.card-agotado .card-img{filter:grayscale(0.7) opacity(0.75)}
.card-agotado .card-price{color:#888;text-decoration:line-through}
.agotado-msg{background:#f5f5f5;color:#666;text-align:center;padding:10px;border-radius:6px;font-size:12px;font-weight:700;font-style:italic;border:1px dashed #ccc;margin-bottom:8px}

/* AMAZON PRICE (value stacking) */
.card-amazon{font-size:11px;color:#999;margin-top:2px}
.card-amazon s{color:#ccc}

/* SABIAS QUE */
.sabias-section{max-width:1100px;margin:0 auto 20px;padding:0 16px}
.sabias-card{background:#fff;border:2px solid #E8E2D0;border-radius:12px;padding:20px;text-align:center}
.sabias-title{font-size:20px;font-weight:900;color:#E31837;margin-bottom:16px}
.sabias-items{display:grid;gap:12px}
@media(min-width:640px){.sabias-items{grid-template-columns:repeat(3,1fr)}}
.sabias-item{background:#F5F0E1;border-radius:8px;padding:14px 12px;display:flex;flex-direction:column;gap:4px}
.sabias-product{font-size:14px;font-weight:800;color:#2D1117}
.sabias-amazon{font-size:13px;color:#999}
.sabias-amazon s{color:#ccc}
.sabias-us{font-size:14px;font-weight:800;color:#2E7D32}

/* TAMBIEN TENEMOS */
.tambien-section{max-width:1100px;margin:0 auto 20px;padding:0 16px}
.tambien-card{background:#fff;border:2px solid #E8E2D0;border-radius:12px;padding:20px}
.tambien-title{font-size:18px;font-weight:900;color:#2D1117;text-align:center;margin-bottom:4px}
.tambien-sub{font-size:13px;color:#999;text-align:center;margin-bottom:16px}
.tambien-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
@media(min-width:640px){.tambien-grid{grid-template-columns:repeat(3,1fr)}}
.tambien-item{border-color:#ddd}
.tambien-item .card-name{font-size:13px}
.tambien-item .card-price{font-size:14px}

/* SUGERENCIAS */
.suggest-section{max-width:1100px;margin:0 auto 20px;padding:0 16px}
.suggest-card{background:#fff;border:2px solid #E8E2D0;border-radius:12px;padding:20px;text-align:center}
.suggest-title{font-size:18px;font-weight:900;color:#E31837;margin-bottom:4px}
.suggest-sub{font-size:13px;color:#999;margin-bottom:14px}
.suggest-input-wrap{display:flex;gap:8px;max-width:500px;margin:0 auto}
.suggest-input{flex:1;padding:12px 14px;border:2px solid #E8E2D0;border-radius:8px;font-size:14px;font-family:'Outfit',sans-serif;outline:none;transition:border-color 0.2s}
.suggest-input:focus{border-color:#E31837}
.suggest-btn{background:#E31837;color:#fff;border:none;padding:12px 20px;border-radius:8px;font-size:14px;font-weight:800;cursor:pointer;font-family:'Outfit',sans-serif;white-space:nowrap}

/* ========== MOBILE (max 480px) ========== */
@media(max-width:480px){
  /* Header: tighten padding, reduce chile size */
  .header{padding:12px 12px 16px}
  .header-top{gap:8px}
  .header-chile{font-size:22px}
  .header-tagline{font-size:11px;letter-spacing:1.5px}

  /* Hero */
  .hero{margin:8px auto 0;padding:0 12px}
  .hero-inner{padding:10px 14px;border-radius:10px}
  .hero-proof{flex-direction:column;gap:4px}
  .hero-cta{width:100%;text-align:center;padding:14px 24px}

  /* Viral */
  .viral-section{padding:0 12px}
  .viral-card .card-name{font-size:14px}
  .viral-card .card-price{font-size:16px}

  /* Filters: horizontally scrollable on small phones */
  .filters{flex-wrap:nowrap;overflow-x:auto;justify-content:flex-start;padding:14px 12px 10px;gap:6px;-webkit-overflow-scrolling:touch;scrollbar-width:none;-ms-overflow-style:none}
  .filters::-webkit-scrollbar{display:none}
  .filter-btn{flex-shrink:0;padding:9px 16px;font-size:13px;border-radius:20px;min-height:40px}

  /* Grid */
  .grid{gap:8px;padding:0 10px 20px}

  /* Cards */
  .card{border-radius:10px}
  .card-info{padding:8px 10px 4px}
  .card-name{font-size:13px}
  .card-tag{font-size:10px}
  .card-price{font-size:15px;margin-top:3px}
  .card-vote{padding:6px 10px 10px}

  /* Vote button */
  .vote-btn{padding:10px 6px;font-size:12px;border-radius:6px;min-height:42px}
  .vote-count{font-size:10px}

  /* Detail */
  .detail{padding:8px 10px 4px}
  .detail-hook{font-size:11px}
  .detail-why{font-size:11px;padding:6px 8px}

  /* How section */
  .how-section{padding:0 12px}
  .how-card{padding:16px}
  .how-title{font-size:18px;margin-bottom:10px}
  .how-steps{grid-template-columns:1fr 1fr;gap:8px}
  .step{padding:10px 8px}
  .step-num{font-size:18px}
  .step-text{font-size:11px}

  /* CTA */
  .cta-section{padding:0 12px}
  .cta-card{padding:20px 16px}
  .cta-title{font-size:16px}
  .cta-text{font-size:12px;margin-bottom:12px}
  .cta-btn{padding:14px 24px;font-size:14px;border-radius:8px;width:100%;text-align:center}

  /* Emoji fallback */
  .card-img-emoji{font-size:44px}

  /* Toast */
  .toast{bottom:16px;font-size:12px;padding:10px 18px}

  /* Sugerencias mobile */
  .suggest-input-wrap{flex-direction:column}
  .suggest-btn{width:100%}
}

/* ========== VERY SMALL PHONES (max 360px) ========== */
@media(max-width:360px){
  .header-name{font-size:22px}
  .grid{gap:6px;padding:0 8px 16px}
  .card-name{font-size:12px}
  .card-price{font-size:14px}
  .vote-btn{font-size:11px;padding:10px 4px}
  .filter-btn{padding:8px 12px;font-size:12px}
  .cta-title{font-size:15px}
}

/* ========== LAPTOP (1366px - 1920px) ========== */
@media(min-width:1366px){
  .hero,.viral-section,.filters,.how-section,.cta-section,.sabias-section,.tambien-section{max-width:1300px}
  .grid{max-width:1500px;gap:16px}
  .how-steps{grid-template-columns:repeat(4,1fr);gap:14px}
  .step{padding:16px 12px}
  .step-num{font-size:24px}
  .step-text{font-size:13px}
  .card-info{padding:12px 14px 6px}
  .card-name{font-size:15px}
  .card-price{font-size:17px}
  .cta-card{padding:32px 24px}
  .cta-title{font-size:22px}
  .cta-text{font-size:15px}
  .cta-btn{padding:16px 40px;font-size:16px}
  .hero-inner{padding:40px 32px}
}

/* ========== LARGE DESKTOP (1920px+) ========== */
@media(min-width:1920px){
  .grid{max-width:1700px;grid-template-columns:repeat(6,1fr)}
  .hero,.viral-section,.filters,.how-section,.cta-section,.sabias-section,.tambien-section{max-width:1500px}
}

/* ========== TOUCH DEVICE HINTS ========== */
@media(hover:none) and (pointer:coarse){
  .card:hover{border-color:#E8E2D0}
  .vote-btn:hover{background:#fff;color:#E31837}
  .vote-btn.voted:hover{background:#2E7D32;color:#fff}
  .vote-btn:active{background:#E31837;color:#fff;transform:scale(0.97)}
  .vote-btn.voted:active{background:#1B5E20;transform:scale(0.97)}
  .filter-btn:hover{border-color:#ddd;color:#999}
  .filter-btn.active:hover{border-color:#E31837;color:#E31837}
  .filter-btn:active{border-color:#E31837;color:#E31837;transform:scale(0.96)}
}

/* ========== SAFE AREA (notched phones) ========== */
@supports(padding:env(safe-area-inset-bottom)){
  .toast{bottom:calc(16px + env(safe-area-inset-bottom))}
  .footer{padding-bottom:calc(16px + env(safe-area-inset-bottom))}
}
