body{margin:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;background:#0b1220;color:#fff} .wrap{max-width:960px;margin:0 auto;padding:24px} .card{background:#111a2e;border-radius:16px;padding:16px;margin:12px 0} a{color:#7dd3fc} button{padding:10px 14px;border-radius:12px;border:0;background:#0ea5e9;color:#001018;font-weight:700;cursor:pointer} input{padding:10px 12px;border-radius:12px;border:1px solid rgba(255,255,255,.12);background:#0b1220;color:#fff;width:100%}
.wrap.df-centered{min-height:80vh;display:flex;flex-direction:column;justify-content:center}
.wrap.df-centered h1{margin-bottom:14px}
 *{box-sizing:border-box} #df-wrap label{max-width:100%} #df-wrap select{max-width:100%} #df-wrap .card{max-width:100%} 
/* DineFlow Modifiers UI (minimal pro) */
.df-mod-group{background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.10);border-radius:16px;padding:12px 12px;margin-top:12px}
.df-mod-head{display:flex;align-items:center;justify-content:space-between;gap:10px}
.df-mod-title{font-weight:800}
.df-mod-meta{opacity:.72;font-size:12px;white-space:nowrap}
.df-mod-head-right{display:flex;align-items:center;gap:10px}
.df-mod-toggle{width:34px;height:30px;border-radius:12px;border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.03);color:var(--df-text-color,#e5e7eb);display:inline-flex;align-items:center;justify-content:center;cursor:pointer}
.df-mod-toggle:active{transform:scale(.99)}
.df-mod-chevron{display:inline-block;transition:transform .14s ease;opacity:.9;font-size:14px;line-height:1}
.df-mod-group.is-open .df-mod-chevron{transform:rotate(180deg)}
.df-mod-body{margin-top:10px}
.df-mod-group:not(.is-open) .df-mod-body{display:none}
.df-mod-list{display:flex;flex-direction:column;gap:8px}
.df-mod-option{display:flex;align-items:center;gap:10px;padding:12px 12px;border-radius:14px;border:1px solid rgba(255,255,255,.10);background:rgba(255,255,255,.02);cursor:pointer;transition:transform .08s ease,border-color .12s ease,background .12s ease}
.df-mod-option:active{transform:scale(.99)}
.df-mod-option.is-selected{border-color:var(--df-button-bg,var(--df-primary));background:rgba(14,165,233,.1)}
.df-mod-bullet{width:18px;height:18px;border-radius:999px;border:2px solid rgba(255,255,255,.28);display:inline-flex;align-items:center;justify-content:center;flex:0 0 auto}
.df-mod-option.is-selected .df-mod-bullet{border-color:var(--df-button-bg,var(--df-primary));box-shadow:0 0 0 4px rgba(14,165,233,.15) inset}
.df-mod-check{width:10px;height:10px;border-radius:3px;background:var(--df-button-bg,var(--df-primary));opacity:0;transform:scale(.85);transition:opacity .12s ease,transform .12s ease}
.df-mod-option.is-selected .df-mod-check{opacity:1;transform:scale(1)}
.df-mod-label{flex:1 1 auto;min-width:0;line-height:1.15;color:inherit}
.df-mod-price{opacity:.8;font-size:12px;padding:4px 8px;border:1px solid rgba(255,255,255,.10);border-radius:999px;white-space:nowrap}
.df-mod-select{width:100%;padding:12px 12px;border-radius:14px;border:1px solid rgba(255,255,255,.12);background:var(--df-bg-color,#0b1220);color:var(--df-text-color,#e5e7eb)}

/* ========== App layout (mobile-first) ========== */
:root{--df-brand:#0ea5e9;--df-primary:var(--df-brand);--df-button-bg:var(--df-primary);--df-button-color:#001018;--df-text-color:#e5e7eb;--df-bg-color:#0b1220;--df-bg-image:none;--df-font:system-ui,-apple-system,Segoe UI,Roboto,Inter,Arial,sans-serif;--df-radius:14px;--df-secondary-bg:#1e293b}
.df-btn-primary{padding:10px 16px;border-radius:var(--df-radius,14px);background:var(--df-button-bg,var(--df-primary));color:var(--df-button-color);font-weight:700;border:0;cursor:pointer;min-height:44px}
.df-btn-secondary{padding:10px 16px;border-radius:var(--df-radius,14px);background:var(--df-secondary-bg);color:var(--df-text-color);font-weight:600;border:0;cursor:pointer}
.df-app{min-height:100vh;display:flex;flex-direction:column;font-family:var(--df-font);color:var(--df-text-color);background-color:var(--df-bg-color);background-image:var(--df-bg-image);background-size:cover;background-position:center}
.df-header{position:sticky;top:0;z-index:100;display:flex;align-items:center;gap:12px;padding:14px 18px;background:#0f172a;border-bottom:1px solid rgba(255,255,255,.08);-webkit-tap-highlight-color:transparent}
.df-header__title{font-weight:800;font-size:18px;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.df-header__lang{display:flex;gap:4px;flex-shrink:0}
.df-lang-btn{padding:6px 12px;border-radius:10px;border:1px solid rgba(255,255,255,.2);background:rgba(255,255,255,.06);color:var(--df-text-color,#e5e7eb);font-weight:700;font-size:12px;cursor:pointer}
.df-lang-btn:hover{background:rgba(255,255,255,.1)}
.df-lang-btn.is-active{background:var(--df-button-bg,var(--df-primary));color:var(--df-button-color);border-color:transparent}
.df-header__order{opacity:.85;font-size:13px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:140px}
.df-header__cart-btn{flex-shrink:0;display:inline-flex;align-items:center;gap:8px;padding:12px 16px;border-radius:14px;background:var(--df-button-bg,var(--df-primary));color:var(--df-button-color);font-weight:700;cursor:pointer;border:0;min-height:44px}
.df-header__cart-btn:disabled{opacity:.7;cursor:not-allowed}
.df-header__cart-badge{display:inline-flex;align-items:center;justify-content:center;min-width:22px;height:22px;padding:0 6px;border-radius:999px;background:var(--df-button-color);color:var(--df-button-bg,var(--df-primary));font-size:12px;font-weight:800}
.df-main{flex:1;padding:16px 18px;padding-bottom:88px}
.df-view{display:none;animation:df-fadeIn .2s ease}
.df-view.is-active{display:block}
@keyframes df-fadeIn{from{opacity:0}to{opacity:1}}

/* Bottom bar */
.df-bottom-bar{position:fixed;bottom:0;left:0;right:0;max-width:820px;margin:0 auto;z-index:99;display:flex;gap:12px;padding:14px 18px;background:#111a2e;border-top:1px solid rgba(255,255,255,.08);-webkit-tap-highlight-color:transparent}
.df-bottom-bar__cart,.df-bottom-bar__submit{padding:16px 20px;border-radius:14px;font-weight:800;font-size:16px;cursor:pointer;border:0;min-height:52px;flex:1}
.df-bottom-bar__cart{background:rgba(255,255,255,.08);color:var(--df-text-color)}
.df-bottom-bar__submit{background:var(--df-button-bg,var(--df-primary));color:var(--df-button-color)}
.df-bottom-bar__submit:disabled{opacity:.6;cursor:not-allowed}

/* ========== Menu view ========== */
.df-menu__section-nav{display:flex;gap:8px;overflow-x:auto;padding:0 0 10px;margin-bottom:4px;border-bottom:1px solid rgba(255,255,255,.1);-webkit-overflow-scrolling:touch;scrollbar-width:none}
.df-menu__section-nav::-webkit-scrollbar{display:none}
.df-menu__section-tab{padding:10px 14px;border-radius:10px;border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.04);color:#fff;font-weight:700;white-space:nowrap;cursor:pointer;flex-shrink:0;font-size:14px}
.df-menu__section-tab.is-active{background:var(--df-button-bg,var(--df-primary));color:var(--df-button-color);border-color:transparent}
.df-menu__recommended{margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid rgba(255,255,255,.1)}
.df-menu__recommended-title{font-size:18px;font-weight:800;margin:0 0 12px;opacity:.95}
.df-menu__home-module{margin-bottom:24px;padding-bottom:18px;border-bottom:1px solid rgba(255,255,255,.1)}
.df-menu__home-module-title{font-size:18px;font-weight:800;margin:0 0 12px;opacity:.95}
.df-menu__ver-mas{margin-top:12px;padding:10px 18px;border-radius:12px;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);color:var(--df-text-color);font-weight:700;cursor:pointer}
.df-menu__ver-mas:hover{background:var(--df-button-bg,var(--df-primary));color:var(--df-button-color);border-color:transparent}
.df-menu__especiales{margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid rgba(255,255,255,.1)}
.df-menu__especiales-title{font-size:18px;font-weight:800;margin:0 0 12px;opacity:.95}
.df-menu__especiales-carousel{display:flex;gap:12px;overflow-x:auto;padding:8px 0;-webkit-overflow-scrolling:touch;scrollbar-width:none}
.df-menu__especiales-carousel::-webkit-scrollbar{display:none}
.df-menu__especiales-slide{flex:0 0 auto;border-radius:14px;overflow:hidden;border:2px solid rgba(255,255,255,.12);background:rgba(255,255,255,.04);padding:0;cursor:pointer;display:block;scroll-snap-align:start}
.df-menu__especiales-slide:hover{border-color:var(--df-button-bg,var(--df-primary));}
.df-menu__especiales-slide-img{width:100%;height:100%;object-fit:cover;display:block}
.df-menu__especiales-slide-fallback{display:flex;align-items:center;justify-content:center;width:100%;height:100%;padding:10px;font-size:13px;font-weight:700;text-align:center;line-height:1.2}
/* 1 slide: full width, aspect 1366/500 (banner) — imagen completa sin recortar */
.df-menu__especiales-carousel--slides-1{scroll-snap-type:x mandatory}
.df-menu__especiales-carousel--slides-1 .df-menu__especiales-slide{width:calc(100% - 16px);min-width:calc(100% - 16px);height:auto;aspect-ratio:1366/500}
.df-menu__especiales-carousel--slides-1 .df-menu__especiales-slide-img{object-fit:contain;background:rgba(0,0,0,.15)}
/* 2 slides: half width each */
.df-menu__especiales-carousel--slides-2 .df-menu__especiales-slide{width:160px;height:160px}
.df-menu__especiales-carousel--slides-2{scroll-snap-type:x mandatory}
@media (min-width:480px){
.df-menu__especiales-carousel--slides-2 .df-menu__especiales-slide{width:calc(50vw - 24px);min-width:200px;height:auto;aspect-ratio:1}
}
.df-menu__tabs{display:flex;gap:8px;overflow-x:auto;padding:8px 0 12px;-webkit-overflow-scrolling:touch;scrollbar-width:none}
.df-menu__tabs::-webkit-scrollbar{display:none}
.df-menu__tab{padding:10px 16px;border-radius:12px;border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.04);color:#fff;font-weight:700;white-space:nowrap;cursor:pointer;flex-shrink:0}
.df-menu__tab.is-active{background:var(--df-button-bg,var(--df-primary));color:var(--df-button-color);border-color:transparent}
.df-menu__list{display:flex;flex-direction:column;gap:14px;margin-top:8px}
.df-menu__list--grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
.df-menu__list--grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.df-menu__list--card-image-top .df-menu-card{flex-direction:column;align-items:stretch}
.df-menu__list--card-image-top .df-menu-card__img-wrap{width:100%;order:-1;min-height:0;aspect-ratio:16/10}
.df-menu__list--card-image-left .df-menu-card{flex-direction:row}
.df-menu__list--grid-2 .df-menu-card,.df-menu__list--grid-3 .df-menu-card{flex-direction:column;align-items:stretch}
.df-menu__list--grid-2 .df-menu-card__img-wrap,.df-menu__list--grid-3 .df-menu-card__img-wrap{width:100%;order:-1;min-height:0;aspect-ratio:16/10}
.df-menu-card{background:#111a2e;border:1px solid rgba(255,255,255,.08);border-radius:16px;padding:14px;display:flex;gap:14px;align-items:flex-start}
.df-menu-card__body{flex:1;min-width:0}
.df-menu-card__title{font-weight:800;font-size:16px;margin:0 0 4px}
.df-menu-card__desc{opacity:.8;font-size:13px;line-height:1.35;margin:0}
.df-menu-card__chips{display:flex;flex-wrap:wrap;gap:6px;margin:6px 0 4px}
.df-chip{display:inline-block;padding:4px 10px;border-radius:999px;font-size:11px;font-weight:600;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.12)}
.df-chip--allergen{background:rgba(251,191,36,.15);border-color:rgba(251,191,36,.3)}
.df-menu-card__kcal{opacity:.85;font-size:12px;margin-top:4px}
.df-menu-card__price{font-weight:800;color:var(--df-primary,#0ea5e9);margin-top:8px}
.df-menu-card__add{flex-shrink:0;padding:12px 18px;border-radius:14px;background:var(--df-button-bg,var(--df-primary));color:var(--df-button-color);font-weight:800;border:0;cursor:pointer;min-height:44px}
.df-menu-card__add:disabled{opacity:.6;cursor:not-allowed}
.df-menu-card__img-wrap{flex-shrink:0;width:100px;min-height:80px;border-radius:12px;overflow:hidden;background:rgba(255,255,255,.06)}
.df-menu-card__img{display:block;width:100%;height:100%;object-fit:cover;aspect-ratio:1}
@media (max-width:480px){
  /* Respeta "Grid en móvil" y "Card imagen izquierda": solo imagen arriba cuando NO es card-image-left */
  .df-menu-card{flex-wrap:wrap}
  .df-menu__list--card-image-left .df-menu-card{flex-wrap:nowrap}
  .df-menu__list:not(.df-menu__list--card-image-left) .df-menu-card__img-wrap{width:100%;order:-1;min-height:0;aspect-ratio:16/10}
}

/* ========== Item detail view ========== */
.df-detail-back{margin-bottom:14px;padding:10px 14px;border-radius:12px;border:1px solid rgba(255,255,255,.14);background:rgba(255,255,255,.06);color:var(--df-text-color);font-weight:700;cursor:pointer}
.df-detail-card{padding:16px}
.df-detail__img-wrap{width:100%;border-radius:14px;overflow:hidden;background:rgba(255,255,255,.06);margin-bottom:14px}
.df-detail__img{display:block;width:100%;height:auto;max-height:min(70vh,560px);object-fit:contain;vertical-align:top}
.df-detail__title{font-size:22px;font-weight:800;margin:0 0 10px}
.df-detail__desc{opacity:.9;line-height:1.5;margin-bottom:12px;white-space:pre-wrap}
.df-detail__price{font-weight:800;color:var(--df-primary,#0ea5e9);font-size:18px;margin-bottom:12px}
.df-detail__section{margin-top:16px;padding-top:14px;border-top:1px solid rgba(255,255,255,.08)}
.df-detail__section-title{font-weight:700;font-size:14px;margin-bottom:8px;opacity:.9}
.df-detail__chips{display:flex;flex-wrap:wrap;gap:6px}
.df-detail__chips .df-chip{font-size:12px;padding:6px 12px}
.df-detail__nutrition{display:flex;flex-wrap:wrap;gap:12px;font-size:13px;opacity:.9}
.df-detail__nutrition span{padding:4px 0}
.df-detail__ingredients{font-size:14px;line-height:1.5;opacity:.9}
.df-detail__section--includes .df-detail__includes-item{margin-bottom:12px;padding:10px 12px;border-radius:10px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.06)}
.df-detail__section--includes .df-detail__includes-item:last-child{margin-bottom:0}
.df-detail__includes-item-title{font-weight:700;font-size:14px;margin-bottom:6px}
.df-detail__includes-modifiers{font-size:12px;opacity:.85;line-height:1.4}
.df-detail__includes-mod-line{margin-top:4px;padding-left:8px;border-left:2px solid rgba(255,255,255,.12)}
.df-detail__actions .df-menu-card__add{background:var(--df-button-bg,var(--df-primary));color:var(--df-button-color)}

/* ========== Cart view (grouped by status) ========== */
.df-view--cart #df-refresh{display:none !important}
.df-view--cart #df-waiting-approval:empty{display:none}
.df-cart__section{margin-bottom:20px}
.df-cart__section-title{font-weight:800;font-size:14px;opacity:.9;margin-bottom:10px;text-transform:uppercase;letter-spacing:.04em}
.df-cart-item{border-top:1px solid rgba(255,255,255,.08);padding:12px 0;display:flex;justify-content:space-between;gap:12px;align-items:flex-start}
.df-cart-item__info{flex:1;min-width:0}
.df-cart-item__name{font-weight:700}
.df-cart-item__meta{opacity:.75;font-size:12px;margin-top:4px}
.df-cart-item__total{font-weight:700;flex-shrink:0}
.df-cart-item__actions{display:flex;align-items:center;gap:8px;margin-top:8px}
.df-cart-totals{margin-top:16px;padding-top:14px;border-top:1px solid rgba(255,255,255,.12);font-weight:800;font-size:16px}
.df-cart-empty,.df-status-empty{text-align:center;padding:32px 20px;opacity:.85}
.df-cart-empty p,.df-status-empty p{margin:0 0 8px}

/* ========== Host panel (vertical) ========== */
#df-host{padding:16px}
#df-host > div:first-child{display:none} /* Hide old inline "Host" label; renderHost() provides the layout */
#df-hostlabel{display:flex;flex-direction:column;gap:8px}
.df-host-panel__name{font-weight:900;font-size:15px;opacity:.98;line-height:1.25}
.df-host-panel__meta{opacity:.72;font-size:12px;line-height:1.2}
.df-host-panel__total{margin-top:2px;padding:10px 12px;border-radius:14px;background:rgba(14,165,233,.12);border:1px solid rgba(14,165,233,.35);font-weight:900;font-size:18px;color:var(--df-primary,#0ea5e9)}

/* ========== Status view (stepper) ========== */
.df-status-stepper{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:20px 0}
.df-status-step{flex:1;display:flex;flex-direction:column;align-items:center;gap:6px;position:relative}
.df-status-step::before{content:"";position:absolute;top:14px;left:50%;right:-50%;height:2px;background:rgba(255,255,255,.15);z-index:0}
.df-status-step:last-child::before{display:none}
.df-status-step.is-done::before,.df-status-step.is-current::before{background:var(--df-primary,#0ea5e9)}
.df-status-step__dot{width:28px;height:28px;border-radius:999px;background:rgba(255,255,255,.12);border:2px solid rgba(255,255,255,.2);position:relative;z-index:1;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:800}
.df-status-step.is-done .df-status-step__dot{background:var(--df-button-bg,var(--df-primary));border-color:var(--df-button-bg,var(--df-primary));color:var(--df-button-color)}
.df-status-step.is-current .df-status-step__dot{background:rgba(255,255,255,.12);border-color:var(--df-primary,#0ea5e9);color:var(--df-text-color)}
.df-status-step__label{font-size:12px;font-weight:700;opacity:.9;text-align:center;max-width:80px}

/* ========== Add-item modal (from menu) ========== */
.df-add-modal{overflow-y:auto;-webkit-overflow-scrolling:touch;color:var(--df-text-color)}
.df-add-modal .df-mod-group{margin-top:10px}
.df-app #df-add-modal>div,.df-app #df-modal>div,.df-app #df-alert>div{background:var(--df-bg-color,#0f172a);color:var(--df-text-color);border-color:rgba(255,255,255,.12)}
.df-app .card{background:var(--df-bg-color,#111a2e);color:var(--df-text-color)}
.df-app .df-header,.df-app .df-bottom-bar{background:var(--df-bg-color,#0f172a);border-color:rgba(255,255,255,.08)}
.df-app .df-menu-card{background:var(--df-bg-color,#111a2e)}

/* ========== Toast ========== */
#df-toast{font-size:14px;font-weight:700;text-align:center}

/* ========== Skeleton / loading ========== */
.df-skeleton{background:linear-gradient(90deg,rgba(255,255,255,.06) 25%,rgba(255,255,255,.12) 50%,rgba(255,255,255,.06) 75%);background-size:200% 100%;animation:df-skeleton 1.2s ease-in-out infinite;border-radius:12px}
@keyframes df-skeleton{0%{background-position:200% 0}100%{background-position:-200% 0}}
.df-spinner{width:32px;height:32px;border:3px solid rgba(255,255,255,.15);border-top-color:var(--df-primary,#0ea5e9);border-radius:999px;animation:df-spin .7s linear infinite;margin:20px auto}
@keyframes df-spin{to{transform:rotate(360deg)}}

/* ========== Utility ========== */
.df-hidden{display:none !important}
.df-btn-danger{background:rgba(239,68,68,.2);color:#fecaca;border:1px solid rgba(239,68,68,.35)}

/* ========== Mode selector modal ========== */
.df-mode-modal{max-width:520px;width:100%;background:var(--df-bg-color,#0f172a);color:var(--df-text-color);border-radius:18px;padding:18px;border:1px solid rgba(255,255,255,.16);box-shadow:0 20px 60px rgba(0,0,0,.6)}
.df-mode-modal__title{margin:0 0 6px;font-size:18px;font-weight:800}
.df-mode-modal__desc{margin:0 0 14px;opacity:.85;font-size:13px}
.df-mode-modal__grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.df-mode-modal__btn{padding:12px 14px;border-radius:14px;border:1px solid rgba(255,255,255,.16);background:rgba(255,255,255,.04);color:var(--df-text-color);font-weight:700;cursor:pointer;text-align:left}
.df-mode-modal__btn--ghost{background:transparent}
.df-mode-modal__btn:active{transform:scale(.99)}

.df-mode-banner{margin:10px 0 4px;padding:10px 12px;border-radius:12px;border:1px solid rgba(56,189,248,.45);background:rgba(8,47,73,.7);font-size:13px;opacity:.95}

/* ========== Mode classes (tokens) ========== */
.df-mode-dinein{--df-brand:#0ea5e9}
.df-mode-delivery{--df-brand:#22c55e}
.df-mode-togo{--df-brand:#f97316}
.df-mode-visitor{--df-brand:#6b7280}
