*{box-sizing:border-box}
html,body{width:100%;height:100%;margin:0;overflow:hidden;background:#111;color:#fff;font-family:Inter,system-ui,-apple-system,Segoe UI,sans-serif}
.restaurant-kiosk{width:100vw;height:100vh;position:relative;background:#111;isolation:isolate}
.loading-screen{height:100%;display:grid;place-content:center;text-align:center;gap:16px;background:#111;color:#fff}
.loading-screen strong{font-size:clamp(34px,6vw,82px);letter-spacing:.10em}.loading-screen span{font-size:clamp(16px,2vw,28px);color:#e8d6bd}
.slide{position:absolute;inset:0;opacity:0;transition:opacity .72s ease;overflow:hidden;background:#111}.slide.active{opacity:1}
.slide-bg{position:absolute;inset:0;z-index:0;background:#111}.slide-bg img{width:100%;height:100%;object-fit:cover;object-position:center;display:block;filter:saturate(1.10) contrast(1.03) brightness(1.08)}
.slide::before{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(0,0,0,.08) 0%,rgba(0,0,0,0) 28%,rgba(0,0,0,0) 72%,rgba(0,0,0,.08) 100%);pointer-events:none}.slide::after{display:none}
.kiosk-brand{position:absolute;top:clamp(18px,3vh,34px);left:clamp(24px,4vw,70px);right:clamp(24px,4vw,70px);display:flex;align-items:flex-start;justify-content:space-between;gap:18px;z-index:5;min-width:0;pointer-events:none}.kiosk-brand .restaurant-logo{display:block;max-width:min(300px,24vw);max-height:clamp(56px,9vh,92px);object-fit:contain;filter:drop-shadow(0 5px 14px rgba(0,0,0,.45))}.kiosk-brand strong{font-size:clamp(24px,3vw,52px);font-weight:900;line-height:1.02;max-width:min(620px,44vw);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:#fff;text-shadow:0 4px 16px rgba(0,0,0,.55)}.kiosk-brand span{font-size:clamp(13px,1.1vw,20px);color:#fff;white-space:nowrap;text-shadow:0 2px 10px rgba(0,0,0,.35);background:rgba(0,0,0,.24);padding:.32em .66em;border-radius:999px;backdrop-filter:blur(3px)}
.slide-content{position:absolute;right:clamp(26px,4vw,76px);bottom:clamp(42px,6vh,70px);width:min(360px,26vw);z-index:4;padding:clamp(13px,1.15vw,20px);border-radius:clamp(14px,1.5vw,24px);background:rgba(0,0,0,.40);border:1px solid rgba(255,255,255,.18);box-shadow:0 15px 44px rgba(0,0,0,.26);backdrop-filter:blur(4px);max-height:52vh;overflow:hidden}.slide-content h1,.slide-content h2{margin:0 0 clamp(6px,.8vh,10px);font-size:clamp(22px,2vw,38px);line-height:1.04;font-weight:900;letter-spacing:-.035em;text-wrap:balance;overflow-wrap:anywhere;color:#fff;text-shadow:0 2px 10px rgba(0,0,0,.34)}.slide-content p{max-width:520px;font-size:clamp(13px,1vw,19px);line-height:1.20;color:rgba(255,255,255,.92);margin:0;text-shadow:0 2px 8px rgba(0,0,0,.28)}.price{display:inline-flex;align-self:flex-start;margin-top:clamp(9px,1.2vh,16px);background:rgba(0,0,0,.68);color:#fff;border:1px solid rgba(255,255,255,.18);border-radius:999px;padding:clamp(6px,.8vh,9px) clamp(12px,1.3vw,20px);font-size:clamp(16px,1.45vw,25px);font-weight:900;box-shadow:0 9px 22px rgba(0,0,0,.20);letter-spacing:-.03em}.kiosk-badge{display:inline-flex;align-items:center;gap:7px;margin-bottom:clamp(7px,.8vh,10px);border:1px solid rgba(255,255,255,.20);background:rgba(0,0,0,.22);border-radius:999px;padding:5px 10px;color:#fde8c8;font-size:clamp(9px,.68vw,12px);font-weight:900;letter-spacing:.08em;text-transform:uppercase}.kiosk-badge::before{content:"";width:6px;height:6px;border-radius:999px;background:#22c55e}
.menu-slide .slide-content{right:clamp(24px,4vw,70px);bottom:clamp(108px,14vh,150px);width:min(340px,24vw);max-height:42vh}.menu-slide .slide-content h2{font-size:clamp(22px,1.85vw,34px)}.menu-slide .slide-content p{font-size:clamp(12px,.95vw,17px)}
.daily-list{position:absolute;left:clamp(22px,4vw,70px);bottom:clamp(18px,3vh,34px);width:min(640px,44vw);display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:clamp(7px,.7vw,11px);z-index:4;pointer-events:none}.daily-box{background:rgba(0,0,0,.38);border:1px solid rgba(255,255,255,.16);backdrop-filter:blur(4px);border-radius:clamp(11px,1vw,16px);padding:clamp(7px,.75vw,11px);box-shadow:0 9px 24px rgba(0,0,0,.18);min-height:0}.daily-box h3{text-transform:uppercase;letter-spacing:.11em;color:#ffd9a3;font-size:clamp(8px,.62vw,11px);margin:0 0 5px}.daily-box p{font-size:clamp(10px,.72vw,13px);margin:3px 0;color:rgba(255,255,255,.92);line-height:1.10;font-weight:800}.daily-box:empty{display:none}.menu-slide .daily-list{right:auto}
.photo-slide .slide-bg img,.cover-slide .slide-bg img{filter:saturate(1.10) contrast(1.03) brightness(1.08)}.photo-slide::before,.cover-slide::before{background:linear-gradient(180deg,rgba(0,0,0,.08),rgba(0,0,0,0) 36%,rgba(0,0,0,.06))}.photo-slide .slide-content{right:clamp(26px,4vw,76px);bottom:clamp(42px,6vh,70px);top:auto;transform:none;width:min(350px,25vw)}.photo-slide .slide-content h2{font-size:clamp(22px,2vw,38px)}
.footer-info,.slide-count,.kiosk-footer,.kiosk-slogan{display:none!important}.kiosk-progress{position:absolute;left:0;right:0;bottom:0;height:4px;background:rgba(255,255,255,.20);z-index:20}.kiosk-progress span{display:block;height:100%;width:0;background:linear-gradient(90deg,#f97316,#22c55e,#38bdf8);animation:progressBar var(--slide-duration,8s) linear infinite}
@keyframes progressBar{from{width:0}to{width:100%}}
@media(max-width:1200px){.slide-content,.photo-slide .slide-content,.menu-slide .slide-content{width:min(360px,36vw);right:24px}.daily-list{grid-template-columns:repeat(2,minmax(0,1fr));width:min(400px,38vw)}}
@media(max-width:760px){.kiosk-brand{flex-direction:column;align-items:flex-start;gap:8px}.kiosk-brand .restaurant-logo{max-width:220px;max-height:70px}.kiosk-brand strong{max-width:88vw}.slide::before,.menu-slide::before,.photo-slide::before,.cover-slide::before{background:rgba(0,0,0,.08)}.slide-content,.photo-slide .slide-content,.menu-slide .slide-content{left:18px;right:18px;width:auto;bottom:48px;padding:14px;max-height:50vh}.daily-list{display:none}.price{font-size:20px}}


/* v33: restaurante demo mas limpia, plato protagonista y QR */
.slide-bg img{filter:saturate(1.12) contrast(1.04) brightness(1.06)!important}
.slide::before{background:linear-gradient(180deg,rgba(0,0,0,.04),rgba(0,0,0,0) 42%,rgba(0,0,0,.05))!important}
.kiosk-brand{top:clamp(16px,2.6vh,30px);left:clamp(20px,3.2vw,62px);right:clamp(20px,3.2vw,62px)}
.kiosk-brand .restaurant-logo{max-width:min(230px,18vw);max-height:clamp(48px,7vh,74px)}
.kiosk-brand strong{font-size:clamp(22px,2.4vw,42px)}
.kiosk-brand span{font-size:clamp(12px,.95vw,17px);background:rgba(0,0,0,.28)}
.slide-content{right:clamp(28px,4vw,76px);bottom:clamp(94px,12vh,132px);width:min(310px,22vw);padding:clamp(11px,1vw,16px);border-radius:clamp(12px,1.3vw,20px);background:rgba(0,0,0,.48);border-color:rgba(255,255,255,.16);box-shadow:0 12px 34px rgba(0,0,0,.22);backdrop-filter:blur(3px);max-height:42vh}
.slide-content h1,.slide-content h2{font-size:clamp(20px,1.62vw,30px);line-height:1.04;margin-bottom:6px;color:#fff;text-shadow:0 2px 8px rgba(0,0,0,.36)}
.slide-content p{font-size:clamp(12px,.86vw,16px);line-height:1.18;color:rgba(255,255,255,.9)}
.kiosk-badge{font-size:clamp(8px,.55vw,10px);padding:4px 8px;margin-bottom:7px;background:rgba(0,0,0,.24)}
.price{font-size:clamp(14px,1.16vw,21px);padding:6px 13px;margin-top:10px;background:rgba(0,0,0,.72)}
.menu-slide .slide-content{right:clamp(24px,4vw,72px);bottom:clamp(108px,14vh,150px);width:min(300px,21vw);max-height:38vh}
.menu-slide .slide-content h2{font-size:clamp(20px,1.48vw,28px)}
.menu-slide .slide-content p{font-size:clamp(11px,.78vw,15px)}
.daily-list{left:clamp(18px,3.2vw,58px);bottom:clamp(18px,2.8vh,32px);width:min(560px,38vw);gap:clamp(6px,.55vw,9px)}
.daily-box{background:rgba(0,0,0,.44);border-color:rgba(255,255,255,.14);border-radius:14px;padding:8px;box-shadow:0 8px 18px rgba(0,0,0,.16)}
.daily-box h3{font-size:clamp(7px,.52vw,9px);margin-bottom:4px}
.daily-box p{font-size:clamp(9px,.62vw,11px);line-height:1.08;margin:2px 0}
.kiosk-qr{position:absolute;right:clamp(18px,2.5vw,42px);bottom:clamp(18px,2.5vh,34px);z-index:8;width:clamp(82px,7.2vw,122px);padding:6px;border-radius:14px;background:rgba(255,255,255,.90);box-shadow:0 8px 24px rgba(0,0,0,.24);text-align:center;color:#111;pointer-events:none}
.kiosk-qr img{display:block;width:100%;height:auto;border-radius:8px}.kiosk-qr span{display:block;margin-top:3px;font-size:clamp(8px,.62vw,11px);font-weight:900;line-height:1;color:#1b1b1b}
.footer-info,.slide-count,.kiosk-footer,.kiosk-slogan{display:none!important}
@media(max-width:1200px){.slide-content,.photo-slide .slide-content,.menu-slide .slide-content{width:min(320px,34vw);right:22px}.daily-list{width:min(420px,42vw);grid-template-columns:repeat(2,minmax(0,1fr))}.kiosk-qr{width:86px}}
@media(max-width:760px){.slide-content,.photo-slide .slide-content,.menu-slide .slide-content{left:18px;right:18px;width:auto;bottom:104px}.kiosk-qr{width:84px;right:18px;bottom:12px}.daily-list{display:none}}

/* v34: encuadre configurable por fotografia */
.slide-bg{overflow:hidden}.slide-bg img{object-fit:var(--img-fit,cover);object-position:var(--img-x,50%) var(--img-y,50%);transform:scale(var(--img-zoom,1));transform-origin:var(--img-x,50%) var(--img-y,50%)}

/* v35: QR compacto arriba derecha y sin segunda caja de texto */
.kiosk-qr{
  top:clamp(66px,9.4vh,112px)!important;
  right:clamp(34px,4vw,70px)!important;
  bottom:auto!important;
  width:clamp(82px,6.4vw,116px)!important;
  padding:5px!important;
  border-radius:12px!important;
  background:rgba(255,255,255,.92)!important;
  border:1px solid rgba(0,0,0,.10)!important;
  box-shadow:0 10px 26px rgba(0,0,0,.24)!important;
  z-index:9!important;
}
.kiosk-qr img{display:block;width:100%;height:auto;border-radius:8px}
.kiosk-qr span{display:none!important}
.slide-content{right:clamp(28px,4vw,76px);bottom:clamp(48px,7vh,82px)}
.menu-slide .slide-content{right:clamp(28px,4vw,76px);bottom:clamp(54px,8vh,90px)}
@media(max-width:760px){.kiosk-qr{top:auto!important;right:16px!important;bottom:16px!important;width:82px!important}}

/* v39: logo restaurante mas visible en TV y movil */
.kiosk-brand .restaurant-logo{
  max-width:min(320px,22vw)!important;
  max-height:clamp(66px,10vh,110px)!important;
}

@media(max-width:1200px){
  .kiosk-brand .restaurant-logo{
    max-width:min(280px,28vw)!important;
    max-height:clamp(62px,9vh,98px)!important;
  }
}

@media(max-width:760px){
  .kiosk-brand{
    top:12px!important;
    left:14px!important;
    right:14px!important;
  }
  .kiosk-brand .restaurant-logo{
    max-width:min(190px,56vw)!important;
    max-height:74px!important;
  }
  .kiosk-brand span{
    font-size:12px!important;
  }
}

@media(max-width:420px){
  .kiosk-brand .restaurant-logo{
    max-width:170px!important;
    max-height:68px!important;
  }
}


/* v42: usa el mismo color de configuracion para barra superior y zona inferior movil */
:root{--mobile-browser-ui-color:#111111}
html,body{background:var(--mobile-browser-ui-color,#111111)!important}
body::after{
  content:"";
  position:fixed;
  left:0;
  right:0;
  bottom:0;
  height:max(env(safe-area-inset-bottom,0px),0px);
  background:var(--mobile-browser-ui-color,#111111);
  z-index:999999;
  pointer-events:none;
}
.restaurant-kiosk{
  min-height:100dvh;
  background:var(--mobile-browser-ui-color,#111111);
  padding-bottom:env(safe-area-inset-bottom,0px);
}
@supports(padding:max(0px)){
  .restaurant-kiosk{padding-bottom:max(env(safe-area-inset-bottom,0px),0px)}
}

/* v96: restaurante - QR mas grande arriba y sin etiqueta/recuadro de texto */
.restaurant-kiosk .kiosk-qr{
  top:clamp(34px,5vh,58px)!important;
  right:clamp(34px,4vw,70px)!important;
  bottom:auto!important;
  width:clamp(128px,9vw,168px)!important;
  padding:6px!important;
  border-radius:16px!important;
  background:rgba(255,255,255,.96)!important;
  border:0!important;
  box-shadow:0 12px 30px rgba(0,0,0,.26)!important;
  z-index:12!important;
  color:transparent!important;
}
.restaurant-kiosk .kiosk-qr img{
  display:block!important;
  width:100%!important;
  height:auto!important;
  border-radius:10px!important;
}
.restaurant-kiosk .kiosk-qr span,
.restaurant-kiosk .kiosk-qr::before,
.restaurant-kiosk .kiosk-qr::after{
  display:none!important;
  content:none!important;
}
@media(max-width:1200px){
  .restaurant-kiosk .kiosk-qr{
    width:clamp(118px,10vw,150px)!important;
    top:clamp(28px,4.5vh,50px)!important;
  }
}
@media(max-width:760px){
  .restaurant-kiosk .kiosk-qr{
    top:18px!important;
    right:18px!important;
    bottom:auto!important;
    width:104px!important;
    padding:5px!important;
  }
}
