
  /* ============================================================
     LINKCITO CR — La feria del mes
     Direction: Costa Rican carreta-típica folk craft.
     Warm manta paper · espresso ink · the four logo primaries
     as the Sarchí-rosette palette · lotería-ticket numerics.
     ============================================================ */
  :root {
    --azul:#1565F0; --azul-dk:#0D4FC4; --azul-noche:#0B2A6B;
    --rojo:#E5202A; --rojo-dk:#C2121B;
    --sol:#FBBC04;  --sol-dk:#E0A300;
    --verde:#1FA855;--verde-dk:#17833F;

    --paper:#FBF4E6;     /* sunlit manta ground */
    --sand:#F3E8CF;      /* woven band */
    --sand-2:#ECDCB8;
    --card:#FFFDF8;      /* warm white card */
    --espresso:#2A1F1A;  /* warm ink (coffee) */
    --espresso-soft:#6E5F54;
    --line:#E6D8BC;      /* warm hairline */

    --font-display:"Bricolage Grotesque", system-ui, sans-serif;
    --font-body:"Hanken Grotesk", system-ui, sans-serif;
    --font-ticket:"Space Mono", ui-monospace, monospace;
    --shadow:0 22px 48px -28px rgba(42,31,26,.42);
    --shadow-sm:0 10px 24px -16px rgba(42,31,26,.40);
    --maxw:1160px;
    --radius:18px;
  }
  * { box-sizing:border-box; }
  html { scroll-behavior:smooth; }
  body {
    margin:0; background:var(--paper); color:var(--espresso);
    font-family:var(--font-body); font-size:17px; line-height:1.62;
    -webkit-font-smoothing:antialiased; overflow-x:hidden;
  }
  body.locked { overflow:hidden; }
  @media (prefers-reduced-motion: reduce){ html{scroll-behavior:auto} *,*::before,*::after{animation:none!important;transition:none!important} }
  .wrap { width:100%; max-width:var(--maxw); margin:0 auto; padding:0 22px; }
  a { color:inherit; }
  a:focus-visible, button:focus-visible { outline:3px solid var(--azul); outline-offset:3px; border-radius:8px; }
  h1,h2,h3 { font-family:var(--font-display); letter-spacing:-.02em; font-weight:800; }
  .mono { font-family:var(--font-ticket); font-variant-numeric:tabular-nums; }

  /* painted folk band — the carreta thread that ties the page together */
  .folk-band { height:6px; background:
      repeating-linear-gradient(90deg,
        var(--azul) 0 28px, var(--rojo) 28px 56px, var(--sol) 56px 84px, var(--verde) 84px 112px); }

  /* ---------- command bar ---------- */
  .cmd { position:sticky; top:0; z-index:60; background:rgba(251,244,230,.86); backdrop-filter:saturate(1.2) blur(8px); border-bottom:1.5px solid var(--line); }
  .cmd .wrap { display:flex; align-items:center; gap:12px; height:62px; }
  .brand { display:inline-flex; align-items:center; text-decoration:none; }
  .brand-logo { display:block; height:34px; width:auto; }
  .cmd-status { display:none; align-items:center; gap:8px; font-size:13px; font-weight:600; color:var(--espresso-soft); padding:5px 12px; background:var(--card); border:1.5px solid var(--line); border-radius:999px; }
  .dot { width:9px; height:9px; border-radius:50%; background:var(--verde); box-shadow:0 0 0 0 rgba(31,168,85,.6); animation:pulse 2s infinite; }
  @keyframes pulse { 0%{box-shadow:0 0 0 0 rgba(31,168,85,.55)} 70%{box-shadow:0 0 0 7px rgba(31,168,85,0)} 100%{box-shadow:0 0 0 0 rgba(31,168,85,0)} }
  .cmd-clock { margin-left:auto; font-family:var(--font-ticket); font-weight:700; font-size:13px; color:var(--rojo-dk); display:none; }
  .cmd-spacer { margin-left:auto; }
  .cart-btn { display:inline-flex; align-items:center; gap:8px; background:var(--espresso); color:var(--paper); border:none; cursor:pointer; font-family:var(--font-display); font-weight:700; font-size:14px; padding:10px 15px; border-radius:999px; }
  .cart-btn:hover { background:#3a2c24; }
  .cart-btn .cart-count { font-family:var(--font-ticket); font-weight:700; background:var(--sol); color:var(--espresso); border-radius:999px; min-width:22px; height:22px; display:inline-flex; align-items:center; justify-content:center; font-size:12px; padding:0 6px; }
  .cmd-clock + .cart-btn { margin-left:14px; }
  @media (min-width:720px){ .cmd-status{display:inline-flex} }
  @media (min-width:980px){ .cmd-clock{display:block} }

  /* ---------- hero ---------- */
  .hero { position:relative; padding:60px 0 70px; overflow:hidden; }
  .hero::before { content:""; position:absolute; inset:0; z-index:0; pointer-events:none;
    background:
      radial-gradient(closest-side, rgba(21,101,240,.10), transparent) -8% 18%/440px 440px no-repeat,
      radial-gradient(closest-side, rgba(229,32,42,.09), transparent) 108% 90%/420px 420px no-repeat,
      radial-gradient(closest-side, rgba(251,188,4,.14), transparent) 80% -10%/520px 520px no-repeat; }
  .hero .wrap { position:relative; z-index:1; display:grid; grid-template-columns:1.05fr .95fr; gap:48px; align-items:center; }
  .eyebrow { display:inline-flex; align-items:center; gap:9px; font-family:var(--font-display); font-weight:700; font-size:12.5px; letter-spacing:.16em; text-transform:uppercase; color:var(--azul-dk); background:var(--card); border:1.5px solid var(--line); padding:7px 14px; border-radius:999px; }
  .eyebrow .beacon { width:8px; height:8px; border-radius:50%; background:var(--rojo); box-shadow:0 0 10px 1px rgba(229,32,42,.6); }
  .hero h1 { font-size:clamp(2.4rem, 6.2vw, 4.4rem); line-height:1.02; margin:20px 0 0; max-width:15ch; }
  .hero h1 .mes { color:var(--rojo); white-space:nowrap; }
  .hero .lede { color:var(--espresso-soft); font-size:clamp(1.04rem,2vw,1.22rem); max-width:50ch; margin:20px 0 0; }
  .lede-em { font-family:var(--font-display); font-weight:600; font-size:clamp(1.05rem,2vw,1.2rem); color:var(--espresso); max-width:46ch; margin:18px 0 0; padding-left:16px; border-left:4px solid var(--sol); }
  .cta-row { display:flex; flex-wrap:wrap; gap:12px; margin:30px 0 0; }
  .btn { display:inline-flex; align-items:center; gap:9px; text-decoration:none; font-family:var(--font-display); font-weight:800; font-size:1rem; padding:15px 24px; border-radius:13px; border:2.5px solid var(--espresso); cursor:pointer; transition:transform .14s ease, box-shadow .14s ease; box-shadow:4px 4px 0 var(--espresso); }
  .btn:hover { transform:translate(-2px,-2px); box-shadow:6px 6px 0 var(--espresso); }
  .btn:active { transform:translate(2px,2px); box-shadow:0 0 0 var(--espresso); }
  .btn-green { background:var(--verde); color:#fff; }
  .btn-sun { background:var(--sol); color:var(--espresso); }
  .btn-paper { background:var(--card); color:var(--espresso); }
  .trust { display:flex; flex-wrap:wrap; gap:7px 16px; margin:30px 0 0; padding-top:22px; border-top:1.5px dashed var(--line); font-size:14px; font-weight:600; color:var(--espresso-soft); }
  .trust span { display:inline-flex; align-items:center; gap:7px; }
  .trust span::before { content:""; width:7px; height:7px; border-radius:2px; transform:rotate(45deg); background:var(--verde); }

  /* ---------- el sello + boleto ---------- */
  .sello-wrap { display:flex; flex-direction:column; align-items:center; gap:18px; }
  .sello-status { font-family:var(--font-display); font-weight:700; font-size:13px; letter-spacing:.06em; color:var(--verde-dk); display:inline-flex; align-items:center; gap:8px; background:var(--card); border:1.5px solid var(--line); padding:7px 16px; border-radius:999px; }
  .sello-status .dot { width:8px; height:8px; }
  .sello-status.closed { color:var(--rojo-dk); }
  .sello-status.closed .dot { background:var(--rojo); animation:none; }
  .sello { position:relative; width:min(360px,80vw); aspect-ratio:1; filter:drop-shadow(0 24px 30px rgba(42,31,26,.28)); animation:floaty 7s ease-in-out infinite; }
  @keyframes floaty { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-9px)} }
  .sello-svg { width:100%; height:100%; display:block; }
  .sello-core { position:absolute; inset:0; display:flex; flex-direction:column; align-items:center; justify-content:center; text-align:center; }
  .sello-core .k { font-family:var(--font-ticket); font-weight:700; font-size:10px; letter-spacing:.22em; color:var(--rojo); }
  .sello-core .mes { font-family:var(--font-display); font-weight:800; font-size:clamp(1.5rem,5vw,2.1rem); line-height:.92; color:var(--azul-noche); margin-top:1px; }

  .boleto { position:relative; width:min(360px,84vw); background:var(--card); border:2px solid var(--espresso); border-radius:14px; padding:18px 18px 16px; box-shadow:var(--shadow-sm); }
  .boleto::before, .boleto::after { content:""; position:absolute; width:16px; height:16px; background:var(--paper); border:2px solid var(--espresso); border-radius:50%; top:50%; transform:translateY(-50%); }
  .boleto::before { left:-9px; border-right-color:var(--paper); }
  .boleto::after { right:-9px; border-left-color:var(--paper); }
  .boleto-head { font-family:var(--font-ticket); font-size:11px; letter-spacing:.12em; text-transform:uppercase; color:var(--espresso-soft); text-align:center; }
  .clock { display:grid; grid-template-columns:repeat(4,1fr); gap:8px; margin:12px 0 10px; }
  .clock .cell { text-align:center; background:var(--paper); border:1.5px solid var(--line); border-radius:10px; padding:10px 4px; }
  .clock .num { font-family:var(--font-ticket); font-weight:700; font-size:clamp(1.5rem,5vw,2rem); line-height:1; color:var(--espresso); }
  .clock .lab { font-size:9.5px; letter-spacing:.12em; text-transform:uppercase; color:var(--espresso-soft); margin-top:6px; }
  .clock.closed .num { color:var(--rojo); }
  .boleto-foot { font-size:13px; text-align:center; color:var(--espresso-soft); border-top:1.5px dashed var(--line); padding-top:10px; }
  .boleto-foot b { color:var(--rojo-dk); font-family:var(--font-ticket); font-weight:700; }

  /* ---------- section frame ---------- */
  .sec { padding:62px 0; position:relative; }
  .sec--sand { background:var(--sand); border-top:1.5px solid var(--line); border-bottom:1.5px solid var(--line); }
  .sec--noche { background:var(--azul-noche); color:#eaf0ff; }
  .sec-head { max-width:62ch; margin:0 0 30px; }
  .sec-head.center { margin-left:auto; margin-right:auto; text-align:center; }
  .kicker { display:inline-block; font-family:var(--font-display); font-weight:700; font-size:12.5px; letter-spacing:.15em; text-transform:uppercase; color:var(--rojo); margin-bottom:8px; }
  .sec--noche .kicker { color:var(--sol); }
  .sec-head h2 { font-size:clamp(1.8rem,4vw,2.7rem); line-height:1.04; margin:0; }
  .sec-head p { color:var(--espresso-soft); margin:12px 0 0; font-size:1.05rem; }
  .sec--noche .sec-head p { color:#b9c6ec; }

  /* ---------- el ritual (almanac timeline) ---------- */
  .almanac { display:grid; grid-template-columns:repeat(6,1fr); gap:14px; counter-reset:step; }
  .alm { position:relative; background:var(--card); border:1.5px solid var(--line); border-radius:14px; padding:18px 16px 16px; }
  .alm::before { counter-increment:step; content:counter(step); position:absolute; top:-14px; left:16px; width:30px; height:30px; border-radius:50%; background:var(--azul); color:#fff; font-family:var(--font-display); font-weight:800; font-size:15px; display:flex; align-items:center; justify-content:center; border:2px solid var(--paper); }
  .alm.key::before { background:var(--rojo); }
  .alm .date { font-family:var(--font-ticket); font-weight:700; font-size:12.5px; color:var(--azul-noche); margin-top:8px; }
  .alm.key .date { color:var(--rojo-dk); }
  .alm h3 { font-size:1.02rem; margin:6px 0 5px; line-height:1.15; }
  .alm p { color:var(--espresso-soft); font-size:13.5px; margin:0; }
  @media (max-width:920px){ .almanac{grid-template-columns:repeat(2,1fr); gap:22px 14px} }
  @media (max-width:460px){ .almanac{grid-template-columns:1fr} }

  /* ---------- offers grid ---------- */
  .grid { display:grid; gap:18px; grid-template-columns:repeat(4,1fr); }
  @media (max-width:1000px){ .grid{grid-template-columns:repeat(3,1fr)} }
  @media (max-width:760px){ .grid{grid-template-columns:repeat(2,1fr)} }
  @media (max-width:430px){ .grid{grid-template-columns:1fr} }
  .card { position:relative; background:var(--card); border:2px solid var(--espresso); border-radius:var(--radius); overflow:hidden; display:flex; flex-direction:column; box-shadow:var(--shadow-sm); transition:transform .16s ease; cursor:pointer; }
  .card-link { position:absolute; inset:0; z-index:1; border-radius:var(--radius); }
  .card:focus-within { outline:3px solid var(--azul); outline-offset:3px; }
  .card:hover { transform:translateY(-4px); }
  .thumb { aspect-ratio:1/1; position:relative; background:var(--sand); display:flex; align-items:center; justify-content:center; border-bottom:2px solid var(--espresso); }
  .thumb .ph { font-family:var(--font-display); font-weight:800; color:var(--sand-2); font-size:2rem; }
  .thumb .code { position:absolute; left:9px; bottom:9px; background:var(--espresso); color:var(--paper); font-family:var(--font-ticket); font-size:10.5px; padding:3px 8px; border-radius:6px; }
  .thumb .brand-chip { position:absolute; left:9px; top:9px; background:var(--card); border:1.5px solid var(--espresso); font-family:var(--font-display); font-weight:700; font-size:10.5px; padding:3px 9px; border-radius:999px; max-width:60%; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
  .badge { position:absolute; right:9px; top:9px; font-family:var(--font-display); font-size:11px; font-weight:800; padding:4px 9px; border-radius:999px; color:#fff; border:1.5px solid var(--espresso); }
  .b-red{background:var(--rojo)} .b-green{background:var(--verde)} .b-sun{background:var(--sol);color:var(--espresso)}
  .card .body { padding:14px 15px 16px; display:flex; flex-direction:column; flex:1; }
  .card h4 { font-family:var(--font-display); font-weight:700; font-size:1rem; margin:0 0 6px; line-height:1.18; }
  .card .cat { font-size:11.5px; letter-spacing:.04em; text-transform:uppercase; color:var(--espresso-soft); margin-bottom:10px; }
  .aura-badge { display:inline-block; font-family:var(--font-display); font-weight:800; font-size:10px; letter-spacing:.1em; color:var(--rojo-dk); background:var(--sand); border:1.5px solid var(--line); padding:3px 9px; border-radius:6px; margin-bottom:9px; }
  .aura-pitch { font-size:12.5px; line-height:1.35; color:var(--espresso); margin:0 0 10px; }
  .card-meta { font-size:11px; letter-spacing:.02em; color:var(--espresso-soft); margin-bottom:7px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
  .card-meta .brand-tag { font-family:var(--font-display); font-weight:700; color:var(--azul-dk); text-transform:uppercase; }
  .card-meta .code-tag { font-family:var(--font-ticket); }
  .priceline { display:flex; flex-direction:column; margin-top:auto; }
  .price-label { font-family:var(--font-ticket); font-size:10px; letter-spacing:.06em; text-transform:uppercase; color:var(--espresso-soft); }
  .price { font-family:var(--font-ticket); font-weight:700; font-size:1.4rem; color:var(--verde-dk); }
  .price-was { font-family:var(--font-ticket); font-size:12px; color:var(--espresso-soft); }
  .price-was s { text-decoration:line-through; }
  .price-save { font-family:var(--font-display); font-weight:800; font-size:11px; color:var(--verde-dk); margin-top:1px; }
  .price-note { font-size:11px; color:var(--espresso-soft); margin:2px 0 0; }
  .add { position:relative; z-index:2; margin-top:13px; display:flex; gap:8px; }
  .add-go { width:100%; border:2px solid var(--espresso); background:var(--verde); color:#fff; font-family:var(--font-display); font-weight:800; font-size:14px; padding:11px 10px; border-radius:11px; cursor:pointer; transition:background .14s ease; }
  .add-go:hover { background:var(--verde-dk); }
  .add-go.added { background:var(--espresso); }
  .add-see { border:2px solid var(--espresso); background:var(--card); color:var(--espresso); font-family:var(--font-display); font-weight:800; font-size:14px; padding:11px 14px; border-radius:11px; text-decoration:none; }
  .grid-msg { grid-column:1/-1; color:var(--espresso-soft); background:var(--card); border:1.5px dashed var(--line); border-radius:14px; padding:30px; text-align:center; }
  .grid-msg a { color:var(--azul-dk); font-weight:800; }
  .chips { display:flex; flex-wrap:wrap; gap:8px; margin-bottom:22px; }
  .chip { font-family:var(--font-display); font-weight:700; font-size:13px; padding:8px 14px; border:2px solid var(--espresso); background:var(--card); border-radius:999px; cursor:pointer; white-space:nowrap; }
  .chip.on { background:var(--espresso); color:var(--paper); }
  .chip.cazado { color:var(--rojo-dk); } .chip.cazado.on { background:var(--rojo); border-color:var(--rojo); color:#fff; }
  .count { font-family:var(--font-ticket); font-size:1rem; color:var(--espresso-soft); font-weight:400; }
  .feat { position:absolute; right:9px; bottom:9px; background:var(--rojo); color:#fff; font-family:var(--font-display); font-weight:800; font-size:10.5px; padding:3px 8px; border-radius:6px; border:1.5px solid var(--espresso); z-index:1; }
  .grid-more { text-align:center; color:var(--espresso-soft); margin-top:18px; }

  /* ---------- delivery tiers + meter ---------- */
  .meter { background:var(--card); border:2px solid var(--espresso); border-radius:16px; padding:22px; box-shadow:var(--shadow-sm); }
  .meter-track { position:relative; height:16px; border-radius:999px; background:var(--sand); border:1.5px solid var(--espresso); overflow:hidden; }
  .meter-track > i { position:absolute; inset:0 auto 0 0; width:0%; background:linear-gradient(90deg,var(--sol),var(--verde)); transition:width .5s ease; }
  .meter-ticks { display:flex; justify-content:space-between; font-family:var(--font-ticket); font-size:12px; font-weight:700; color:var(--espresso-soft); margin-top:9px; }
  .meter-msg { margin:14px 0 0; font-size:14.5px; font-weight:600; }
  .tiers { display:grid; grid-template-columns:repeat(3,1fr); gap:16px; margin-top:24px; }
  @media (max-width:760px){ .tiers{grid-template-columns:1fr} }
  .tier { background:var(--card); border:2px solid var(--espresso); border-radius:16px; padding:20px; }
  .tier .tl { font-family:var(--font-ticket); font-size:12px; font-weight:700; letter-spacing:.04em; }
  .tier .amt { font-family:var(--font-display); font-weight:800; font-size:1.35rem; margin:4px 0 0; }
  .tier p { color:var(--espresso-soft); font-size:14px; margin:8px 0 0; }
  .tier.t1{ border-top:7px solid var(--rojo) } .tier.t1 .tl{ color:var(--rojo-dk) }
  .tier.t2{ border-top:7px solid var(--sol) } .tier.t2 .tl{ color:var(--sol-dk) }
  .tier.t3{ border-top:7px solid var(--verde) } .tier.t3 .tl{ color:var(--verde-dk) }
  .zones { display:flex; flex-wrap:wrap; gap:9px; margin-top:22px; align-items:center; }
  .zones .zl { font-size:13px; font-weight:700; color:var(--espresso-soft); }
  .zone { font-family:var(--font-ticket); font-size:12.5px; font-weight:700; background:var(--paper); border:1.5px solid var(--espresso); padding:6px 12px; border-radius:999px; }

  /* ---------- garantía / official ---------- */
  .guarantee { display:grid; grid-template-columns:repeat(2,1fr); gap:16px; }
  @media (max-width:760px){ .guarantee{grid-template-columns:1fr} }
  .gcard { background:rgba(255,255,255,.06); border:1.5px solid rgba(255,255,255,.16); border-radius:16px; padding:24px; }
  .gcard .gi { font-size:1.5rem; }
  .gcard h3 { color:#fff; font-size:1.2rem; margin:10px 0 6px; }
  .gcard p { color:#b9c6ec; font-size:14.5px; margin:0; }
  .official { display:flex; align-items:center; gap:14px; background:rgba(255,255,255,.06); border:1.5px solid rgba(255,255,255,.16); border-radius:14px; padding:18px 22px; margin-top:16px; }
  .official .seal { flex:none; width:42px; height:42px; border-radius:50%; background:var(--verde); color:#fff; display:flex; align-items:center; justify-content:center; font-weight:800; border:2px solid #fff; }
  .official p { margin:0; font-size:14.5px; color:#eaf0ff; }
  .official p span { color:#b9c6ec; }

  /* ---------- promo band (reserved) ---------- */
  .band { background:var(--azul); color:#fff; border:2.5px solid var(--espresso); box-shadow:8px 8px 0 var(--espresso); border-radius:22px; padding:clamp(26px,5vw,46px); display:grid; grid-template-columns:1.5fr 1fr; gap:24px; align-items:center; }
  @media (max-width:720px){ .band{grid-template-columns:1fr} }
  .band .k { font-family:var(--font-display); font-weight:700; font-size:12px; letter-spacing:.14em; text-transform:uppercase; color:var(--sol); }
  .band h2 { font-size:clamp(1.5rem,3.4vw,2.2rem); margin:8px 0 8px; color:#fff; }
  .band p { opacity:.96; margin:0; }
  .band .btn-light { display:inline-flex; align-items:center; gap:8px; background:var(--sol); color:var(--espresso); border:2.5px solid var(--espresso); box-shadow:4px 4px 0 var(--espresso); font-family:var(--font-display); font-weight:800; padding:14px 22px; border-radius:13px; text-decoration:none; transition:transform .14s ease, box-shadow .14s ease; }
  .band .btn-light:hover { transform:translate(-2px,-2px); box-shadow:6px 6px 0 var(--espresso); }

  /* ---------- footer ---------- */
  footer { background:var(--espresso); color:#d8cbb8; padding:54px 0 44px; }
  .foot-top { display:flex; justify-content:space-between; gap:24px; flex-wrap:wrap; }
  .foot-brand img { height:38px; background:var(--paper); padding:6px 10px; border-radius:10px; }
  .foot-brand p { max-width:38ch; margin:14px 0 0; font-size:14px; }
  .handles { display:flex; gap:10px; flex-wrap:wrap; align-content:flex-start; }
  .handles a { text-decoration:none; font-weight:700; font-size:13.5px; color:#fff; border:1.5px solid rgba(255,255,255,.22); padding:8px 13px; border-radius:999px; }
  .handles a:hover { border-color:#fff; background:rgba(255,255,255,.06); }
  .aliados { margin-top:26px; font-size:12px; color:#8a7965; }
  .aliados a { color:#a3927d; text-decoration:underline; text-underline-offset:2px; }
  .aliados a:hover { color:#d8cbb8; }
  .fineprint { margin-top:14px; padding-top:22px; border-top:1px solid rgba(255,255,255,.12); font-size:12px; color:#a3927d; max-width:80ch; line-height:1.65; }

  /* ---------- cart drawer ---------- */
  .overlay { position:fixed; inset:0; background:rgba(42,31,26,.5); opacity:0; visibility:hidden; transition:opacity .25s ease; z-index:90; }
  .overlay.open { opacity:1; visibility:visible; }
  .drawer { position:fixed; top:0; right:0; height:100%; width:min(420px,100%); background:var(--paper); z-index:100; display:flex; flex-direction:column; transform:translateX(100%); transition:transform .28s cubic-bezier(.4,0,.2,1); box-shadow:-30px 0 60px -30px rgba(42,31,26,.6); }
  .drawer.open { transform:translateX(0); }
  .drawer-head { background:var(--azul-noche); color:#fff; padding:18px 20px; display:flex; align-items:center; justify-content:space-between; }
  .drawer-head h2 { color:#fff; font-size:1.3rem; margin:0; display:flex; align-items:center; gap:10px; }
  .drawer-head .dc { font-family:var(--font-ticket); font-size:12px; background:var(--sol); color:var(--espresso); padding:2px 9px; border-radius:999px; }
  .drawer-close { background:transparent; border:none; color:#fff; font-size:24px; cursor:pointer; line-height:1; padding:4px; }
  .drawer-body { flex:1; overflow-y:auto; padding:18px 20px; }
  .ci { display:flex; gap:12px; padding:14px 0; border-bottom:1.5px dashed var(--line); }
  .ci-thumb { width:58px; height:58px; flex:none; border-radius:10px; background:var(--sand); border:1.5px solid var(--line); object-fit:cover; }
  .ci-main { flex:1; min-width:0; }
  .ci-main h4 { font-family:var(--font-display); font-weight:700; font-size:.92rem; margin:0 0 4px; line-height:1.2; }
  .ci-price { font-family:var(--font-ticket); font-weight:700; color:var(--verde-dk); font-size:.95rem; }
  .ci-qty { display:inline-flex; align-items:center; gap:0; margin-top:8px; border:1.5px solid var(--espresso); border-radius:8px; overflow:hidden; }
  .ci-qty button { width:28px; height:26px; border:none; background:var(--card); cursor:pointer; font-weight:800; font-size:15px; color:var(--espresso); }
  .ci-qty button:hover { background:var(--sand); }
  .ci-qty span { min-width:30px; text-align:center; font-family:var(--font-ticket); font-weight:700; font-size:14px; }
  .ci-rm { background:none; border:none; color:var(--espresso-soft); font-size:12px; cursor:pointer; text-decoration:underline; margin-top:6px; padding:0; display:block; }
  .cart-empty { text-align:center; color:var(--espresso-soft); padding:40px 10px; }
  .cart-empty .big { font-size:2.4rem; }
  .drawer-foot { border-top:2px solid var(--espresso); padding:18px 20px; background:var(--card); }
  .manifest { margin-bottom:12px; }
  .m-row { display:flex; justify-content:space-between; align-items:center; gap:10px; font-size:14px; padding:5px 0; }
  .m-row .mono { font-family:var(--font-ticket); font-weight:700; }
  .m-delivery { color:var(--espresso-soft); font-size:13px; }
  .m-prot { cursor:pointer; color:var(--espresso-soft); font-size:13px; }
  .m-prot em { font-style:normal; opacity:.7; }
  .m-prot input { accent-color:var(--verde); margin-right:5px; vertical-align:middle; }
  .m-total { border-top:1.5px dashed var(--line); margin-top:4px; padding-top:10px; font-family:var(--font-display); font-weight:800; font-size:1.05rem; }
  .m-total .mono { font-size:1.3rem; color:var(--espresso); }
  .sub-row { display:flex; justify-content:space-between; align-items:baseline; margin-bottom:14px; }
  .sub-row .sl { font-family:var(--font-display); font-weight:700; }
  .sub-row .sv { font-family:var(--font-ticket); font-weight:700; font-size:1.4rem; color:var(--espresso); }
  .checkout { width:100%; border:2.5px solid var(--espresso); background:var(--verde); color:#fff; font-family:var(--font-display); font-weight:800; font-size:1.05rem; padding:15px; border-radius:13px; cursor:pointer; text-decoration:none; display:block; text-align:center; box-shadow:4px 4px 0 var(--espresso); transition:transform .14s ease, box-shadow .14s ease; }
  .checkout:hover { transform:translate(-2px,-2px); box-shadow:6px 6px 0 var(--espresso); }
  .checkout[aria-disabled="true"] { background:var(--sand-2); color:var(--espresso-soft); pointer-events:none; box-shadow:none; }
  .drawer-fine { font-size:11px; color:var(--espresso-soft); margin:12px 0 0; line-height:1.5; text-align:center; }

  /* When the cart drawer is open, suppress every bottom-pinned overlay so the checkout CTA
     (#checkout, in .drawer-foot) is never physically covered/un-tappable. The coupon sticky bar
     (.lc-ah.lc-sticky, z-index:9000, full-width-bottom on mobile) and the consent banner
     (#lc-consent, z-index:200, bottom-pinned) otherwise sit ON TOP of the drawer footer and steal
     the tap. Page-own .sticky-cart is redundant while the drawer is up. Scoped to the drawer session
     only — they reappear on close. The money button always wins. */
  body.drawer-open .lc-ah.lc-sticky,
  body.drawer-open #lc-consent,
  body.drawer-open .sticky-cart { display:none !important; pointer-events:none !important; }

  /* ---------- sticky mobile cart ---------- */
  .sticky-cart { position:fixed; left:14px; right:14px; bottom:14px; z-index:70; display:none; }
  .sticky-cart button { width:100%; border:2.5px solid var(--espresso); background:var(--verde); color:#fff; font-family:var(--font-display); font-weight:800; font-size:1rem; padding:15px; border-radius:14px; cursor:pointer; display:flex; justify-content:center; align-items:center; gap:10px; box-shadow:0 12px 30px -10px rgba(42,31,26,.7); }
  .sticky-cart .st { font-family:var(--font-ticket); }
  @media (max-width:760px){ .sticky-cart.show{display:block} }

  @media (max-width:880px){
    .hero .wrap { grid-template-columns:1fr; gap:36px; }
    .sello-wrap { order:-1; }
    .hero h1 { max-width:none; }
  }
  @media (max-width:480px){
    .eyebrow { font-size:10.5px; letter-spacing:.07em; white-space:normal; line-height:1.35; border-radius:14px; }
    .boleto-foot { font-size:12px; }
    .btn { padding:14px 18px; }
  }

/* catalog pagination + compliance action */
.ver-mas { font-family:var(--font-display); font-weight:800; font-size:1rem; padding:14px 28px; border:2.5px solid var(--espresso); background:var(--card); color:var(--espresso); border-radius:13px; cursor:pointer; box-shadow:4px 4px 0 var(--espresso); transition:transform .14s,box-shadow .14s; }
.ver-mas:hover { transform:translate(-2px,-2px); box-shadow:6px 6px 0 var(--espresso); background:var(--sol); }
.add-detail { display:block; width:100%; text-align:center; text-decoration:none; border:2px solid var(--espresso); background:var(--card); color:var(--espresso); font-family:var(--font-display); font-weight:800; font-size:14px; padding:11px 10px; border-radius:11px; }
.add-detail:hover { background:var(--sand); }

/* homepage category tiles (recycled product imagery) */
.cats { display:grid; grid-template-columns:repeat(5,1fr); gap:14px; }
@media(max-width:900px){ .cats{grid-template-columns:repeat(3,1fr)} }
@media(max-width:560px){ .cats{grid-template-columns:repeat(2,1fr)} }
.cat-tile { position:relative; aspect-ratio:1; border:2px solid var(--espresso); border-radius:16px; overflow:hidden; text-decoration:none; display:flex; flex-direction:column; justify-content:flex-end; padding:14px; box-shadow:var(--shadow-sm); transition:transform .16s ease; color:#fff; }
.cat-tile:hover { transform:translateY(-4px); }
.cat-tile .cat-img { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; z-index:0; }
.cat-tile .cat-scrim { position:absolute; inset:0; z-index:1; background:linear-gradient(to top, rgba(11,42,107,.82) 0%, rgba(11,42,107,.12) 48%, rgba(255,255,255,.14) 100%); }
.cat-tile .e { position:absolute; top:14px; left:14px; z-index:2; font-size:2.2rem; line-height:1; filter:drop-shadow(0 2px 4px rgba(0,0,0,.3)); display:none; }
.cat-tile.noimg .e { display:block; }
.cat-tile.noimg .cat-scrim { background:linear-gradient(to top, rgba(11,42,107,.55) 0%, transparent 55%); }
.cat-tile .lab { position:relative; z-index:2; }
.cat-tile .lab h4 { font-family:var(--font-display); font-weight:800; font-size:1rem; margin:0; line-height:1.12; text-shadow:0 1px 3px rgba(0,0,0,.35); }
.cat-tile .lab .n { font-family:var(--font-ticket); font-size:11px; opacity:.95; text-shadow:0 1px 2px rgba(0,0,0,.35); }

/* in-cart button state + always-visible sticky progress bar */
.add-go.incart { background:var(--espresso); color:#fff; }
/* state-aware card CTA: quantity controls when item is in the Drop */
.qty-ctl { display:flex; align-items:center; justify-content:space-between; gap:6px; border:2px solid var(--espresso); border-radius:11px; background:var(--verde); overflow:hidden; }
.qty-ctl .qbtn { flex:0 0 auto; width:40px; height:38px; border:none; background:rgba(0,0,0,.14); color:#fff; font-size:20px; font-weight:800; line-height:1; cursor:pointer; font-family:var(--font-display); }
.qty-ctl .qbtn:active { background:rgba(0,0,0,.28); }
.qty-ctl .qn { flex:1; text-align:center; color:#fff; font-family:var(--font-display); font-weight:800; font-size:13px; }
/* quiet add confirmation toast — cart does NOT auto-open on add */
.lc-toast { position:fixed; left:50%; bottom:24px; transform:translateX(-50%) translateY(20px); background:var(--espresso); color:#fff; padding:12px 20px; border-radius:999px; font-family:var(--font-display); font-weight:700; font-size:14px; z-index:9999; opacity:0; pointer-events:none; transition:opacity .2s ease, transform .2s ease; box-shadow:0 6px 24px rgba(0,0,0,.25); }
.lc-toast.show { opacity:1; transform:translateX(-50%) translateY(0); }
.sticky-cart .sc-meter { height:8px; border-radius:999px 999px 0 0; background:rgba(42,31,26,.25); overflow:hidden; border:2.5px solid var(--espresso); border-bottom:none; }
.sticky-cart .sc-meter > i { display:block; height:100%; width:0; background:linear-gradient(90deg,var(--sol),var(--verde)); transition:width .4s ease; }
.sticky-cart button { border-radius:0 0 14px 14px !important; }
#sticky-msg { font-family:var(--font-body); font-weight:600; font-size:12px; opacity:.92; }
@media (min-width:761px){ .sticky-cart.show{ display:block; left:auto; right:20px; width:340px; } }

/* legal documents (terms / privacy / cookies) */
.legal { max-width:780px; margin:0 auto; }
.legal .lead { font-size:15px; color:var(--espresso-soft); margin:0 0 6px; }
.legal .meta { font-family:var(--font-ticket); font-size:12.5px; color:var(--espresso-soft); background:var(--sand); border:1.5px solid var(--line); border-radius:10px; padding:12px 14px; margin:16px 0 26px; line-height:1.7; }
.legal .pend { font-style:italic; color:var(--rojo-dk); }
.legal h3 { font-family:var(--font-display); font-weight:800; font-size:1.12rem; margin:30px 0 8px; padding-top:18px; border-top:1.5px solid var(--line); }
.legal h3:first-of-type { border-top:none; padding-top:0; }
.legal p { font-size:14.5px; line-height:1.72; margin:10px 0; color:var(--espresso); }
.legal ul, .legal ol { font-size:14.5px; line-height:1.7; padding-left:22px; margin:10px 0; }
.legal li { margin:4px 0; }
.legal .upd { font-size:12.5px; color:var(--espresso-soft); }

/* cookie consent banner */
#lc-consent { position:fixed; left:14px; right:14px; bottom:14px; z-index:200; max-width:560px; margin:0 auto; background:var(--card); border:2px solid var(--espresso); border-radius:16px; padding:18px 18px 16px; box-shadow:0 18px 50px -12px rgba(42,31,26,.6); font-family:var(--font-body); display:none; }
#lc-consent.show { display:block; }
#lc-consent p { font-size:13.5px; line-height:1.6; margin:0 0 12px; color:var(--espresso); }
#lc-consent a { color:var(--azul-dk); font-weight:700; }
#lc-consent .row { display:flex; gap:8px; flex-wrap:wrap; }
#lc-consent button { font-family:var(--font-display); font-weight:800; font-size:13px; border:2px solid var(--espresso); border-radius:10px; padding:10px 14px; cursor:pointer; flex:1; min-width:120px; }
#lc-consent .acc { background:var(--verde); color:#fff; }
#lc-consent .rej { background:var(--card); color:var(--espresso); }
#lc-consent .cfg { background:var(--sand); color:var(--espresso); }
