/* components.css — camisetaspersonalizadas.com
   v1.0 — bloques comunes y estilos compartidos (mobile-first) */

/* ===== Tokens (colores, tipografía base) ===== */
:root{
    --brand:#2F6DF6; --brand-dark:#1E4EC2;
    --text:#0F172A; --muted:#667085;
    --bg:#F7FAFC; --card:#FFFFFF; --border:#E5EAF0;
    --badge:#E7F0FF; --badge-text:#1E4EC2;
    --pill-bg:#EEF6FF; --pill-text:#0B6CF8;
    --whats:#22C55E; --whats-text:#166534;
  }
  
  /* ===== Base utilidades ===== */
  *{box-sizing:border-box}
  .mod-wrap{margin:16px 0}
  .card{background:var(--card); border:1px solid var(--border); border-radius:14px; padding:14px}
  .title{margin:0 0 8px; font-size:1.1rem; font-weight:800; color:var(--text)}
  .text{margin:0; color:var(--muted); font-size:.95rem}
  a{color:var(--brand); text-decoration:underline}
  a:hover{filter:saturate(1.1)}
  .btn{display:inline-flex; align-items:center; justify-content:center; gap:8px;
       padding:12px 16px; border-radius:999px; font-weight:800; font-size:.95rem;
       border:1px solid var(--border); background:#fff; color:var(--text); text-decoration:none}
  .btn-primary{background:var(--brand); color:#fff; border-color:var(--brand)}
  .btn-secondary{background:#fff; color:var(--text); border-color:var(--border)}
  .btn:hover{filter:saturate(1.1)}
  .btn:focus-visible{outline:2px solid var(--brand); outline-offset:2px}
  .badge{display:inline-flex; align-items:center; gap:6px; padding:6px 10px; border-radius:999px;
         background:var(--badge); color:var(--badge-text); font-weight:800; font-size:.85rem}
  .pill{display:inline-flex; align-items:center; gap:6px; padding:6px 10px; border-radius:999px;
        background:var(--pill-bg); color:var(--pill-text); font-weight:800; font-size:.9rem}
  .icon{width:20px; height:20px; display:inline-block}
  
  /* ===== HERO (texto, CTAs, confianza, reviews) ===== */
  .hero-content{max-width:560px; padding:8px 0 12px; color:var(--text); margin:0 auto; text-align:center}
  .sub{font-size:1.125rem; line-height:1.5; margin:0 0 14px}
  .hero-ctas{display:flex; flex-wrap:wrap; gap:10px 12px; align-items:center; justify-content:center; margin-bottom:10px}
  .link-tertiary{color:var(--brand); text-decoration:underline; font-weight:600}
  .cta-note{font-size:.8rem; color:var(--muted)}
  .micro{margin:6px 0 14px; color:var(--muted); font-size:.95rem}
  .trust{list-style:none; margin:0 0 12px; padding:0; display:grid; grid-template-columns:1fr; gap:8px 18px; text-align:left}
  .trust li{position:relative; padding-left:20px; font-size:.95rem; color:var(--text)}
  .trust li::before{content:"✓"; position:absolute; left:0; top:0; color:var(--brand); font-weight:700}
  .trust a{text-decoration:underline}
  .reviews{display:flex; align-items:center; gap:8px; font-size:.95rem; color:var(--text); margin:6px 0 12px; line-height:1; justify-content:center}
  .reviews .stars{display:inline-flex; gap:3px; line-height:1}
  .reviews .stars img{display:block; width:18px; height:18px; object-fit:contain}
  .reviews .rating{font-weight:700}
  .help-cta{display:flex; flex-wrap:wrap; gap:8px; justify-content:center; margin:4px 0 0}
  .btn-mini{padding:10px 14px; border-radius:999px; font-weight:700; font-size:.9rem; border:1px solid var(--border); color:var(--text); background:#fff; text-decoration:none}
  .btn-mini--whats{border-color:var(--whats); color:var(--whats-text)}
  
  /* ===== CÓMO FUNCIONA (howit) ===== */
  .howit{background:var(--bg); border-radius:16px; padding:22px 14px}
  .howit__title{margin:0 0 18px; color:var(--text); font-size:1.35rem; line-height:1.2; text-align:center; font-weight:800}
  .howit__steps{list-style:none; margin:0; padding:0; display:grid; gap:14px; grid-template-columns:1fr}
  .howit__step{background:#fff; border:1px solid var(--border); border-radius:16px; padding:14px; text-align:left; display:flex; gap:14px; align-items:center}
  .howit__art{width:112px; height:112px; border-radius:999px; overflow:hidden; display:flex; align-items:center; justify-content:center; background:#ECF5FF; flex:0 0 112px}
  .howit__art img{width:100%; height:100%; object-fit:contain}
  .howit__h3{margin:6px 0 4px; font-size:1rem; color:var(--text); font-weight:800}
  .howit__p{margin:0; color:var(--muted); font-size:.95rem}
  
  /* ===== Precios por cantidad (zebra + badge) ===== */
  .prices{width:100%; border:1px solid var(--border); border-radius:14px; overflow:hidden; background:#fff}
  .prices table{width:100%; border-collapse:collapse}
  .prices th,.prices td{padding:12px 14px; text-align:left; font-size:.95rem}
  .prices thead th{background:var(--bg); color:var(--text); font-weight:800; border-bottom:1px solid var(--border)}
  .prices tbody tr:nth-child(odd){background:#fff}
  .prices tbody tr:nth-child(even){background:#FBFDFF}
  .note{margin:8px 4px 0; color:var(--muted); font-size:.9rem}
  
  /* ===== Plazos (tarjeta + reloj + pill) ===== */
  .deadline{display:flex; gap:12px; align-items:flex-start}
  .deadline .clock{width:36px; height:36px; border-radius:999px; background:var(--pill-bg);
    display:flex; align-items:center; justify-content:center; color:var(--pill-text); flex:0 0 36px}
  
  /* ===== Tallas (card + botón) ===== */
  .sizes-list{margin:8px 0 12px; padding-left:18px; color:var(--muted); font-size:.95rem}
  .sizes-list li{margin:4px 0}
  
  /* ===== Técnicas / Materiales (3 cards grid) ===== */
  .grid-3{display:grid; grid-template-columns:1fr; gap:10px}
  .tech .row{display:flex; gap:10px; align-items:flex-start}
  .tech .mini{width:28px; height:28px; border-radius:6px; background:var(--bg);
    display:flex; align-items:center; justify-content:center; flex:0 0 28px; color:var(--brand)}
  .tech h4{margin:0 0 2px; font-size:1rem; font-weight:800; color:var(--text)}
  .tech p{margin:0; color:var(--muted); font-size:.95rem}
  
  /* ===== CTA sticky móvil ===== */
  .sticky-cta{position:fixed; inset:auto 0 0 0; z-index:50; display:flex; gap:10px;
    align-items:center; justify-content:space-between; background:var(--brand);
    color:#fff; padding:10px 14px}
  .sticky-cta a{background:#fff; color:var(--brand); padding:10px 14px; border-radius:999px; font-weight:800; text-decoration:none}
  
  /* ===== Responsivo (desktop up) ===== */
  @media (min-width:768px){
    .hero-content{text-align:left; margin:0}
    .hero-ctas{justify-content:flex-start}
    .trust{grid-template-columns:repeat(2,minmax(0,1fr))}
    .help-cta{justify-content:flex-start}
  
    .howit{padding:28px 18px}
    .howit__title{font-size:2rem; text-align:center}
    .howit__steps{grid-template-columns:repeat(3,minmax(0,1fr)); gap:28px}
    .howit__step{display:block; text-align:center; padding:18px}
    .howit__art{width:180px; height:180px; margin:0 auto 12px; flex:none}
  
    .grid-3{grid-template-columns:repeat(3,minmax(0,1fr))}
    .deadline{align-items:center}
    .sticky-cta{display:none}
  }
  
  /* ===== Preferencias de movimiento ===== */
  @media (prefers-reduced-motion:reduce){
    .btn, .card, .howit__step{transition:none}
  }
  