:root{--color-primary: #43286B;--color-secondary: #00A99D;--color-bg: #f8f9fc;--color-text: #333333;--color-white: #FFFFFF;--font-main: "Inter", sans-serif;--shadow-sm: 0 4px 6px rgba(0,0,0,.05);--shadow-md: 0 10px 15px rgba(0,0,0,.1);--shadow-lg: 0 20px 25px rgba(0,0,0,.15);--radius-md: 12px;--radius-lg: 20px}*{margin:0;padding:0;box-sizing:border-box}body{font-family:var(--font-main);background-color:var(--color-bg);color:var(--color-text);line-height:1.6;-webkit-font-smoothing:antialiased}.container{max-width:1200px;margin:0 auto;padding:0 20px}.text-primary{color:var(--color-primary)}.text-secondary{color:var(--color-secondary)}.bg-primary{background-color:var(--color-primary)}.bg-secondary{background-color:var(--color-secondary)}.btn{display:inline-block;padding:12px 24px;border-radius:var(--radius-md);font-weight:600;cursor:pointer;transition:all .3s ease;border:none;text-align:center}.btn-primary{background-color:var(--color-primary);color:var(--color-white);box-shadow:0 4px 10px #43286b4d}.btn-primary:hover{background-color:#321e50;transform:translateY(-2px);box-shadow:0 6px 15px #43286b66}.btn-secondary{background-color:var(--color-secondary);color:var(--color-white);box-shadow:0 4px 10px #00a99d4d}.btn-secondary:hover{background-color:#008f84;transform:translateY(-2px);box-shadow:0 6px 15px #00a99d66}.section{padding:80px 0}.section-title{text-align:center;font-size:2.5rem;color:var(--color-primary);margin-bottom:15px;font-weight:700}.section-subtitle{text-align:center;color:#666;font-size:1.1rem;max-width:600px;margin:0 auto 50px}.hero{background:linear-gradient(135deg,#43286be6,#00a99dcc),url(/public/logo.jpg) center/cover no-repeat;color:var(--color-white);padding:120px 20px;text-align:center;border-radius:0 0 40px 40px;margin-bottom:40px}.hero h1{font-size:3.5rem;font-weight:800;margin-bottom:20px;text-shadow:0 2px 10px rgba(0,0,0,.2)}.hero p{font-size:1.2rem;max-width:700px;margin:0 auto 30px;opacity:.9}.areas-grid{display:flex;flex-wrap:wrap;justify-content:center;gap:30px}.area-card{position:relative;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-md);cursor:pointer;transition:transform .4s ease,box-shadow .4s ease;background:var(--color-white);height:300px;width:280px;flex-shrink:0}.area-card:hover{transform:translateY(-10px);box-shadow:var(--shadow-lg)}.area-image{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}.area-card:hover .area-image{transform:scale(1.05)}.area-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:transparent;display:flex;flex-direction:column;justify-content:flex-end;padding:25px;transition:background .3s ease}.area-card:hover .area-overlay{background:linear-gradient(to top,#43286bf2,#00a99d80)}.area-title{color:var(--color-white);font-size:1.5rem;font-weight:700;margin-bottom:10px;opacity:0;transform:translateY(20px);transition:transform .3s ease,opacity .3s ease;text-shadow:0 2px 8px rgba(0,0,0,.8)}.area-card:hover .area-title{opacity:1;transform:translateY(0)}.area-action{opacity:0;transform:translateY(20px);transition:all .3s ease}.area-card:hover .area-action{opacity:1;transform:translateY(0);transition-delay:.1s}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);display:flex;align-items:center;justify-content:center;z-index:1000;opacity:0;animation:fadeIn .3s forwards}.modal-content{background:var(--color-white);border-radius:var(--radius-lg);width:100%;max-width:500px;padding:30px;box-shadow:var(--shadow-lg);transform:scale(.9);animation:scaleIn .3s forwards}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.modal-title{color:var(--color-primary);font-size:1.5rem}.close-btn{background:none;border:none;font-size:1.5rem;color:#999;cursor:pointer;transition:color .2s}.close-btn:hover{color:var(--color-primary)}.form-group{margin-bottom:20px}.form-label{display:block;margin-bottom:8px;font-weight:600;color:#555}.form-control{width:100%;padding:12px 15px;border:1px solid #ddd;border-radius:var(--radius-md);font-family:inherit;transition:border-color .3s}.form-control:focus{outline:none;border-color:var(--color-secondary);box-shadow:0 0 0 3px #00a99d1a}.radio-group{display:flex;gap:15px}.radio-label{display:flex;align-items:center;gap:8px;cursor:pointer}@keyframes fadeIn{to{opacity:1}}@keyframes scaleIn{to{transform:scale(1)}}.appt-duo{display:flex;width:95vw;max-width:860px;max-height:92vh;border-radius:20px;overflow:hidden;box-shadow:0 24px 64px #0000004d;animation:scaleIn .3s forwards;transform:scale(.9)}.appt-panel-consultor{flex:0 0 260px;background:linear-gradient(160deg,var(--color-primary) 0%,#2d1060 100%);color:#fff;padding:36px 24px;display:flex;flex-direction:column;align-items:center;text-align:center;gap:10px}.appt-consultor-img{width:120px;height:120px;object-fit:cover;border-radius:50%;border:3px solid rgba(255,255,255,.35);margin-bottom:4px}.appt-consultor-badge{background:#ffffff2e;border:1px solid rgba(255,255,255,.3);border-radius:20px;font-size:.75rem;font-weight:600;letter-spacing:.5px;padding:4px 14px;text-transform:uppercase}.appt-consultor-nombre{font-size:1rem;font-weight:700;margin:4px 0 0;line-height:1.3}.appt-consultor-titulo{font-size:.82rem;opacity:.8;margin:0}.appt-consultor-divider{width:40px;height:2px;background:#ffffff4d;border-radius:2px;margin:4px 0}.appt-consultor-desc{font-size:.85rem;opacity:.85;line-height:1.5;margin:0}.appt-consultor-horario{margin-top:auto;background:#ffffff1f;border-radius:10px;padding:10px 14px;font-size:.8rem;opacity:.9;width:100%}.appt-panel-form{flex:1;background:#fff;padding:20px 24px;overflow-y:auto}.appt-form-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}.appt-form-titulo{font-size:1.2rem;color:var(--color-primary);font-weight:700;margin:0}.appt-panel-form .form-group{margin-bottom:10px}.appt-panel-form .form-label{margin-bottom:4px;font-size:.83rem}.appt-panel-form .form-control{padding:8px 12px;font-size:.9rem}.appt-tipo-grupo{display:flex;gap:8px}.appt-tipo-opcion{flex:1;text-align:center;padding:8px 6px;border-radius:9px;border:2px solid #e5e7eb;cursor:pointer;font-size:.84rem;font-weight:500;color:#555;transition:all .2s;-webkit-user-select:none;user-select:none}.appt-tipo-activo{border-color:var(--color-primary);background:var(--color-primary);color:#fff;font-weight:600}.appt-fecha-input{font-size:.9rem;cursor:pointer}.appt-slots-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:6px}.appt-slot{padding:7px 4px;border-radius:8px;font-size:.78rem;font-weight:500;border:1.5px solid #e5e7eb;background:#fff;color:#374151;cursor:pointer;transition:all .18s}.appt-slot:hover:not(:disabled){border-color:var(--color-primary);color:var(--color-primary)}.appt-slot-sel{background:var(--color-primary)!important;border-color:var(--color-primary)!important;color:#fff!important;font-weight:700}.appt-slot-dis{background:#f3f4f6;color:silver;cursor:not-allowed;text-decoration:line-through}.appt-wa-wrap{display:flex;align-items:center;border:1px solid #ddd;border-radius:var(--radius-md);overflow:hidden;transition:border-color .3s}.appt-wa-wrap:focus-within{border-color:var(--color-secondary);box-shadow:0 0 0 3px #00a99d1a}.appt-wa-prefix{padding:8px 12px;background:#f9fafb;color:#888;font-weight:600;font-size:.85rem;border-right:1px solid #ddd;white-space:nowrap}.appt-wa-input{border:none!important;border-radius:0!important;box-shadow:none!important}.appt-wa-input:focus{outline:none;box-shadow:none!important}.appt-hint{color:#9ca3af;font-size:.85rem;margin:0}.appt-error{color:#dc2626;font-size:.88rem;margin-bottom:12px;background:#fef2f2;padding:10px 14px;border-radius:8px;border-left:3px solid #dc2626}.appt-submit{width:100%;margin-top:6px;padding:11px;font-size:.95rem}.appt-confirm-card{background:#fff;border-radius:20px;padding:40px 36px;width:95vw;max-width:420px;text-align:center;box-shadow:0 24px 64px #00000040;animation:scaleIn .3s forwards;transform:scale(.9);position:relative}.appt-confirm-close{position:absolute;top:16px;right:20px}.appt-confirm-check{width:72px;height:72px;border-radius:50%;background:var(--color-primary);color:#fff;font-size:2.2rem;display:flex;align-items:center;justify-content:center;margin:0 auto 16px}.appt-confirm-titulo{color:var(--color-primary);font-size:1.6rem;font-weight:700;margin:0 0 6px}.appt-confirm-area{color:var(--color-secondary);font-weight:600;font-size:.95rem;margin:0 0 4px;text-transform:uppercase;letter-spacing:.5px}.appt-confirm-fecha{color:#374151;font-weight:600;font-size:1rem;margin:4px 0 2px}.appt-confirm-hora{color:var(--color-secondary);font-size:1.15rem;font-weight:700;margin:0 0 20px}.appt-confirm-folio-wrap{background:#f5f3ff;border-radius:14px;padding:16px 20px;margin-bottom:16px}.appt-confirm-folio-label{color:#7c3aed;font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;margin:0 0 6px}.appt-confirm-folio{display:inline-block;background:var(--color-primary);color:#fff;font-family:monospace;font-size:1.5rem;font-weight:700;letter-spacing:3px;padding:8px 22px;border-radius:10px}.appt-confirm-folio-hint{color:#9ca3af;font-size:.8rem;margin:8px 0 0}.appt-confirm-wa{background:#f0fdf4;border:1px solid #bbf7d0;border-radius:10px;color:#16a34a;font-size:.88rem;font-weight:500;padding:10px 16px}@media (max-width: 640px){.appt-panel-consultor{display:none}.appt-duo{flex-direction:column;max-height:95vh;border-radius:16px}.appt-panel-form{padding:24px 20px}.appt-slots-grid{grid-template-columns:repeat(2,1fr)}.appt-confirm-card{padding:32px 24px}}@keyframes navbarGradient{0%{background-position:0% 50%}50%{background-position:100% 50%}to{background-position:0% 50%}}.ubsi-navbar{position:sticky;top:0;z-index:900;background:linear-gradient(135deg,#43286b,#2a5298,#00a99d,#43286b);background-size:300% 300%;animation:navbarGradient 8s ease infinite;box-shadow:0 2px 12px #00000040}.ubsi-navbar-inner{max-width:1200px;margin:0 auto;padding:0 24px;height:56px;display:flex;align-items:center;justify-content:space-between}.ubsi-navbar-brand{display:flex;flex-direction:row;align-items:center;gap:10px;text-decoration:none}.ubsi-navbar-logo{width:38px;height:38px;border-radius:50%;object-fit:cover;border:2px solid rgba(255,255,255,.5);flex-shrink:0}.ubsi-navbar-brand-text{display:flex;flex-direction:column;line-height:1.15}.ubsi-navbar-brand-main{font-size:1.05rem;font-weight:700;color:#fff;letter-spacing:.3px;text-shadow:0 1px 4px rgba(0,0,0,.2)}.ubsi-navbar-brand-sub{font-size:.7rem;font-weight:400;color:#ffffffd1;letter-spacing:.3px}.ubsi-navbar-cita-btn{background:#ffffff26;border:2px solid rgba(255,255,255,.8);color:#fff;border-radius:20px;padding:6px 18px;font-size:.88rem;font-weight:600;cursor:pointer;transition:all .2s;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.ubsi-navbar-cita-btn:hover{background:#ffffff4d;border-color:#fff}.micita-panel{background:#fff;border-radius:20px;width:95vw;max-width:480px;max-height:90vh;overflow-y:auto;box-shadow:0 24px 64px #00000040;animation:scaleIn .3s forwards;transform:scale(.9)}.micita-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px 0;position:sticky;top:0;background:#fff;z-index:1}.micita-titulo{font-size:1.2rem;font-weight:700;color:var(--color-primary);margin:0}.micita-body{padding:16px 24px 24px}.micita-subtitulo{color:#6b7280;font-size:.9rem;margin:0 0 16px;line-height:1.5}.micita-folio-input{font-size:1.2rem;text-align:center;letter-spacing:3px;text-transform:uppercase;font-weight:600}.micita-btn-buscar{width:100%;margin-top:14px;padding:12px}.micita-card{border:1px solid #e5e7eb;border-radius:14px;overflow:hidden;margin-bottom:16px}.micita-fila{display:flex;justify-content:space-between;align-items:center;padding:11px 16px;border-bottom:1px solid #f3f4f6;gap:12px}.micita-fila:last-child{border-bottom:none}.micita-label{color:#9ca3af;font-size:.82rem;font-weight:500;white-space:nowrap}.micita-valor{color:#111827;font-size:.9rem;font-weight:600;text-align:right}.micita-estado{font-size:.8rem;font-weight:600;padding:3px 10px;border-radius:12px}.micita-estado-ok{background:#d1fae5;color:#065f46}.micita-estado-err{background:#fee2e2;color:#991b1b}.micita-folio-badge{background:var(--color-primary);color:#fff;font-family:monospace;font-size:.9rem;font-weight:700;letter-spacing:2px;padding:4px 12px;border-radius:8px}.micita-acciones{display:flex;flex-direction:column;gap:10px}.micita-btn-cancelar{background:none;border:2px solid #dc2626;color:#dc2626;border-radius:10px;padding:10px;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s;width:100%}.micita-btn-cancelar:hover{background:#dc2626;color:#fff}.micita-pills{display:flex;gap:8px;flex-wrap:wrap}.micita-pill{background:var(--color-primary);color:#fff;border-radius:20px;padding:4px 14px;font-size:.82rem;font-weight:600}.micita-pill-gray{background:#6b7280}.micita-btn-volver{background:none;border:none;color:#9ca3af;font-size:.85rem;cursor:pointer;margin-top:12px;padding:0;display:block}.micita-btn-volver:hover{color:var(--color-primary)}.micita-success{text-align:center}.micita-success-titulo{font-size:1.4rem;font-weight:700;color:var(--color-primary);margin:12px 0 4px}.micita-success-sub{color:var(--color-secondary);font-weight:600;font-size:.9rem;text-transform:uppercase;letter-spacing:.5px;margin:0}.micita-success-fecha{color:#374151;font-weight:600;margin:8px 0 2px}.micita-success-hora{color:var(--color-secondary);font-size:1.1rem;font-weight:700;margin:0}.footer{background:var(--color-primary);color:var(--color-white);padding:60px 0 30px;margin-top:60px}.map-container iframe{width:100%;border-radius:var(--radius-lg);box-shadow:var(--shadow-md)}@media (max-width: 768px){.hero{padding:70px 20px;border-radius:0 0 24px 24px}.hero h1{font-size:2.2rem}.hero p{font-size:1rem}.section-title{font-size:1.8rem}.section-subtitle{font-size:1rem}.section{padding:50px 0}.area-card{width:90vw;max-width:360px;height:260px}.modal-content{margin:16px;padding:20px;max-width:calc(100vw - 32px)}.modal-title{font-size:1.2rem}}@media (max-width: 480px){.hero h1{font-size:1.8rem}.btn{padding:10px 18px;font-size:.9rem}.area-card{width:95vw;height:240px}}.kiosco-root{min-height:100dvh;background:var(--color-bg);font-size:20px;color:var(--color-text);display:flex;flex-direction:column}.kiosco-root.inicio{background:var(--color-primary);color:var(--color-white)}.kiosco-header{display:flex;justify-content:space-between;align-items:center;padding:16px 24px;background:var(--color-white);box-shadow:0 1px 4px #00000014;flex-shrink:0}.kiosco-logo{height:48px;object-fit:contain}.kiosco-header-brand{font-size:17px;font-weight:700;color:var(--color-primary);text-align:center;flex:1;padding:0 12px;line-height:1.2}.consultor-card-compacta{display:flex;align-items:center;gap:20px;background:var(--color-white);border-radius:16px;padding:20px;box-shadow:0 2px 12px #00000012}.consultor-info{flex:1;min-width:0}.kiosco-content{max-width:800px;width:100%;margin:0 auto;padding:24px;flex:1;display:flex;flex-direction:column}.kiosco-btn{min-height:64px;font-size:20px;font-weight:600;border-radius:12px;padding:0 28px;cursor:pointer;width:100%;border:none;font-family:inherit;touch-action:manipulation;-webkit-tap-highlight-color:transparent;transition:opacity .1s,transform .1s;display:flex;align-items:center;justify-content:center;text-align:center}.kiosco-btn:active{transform:scale(.98)}.kiosco-btn-primary{background:var(--color-primary);color:var(--color-white)}.kiosco-btn-secondary{background:transparent;color:var(--color-primary);border:2px solid var(--color-primary)}.kiosco-btn-teal{background:var(--color-secondary);color:var(--color-white)}.kiosco-btn-danger{background:transparent;color:var(--color-error);border:2px solid var(--color-error)}.kiosco-btn-atras{min-height:44px;font-size:18px;background:none;border:none;color:var(--color-muted);cursor:pointer;padding:0 8px;font-family:inherit}.kiosco-btn-atras:hover{color:var(--color-primary)}.kiosco-btn:disabled{opacity:.5;cursor:not-allowed}.kiosco-btn-fijo{position:sticky;bottom:0;margin-top:auto;padding-top:16px;background:var(--color-bg)}.kiosco-root.inicio .kiosco-btn-fijo{background:var(--color-primary)}.kiosco-input{width:100%;height:56px;font-size:20px;padding:0 16px;border:2px solid var(--color-disabled);border-radius:10px;font-family:inherit;color:var(--color-text);background:var(--color-white);transition:border-color .2s}.kiosco-input:focus{outline:none;border-color:var(--color-primary)}.kiosco-input::placeholder{color:var(--color-disabled)}.kiosco-label{display:block;font-size:18px;font-weight:600;margin-bottom:8px;color:var(--color-text)}.kiosco-input-error{border-color:var(--color-error)}.kiosco-error-text{color:var(--color-error);font-size:16px;margin-top:6px}.especialidades-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:16px;margin-top:24px}.especialidad-card:nth-child(-n+3){grid-column:span 2}.especialidad-card:nth-child(n+4){grid-column:span 3}.especialidad-card{position:relative;height:200px;border-radius:12px;overflow:hidden;cursor:pointer;transition:transform .15s}.especialidad-card img{width:100%;height:100%;object-fit:cover;display:block}.especialidad-card-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#00000073;display:flex;align-items:flex-end;padding:16px}.especialidad-card-nombre{color:#fff;font-size:22px;font-weight:700}.especialidad-card:active{outline:3px solid var(--color-primary);transform:scale(1.02)}.slots-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-top:16px}.slot{padding:16px 4px;border-radius:10px;font-size:16px;cursor:pointer;text-align:center;border:2px solid transparent;font-family:inherit;background:none;touch-action:manipulation;-webkit-tap-highlight-color:transparent;transition:all .12s}.slot-disponible{background:var(--color-white);border-color:var(--color-secondary);color:var(--color-text)}.slot-disponible:hover{background:#e6fffa}.slot-seleccionado{background:var(--color-primary);border-color:var(--color-primary);color:var(--color-white);font-weight:700}.slot-ocupado{background:var(--color-disabled);color:#9ca3af;text-decoration:line-through;cursor:not-allowed}.slot-en-proceso{background:#fef3c7;border-color:var(--color-warning);color:var(--color-warning);cursor:not-allowed;font-size:14px}.folio-badge{font-family:Courier New,Courier,monospace;font-size:28px;background:var(--color-primary);color:var(--color-white);padding:12px 24px;border-radius:10px;letter-spacing:3px;display:inline-block;text-transform:uppercase}.kiosco-timer{padding:12px 16px;border-radius:10px;background:#f0fdf4;border:1px solid #BBF7D0;font-size:18px;margin-bottom:20px}.kiosco-timer.urgente{background:#fef2f2;border-color:#fecaca;color:var(--color-error)}.kiosco-timer-barra{height:6px;border-radius:3px;background:var(--color-secondary);transition:width 1s linear;margin-top:8px}.kiosco-timer-barra.urgente{background:var(--color-error)}.kiosco-timer-barra.advertencia{background:var(--color-warning)}.kiosco-icono-circulo{width:100px;height:100px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 24px;font-size:48px;color:#fff}.kiosco-icono-circulo.success{background:var(--color-success);animation:popIn .4s ease}.kiosco-icono-circulo.error{background:var(--color-error);animation:popIn .4s ease}@keyframes popIn{0%{transform:scale(.5);opacity:0}to{transform:scale(1);opacity:1}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.kiosco-fade-in{animation:fadeIn .5s ease}.doctor-placeholder{width:150px;height:150px;border-radius:50%;background:var(--color-primary);display:flex;align-items:center;justify-content:center;color:#fff;font-size:40px;font-weight:700;margin:0 auto 20px}.tipo-paciente-card{width:100%;min-height:140px;border:2px solid var(--color-disabled);border-radius:12px;padding:24px;cursor:pointer;transition:all .2s;background:var(--color-white);text-align:left;font-family:inherit}.tipo-paciente-card.seleccionado{border:3px solid var(--color-primary);background:#f0ebf8}.tipo-paciente-titulo{font-size:24px;font-weight:700;color:var(--color-text);margin-bottom:4px}.tipo-paciente-sub{font-size:16px;color:var(--color-muted)}.kiosco-resumen-pills{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:24px}.resumen-pill{background:var(--color-primary);color:#fff;border-radius:999px;padding:6px 16px;font-size:16px;font-weight:600;white-space:nowrap}.kiosco-detalle-card{background:var(--color-white);border-radius:12px;padding:24px;box-shadow:0 4px 20px #0000001a;margin-top:16px}.kiosco-detalle-fila{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-bottom:1px solid #E5E7EB;font-size:18px}.kiosco-detalle-fila:last-child{border-bottom:none}.kiosco-detalle-label{color:var(--color-muted)}.kiosco-detalle-valor{font-weight:600}.badge{display:inline-block;padding:6px 14px;border-radius:20px;font-size:14px;font-weight:600}.badge-primary{background:var(--color-primary);color:var(--color-white)}.badge-success{background:#dcfce7;color:var(--color-success)}.badge-error{background:#fee2e2;color:var(--color-error)}.badge-muted{background:#f3f4f6;color:var(--color-muted)}.kiosco-toast{position:fixed;bottom:32px;left:50%;transform:translate(-50%);background:var(--color-error);color:#fff;padding:14px 28px;border-radius:10px;font-size:18px;z-index:999;animation:fadeIn .3s ease;white-space:nowrap}.kiosco-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:998;animation:fadeIn .2s ease}.kiosco-modal{background:var(--color-white);border-radius:16px;padding:32px;max-width:420px;width:90%;text-align:center;animation:popIn .3s ease}.kiosco-modal-titulo{font-size:24px;font-weight:700;margin-bottom:12px;color:var(--color-text)}.kiosco-modal-texto{font-size:18px;color:var(--color-muted);margin-bottom:24px}.kiosco-modal-botones{display:flex;gap:12px}.kiosco-countdown{font-size:16px;color:var(--color-muted);text-align:center;margin-top:16px}.kiosco-spinner{display:flex;align-items:center;justify-content:center;gap:8px;font-size:18px;color:var(--color-muted);padding:20px}.kiosco-spinner:before{content:"";width:20px;height:20px;border:2px solid var(--color-disabled);border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.inicio-container{display:flex;flex-direction:column;align-items:center;justify-content:space-between;min-height:100dvh;padding:60px 32px 52px;text-align:center;animation:fadeIn .5s ease}.inicio-marca{display:flex;flex-direction:column;align-items:center}.inicio-logo{width:180px;height:auto;margin-bottom:28px;border-radius:16px}.inicio-titulo{font-size:38px;font-weight:800;color:#fff;margin-bottom:10px;letter-spacing:-.5px}.inicio-subtitulo{font-size:20px;color:#ffffffbf}.inicio-botones{width:100%;max-width:480px;display:flex;flex-direction:column;align-items:center;gap:20px}.inicio-btn-principal{width:88%;min-height:96px;background:var(--color-white);color:var(--color-primary);font-size:26px;font-weight:800;border:none;border-radius:18px;cursor:pointer;font-family:inherit;touch-action:manipulation;-webkit-tap-highlight-color:transparent;transition:transform .1s,opacity .1s;box-shadow:0 6px 20px #00000040}.inicio-btn-principal:active{transform:scale(.96);opacity:.92}@keyframes pulsarBoton{0%,to{box-shadow:0 6px 20px #00000040,0 0 #ffffff80}50%{box-shadow:0 6px 20px #00000040,0 0 0 14px #fff0}}.inicio-btn-pulse{animation:pulsarBoton 1.8s ease-in-out infinite}.inicio-btn-secundario{width:68%;min-height:72px;background:transparent;color:var(--color-white);font-size:19px;font-weight:600;border:2px solid rgba(255,255,255,.7);border-radius:14px;cursor:pointer;font-family:inherit;touch-action:manipulation;-webkit-tap-highlight-color:transparent;transition:transform .1s,background .1s}.inicio-btn-secundario:active{transform:scale(.96);background:#ffffff1f}.inicio-label-secundario{font-size:16px;color:#ffffff8c;letter-spacing:.5px;text-transform:uppercase;margin:0}.inicio-acciones-secundarias{display:flex;gap:12px;width:100%;justify-content:center}.inicio-btn-accion{flex:1;max-width:180px;min-height:72px;background:#ffffff1f;color:var(--color-white);font-size:19px;font-weight:700;border:1.5px solid rgba(255,255,255,.4);border-radius:14px;cursor:pointer;font-family:inherit;touch-action:manipulation;-webkit-tap-highlight-color:transparent;display:flex;align-items:center;justify-content:center;transition:transform .1s,background .1s}.inicio-btn-accion:active{transform:scale(.94);background:#ffffff38}.inicio-btn-accion-danger{border-color:#ff787899;color:#ffb3b3}.inicio-btn-accion-danger:active{background:#ff646433}.especialidad-card-activa{outline:4px solid var(--color-secondary);transform:scale(1.04)}.especialidad-card-check{position:absolute;top:10px;right:10px;width:36px;height:36px;background:var(--color-secondary);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:20px;font-weight:700}.especialidad-badge{display:inline-block;align-self:flex-start;background:var(--color-primary);color:var(--color-white);border:2px solid var(--color-primary);border-radius:24px;padding:6px 20px;font-size:18px;font-weight:700;margin-bottom:12px}.fecha-display{width:100%;min-height:60px;background:var(--color-white);border:2px solid var(--color-disabled);border-radius:12px;padding:0 16px 0 20px;font-size:19px;font-weight:500;color:var(--color-text);display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:8px;cursor:pointer;font-family:inherit;text-align:left;touch-action:manipulation;-webkit-tap-highlight-color:transparent;transition:border-color .15s,background .15s}.fecha-display:active{background:#f5f3fa}.fecha-display-activa{border-color:var(--color-primary)}.fecha-display-texto{flex:1;font-weight:600;color:var(--color-primary)}.fecha-display-placeholder{color:var(--color-muted);font-weight:400;letter-spacing:1px}.fecha-display-icono{flex-shrink:0;color:var(--color-muted)}.calendario{background:var(--color-white);border-radius:16px;padding:12px;box-shadow:0 2px 12px #00000014;margin-top:12px}.calendario-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.calendario-nav{width:44px;height:44px;border:none;background:var(--color-bg);border-radius:10px;font-size:26px;cursor:pointer;touch-action:manipulation;-webkit-tap-highlight-color:transparent;display:flex;align-items:center;justify-content:center;color:var(--color-primary);transition:background .1s}.calendario-nav:disabled{opacity:.25;cursor:not-allowed}.calendario-nav:not(:disabled):active{background:#e0d8f0}.calendario-mes{font-size:20px;font-weight:700;color:var(--color-primary)}.calendario-dias-header{display:grid;grid-template-columns:repeat(7,1fr);margin-bottom:6px}.calendario-dia-nombre{text-align:center;font-size:13px;font-weight:700;color:var(--color-muted);padding:4px 0 8px}.calendario-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}.calendario-dia{height:46px;border:none;background:none;border-radius:10px;font-size:15px;font-family:inherit;color:var(--color-text);cursor:pointer;touch-action:manipulation;-webkit-tap-highlight-color:transparent;transition:background .1s}.calendario-dia:not(.calendario-dia-disabled):not(.calendario-dia-selected):active{background:#e6fffa}.calendario-dia-selected{background:var(--color-primary)!important;color:var(--color-white)!important;font-weight:700}.calendario-dia-hoy{border:2px solid var(--color-secondary);color:var(--color-secondary);font-weight:700}.calendario-dia-disabled{color:var(--color-disabled);cursor:not-allowed}.confirmacion-root{min-height:100dvh;background:var(--color-bg);display:flex;flex-direction:column;align-items:center;padding:32px 24px;gap:24px}.confirmacion-estado{text-align:center}.confirmacion-titulo{font-size:32px;font-weight:800;color:var(--color-success);margin-bottom:8px}.confirmacion-subtitulo{font-size:17px;color:var(--color-muted);max-width:380px}.ticket{background:var(--color-white);border-radius:20px;padding:28px 24px;width:100%;max-width:420px;box-shadow:0 4px 24px #0000001f;border-top:6px solid var(--color-primary)}.ticket-header{display:flex;align-items:center;gap:14px;margin-bottom:20px;padding-bottom:16px;border-bottom:1px dashed #E5E7EB}.ticket-logo{width:52px;height:52px;object-fit:contain;border-radius:8px}.ticket-clinica{font-size:20px;font-weight:800;color:var(--color-primary)}.ticket-clinica-sub{font-size:13px;color:var(--color-muted)}.ticket-folio-wrap{text-align:center;padding:16px 0 20px;border-bottom:1px dashed #E5E7EB;margin-bottom:16px}.ticket-folio-label{display:block;font-size:13px;color:var(--color-muted);margin-bottom:8px;text-transform:uppercase;letter-spacing:1px}.ticket-folio{font-size:32px;padding:14px 28px}.ticket-datos{display:flex;flex-direction:column;gap:10px;margin-bottom:16px}.ticket-fila{display:flex;justify-content:space-between;align-items:flex-start;font-size:16px}.ticket-label{color:var(--color-muted);flex-shrink:0;margin-right:12px}.ticket-valor{font-weight:600;text-align:right}.ticket-direccion{font-size:14px;color:var(--color-muted);text-align:center;padding-top:14px;border-top:1px dashed #E5E7EB}.confirmacion-acciones{display:flex;flex-direction:column;gap:12px;width:100%;max-width:420px;align-items:center}.kiosco-titulo{font-size:32px;font-weight:700;color:var(--color-primary);margin-bottom:8px}.kiosco-subtitulo{font-size:20px;color:var(--color-muted);margin-bottom:24px}.kiosco-seccion-titulo{font-size:22px;font-weight:700;margin:24px 0 12px}.kiosco-separador{border:none;border-top:1px solid #E5E7EB;margin:20px 0}:root{--color-muted: #6B7280;--color-success: #16A34A;--color-error: #DC2626;--color-warning: #D97706;--color-disabled: #D1D5DB}@media (max-width: 768px){.especialidades-grid{gap:12px}.especialidad-card{height:160px}.slots-grid{grid-template-columns:repeat(4,1fr);gap:8px}.slot{font-size:14px;padding:12px 2px}}.check-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;display:flex;align-items:center;justify-content:center;background:#0000008c;animation:check-overlay-fade .4s ease forwards,check-overlay-out .5s ease 2.5s forwards}.check-contenido{display:flex;flex-direction:column;align-items:center;gap:20px;animation:check-pop .4s cubic-bezier(.34,1.56,.64,1) forwards}.check-circulo{width:160px;height:160px;border-radius:50%;background:#22c55e;color:#fff;display:flex;align-items:center;justify-content:center;font-size:80px;line-height:1;box-shadow:0 8px 40px #22c55e73}.check-label{color:#fff;font-size:32px;font-weight:700;margin:0;text-shadow:0 2px 8px rgba(0,0,0,.3)}@keyframes check-overlay-fade{0%{opacity:0}to{opacity:1}}@keyframes check-overlay-out{0%{opacity:1}to{opacity:0;pointer-events:none}}@keyframes check-pop{0%{transform:scale(.3);opacity:0}to{transform:scale(1);opacity:1}}@media (prefers-reduced-motion: reduce){.kiosco-fade-in,.kiosco-icono-circulo.success,.kiosco-icono-circulo.error,.kiosco-modal-overlay,.kiosco-modal,.kiosco-toast,.check-overlay,.check-circulo{animation:none!important}}
