/* ── Panels: Detail panel, premium sections, sabor cards, carta overlay, vote explainer, profile ── */

/* Drag handle — hidden on desktop, visible as pill on mobile bottom sheet */
.pnl-drag-handle{display:none}

/* ── PANEL FICHA ── */
#panel{position:absolute;top:0;right:-480px;width:460px;height:100%;
  background:var(--color-white);box-shadow:-2px 0 24px rgba(11,31,56,.08),-8px 0 60px rgba(11,31,56,.06);
  z-index:1000;transition:right .32s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;overflow:hidden;
  border-left:1px solid rgba(0,0,0,.04)}
#panel.open{right:0}
#panel.premium-mode{width:min(620px,100%);right:-640px}
#panel.premium-mode.open{right:0}

/* ── Photo hero (premium) ── */
.pnl-hero{position:relative;overflow:hidden;background:linear-gradient(135deg,#1A1A2E,#16213E)}
.pnl-hero-img{width:100%;height:300px;object-fit:cover;object-position:center 30%;display:block;
  filter:brightness(.88) saturate(1.05);transition:opacity .5s}
.pnl-hero-overlay{position:absolute;inset:0;
  background:linear-gradient(transparent 20%,rgba(11,31,56,.5) 55%,rgba(11,31,56,.92) 100%)}
.pnl-hero-content{position:absolute;bottom:0;left:0;right:0;padding:24px 28px}
.pnl-hero-content .pnl-name{font-family:'Playfair Display',serif;font-size:28px;color:var(--color-white);line-height:1.25;margin-bottom:8px;text-shadow:0 2px 12px rgba(0,0,0,.4);letter-spacing:-.02em}
.pnl-hero-content .pnl-subtitle{font-size:12px;color:rgba(255,255,255,.7);display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.pnl-hero-badge{display:inline-flex;align-items:center;gap:4px;padding:4px 12px;border-radius:20px;
  font-size:11px;font-weight:700;letter-spacing:.6px;text-transform:uppercase;
  background:rgba(255,255,255,.12);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);color:var(--color-white);
  border:1px solid rgba(255,255,255,.1)}

/* ── Photo gallery (standard) ── */
.pnl-photo{margin:-0 -0 0 -0;overflow:hidden;position:relative;background:var(--color-neutral-pale)}
.pnl-photo img{width:100%;height:220px;object-fit:cover;object-position:center 30%;display:block;transition:opacity .3s}
.pnl-photo-grad{position:absolute;bottom:0;left:0;right:0;height:40px;background:linear-gradient(transparent,rgba(255,255,255,.6))}

/* ── Header (standard) ── */
.pnl-hdr{padding:18px 20px 16px;border-bottom:none;flex-shrink:0;position:relative;
  background:linear-gradient(135deg,var(--navy) 0%,var(--color-navy-gradient-end) 100%)}
.pnl-x{position:absolute;top:14px;right:14px;width:30px;height:30px;border-radius:50%;
  border:none;background:rgba(255,255,255,.08);cursor:pointer;color:rgba(255,255,255,.6);font-size:14px;
  display:flex;align-items:center;justify-content:center;transition:var(--transition)}
.pnl-x:hover{background:rgba(255,255,255,.15);color:var(--color-white)}
.pnl-tipo{font-size:11px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;margin-bottom:5px;opacity:.7}
.pnl-name{font-family:'Playfair Display',serif;font-size:22px;color:var(--color-white);line-height:1.3;margin-bottom:10px;padding-right:40px;letter-spacing:-.02em}
.pnl-bolas{display:flex;gap:4px;align-items:center;margin-bottom:10px}
.bola{width:13px;height:13px;border-radius:50%}
.bola-lbl{font-size:11px;color:rgba(255,255,255,.5);margin-left:4px}
.b1{background:var(--color-success-light)}.b2{background:var(--color-bola-2)}.b3{background:var(--color-gold)}.b0{background:rgba(255,255,255,.18)}
.pnl-rating{display:flex;align-items:center;gap:8px}
.pnl-rnum{font-size:22px;font-weight:700;color:var(--color-white);line-height:1}
.pnl-stars{color:var(--color-gold);font-size:13px;letter-spacing:1.5px}
.pnl-revs{font-size:12px;color:rgba(255,255,255,.45)}

.pnl-body{flex:1;overflow-y:auto;
  -webkit-overflow-scrolling:touch; /* iOS momentum scroll — P2 fix Sprint 10 */
  /* Padding inferior para que el contenido no quede oculto bajo el tab del CTA */
  padding-bottom:58px}
.pnl-body::-webkit-scrollbar{width:4px}
.pnl-body::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}
.psec{padding:14px 18px;border-bottom:1px solid var(--border)}
.psec:last-child{border-bottom:none}
.psec-h{font-size:11px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--mid);margin-bottom:9px}

.irow{display:flex;align-items:flex-start;gap:8px;margin-bottom:7px;font-size:13px}
.irow:last-child{margin-bottom:0}
.iico{width:16px;flex-shrink:0;margin-top:1px;color:var(--teal)}
.ival{color:var(--gray);line-height:1.45}
.ival a{color:var(--teal);text-decoration:none}
.ival a:hover{text-decoration:underline}

.chips{display:flex;flex-wrap:wrap;gap:5px;margin-top:2px}
.chip{padding:3px 10px;border-radius:20px;font-size:12px;background:var(--smoke);color:var(--gray);border:1px solid var(--border)}

.hor-t{width:100%;border-collapse:collapse;font-size:13px}
.hor-t td{padding:3.5px 0;color:var(--gray)}
.hor-t td:first-child{font-weight:500;color:var(--navy);width:96px}
.hor-t tr.hoy td{color:var(--teal);font-weight:600}
.hor-t tr.hoy td:first-child{color:var(--teal)}

.ext-links{display:flex;gap:7px;flex-wrap:wrap;margin-top:2px}
.ext-a{padding:7px 14px;border-radius:8px;font-size:13px;text-decoration:none;font-weight:500;
  font-family:'DM Sans',sans-serif;transition:opacity .15s;display:inline-flex;align-items:center;gap:5px}
.ext-a:hover{opacity:.8}
.ext-gm{background:var(--color-info-bg);color:var(--color-info-blue)}
.ext-wb{background:var(--smoke);color:var(--navy);border:1px solid var(--border)}

.badge-tag{display:inline-flex;align-items:center;gap:3px;padding:3px 9px;border-radius:14px;
  font-size:11px;font-weight:500;margin-right:4px;margin-bottom:4px}
.badge-green{background:var(--color-success-bg);color:var(--color-success-dark);border:1px solid var(--color-success-light)}
.badge-blue{background:var(--color-info-bg);color:var(--color-info-dark);border:1px solid var(--color-info-light)}
.badge-gold{background:var(--color-orange-pale);color:var(--color-gold-dark);border:1px solid var(--color-warning-border)}
.badge-red{background:var(--color-error-bg);color:var(--color-error-border);border:1px solid var(--color-error-border)}
.badge-teal{background:var(--color-accent-pale);color:var(--color-accent-dark);border:1px solid var(--color-accent-light)}
.badge-founder{background:linear-gradient(135deg,var(--color-warning-bg),var(--color-warning-border));color:var(--color-gold-dark);border:1px solid var(--color-gold);
  font-weight:700;letter-spacing:.3px;box-shadow:0 1px 4px rgba(245,158,11,.25)}

/* ── Premium sections ── */
.prem-section{padding:20px 28px;border-bottom:1px solid rgba(0,0,0,.05)}
.prem-section:last-child{border-bottom:none}
.prem-section-title{font-size:11px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;
  color:var(--teal);margin-bottom:12px;display:flex;align-items:center;gap:8px}
.prem-section-title::after{content:'';flex:1;height:1px;background:linear-gradient(to right,var(--border),transparent)}
.prem-story{font-size:14px;color:var(--navy);line-height:1.75;margin-bottom:8px}
.prem-story em{color:var(--teal);font-style:normal;font-weight:600}
.prem-highlights{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin:12px 0}
.prem-highlight{padding:14px;border-radius:14px;background:linear-gradient(135deg,var(--color-accent-pale),#E6FFF9);border:1px solid rgba(153,246,228,.5)}
.prem-highlight-title{font-size:11px;font-weight:700;color:var(--teal);text-transform:uppercase;letter-spacing:.1em;margin-bottom:4px}
.prem-highlight-text{font-size:13px;color:var(--gray);line-height:1.55}
.prem-heladero{display:flex;gap:18px;padding:18px;background:var(--smoke);border-radius:16px;align-items:flex-start}
.prem-heladero img{width:76px;height:76px;border-radius:50%;object-fit:cover;flex-shrink:0;
  border:3px solid var(--teal);box-shadow:0 4px 16px rgba(13,148,136,.15)}
.prem-heladero-info h4{font-size:17px;color:var(--navy);margin-bottom:4px;font-family:'Playfair Display',serif}
.prem-heladero-info p{font-size:13px;color:var(--gray);line-height:1.6}
.prem-gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:6px}
.prem-gallery img{width:100%;aspect-ratio:1;object-fit:cover;border-radius:12px;cursor:pointer;
  transition:var(--transition);box-shadow:0 2px 8px rgba(0,0,0,.06)}
.prem-gallery img:hover{transform:scale(1.02);box-shadow:0 4px 16px rgba(0,0,0,.12)}
.prem-gallery img:first-child{grid-column:1/-1;aspect-ratio:16/9;border-radius:14px}

/* ── Sabores Premium ── */
.prem-sabor-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(90px,1fr));gap:10px}
.sabor-card-prem{position:relative;display:flex;flex-direction:column;align-items:center;gap:4px;
  padding:10px 6px 8px;border-radius:14px;background:#FAFAFA;border:1.5px solid var(--border);
  cursor:pointer;transition:all .25s ease;text-align:center}
.sabor-card-prem:hover{transform:translateY(-3px);box-shadow:0 6px 16px rgba(0,0,0,.08);border-color:var(--teal)}
.sabor-card-prem.voted{background:linear-gradient(135deg,var(--color-success-bg),var(--color-success-pale));border-color:var(--color-success-light)}
.sabor-card-prem-img{width:56px;height:56px;border-radius:10px;overflow:hidden;flex-shrink:0}
.sabor-card-prem-img img,.sabor-card-prem-img div{width:100%;height:100%}
.sabor-card-prem-name{font-size:11px;font-weight:600;color:var(--navy);line-height:1.2;
  max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.sabor-card-prem-votes{font-size:11px;font-weight:700}
.sabor-badge{display:inline-flex;align-items:center;gap:2px;font-size:11px;font-weight:600;
  padding:1px 6px;border-radius:8px;line-height:1.4}
.sabor-stars{display:inline-flex;gap:1px;font-size:11px;line-height:1}
.sabor-stars .on{color:var(--color-gold)}.sabor-stars .off{color:var(--color-neutral-border)}

/* ── Carta completa overlay ── */
.carta-overlay{position:fixed;inset:0;z-index:9999;background:rgba(0,0,0,.55);display:flex;
  align-items:center;justify-content:center;opacity:0;transition:opacity .3s;pointer-events:none}
.carta-overlay.active{opacity:1;pointer-events:all}
.carta-panel{background:var(--color-white);border-radius:20px;width:95vw;max-width:520px;max-height:90vh;
  overflow-y:auto;box-shadow:0 24px 64px rgba(0,0,0,.2);position:relative;
  animation:carta-in .35s ease}
@keyframes carta-in{from{transform:translateY(40px);opacity:0}to{transform:none;opacity:1}}
.carta-header{padding:20px 24px 16px;background:linear-gradient(135deg,var(--color-premium) 0%,var(--color-premium-dark) 100%);
  color:var(--color-white);border-radius:20px 20px 0 0;position:sticky;top:0;z-index:2}
.carta-header h3{font-size:18px;font-weight:700;margin:0 0 2px}
.carta-header p{font-size:12px;opacity:.8;margin:0}
.carta-close{position:absolute;top:12px;right:16px;background:rgba(255,255,255,.2);
  border:none;color:var(--color-white);width:32px;height:32px;border-radius:50%;font-size:18px;
  cursor:pointer;display:flex;align-items:center;justify-content:center;transition:.2s}
.carta-close:hover{background:rgba(255,255,255,.4)}
.carta-body{padding:16px 20px 24px}
.carta-sabor{display:flex;align-items:center;gap:12px;padding:12px;border-radius:12px;
  border:1.5px solid var(--color-neutral-bg);margin-bottom:8px;transition:all .2s;min-height:68px}
.carta-sabor:hover{border-color:var(--color-premium-border);background:#FAFAFF}
.carta-sabor.highlighted{background:var(--color-premium-wash);border-color:var(--color-premium-muted);box-shadow:0 0 0 3px rgba(124,58,237,.1)}
.carta-sabor-img{width:52px;height:52px;border-radius:10px;overflow:hidden;flex-shrink:0}
.carta-sabor-img img{width:100%;height:100%;object-fit:cover}
.carta-sabor-info{flex:1;min-width:0}
.carta-sabor-name{font-size:13px;font-weight:600;color:var(--navy)}
.carta-sabor-desc{font-size:11px;color:var(--mid);line-height:1.3;margin-top:2px}
.carta-sabor-tags{display:flex;gap:4px;margin-top:4px;flex-wrap:wrap}
.carta-sabor-tag{font-size:11px;padding:1px 6px;border-radius:6px;font-weight:600}
.carta-sabor-vote{display:flex;flex-direction:column;align-items:center;gap:4px;flex-shrink:0}
.star-rate{display:flex;gap:2px;cursor:pointer}
.star-rate span{font-size:20px;color:var(--color-neutral-border);transition:color .15s;user-select:none}
.star-rate span.active{color:var(--color-gold)}
.star-rate span:hover~span{color:var(--color-neutral-border) !important}
@keyframes vote-pop{0%{transform:scale(1)}50%{transform:scale(1.3)}100%{transform:scale(1)}}
.vote-success{animation:vote-pop .4s ease}
.btn-ver-carta{display:flex;align-items:center;justify-content:center;gap:6px;width:100%;
  padding:10px;margin-top:10px;border-radius:12px;border:1.5px solid var(--color-premium-border);
  background:linear-gradient(135deg,var(--color-premium-wash),var(--color-premium-pale));color:var(--color-premium);font-weight:600;
  font-size:12px;cursor:pointer;transition:all .2s}
.btn-ver-carta:hover{background:linear-gradient(135deg,var(--color-premium-pale),var(--color-premium-border));border-color:var(--color-premium-muted);transform:translateY(-1px)}

/* ── Premium CTA section ── */
.prem-cta-section{padding:24px 28px;background:linear-gradient(135deg,var(--color-accent-darker) 0%,var(--color-accent) 50%,var(--color-accent-dark) 100%);text-align:center;position:relative;overflow:hidden}
.prem-cta-section::before{content:'';position:absolute;top:-30px;right:-30px;width:120px;height:120px;border-radius:50%;background:rgba(255,255,255,.06)}
.prem-cta-section h4{font-size:16px;color:var(--color-white);margin-bottom:6px;font-weight:600;font-family:'Playfair Display',serif}
.prem-cta-section p{font-size:13px;color:rgba(255,255,255,.8);margin-bottom:14px;line-height:1.5}
.prem-cta-btn{display:inline-flex;align-items:center;gap:6px;padding:11px 28px;border-radius:24px;
  background:var(--color-white);color:var(--teal);font-size:13px;font-weight:700;text-decoration:none;
  transition:var(--transition);border:none;cursor:pointer;font-family:'DM Sans',sans-serif;
  box-shadow:0 4px 12px rgba(0,0,0,.1)}
.prem-cta-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(0,0,0,.15)}

/* ── Vote explainer ── */
.vote-explainer{padding:14px 18px;background:linear-gradient(135deg,var(--color-info-bg),var(--color-info-pale));border-radius:12px;
  margin:0;display:flex;align-items:center;gap:12px;font-size:13px;color:var(--color-info-dark);border:1px solid var(--color-info-light)}
.vote-explainer-icon{font-size:28px;flex-shrink:0}
.vote-explainer strong{display:block;font-size:13px;margin-bottom:2px}

/* ── Expandable premium section ── */
.prem-expand{cursor:pointer;user-select:none}
.prem-expand .prem-arrow{transition:transform .2s;display:inline-block}
.prem-wrapper.open .prem-arrow{transform:rotate(90deg)}
.prem-content{max-height:0;overflow:hidden;transition:max-height .4s ease}
.prem-wrapper.open .prem-content{max-height:3000px}

/* ── Photo gallery ── */
.shop-gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;margin-top:6px}
.shop-gallery img{width:100%;height:80px;object-fit:cover;border-radius:8px;cursor:pointer}

/* ── Sabor grid → consolidated in sabores.css ── */
.sabor-votes{font-weight:700;font-size:11px;color:var(--gold)}

/* ══════════════════════════════════════════════════════════════
   EL HELADERO — Collapsible tab with social-media-inspired profile
   ══════════════════════════════════════════════════════════════ */

/* Tab container */
.hel-tab{border-radius:16px;overflow:hidden;
  box-shadow:0 2px 12px rgba(0,0,0,.06),0 0 0 1px rgba(0,0,0,.04);
  background:var(--color-white);margin:0 0 16px}

/* Tab header — always visible, clickable */
.hel-tab-header{display:flex;align-items:center;justify-content:space-between;
  padding:14px 16px;cursor:pointer;transition:background .15s;user-select:none}
.hel-tab-header:hover{background:var(--smoke)}
.hel-tab-left{display:flex;align-items:center;gap:12px}
.hel-tab-avatar{width:44px;height:44px;border-radius:50%;object-fit:cover;flex-shrink:0;
  border:2px solid var(--border);box-shadow:0 2px 8px rgba(0,0,0,.08)}
.hel-tab-avatar-ph{display:flex;align-items:center;justify-content:center;
  font-size:16px;font-weight:800;color:var(--color-white);font-family:'Playfair Display',serif}
.hel-tab-label{font-size:11px;font-weight:600;color:var(--teal);text-transform:uppercase;letter-spacing:.04em;margin-bottom:1px}
.hel-tab-name{font-size:14px;font-weight:700;color:var(--navy);font-family:'Playfair Display',serif}
.hel-tab-arrow{color:var(--mid);transition:transform .3s cubic-bezier(.4,0,.2,1)}

/* Expand/collapse animation */
.hel-tab-content{max-height:0;overflow:hidden;transition:max-height .45s cubic-bezier(.4,0,.2,1)}
.hel-tab.open .hel-tab-content{max-height:2000px}
.hel-tab.open .hel-tab-arrow{transform:rotate(180deg)}
.hel-tab.open .hel-tab-header{border-bottom:1px solid var(--border)}

/* Profile card inside dropdown */
.hel-profile{padding:0}
.hel-cover{height:100px;position:relative;overflow:hidden;background:linear-gradient(135deg,var(--navy) 0%,var(--navy2) 100%)}
.hel-cover-img{width:100%;height:100%;object-fit:cover;display:block}
.hel-avatar-row{display:flex;justify-content:center;margin-top:-36px;position:relative;z-index:2}
.hel-avatar{width:72px;height:72px;border-radius:50%;object-fit:cover;
  border:3px solid var(--color-white);box-shadow:0 4px 16px rgba(0,0,0,.15)}
.hel-avatar-ph{display:flex;align-items:center;justify-content:center;
  font-size:22px;font-weight:800;color:var(--color-white);font-family:'Playfair Display',serif;letter-spacing:1px}

/* Info block */
.hel-info{text-align:center;padding:10px 20px 0}
.hel-info-name{font-size:18px;font-weight:700;color:var(--navy);font-family:'Playfair Display',serif}
.hel-info-title{font-size:11px;color:var(--mid);margin-top:2px;line-height:1.4}

/* Stats row — Instagram-style counters */
.hel-stats{display:flex;justify-content:center;gap:0;padding:14px 20px;margin-top:10px;
  border-top:1px solid var(--smoke);border-bottom:1px solid var(--smoke)}
.hel-stat{flex:1;text-align:center;padding:0 8px}
.hel-stat+.hel-stat{border-left:1px solid var(--smoke)}
.hel-stat-val{font-size:16px;font-weight:800;color:var(--navy)}
.hel-stat-lbl{font-size:11px;color:var(--mid);text-transform:uppercase;letter-spacing:.04em;margin-top:1px}

/* Lema / tagline */
.hel-lema{padding:8px 20px 0;font-size:13px;font-weight:600;font-style:italic;color:var(--navy);text-align:center;letter-spacing:.02em}
/* Bio */
.hel-bio{padding:14px 20px;font-size:13px;color:var(--gray);line-height:1.65}

/* Social links — big, prominent buttons */
.hel-socials{display:flex;gap:8px;padding:0 20px 16px;justify-content:center;flex-wrap:wrap}
.hel-social{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:10px;
  font-size:12px;font-weight:600;text-decoration:none;transition:all .2s;
  border:1px solid var(--border)}
.hel-social:hover{transform:translateY(-2px);box-shadow:0 4px 12px rgba(0,0,0,.1)}
.hel-social-ig{color:#E1306C;background:rgba(225,48,108,.04)}
.hel-social-ig:hover{background:rgba(225,48,108,.1);border-color:#E1306C}
.hel-social-tk{color:#010101;background:rgba(0,0,0,.03)}
.hel-social-tk:hover{background:rgba(0,0,0,.08);border-color:#333}
.hel-social-fb{color:#1877F2;background:rgba(24,119,242,.04)}
.hel-social-fb:hover{background:rgba(24,119,242,.1);border-color:#1877F2}
.hel-social-yt{color:#FF0000;background:rgba(255,0,0,.04)}
.hel-social-yt:hover{background:rgba(255,0,0,.1);border-color:#FF0000}

/* Detail sections — icon + text blocks */
.hel-section{display:flex;gap:12px;padding:14px 20px;border-top:1px solid var(--smoke)}
.hel-section-icon{font-size:18px;flex-shrink:0;margin-top:1px}
.hel-section-title{font-size:11px;font-weight:700;color:var(--navy);margin-bottom:4px}
.hel-section-text{font-size:12px;color:var(--gray);line-height:1.6;margin:0}

/* Tags/chips for specialties, awards */
.hel-tags{display:flex;gap:5px;flex-wrap:wrap;margin-top:4px}
.hel-tag{padding:4px 10px;border-radius:8px;font-size:11px;font-weight:600;
  background:var(--smoke);color:var(--navy);border:1px solid var(--border)}
.hel-tag-gold{background:var(--color-gold-pale);color:var(--color-gold-dark);border-color:var(--color-warning-border)}

/* Empty state */
.hel-empty{padding:32px 20px;text-align:center}
.hel-cta{background:linear-gradient(180deg,var(--color-neutral-pale) 0%,var(--color-accent-pale) 100%);border-top:1px solid var(--color-neutral-border)}

/* ── 4-column preview grid ── */
.prem-sabor-cards-4{grid-template-columns:repeat(4,1fr)}

/* ── Sabor card badges ── */
.sabor-card-badge{position:absolute;top:4px;right:4px;font-size:11px;font-weight:700;padding:2px 6px;
  border-radius:6px;line-height:1.3;letter-spacing:.02em}
.sabor-card-badge-esp{background:rgba(124,58,237,.13);color:var(--color-premium)}
.sabor-card-badge-tmp{background:rgba(236,72,153,.13);color:var(--color-fuchsia)}

/* ── Carta filter chips ── */
.carta-chips{display:flex;gap:6px;padding:10px 20px 4px;overflow-x:auto;-webkit-overflow-scrolling:touch;
  scrollbar-width:none}
.carta-chips::-webkit-scrollbar{display:none}
.carta-chip{flex-shrink:0;padding:6px 14px;border-radius:20px;border:1.5px solid var(--border);
  background:var(--color-white);color:var(--gray);font-size:11px;font-weight:600;cursor:pointer;
  transition:all .2s;font-family:'DM Sans',sans-serif;white-space:nowrap}
.carta-chip:hover{border-color:var(--color-premium-border);color:var(--color-premium)}
.carta-chip.active{background:var(--color-premium);color:var(--color-white);border-color:var(--color-premium)}

/* ── Carta familia groups ── */
.carta-familia-group{margin-bottom:8px}
.carta-familia-header{font-size:11px;font-weight:700;color:var(--navy);padding:12px 0 6px;
  display:flex;align-items:center;gap:6px;border-bottom:1px solid var(--border);margin-bottom:8px}

/* ── Carta tag specializations ── */
.carta-tag-esp{background:rgba(124,58,237,.07);color:var(--color-premium)}
.carta-tag-tmp{background:rgba(236,72,153,.07);color:var(--color-fuchsia)}

/* ── Carta voted state ── */
.carta-sabor-voted{background:linear-gradient(135deg,var(--color-success-bg),var(--color-success-pale));border-color:var(--color-success-light)}
.carta-sabor-your-vote{font-size:11px;font-weight:700;color:var(--color-success);margin-top:2px}

/* ── Carta floating vote counter ── */
.carta-vote-counter{position:sticky;bottom:0;left:0;right:0;padding:12px 20px;
  background:linear-gradient(135deg,var(--color-premium),var(--color-premium-dark));color:var(--color-white);
  display:flex;align-items:center;justify-content:space-between;gap:12px;
  border-radius:0 0 20px 20px;font-size:13px;font-weight:600;z-index:3;
  animation:carta-counter-in .3s ease}
@keyframes carta-counter-in{from{transform:translateY(100%);opacity:0}to{transform:none;opacity:1}}
.carta-vote-counter-btn{padding:8px 18px;border-radius:20px;border:none;
  background:var(--color-white);color:var(--color-premium);font-size:12px;font-weight:700;cursor:pointer;
  font-family:'DM Sans',sans-serif;transition:all .2s}
.carta-vote-counter-btn:hover{transform:scale(1.04);box-shadow:0 2px 8px rgba(0,0,0,.15)}

/* ── Carta CTA info ── */
.carta-cta-info{padding:16px;border-radius:12px;background:var(--color-premium-wash);text-align:center;margin-top:12px}

/* ── Sabor bridge micro-bar ── */
.sabor-bridge{padding:0 28px;overflow:hidden;max-height:0;opacity:0;
  transition:max-height .4s ease,opacity .3s ease,padding .3s ease}
.sabor-bridge.visible{max-height:120px;opacity:1;padding:8px 28px 12px}
.sabor-bridge-inner{display:flex;align-items:center;justify-content:space-between;gap:12px;
  padding:12px 16px;border-radius:12px;
  background:linear-gradient(135deg,var(--color-success-bg),var(--color-success-pale));border:1.5px solid var(--color-success-light)}
.sabor-bridge-text{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--navy);font-weight:500}
.sabor-bridge-check{width:22px;height:22px;border-radius:50%;background:var(--color-success);color:var(--color-white);
  display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;flex-shrink:0}
.sabor-bridge-cta{padding:8px 16px;border-radius:10px;background:var(--teal);color:var(--color-white);
  font-size:11px;font-weight:700;text-decoration:none;white-space:nowrap;
  transition:all .2s;font-family:'DM Sans',sans-serif}
.sabor-bridge-cta:hover{background:var(--navy);transform:translateY(-1px);box-shadow:0 4px 12px rgba(0,0,0,.15)}

/* ── Post-vote summary toast ── */
.sabor-vote-toast{position:fixed;bottom:20px;left:50%;transform:translateX(-50%) translateY(100px);
  z-index:10001;opacity:0;transition:all .4s cubic-bezier(.4,0,.2,1);pointer-events:none}
.sabor-vote-toast.visible{transform:translateX(-50%) translateY(0);opacity:1;pointer-events:all}
.sabor-toast-inner{display:flex;align-items:center;gap:12px;padding:14px 18px;
  border-radius:16px;background:var(--color-white);box-shadow:0 12px 40px rgba(0,0,0,.18),0 0 0 1px rgba(0,0,0,.04);
  min-width:280px;max-width:420px}
.sabor-toast-icon{font-size:28px;flex-shrink:0}
.sabor-toast-text{flex:1;min-width:0}
.sabor-toast-text strong{display:block;font-size:13px;color:var(--navy)}
.sabor-toast-text span{font-size:11px;color:var(--mid)}
.sabor-toast-collection{flex-shrink:0}
.sabor-toast-close{position:absolute;top:6px;right:10px;background:none;border:none;
  color:var(--mid);font-size:16px;cursor:pointer;padding:4px}

/* ── Sabor skeleton loader ── */
.sabor-skeleton{border-radius:14px;background:linear-gradient(110deg,var(--color-neutral-bg) 8%,var(--color-neutral-border) 18%,var(--color-neutral-bg) 33%);
  background-size:200% 100%;animation:sabor-shimmer 1.4s linear infinite;height:100px}
@keyframes sabor-shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}

/* ── Sabor card entrance animation ── */
.sabor-card-enter{animation:sabor-fade-up .35s ease both}
@keyframes sabor-fade-up{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}

/* ── Sabor empty state ── */
.sabor-empty-state{grid-column:1/-1;text-align:center;padding:20px 16px;color:var(--mid);font-size:12px;
  display:flex;flex-direction:column;align-items:center;gap:6px}
.sabor-empty-icon{font-size:28px;opacity:.4}

/* ── Bridge bar pulse CTA ── */
.sabor-bridge-cta{position:relative;overflow:hidden}
.sabor-bridge-cta::after{content:'';position:absolute;inset:0;background:rgba(255,255,255,.15);
  animation:bridge-pulse 2s ease-in-out infinite}
@keyframes bridge-pulse{0%,100%{opacity:0}50%{opacity:1}}

/* ── Post-Dragcream sabor quick cards ── */
.sabor-quick-card{display:flex;align-items:center;gap:12px;padding:12px 14px;
  border-radius:12px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.08);
  margin-bottom:8px;transition:background .2s}
.sabor-quick-card:active{background:rgba(255,255,255,.12)}
.sabor-quick-icon{width:44px;height:44px;border-radius:10px;display:flex;align-items:center;
  justify-content:center;font-size:20px;flex-shrink:0}
.sabor-quick-name{flex:1;font-size:13px;font-weight:600;color:var(--color-white);min-width:0;
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.sabor-quick-stars{display:flex;gap:2px;flex-shrink:0}
.sq-star{font-size:24px;color:rgba(255,255,255,.25);cursor:pointer;user-select:none;
  transition:color .15s;min-width:28px;min-height:28px;display:inline-flex;
  align-items:center;justify-content:center}
.sq-star.active{color:var(--color-gold)}

/* ── Unified vote summary overlay ── */
.vote-summary-overlay{position:fixed;inset:0;z-index:10002;background:rgba(0,0,0,.6);
  display:flex;align-items:center;justify-content:center;opacity:0;
  transition:opacity .3s;pointer-events:none}
.vote-summary-overlay.active{opacity:1;pointer-events:all}
.vote-summary-card{background:var(--color-white);border-radius:24px;width:92vw;max-width:380px;
  padding:28px 24px;text-align:center;box-shadow:0 24px 64px rgba(0,0,0,.25);
  animation:carta-in .4s ease}
.vote-summary-score{font-size:52px;font-weight:800;color:var(--teal);line-height:1;
  font-family:'Playfair Display',serif;margin:8px 0}
.vote-summary-label{font-size:13px;color:var(--mid);margin-bottom:16px}
.vote-summary-sabores{display:flex;flex-wrap:wrap;gap:6px;justify-content:center;margin:12px 0 20px}
.vote-summary-sabor{padding:5px 12px;border-radius:20px;font-size:11px;font-weight:600;
  background:var(--color-premium-wash);color:var(--color-premium);border:1px solid var(--color-premium-border)}
.vote-summary-cta{display:inline-flex;align-items:center;gap:6px;padding:12px 28px;
  border-radius:24px;border:none;background:var(--teal);color:var(--color-white);font-size:14px;
  font-weight:700;cursor:pointer;font-family:'DM Sans',sans-serif;transition:all .2s;
  box-shadow:0 4px 16px rgba(13,148,136,.3)}
.vote-summary-cta:hover{transform:translateY(-2px);box-shadow:0 6px 24px rgba(13,148,136,.4)}
.vote-summary-fid{margin-top:12px;padding:10px 16px;border-radius:12px;
  background:linear-gradient(135deg,var(--color-orange-pale),var(--color-gold-pale));border:1px solid var(--color-warning-border);
  font-size:11px;color:var(--color-gold-dark);font-weight:600}

/* ── Heladero sabor editor ── */
.hp-sabor-row{display:flex;align-items:flex-start;gap:10px;padding:10px 12px;border-radius:12px;
  background:var(--smoke);border:1px solid var(--border);margin-bottom:8px;transition:all .2s}
.hp-sabor-row:hover{border-color:var(--teal);box-shadow:0 2px 8px rgba(0,0,0,.04)}
.hp-sabor-foto-btn{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:8px;
  background:var(--color-premium-wash);color:var(--color-premium);font-size:11px;font-weight:600;cursor:pointer;
  border:1px solid var(--color-premium-border);transition:all .2s;white-space:nowrap}
.hp-sabor-foto-btn:hover{background:var(--color-premium-pale);border-color:var(--color-premium-muted)}

/* ── Sabor image consistency (all views) ── */
.sabor-card-prem-img,.carta-sabor-img,.sabor-quick-icon{border-radius:10px;overflow:hidden}
.sabor-card-prem-img img,.carta-sabor-img img{width:100%;height:100%;object-fit:cover;border-radius:inherit}

/* ── Brand logo ── */
.brand-logo{height:28px;border-radius:4px;margin-left:auto;flex-shrink:0}

/* ══════════════════════════════════════════════════════════════
   GELATOMAPS SCORE — New scoring system components
   ══════════════════════════════════════════════════════════════ */

/* Score section container */
.gm-score-section{padding:16px 18px 12px;border-bottom:1px solid var(--border);background:linear-gradient(180deg,#FAFFFE 0%,#fff 100%)}

/* Score block */
.gm-score-block{display:flex;flex-direction:column;gap:6px}
.gm-score-block.gm-score-none{padding:8px 0}
.gm-score-main{display:flex;align-items:center;gap:10px}
.gm-score-bolas{display:flex;align-items:center;gap:2px;flex-shrink:0}
.gm-score-numbers{display:flex;align-items:baseline;gap:1px}
.gm-score-value{font-size:28px;font-weight:800;line-height:1;font-family:'DM Sans',sans-serif;letter-spacing:-.02em}
.gm-score-max{font-size:13px;font-weight:500;color:var(--mid)}
.gm-score-label{font-size:11px;font-weight:700;letter-spacing:.04em;margin-left:auto;
  padding:4px 12px;border-radius:20px;background:var(--smoke);white-space:nowrap}
.gm-score-google{display:flex;align-items:center;gap:5px;margin-top:4px;font-size:12px;color:var(--mid)}
.gm-score-google-star{color:var(--color-gold);font-size:14px}
.gm-score-google-val{font-weight:700;color:var(--navy);font-size:13px}
.gm-score-google-count{font-size:11px;color:var(--mid)}

/* Signals chips */
.gm-signals{display:flex;flex-wrap:wrap;gap:6px;margin-top:10px}
.gm-signal{display:inline-flex;align-items:center;gap:5px;padding:4px 10px 4px 4px;
  border-radius:20px;font-size:11px;font-weight:600;color:var(--navy);
  background:var(--color-white);border:1px solid var(--border);transition:all .15s}
.gm-signal:hover{border-color:var(--sig-color,var(--border));box-shadow:0 2px 8px rgba(0,0,0,.06)}
.gm-signal-icon{width:20px;height:20px;border-radius:50%;display:inline-flex;align-items:center;
  justify-content:center;font-size:11px;font-weight:800;color:var(--color-white);flex-shrink:0;letter-spacing:.02em}

/* Open/Closed badges */
.gm-open{display:inline-flex;align-items:center;gap:4px;padding:2px 10px;border-radius:12px;
  font-size:11px;font-weight:700;background:var(--color-success-pale);color:var(--color-success-dark);border:1px solid var(--color-success-light);
  margin-left:8px;vertical-align:middle;letter-spacing:.02em}
.gm-closed{display:inline-flex;align-items:center;gap:4px;padding:2px 10px;border-radius:12px;
  font-size:11px;font-weight:700;background:var(--color-error-bg);color:var(--color-error-border);border:1px solid var(--color-error-border);
  margin-left:8px;vertical-align:middle;letter-spacing:.02em}
.gm-next-change{font-size:11px;color:var(--mid);margin-left:4px;font-weight:500}

/* Horarios header with badge */
.gm-horarios-header{display:flex;align-items:center;gap:0}

/* ════════════════════════════════════════════════════════════════
   BOTTOM SHEET — Mobile panel (≤640px)
   Three states (Sprint 2):
     closed  → bottom:-100vh (no .open)
     half    → .open.half   — 40vh, muestra título + datos básicos
     full    → .open        — 72vh, detalle completo
   Pattern: Google Maps / TheFork mobile.
   ════════════════════════════════════════════════════════════════ */
@media(max-width:640px){
  /* Override base rule: slide up from bottom instead of from right */
  #panel,#panel.premium-mode{
    top:auto!important;
    bottom:-100vh!important;
    right:0!important;
    left:0!important;
    width:100%!important;
    max-width:100%!important;
    height:72vh;
    /* iOS safe area: add bottom padding for home indicator */
    padding-bottom:env(safe-area-inset-bottom,0px);
    border-radius:var(--radius-xl,24px) var(--radius-xl,24px) 0 0;
    border-left:none;
    box-shadow:0 -8px 40px rgba(11,31,56,.22),0 -2px 8px rgba(11,31,56,.08);
    /* Transition bottom instead of right */
    transition:bottom .32s cubic-bezier(.4,0,.2,1)!important;
  }
  #panel.open,#panel.premium-mode.open{
    bottom:0!important;
    right:0!important;
  }

  /* Drag handle pill — visual cue to swipe/dismiss */
  .pnl-drag-handle{
    display:flex;
    justify-content:center;
    align-items:center;
    padding:10px 0 4px;
    flex-shrink:0;
    /* Expand tap area for dismiss gesture */
    min-height:28px;
    cursor:grab;
  }
  .pnl-drag-handle::after{
    content:'';
    display:block;
    width:40px;height:4px;
    background:rgba(255,255,255,.22);
    border-radius:2px;
  }

  /* Close button: keep top-right but shift down for handle */
  .pnl-x{
    top:var(--sp-base,16px)!important;
    right:var(--sp-base,16px)!important;
    /* Increase tap area on mobile */
    width:44px!important;height:44px!important;
    font-size:18px!important;
  }

  /* Panel body: extra bottom padding for iOS home bar */
  #panel .pnl-body{
    padding-bottom:calc(72px + env(safe-area-inset-bottom,0px))!important;
  }

  /* ── State: half (40vh) — título + info básica visible, mapa en 60% ── */
  #panel.open.half{
    height:40vh;
    /* pnl-body scroll disabled en half para que el swipe up expanda */
    overflow:hidden;
  }

  /* ── Durante el drag: suprimir transición CSS para seguir el dedo ── */
  #panel.dragging{
    transition:none!important;
    /* Quitar shadow en drag: reduce el visual lag */
    box-shadow:0 -4px 20px rgba(11,31,56,.18)!important;
  }

  /* ── Geo FAB: botón de ubicación flotante sobre el mapa ── */
  #geoFab{
    position:fixed;
    right:12px;
    bottom:20px;
    z-index:450; /* sobre mapa (400), bajo panel (500) */
    width:48px;height:48px;
    border-radius:50%;
    background:var(--navy,#0B1F38);
    border:1.5px solid rgba(13,148,136,.45);
    color:var(--teal,#14B8A6);
    display:flex;align-items:center;justify-content:center;
    box-shadow:0 4px 18px rgba(0,0,0,.35);
    cursor:pointer;
    transition:bottom .32s cubic-bezier(.4,0,.2,1),
               background .15s, border-color .15s;
    touch-action:manipulation;
    -webkit-tap-highlight-color:transparent;
  }
  #geoFab:active{ background:rgba(13,148,136,.2); border-color:var(--teal,#14B8A6); }
  #geoFab.active{ background:var(--teal,#14B8A6); color:var(--color-white); border-color:var(--teal,#14B8A6); }
  /* When panel open: FAB moves above the panel */
  #geoFab.above-panel-full{ bottom:calc(72vh + 10px); }
  #geoFab.above-panel-half{ bottom:calc(40vh + 10px); }
}

/* ════════════════════════════════════════════════════════════════
   ACTION BUTTONS inside panel detail — Llamar / Web / Maps
   44px touch targets, teal outline style.
   ════════════════════════════════════════════════════════════════ */
#pnlDetailAct{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin:12px 0 4px;
}
.pnl-act-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:5px;
  min-height:44px;
  padding:10px 18px;
  border-radius:10px;
  background:rgba(255,255,255,.05);
  border:1.5px solid rgba(13,148,136,.35);
  color:var(--teal,#14B8A6);
  font-size:13px;
  font-weight:600;
  font-family:'DM Sans',sans-serif;
  text-decoration:none;
  transition:background .15s,border-color .15s,color .15s;
  touch-action:manipulation;
  -webkit-tap-highlight-color:transparent;
  cursor:pointer;
}
.pnl-act-btn:hover,.pnl-act-btn:active{
  background:rgba(13,148,136,.15);
  border-color:var(--teal,#14B8A6);
  color:var(--teal,#14B8A6);
}
/* Desktop: compactos */
@media(min-width:641px){
  .pnl-act-btn{ min-height:38px; padding:8px 14px; font-size:12px; }
  /* Geo FAB hidden on desktop — use header geo-btn */
  #geoFab{ display:none!important; }
}
