*{box-sizing:border-box}html,body{margin:0;height:100%;font-family:Inter,system-ui,-apple-system,Segoe UI,sans-serif;background:#04141b;color:#fff;overflow:hidden}.dental-kiosk{position:fixed;inset:0;background:#051820}.loading-screen{height:100%;display:grid;place-content:center;text-align:center;gap:10px}.slide{position:absolute;inset:0;opacity:0;transition:opacity .8s ease;overflow:hidden}.slide.active{opacity:1}.slide-bg{position:absolute;inset:0;z-index:0}.slide-bg img{width:100%;height:100%;object-fit:cover;filter:saturate(1.05) contrast(1.02)}.slide:after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(2,12,18,.12),rgba(2,12,18,.10) 46%,rgba(2,12,18,.35));z-index:1;pointer-events:none}.clinic-logo{position:absolute;z-index:3;left:4vw;top:5vh;width:min(320px,20vw);border-radius:18px;box-shadow:0 18px 50px rgba(0,0,0,.24)}.tag{position:absolute;right:4vw;top:5vh;z-index:3;background:rgba(3,30,42,.72);padding:12px 22px;border-radius:999px;font-weight:900}.qr{position:absolute;right:4.5vw;top:12vh;z-index:3;background:#fff;border-radius:18px;padding:12px;box-shadow:0 20px 50px rgba(0,0,0,.25)}.qr img{width:130px;height:130px;display:block}.panel{position:absolute;z-index:3;right:5vw;bottom:9vh;width:min(500px,31vw);border-radius:26px;padding:24px 26px;background:rgba(5,18,25,.62);backdrop-filter:blur(14px);border:1px solid rgba(255,255,255,.18);box-shadow:0 20px 55px rgba(0,0,0,.28)}.badge{display:inline-block;border-radius:999px;background:rgba(255,255,255,.12);padding:6px 13px;color:#bffcff;text-transform:uppercase;letter-spacing:.08em;font-size:.68rem;font-weight:900}.panel h1{font-size:clamp(1.75rem,3.1vw,3.9rem);line-height:.96;margin:16px 0 10px;letter-spacing:-.04em}.panel p{font-size:clamp(.92rem,1.05vw,1.22rem);line-height:1.28;margin:0 0 14px;color:#eefcff}.price{display:inline-block;background:linear-gradient(135deg,#15d8df,#2d75ff);padding:10px 18px;border-radius:999px;font-size:clamp(1rem,1.35vw,1.65rem);font-weight:950}.progress{position:absolute;left:0;bottom:0;height:5px;background:#2ee9ff;z-index:4;animation:grow var(--slide-duration,9s) linear forwards}@keyframes grow{from{width:0}to{width:100%}}
.mobile-user-html,.mobile-user-html body{height:auto;min-height:100%;overflow-y:auto}.mobile-user-page{background:linear-gradient(160deg,#03131a,#064054 58%,#ecfeff);color:#061923;font-family:Inter,system-ui,sans-serif}.mobile-landing{max-width:680px;margin:auto;padding:14px}.mobile-index{position:sticky;top:0;z-index:5;display:flex;gap:8px;background:rgba(4,23,32,.88);padding:8px;border-radius:18px;backdrop-filter:blur(10px)}.mobile-index a{flex:1;text-align:center;color:#fff;text-decoration:none;font-weight:900;background:rgba(255,255,255,.1);border-radius:12px;padding:11px}.mobile-hero-card,.mobile-card{margin-top:14px;border-radius:24px;padding:20px;background:rgba(255,255,255,.86);box-shadow:0 20px 60px rgba(0,0,0,.18)}.mobile-hero-top{display:grid;grid-template-columns:110px 1fr;gap:16px;align-items:start}.mobile-hero-top img{width:110px;border-radius:14px}.mobile-kicker,.mobile-section-title span{font-size:.75rem;text-transform:uppercase;letter-spacing:.1em;color:#0685a0;font-weight:950}.mobile-hero-top h1,.mobile-section-title h2{margin:6px 0;font-size:2rem;line-height:.95}.mobile-actions{display:grid;gap:10px;margin-top:18px}.mobile-main-button,.mobile-link-button{display:block;text-align:center;text-decoration:none;border-radius:16px;padding:15px;font-weight:950;color:#061923;background:linear-gradient(135deg,#35f3e6,#2d75ff)}.mobile-main-button.alt{background:linear-gradient(135deg,#62ffa8,#35f3e6)}.mobile-link-button{background:#073040;color:#fff}.mobile-price-list{display:grid;gap:10px}.service-row-card a{display:block;text-decoration:none;color:#061923;border-radius:16px;background:#f1fbff;padding:14px;border:1px solid #c8eff6}.service-row-card span{display:block;color:#0d7c94;font-weight:900;font-size:.78rem;text-transform:uppercase}.service-row-card strong{display:block;font-size:1.05rem}.service-row-card b{display:block;margin-top:8px;color:#087384}.booking-form form{display:grid;gap:12px}.booking-form input,.booking-form select,.booking-form textarea{width:100%;padding:13px;border:1px solid #a7dbe5;border-radius:12px}.booking-form button{border:0;border-radius:16px;padding:15px;font-weight:950;background:#0ad3e5}.mobile-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.mobile-message{padding:12px;border-radius:12px;background:#dff8e8}.mobile-message.error{background:#ffe0e0}
@media(max-width:800px){html,body{overflow:hidden}.clinic-logo{width:210px}.panel{width:72vw;right:5vw;bottom:7vh;padding:18px;border-radius:22px}.panel h1{font-size:clamp(1.55rem,8vw,2.5rem)}.panel p{font-size:.9rem}.qr{top:15vh}.tag{font-size:.9rem}.mobile-user-html,.mobile-user-html body{overflow-y:auto}}

/* Cliente movil: debe poder desplazarse siempre aunque el kiosko de TV sea fijo */
html.mobile-user-html,
html.mobile-user-html body,
body.mobile-user-page{
  height:auto !important;
  min-height:100dvh !important;
  overflow-x:hidden !important;
  overflow-y:auto !important;
  position:static !important;
}
body.mobile-user-page{
  -webkit-overflow-scrolling:touch;
  padding-bottom:max(24px, env(safe-area-inset-bottom, 0px));
}
.mobile-section-card{scroll-margin-top:86px;}

/* v64 - pagina cliente dental independiente y con scroll real */
html.dental-client-html,
html.dental-client-html body,
body.dental-client-page{
  height:auto !important;
  min-height:100dvh !important;
  overflow-x:hidden !important;
  overflow-y:auto !important;
  position:static !important;
}
body.dental-client-page{
  margin:0;
  color:#071923;
  background:
    radial-gradient(circle at 20% 0%, rgba(61, 238, 255, .22), transparent 28%),
    linear-gradient(160deg, #021018 0%, #063445 48%, #e8fbff 100%);
  font-family:Inter,system-ui,-apple-system,Segoe UI,sans-serif;
  -webkit-overflow-scrolling:touch;
  padding-bottom:max(28px, env(safe-area-inset-bottom, 0px));
}
.client-tabs{
  position:sticky;
  top:0;
  z-index:50;
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:8px;
  max-width:720px;
  margin:0 auto;
  padding:10px;
  background:rgba(3, 19, 27, .88);
  backdrop-filter:blur(12px);
  border-bottom-left-radius:18px;
  border-bottom-right-radius:18px;
  box-shadow:0 10px 30px rgba(0,0,0,.18);
}
.client-tabs a{
  display:block;
  color:#fff;
  text-align:center;
  text-decoration:none;
  font-weight:950;
  padding:12px 8px;
  border-radius:13px;
  background:rgba(255,255,255,.11);
}
.client-wrap{
  width:min(720px, 100%);
  margin:0 auto;
  padding:14px;
}
.client-hero,
.client-card{
  margin-top:14px;
  border-radius:26px;
  padding:20px;
  background:rgba(255,255,255,.9);
  border:1px solid rgba(255,255,255,.65);
  box-shadow:0 24px 70px rgba(0,0,0,.2);
}
.client-hero{
  background:linear-gradient(145deg, rgba(255,255,255,.92), rgba(223,250,255,.9));
}
.client-hero-head{
  display:grid;
  grid-template-columns:112px 1fr;
  gap:16px;
  align-items:start;
}
.client-hero-head img{
  width:112px;
  max-height:90px;
  object-fit:contain;
  border-radius:15px;
  background:#062532;
  padding:8px;
}
.client-hero-head span,
.client-section-title span{
  display:block;
  color:#0387a1;
  font-size:.74rem;
  font-weight:950;
  letter-spacing:.12em;
  text-transform:uppercase;
}
.client-hero h1,
.client-section-title h2{
  margin:6px 0 8px;
  font-size:clamp(1.85rem, 8vw, 2.8rem);
  line-height:.96;
  letter-spacing:-.045em;
}
.client-hero p,
.client-section-title p{
  margin:0;
  color:#315160;
  font-size:1rem;
  line-height:1.35;
}
.client-actions{
  display:grid;
  gap:10px;
  margin-top:18px;
}
.client-button{
  display:block;
  text-align:center;
  text-decoration:none;
  border-radius:16px;
  padding:15px;
  font-weight:950;
}
.client-button.primary{background:linear-gradient(135deg,#33f0e8,#2b77ff);color:#041923;}
.client-button.secondary{background:linear-gradient(135deg,#67ffb2,#32e8f0);color:#041923;}
.client-button.dark{background:#062b37;color:#fff;}
.client-phone,
.client-message,
.client-selected{
  margin:14px 0 0;
  padding:12px 14px;
  border-radius:14px;
  background:#effbff;
  color:#0d3440;
}
.client-message.success{background:#dff8e8;color:#0d5631;}
.client-message.error{background:#ffe4e4;color:#8a1010;}
.client-service-list{
  display:grid;
  gap:12px;
  margin-top:16px;
}
.client-service{
  display:block;
  text-decoration:none;
  color:#071923;
  padding:15px;
  border-radius:17px;
  background:linear-gradient(145deg,#f5fdff,#e9f9fd);
  border:1px solid #bfe9f2;
  box-shadow:0 10px 26px rgba(0,80,110,.08);
}
.client-service span{
  display:block;
  color:#0a8aa3;
  font-weight:950;
  font-size:.76rem;
  text-transform:uppercase;
  letter-spacing:.08em;
}
.client-service strong{
  display:block;
  margin-top:4px;
  font-size:1.08rem;
  line-height:1.15;
}
.client-service small{
  display:block;
  margin-top:5px;
  color:#46606b;
}
.client-service b{
  display:inline-block;
  margin-top:10px;
  padding:7px 10px;
  border-radius:999px;
  background:#06313e;
  color:#fff;
}
.client-booking form{
  display:grid;
  gap:12px;
  margin-top:16px;
}
.client-booking label{
  display:grid;
  gap:6px;
  font-weight:900;
  color:#12313d;
}
.client-booking input,
.client-booking select,
.client-booking textarea{
  width:100%;
  border:1px solid #a7dbe5;
  border-radius:13px;
  padding:13px;
  font:inherit;
  background:#fff;
  color:#071923;
}
.client-booking textarea{min-height:96px;resize:vertical;}
.client-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;}
.client-booking button{
  border:0;
  border-radius:16px;
  padding:16px;
  font-weight:950;
  color:#041923;
  background:linear-gradient(135deg,#33f0e8,#2b77ff);
  cursor:pointer;
}
#inicio,#tratamientos,#cita{scroll-margin-top:84px;}
@media(max-width:520px){
  .client-wrap{padding:10px;}
  .client-hero,.client-card{padding:16px;border-radius:22px;}
  .client-hero-head{grid-template-columns:92px 1fr;gap:12px;}
  .client-hero-head img{width:92px;}
  .client-form-grid{grid-template-columns:1fr;}
}

.client-note-box{border:1px solid rgba(15,205,229,.35);background:rgba(15,205,229,.09);color:#dffaff;border-radius:18px;padding:14px 16px;font-weight:800;line-height:1.45}


/* v89: cliente móvil con barras del navegador y menú fijo */
html.dental-client-html,
body.dental-client-page{
  background:var(--mobile-bars-color,#062b34)!important;
  padding-bottom:env(safe-area-inset-bottom,0px);
}
body.dental-client-page::after{
  content:"";
  position:fixed;
  left:0;right:0;bottom:0;
  height:env(safe-area-inset-bottom,0px);
  background:var(--mobile-bars-color,#062b34);
  z-index:9999;
  pointer-events:none;
}
body.dental-client-page .client-tabs{
  position:sticky!important;
  top:env(safe-area-inset-top,0px)!important;
  z-index:999!important;
  background:color-mix(in srgb, var(--mobile-bars-color,#062b34) 86%, #000 14%)!important;
}
#inicio,#tratamientos,#cita{scroll-margin-top:84px}

/* v90: cliente móvil con menú fijo real */
html.dental-client-html,
body.dental-client-page{
  min-height:100dvh!important;
  overflow-y:auto!important;
  background:var(--mobile-bars-color,#20111d)!important;
}
.client-tabs{
  position:fixed!important;
  top:0!important;
  left:0!important;
  right:0!important;
  z-index:99999!important;
  padding-top:calc(10px + env(safe-area-inset-top,0px))!important;
  background:color-mix(in srgb, var(--mobile-bars-color,#20111d) 88%, #000 12%)!important;
}
.client-wrap{padding-top:calc(70px + env(safe-area-inset-top,0px))!important}
#inicio,#tratamientos,#cita{scroll-margin-top:calc(90px + env(safe-area-inset-top,0px))!important}
body.dental-client-page::after{background:var(--mobile-bars-color,#20111d)!important}
.client-whatsapp-link{display:inline-flex;align-items:center;justify-content:center;min-height:42px;border-radius:14px;background:linear-gradient(135deg,#22c55e,#16a34a);color:#fff;text-decoration:none;font-weight:950;padding:0 16px;margin-top:8px}

/* v91: QR usuario clínica dental - menú realmente fijo arriba */
html.dental-client-html,
html.dental-client-html body.dental-client-page{
  height:auto!important;
  min-height:100dvh!important;
  overflow-y:auto!important;
  overflow-x:hidden!important;
  background:var(--mobile-bars-color,#062b34)!important;
  scroll-behavior:smooth;
}
body.dental-client-page .client-tabs{
  position:fixed!important;
  top:0!important;
  left:0!important;
  right:0!important;
  width:100%!important;
  margin:0!important;
  border-radius:0 0 18px 18px!important;
  z-index:2147483000!important;
  padding:calc(10px + env(safe-area-inset-top,0px)) 10px 10px!important;
  background:color-mix(in srgb, var(--mobile-bars-color,#062b34) 90%, #000 10%)!important;
  box-shadow:0 10px 30px rgba(0,0,0,.28)!important;
}
body.dental-client-page .client-wrap{
  padding-top:calc(78px + env(safe-area-inset-top,0px))!important;
}
#inicio,#tratamientos,#cita{scroll-margin-top:calc(92px + env(safe-area-inset-top,0px))!important;}


/* v95: kiosko dental - QR arriba sin etiqueta de categoria */
.dental-kiosk .slide .tag{
  display:none!important;
}
.dental-kiosk .slide .qr{
  top:5vh!important;
  right:4.5vw!important;
}
@media(max-width:800px){
  .dental-kiosk .slide .qr{
    top:5vh!important;
  }
}


/* v105: logo dental con nombre a dos lineas y mas aire interior */
.clinic-logo{width:min(350px,21vw);height:auto;object-fit:contain;}
@media(max-width:800px){.clinic-logo{width:230px;}}


/* v113: QR usuario dental - menu centrado en escritorio y perfecto en movil */
body.dental-client-page .client-tabs{
  left:50%!important;
  right:auto!important;
  transform:translateX(-50%)!important;
  width:min(720px, calc(100% - 20px))!important;
  max-width:720px!important;
  margin:0!important;
  border-radius:0 0 18px 18px!important;
}
@media(max-width:760px){
  body.dental-client-page .client-tabs{
    left:0!important;
    right:0!important;
    transform:none!important;
    width:100%!important;
    max-width:none!important;
    border-radius:0 0 18px 18px!important;
  }
}


/* VIVEO review 2026-06-03: evitar oscurecimiento global de fotos reales en kiosko */
.dental-kiosk .slide:after{background:linear-gradient(90deg,rgba(2,12,18,.06),rgba(2,12,18,.02) 46%,rgba(2,12,18,.12))!important;}
.dental-kiosk .slide-bg img{filter:saturate(1.06) contrast(1.02) brightness(1.02)!important;}
