/* =========================================
   Base
========================================= */
*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent}
:root{
  --bg-app:#000;
  --bg-card:#fff;
  --bg-soft:#f8f9fa;
  --tx-strong:#111827;
  --tx:#1a1d29;
  --tx-muted:#6b7280;
  --tx-subtle:#9ca3af;
  --brand:#1652f0;
  --shadow-sm:0 1px 3px rgba(16,24,40,.08),0 1px 2px rgba(16,24,40,.06);
  --shadow-md:0 4px 16px rgba(16,24,40,.12);
  --shadow-lg:0 12px 32px rgba(16,24,40,.18);
  --radius:14px;
  --radius-sm:10px;
  --radius-lg:16px;
  --border:rgba(17,24,39,.06);
}
body{font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,'Helvetica Neue',Arial,sans-serif;background:var(--bg-app);color:var(--tx);min-height:100vh;overflow-x:hidden}
.app-container{max-width:430px;margin:0 auto;background:var(--bg-app);min-height:100vh;position:relative}

/* =========================================
   Top Bar
========================================= */
.top-bar{
  position:fixed;top:0;left:50%;transform:translateX(-50%);
  width:100%;max-width:430px;z-index:50;display:flex;align-items:center;justify-content:space-between;
  padding:16px 20px;background:var(--bg-app)
}
.menu-button{
  width:44px;height:44px;border-radius:10px;border:1px solid rgba(255,255,255,.18);
  background:rgba(255,255,255,.10);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:.2s
}
.menu-button:hover{background:rgba(255,255,255,.18)}
.hamburger{display:flex;flex-direction:column;gap:2px}
.hamburger span{width:16px;height:2px;background:#fff;border-radius:1px}
.app-title{font-size:20px;font-weight:700;color:#fff;letter-spacing:-.02em}

/* =========================================
   Lang dropdown
========================================= */
.lang-dropdown{position:relative}
.lang-button{
  display:flex;align-items:center;gap:8px;padding:8px 12px;border:1px solid rgba(255,255,255,.18);
  border-radius:10px;background:rgba(255,255,255,.10);color:#fff;cursor:pointer;transition:.2s;font-weight:600;font-size:13px
}
.lang-button:hover{background:rgba(255,255,255,.18)}
.lang-dropdown-menu{
  position:absolute;top:100%;right:0;margin-top:8px;background:#fff;border-radius:12px;
  box-shadow:var(--shadow-lg);border:1px solid var(--border);min-width:160px;opacity:0;visibility:hidden;transform:translateY(-8px);
  transition:.2s;z-index:1000;overflow:hidden
}
.lang-dropdown.active .lang-dropdown-menu{opacity:1;visibility:visible;transform:translateY(0)}
.lang-option{display:flex;gap:12px;align-items:center;padding:12px 14px;cursor:pointer;border-bottom:1px solid #f1f5f9;font-size:14px;font-weight:600}
.lang-option:hover{background:#f8fafc}
.lang-option:last-child{border-bottom:none}
.lang-option.selected{background:#eaf2ff;color:var(--brand)}
.lang-flag{font-size:18px}
.lang-arrow{width:14px;height:14px;transition:.2s}
.lang-dropdown.active .lang-arrow{transform:rotate(180deg)}

/* =========================================
   Avatar
========================================= */
.avatar-panel{height:55vh;background:var(--bg-app);position:relative;overflow:hidden;margin-top:76px;display:flex;flex-direction:column}
.avatar-stage{flex:1;display:flex;align-items:center;justify-content:center;position:relative;z-index:2}
.avatar-container{position:relative;width:100%;height:100%;user-select:none;-webkit-user-select:none}
.avatar-layer{position:absolute;inset:0}
.avatar-video{width:100%;height:100%;object-fit:cover;object-position:center -100px;display:block}
.avatar-video.hidden{display:none}
.avatar-placeholder{display:none !important}

/* =========================================
   Mic button
========================================= */
.talk-button-container{position:fixed;bottom:90px;right:20px;z-index:1001}
.talk-button{
  position:relative;display:grid;place-items:center;width:58px;height:58px;border-radius:50%;
  background:#0a84ff;color:#fff;border:none;cursor:pointer;box-shadow:0 8px 22px rgba(10,132,255,.35);
  transition:transform .2s ease, box-shadow .2s ease, background .2s ease;outline:none;
}
.talk-button:hover{ transform:scale(1.06); box-shadow:0 12px 30px rgba(10,132,255,.45); }
.talk-button:active{ transform:scale(.96); }
.mic-icon{ width:22px;height:22px; }
.talk-button.listening{
  animation:listen-breathe 1.6s ease-in-out infinite;
}
.talk-button.listening::before,.talk-button.listening::after{
  content:"";position:absolute;inset:-8px;border-radius:50%;border:2px solid rgba(10,132,255,.35);animation:listen-ripple 1.6s ease-in-out infinite;
}
.talk-button.listening::after{ inset:-16px;animation-delay:.3s;border-color:rgba(10,132,255,.22); }
@keyframes listen-breathe{ 0%,100%{transform:scale(1)} 50%{transform:scale(1.04)} }
@keyframes listen-ripple{ 0%{opacity:.65;transform:scale(.92)} 70%{opacity:.15;transform:scale(1.12)} 100%{opacity:0;transform:scale(1.18)} }

/* =========================================
   Map
========================================= */
.map-section{display:none;height:220px;position:relative;overflow:hidden;background:var(--bg-soft)}
#googleMap{width:100%;height:100%}
.map-loading{position:absolute;inset:0;background:linear-gradient(135deg,#dbeafe,#bfdbfe);display:flex;align-items:center;justify-content:center;z-index:10;transition:.3s}
.map-loading.hidden{opacity:0;pointer-events:none}
.map-loading-content{text-align:center;color:var(--brand)}
.map-loading-icon{font-size:44px;margin-bottom:10px;animation:map-pulse 2s ease-in-out infinite}
@keyframes map-pulse{0%,100%{opacity:.85}50%{opacity:1}}
.map-controls{position:absolute;top:10px;right:10px;z-index:20;display:flex;gap:8px}
.map-control-btn{
  width:36px;height:36px;background:#fff;border:1px solid var(--border);border-radius:10px;display:flex;align-items:center;justify-content:center;
  cursor:pointer;box-shadow:var(--shadow-sm);transition:.15s;font-size:14px
}
.map-control-btn:hover{background:#f8f9fa;transform:translateY(-1px)}
.map-control-btn:active{transform:scale(.97)}

/* =========================================
   Content + Chat
========================================= */
.content-section{background:#fff;min-height:40vh;position:relative;padding-bottom:100px}
.chat-view{padding:16px 20px 10px;border-bottom:1px solid var(--border);background:#fff}
.chat-header-row{display:flex;align-items:center;gap:10px;margin-bottom:10px}
.angela-dot{width:10px;height:10px;border-radius:50%;background:#22c55e;animation:pulse-dot 2s infinite}
@keyframes pulse-dot{0%,100%{opacity:1}50%{opacity:.55}}
.chat-messages{max-height:180px;overflow-y:auto;display:flex;flex-direction:column;gap:10px;padding-right:4px}
.message{max-width:85%;padding:12px 14px;border-radius:16px;font-size:14px;line-height:1.35}
.message.angela{background:#fff;color:var(--tx);align-self:flex-start;border:1px solid var(--border);box-shadow:0 1px 2px rgba(0,0,0,.03)}
.message.user{background:var(--brand);color:#fff;align-self:flex-end}
.chat-hint{color:var(--tx-muted);font-size:12px;margin-top:6px}

/* Composer (input + botón) */
.chat-composer{display:flex;gap:8px;align-items:center;margin-top:8px}
.chat-input{
  flex:1;padding:10px 12px;border-radius:10px;
  border:1px solid #e5e7eb;background:#fff;color:#111827;
  font-size:14px;outline:none;transition:.15s
}
.chat-input:focus{border-color:var(--brand);box-shadow:0 0 0 3px rgba(22,82,240,.12)}
.chat-send{white-space:nowrap}

/* Header */
.content-header{background:#fff;padding:20px 20px 12px;border-bottom:1px solid var(--border)}
.header-row{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:6px}
.content-title{font-size:22px;font-weight:800;color:var(--tx-strong);letter-spacing:-.02em}
.location-badge{
  background:#eaf2ff;color:var(--brand);padding:4px 10px;border-radius:999px;font-size:12px;font-weight:700;display:flex;align-items:center;gap:6px
}
.content-subtitle{color:var(--tx-muted);font-size:13px;margin-top:6px}

/* =========================================
   Browse Controls (chips 2k/5k/Ciudad)
========================================= */
#browseControls{
  padding:10px 20px 6px;background:#fff;border-bottom:1px solid var(--border);
  position:sticky; top:0; z-index:10;
}
.filter-bar{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:4px}
.chip{
  appearance:none;border:none;outline:none;cursor:pointer;padding:8px 12px;border-radius:999px;font-size:12px;font-weight:700;
  background:#f3f4f6;color:#374151;border:1px solid #e5e7eb;transition:.15s
}
.chip:hover{background:#eef2ff;border-color:#c7d2fe}
.chip.active{background:var(--brand);color:#fff;border-color:var(--brand);box-shadow:0 2px 10px rgba(22,82,240,.18)}
.hint{font-size:12px;color:var(--tx-muted);margin-top:2px}

/* =========================================
   Recommendation list
========================================= */
.recommendations-list{padding:16px 16px 20px}
.recommendation-item{
  display:flex;align-items:center;gap:12px;padding:14px;border-radius:14px;margin-bottom:12px;
  background:#fff;border:1px solid transparent;box-shadow:var(--shadow-sm);
  transition:transform .12s ease, box-shadow .12s ease, background .2s ease;
}
.recommendation-item:hover{transform:translateY(-1px);box-shadow:var(--shadow-md)}
.item-thumb{flex:0 0 auto;width:64px;height:64px;border-radius:12px;overflow:hidden;background:#f3f4f6}
.item-thumb img{width:100%;height:100%;object-fit:cover;display:block}
.item-content{flex:1;min-width:0}
.item-name{font-size:16px;font-weight:800;color:var(--tx-strong);letter-spacing:-.01em;margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.item-details{display:flex;align-items:center;gap:10px;font-size:13px;color:#6b7280}
.item-rating{display:flex;align-items:center;gap:4px;color:#f59e0b}
.item-arrow{width:18px;height:18px;color:#c0c4cc}

/* =========================================
   Buttons
========================================= */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:8px 12px;border-radius:10px;font-size:13px;font-weight:700;
  text-decoration:none;cursor:pointer;border:1px solid #e5e7eb;background:#fff;color:#1f2937;transition:.15s
}
.btn:hover{background:#f9fafb;transform:translateY(-1px)}
.btn.primary{background:var(--brand);color:#fff;border-color:var(--brand);box-shadow:0 2px 10px rgba(22,82,240,.18)}
.btn.primary:hover{filter:brightness(1.05)}
.btn.danger{background:#ef4444;color:#fff;border-color:#ef4444}
.btn.warning{background:#f59e0b;color:#fff;border-color:#f59e0b}
.btn.block{width:100%}
.btn.sm{padding:6px 10px;font-size:12px}
.btn.icon{width:36px;height:36px;padding:0}

/* =========================================
   Modal (detalles con carrusel)
========================================= */
.modal{position:fixed;inset:0;z-index:1100;display:flex;align-items:center;justify-content:center}
.modal.hidden{pointer-events:none}
.modal-backdrop{position:absolute;inset:0;background:rgba(0,0,0,.45);backdrop-filter:blur(3px)}
.modal-card{
  position:relative;z-index:1;width:92%;max-width:420px;max-height:84vh;overflow:auto;background:#fff;
  border-radius:16px;box-shadow:var(--shadow-lg);padding:14px 14px 18px;border:1px solid var(--border);animation:modal-in .16s ease-out both;
}
@keyframes modal-in{from{transform:translateY(6px);opacity:0}to{transform:translateY(0);opacity:1}}
.modal-close{
  position:absolute;top:8px;right:8px;width:32px;height:32px;border-radius:10px;border:1px solid #e5e7eb;background:#fff;cursor:pointer;
  font-size:16px;display:grid;place-items:center;color:#1f2937;transition:.15s;box-shadow:var(--shadow-sm)
}
.modal-close:hover{background:#f8f9fa;transform:scale(1.05)}
.modal-title{font-size:18px;font-weight:800;color:var(--tx-strong);margin:2px 34px 2px 2px;letter-spacing:-.01em}
.modal-sub{font-size:13px;color:var(--tx-muted);margin-bottom:10px}

/* Carrusel */
.carousel{
  position:relative;background:#f3f4f6;border-radius:12px;overflow:hidden;margin-bottom:12px;border:1px solid var(--border);box-shadow:var(--shadow-sm)
}
.car-viewport{width:100%;display:block}
.car-viewport img{
  width:100%;height:auto;aspect-ratio:16/9;object-fit:cover;display:block
}
.car-btn{
  position:absolute;top:50%;transform:translateY(-50%);border:none;cursor:pointer;width:34px;height:34px;border-radius:999px;
  background:rgba(255,255,255,.95);border:1px solid rgba(0,0,0,.08);box-shadow:var(--shadow-sm);font-size:18px;display:grid;place-items:center;transition:.15s;z-index:2
}
.car-btn:hover{transform:translateY(-50%) scale(1.06)}
.car-btn.left{left:8px}
.car-btn.right{right:8px}

/* Acciones / reseñas / data */
.details-actions{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:8px}
.reviews{margin-top:6px}
.reviews-title{font-size:14px;font-weight:800;color:var(--tx-strong);margin-bottom:6px}
.review{padding:10px;border:1px solid var(--border);border-radius:10px;background:#fafafa;margin-bottom:8px}
.review .rv-hd{font-size:12px;color:var(--tx-strong);margin-bottom:4px}
.review .rv-tx{font-size:13px;color:#4b5563}

/* =========================================
   Asistencia
========================================= */
.assist-grid{display:grid;gap:12px;padding:16px 20px;grid-template-columns:1fr}
@media (min-width:420px){ .assist-grid{grid-template-columns:1fr 1fr} }
.assist-card{background:#fff;border:1px solid transparent;border-radius:14px;padding:14px;display:flex;flex-direction:column;gap:10px;box-shadow:var(--shadow-sm)}
.assist-title{font-size:16px;font-weight:800;color:var(--tx-strong)}
.assist-desc{font-size:13px;color:var(--tx-muted)}
.assist-note{font-size:12px;color:var(--tx-muted)}

/* =========================================
   Hotel
========================================= */
.hotel-form{padding:16px 20px;display:flex;flex-direction:column;gap:10px}
.hotel-form label{font-size:12px;color:var(--tx-muted);margin-bottom:4px}
.hotel-form input{
  width:100%;padding:10px 12px;border-radius:10px;border:1px solid #e5e7eb;outline:none;background:#fff;color:#111827;font-size:14px;transition:.15s
}
.hotel-form input:focus{border-color:var(--brand);box-shadow:0 0 0 3px rgba(22,82,240,.12)}
.grid-2{display:grid;gap:10px;grid-template-columns:1fr 1fr}
.actions{display:flex;gap:8px;flex-wrap:wrap}

/* =========================================
   Bottom menu
========================================= */
.bottom-menu{
  position:fixed;bottom:0;left:0;right:0;height:78px;background:rgba(248,249,250,.96);backdrop-filter:blur(20px);
  border-top:1px solid var(--border);z-index:1000;padding:8px 0
}
.menu-scroll-container{height:100%;overflow-x:auto;overflow-y:hidden;display:flex;align-items:center;padding:0 16px;scroll-behavior:smooth;scrollbar-width:none;-ms-overflow-style:none}
.menu-scroll-container::-webkit-scrollbar{display:none}
.menu-items{display:flex;gap:12px;align-items:center;min-width:max-content}
.menu-item{
  display:flex;flex-direction:column;align-items:center;text-align:center;padding:8px 14px;border-radius:12px;background:#fff;border:1px solid var(--border);
  cursor:pointer;transition:.15s;min-width:78px;text-decoration:none;color:#444;box-shadow:var(--shadow-sm)
}
.menu-item.active{background:var(--brand);color:#fff;border-color:var(--brand);box-shadow:0 6px 16px rgba(22,82,240,.25)}
.menu-item:hover{transform:translateY(-1px)}
.menu-icon{font-size:18px;margin-bottom:4px}
.menu-text{font-size:11px;font-weight:800;letter-spacing:-.2px}

/* =========================================
   Side Menu
========================================= */
.side-menu-overlay{position:fixed;inset:0;background:rgba(0,0,0,.5);opacity:0;visibility:hidden;transition:.25s;z-index:100}
.side-menu-overlay.active{opacity:1;visibility:visible}
.side-menu{position:fixed;top:0;left:-100%;width:85%;max-width:320px;height:100vh;background:#fff;transition:left .25s cubic-bezier(.4,0,.2,1);z-index:101;overflow-y:auto;box-shadow:var(--shadow-lg)}
.side-menu.active{left:0}
.side-menu-header{padding:24px 20px;background:var(--brand);color:#fff}
.side-menu-title{font-size:20px;font-weight:800;margin-bottom:4px}
.side-menu-subtitle{font-size:14px;opacity:.95}
.menu-section{margin-bottom:20px}
.menu-section-title{padding:8px 20px;font-size:12px;font-weight:800;color:var(--tx-muted);text-transform:uppercase;letter-spacing:.05em}
.side-menu-item{display:flex;align-items:center;padding:12px 20px;color:var(--tx);text-decoration:none;font-size:16px;font-weight:700;transition:background .15s}
.side-menu-item:hover{background:#f8f9fa}
.side-menu-item-icon{margin-right:16px;width:20px;height:20px;color:#6b7280}

/* =========================================
   Dev console
========================================= */
.console-toggle{
  position:fixed;bottom:90px;left:20px;width:50px;height:50px;border-radius:50%;background:#0a84ff;border:none;color:#fff;font-size:18px;cursor:pointer;
  box-shadow:0 6px 18px rgba(10,132,255,.35);transition:.25s;z-index:1001;display:flex;align-items:center;justify-content:center
}
.console-toggle:hover{transform:scale(1.08)}
.console-toggle.active{background:#ff6b6b;transform:rotate(45deg)}
.dev-console{position:fixed;bottom:-400px;left:0;right:0;height:400px;background:#1e1e1e;border-top:1px solid #333;transition:bottom .25s;z-index:200;display:flex;flex-direction:column}
.dev-console.active{bottom:0}
.console-header{display:flex;align-items:center;justify-content:space-between;padding:8px 16px;background:#2d2d2d;border-bottom:1px solid #333;font-size:12px;color:#ccc}
.console-content{flex:1;overflow-y:auto;padding:8px;font-family:Menlo,Monaco,Consolas,monospace;font-size:11px;line-height:1.4}
.console-input-area{border-top:1px solid #333;padding:8px 16px;background:#252526;display:flex;gap:8px;align-items:center}
.console-prompt{color:#569cd6;font-weight:bold}
.console-input{flex:1;background:transparent;border:none;color:#d4d4d4;font-family:inherit;font-size:11px;outline:none}
.console-message{margin-bottom:4px;white-space:pre-wrap;word-break:break-word}
.console-message.info{color:#d4d4d4}
.console-message.warn{color:#dcdcaa}
.console-message.error{color:#f48771}
.console-message.success{color:#4ec9b0}
.console-message.system{color:#569cd6}
.console-message .timestamp{color:#6a6a6a;margin-right:8px}

/* =========================================
   Utilities & responsive
========================================= */
.hidden{display:none !important}
@media (max-width:430px){
  .app-container{max-width:100%}
  .top-bar{max-width:100%;left:0;transform:none}
  .console-toggle{bottom:85px;left:15px;width:45px;height:45px}
  .talk-button-container{bottom:85px;right:15px}
  .talk-button{width:54px;height:54px}
  .mic-icon{width:22px;height:22px}
  .dev-console{height:350px;bottom:-350px}
}
@media (max-height:700px){.avatar-panel{height:50vh}.map-section{height:180px}}
@media (min-width:431px){
  .app-container{border-radius:12px;margin:20px auto;min-height:calc(100vh - 40px);overflow:hidden}
  .top-bar{border-radius:12px 12px 0 0}
  .modal-card{max-height:76vh}
}

/* === Suavizado de cards y expansión inline ============================== */

/* La fila clickeable de la card (sin aspecto de botón nativo) */
.item-row{
  display:flex; align-items:center; gap:12px; width:100%;
  background:transparent; border:none; padding:0; text-align:left;
}
.item-row:focus{ outline:none }

/* Card base (muy suave) */
.recommendation-item{
  border:1px solid var(--border);
  background:#fff;
  box-shadow: var(--shadow-sm);
  border-radius: var(--radius);
}

/* Subtítulo (dirección) */
.item-sub{
  font-size:12px; color:var(--tx-subtle); margin-top:4px;
  white-space:nowrap; overflow:hidden; text-overflow:ellipsis;
}

/* Zona expandida (debajo de la card, empuja hacia abajo) */
.item-detail{
  margin-top:10px;
  padding:12px;
  background:#fafbff;
  border:1px solid #e6e9ef;
  border-radius:12px;
}
.item-detail.hidden{ display:none !important; }

.detail-inner{ display:flex; flex-direction:column; gap:10px; }

/* Carrusel acorde a tu estilo */
.detail-photos .carousel{
  border:1px solid var(--border);
  background:#f3f4f6;
  border-radius:12px;
  box-shadow: var(--shadow-sm);
}
.detail-photos .car-viewport img{
  width:100%; height:auto; aspect-ratio:16/9; object-fit:cover; display:block;
}
.car-btn{ width:34px; height:34px; }

/* Acción/links y horario */
.detail-meta{
  display:flex; gap:8px; flex-wrap:wrap; align-items:center; margin-bottom:6px;
}
.btn.btn-xs{
  padding:6px 8px; font-size:12px; border-radius:8px;
}
.hours-list{
  list-style:none; margin:6px 0 0; padding:0;
  font-size:12px; color:var(--tx-muted);
}
.hours-list li{ margin:2px 0 }

/* Resumen GPT */
.detail-summary{ font-size:13px; color:var(--tx); }

/* Prompt de modo (más sutil) */
.mode-prompt{ padding:24px 16px; text-align:center; }
.mode-prompt h3{
  font-size:18px; font-weight:800; color:var(--tx-strong); margin-bottom:8px; letter-spacing:-.01em;
}
.mode-prompt p{ font-size:14px; color:var(--tx-muted); margin-bottom:14px; }
.mode-prompt .actions{ display:flex; flex-direction:column; gap:10px; align-items:center; }

/* ==== Layout de card en columna (detalle debajo, independiente) ==== */
.recommendations-list .recommendation-item{
  display:block;
  padding:14px;
}

/* Fila interna clickeable con el layout horizontal de la card */
.item-row{
  display:flex; align-items:center; gap:12px; width:100%;
  background:transparent; border:none; padding:0; text-align:left;
}
.item-row:focus{ outline:none }

/* Miniatura estandarizada */
.item-thumb{ width:64px; height:64px; border-radius:12px; overflow:hidden; background:#f3f4f6; flex:0 0 auto; }
.item-thumb img{ width:100%; height:100%; object-fit:cover; display:block; }

/* Subtítulo (dirección) */
.item-sub{
  font-size:12px; color:var(--tx-subtle); margin-top:4px;
  white-space:nowrap; overflow:hidden; text-overflow:ellipsis;
}

/* Flecha sutil: apuntando hacia abajo al abrir (rotación) */
.item-arrow{ width:18px; height:18px; color:#b9bfca; flex:0 0 auto; transition:.15s transform; }
.recommendation-item.open .item-arrow{ transform:rotate(180deg); }

/* Bloque de detalle: aparece debajo sin modificar la altura de la fila */
.item-detail{
  margin-top:10px;
  padding:12px;
  background:#fafbff;
  border:1px solid #e6e9ef;
  border-radius:12px;
}
.item-detail.hidden{ display:none !important; }
.detail-inner{ display:flex; flex-direction:column; gap:10px; }

/* Carrusel dentro del detalle */
.detail-photos .carousel{
  border:1px solid var(--border);
  background:#f3f4f6;
  border-radius:12px;
  box-shadow: var(--shadow-sm);
}
.detail-photos .car-viewport img{
  width:100%; height:auto; aspect-ratio:16/9; object-fit:cover; display:block;
}
.carousel-btn, .car-btn{ width:34px; height:34px; }

/* Meta/acciones/horario/resumen */
.detail-meta{ display:flex; gap:8px; flex-wrap:wrap; align-items:center; margin-bottom:6px; }
.btn.btn-xs{ padding:6px 8px; font-size:12px; border-radius:8px; }
.hours-list{ list-style:none; margin:6px 0 0; padding:0; font-size:12px; color:var(--tx-muted); }
.hours-list li{ margin:2px 0 }
.detail-summary{ font-size:13px; color:var(--tx); }

/* Prompt de modo, suave */
.mode-prompt{ padding:24px 16px; text-align:center; }
.mode-prompt h3{ font-size:18px; font-weight:800; color:var(--tx-strong); margin-bottom:8px; letter-spacing:-.01em; }
.mode-prompt p{ font-size:14px; color:var(--tx-muted); margin-bottom:14px; }
.mode-prompt .actions{ display:flex; flex-direction:column; gap:10px; align-items:center; }

/* ==== Carrusel móvil (estructura .carousel > .carousel-track > .carousel-slide) ==== */
.carousel{
  position:relative;
  width:100%;
  border-radius:12px;
  overflow:hidden;
  background:#f3f4f6;
  border:1px solid var(--border);
  box-shadow: var(--shadow-sm);
}
.carousel-track{ display:flex; width:100%; transition: transform .2s ease; will-change: transform; }
.carousel-slide{
  min-width:100%; block-size:auto; aspect-ratio:16/9;
  display:grid; place-items:center; background:#eef1f5;
}
.carousel-slide img{ width:100%; height:100%; object-fit:cover; display:block; }
.carousel-btn{
  position:absolute; top:50%; transform:translateY(-50%);
  width:34px; height:34px; border:none; cursor:pointer; border-radius:999px;
  background:rgba(255,255,255,.95); border:1px solid rgba(0,0,0,.08);
  box-shadow:var(--shadow-sm); font-size:18px; display:grid; place-items:center; transition:.15s; z-index:2;
}
.carousel-btn:hover{ transform:translateY(-50%) scale(1.06) }
.carousel-btn.prev{ left:8px }
.carousel-btn.next{ right:8px }

/* Mensaje vacío */
.carousel-empty{
  width:100%; padding:16px; text-align:center; font-size:13px; color:var(--tx-muted);
  background:#fafafa; border:1px dashed #e5e7eb; border-radius:12px;
}

/* Ajuste para pantallas más pequeñas */
@media (max-width:380px){
  .carousel-slide{ aspect-ratio: 4/3; }
}
/* Audio controls */
.audio-ctrl{ display:flex; align-items:center; gap:8px; margin-left:8px; }
.audio-btn{
  width:36px;height:36px;border-radius:10px;border:1px solid rgba(255,255,255,.18);
  background:rgba(255,255,255,.10);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;
  transition:.2s;font-size:16px
}
.audio-btn:hover{ background:rgba(255,255,255,.18); }
.audio-btn.muted{ opacity:.65; }
.audio-range{
  -webkit-appearance:none; appearance:none; width:120px; height:6px; border-radius:6px;
  background:rgba(255,255,255,.25); outline:none;
}
.audio-range::-webkit-slider-thumb{
  -webkit-appearance:none; appearance:none; width:16px; height:16px; border-radius:50%;
  background:#fff; border:1px solid rgba(0,0,0,.15);
}
