@import"https://fonts.googleapis.com/css2?family=Syne:wght@400;600&family=DM+Sans:wght@400;500;600&display=swap";@import"https://fonts.googleapis.com/css2?family=Syne:wght@600;700;800&family=DM+Sans:wght@300;400;500;600&display=swap";:root{--toastify-color-light: #fff;--toastify-color-dark: #121212;--toastify-color-info: #3498db;--toastify-color-success: #07bc0c;--toastify-color-warning: #f1c40f;--toastify-color-error: hsl(6, 78%, 57%);--toastify-color-transparent: rgba(255, 255, 255, .7);--toastify-icon-color-info: var(--toastify-color-info);--toastify-icon-color-success: var(--toastify-color-success);--toastify-icon-color-warning: var(--toastify-color-warning);--toastify-icon-color-error: var(--toastify-color-error);--toastify-container-width: fit-content;--toastify-toast-width: 320px;--toastify-toast-offset: 16px;--toastify-toast-top: max(var(--toastify-toast-offset), env(safe-area-inset-top));--toastify-toast-right: max(var(--toastify-toast-offset), env(safe-area-inset-right));--toastify-toast-left: max(var(--toastify-toast-offset), env(safe-area-inset-left));--toastify-toast-bottom: max(var(--toastify-toast-offset), env(safe-area-inset-bottom));--toastify-toast-background: #fff;--toastify-toast-padding: 14px;--toastify-toast-min-height: 64px;--toastify-toast-max-height: 800px;--toastify-toast-bd-radius: 6px;--toastify-toast-shadow: 0px 4px 12px rgba(0, 0, 0, .1);--toastify-font-family: sans-serif;--toastify-z-index: 9999;--toastify-text-color-light: #757575;--toastify-text-color-dark: #fff;--toastify-text-color-info: #fff;--toastify-text-color-success: #fff;--toastify-text-color-warning: #fff;--toastify-text-color-error: #fff;--toastify-spinner-color: #616161;--toastify-spinner-color-empty-area: #e0e0e0;--toastify-color-progress-light: linear-gradient(to right, #4cd964, #5ac8fa, #007aff, #34aadc, #5856d6, #ff2d55);--toastify-color-progress-dark: #bb86fc;--toastify-color-progress-info: var(--toastify-color-info);--toastify-color-progress-success: var(--toastify-color-success);--toastify-color-progress-warning: var(--toastify-color-warning);--toastify-color-progress-error: var(--toastify-color-error);--toastify-color-progress-bgo: .2}.Toastify__toast-container{z-index:var(--toastify-z-index);-webkit-transform:translate3d(0,0,var(--toastify-z-index));position:fixed;width:var(--toastify-container-width);box-sizing:border-box;color:#fff;display:flex;flex-direction:column}.Toastify__toast-container--top-left{top:var(--toastify-toast-top);left:var(--toastify-toast-left)}.Toastify__toast-container--top-center{top:var(--toastify-toast-top);left:50%;transform:translate(-50%);align-items:center}.Toastify__toast-container--top-right{top:var(--toastify-toast-top);right:var(--toastify-toast-right);align-items:end}.Toastify__toast-container--bottom-left{bottom:var(--toastify-toast-bottom);left:var(--toastify-toast-left)}.Toastify__toast-container--bottom-center{bottom:var(--toastify-toast-bottom);left:50%;transform:translate(-50%);align-items:center}.Toastify__toast-container--bottom-right{bottom:var(--toastify-toast-bottom);right:var(--toastify-toast-right);align-items:end}.Toastify__toast{--y: 0;position:relative;touch-action:none;width:var(--toastify-toast-width);min-height:var(--toastify-toast-min-height);box-sizing:border-box;margin-bottom:1rem;padding:var(--toastify-toast-padding);border-radius:var(--toastify-toast-bd-radius);box-shadow:var(--toastify-toast-shadow);max-height:var(--toastify-toast-max-height);font-family:var(--toastify-font-family);z-index:0;display:flex;flex:1 auto;align-items:center;word-break:break-word}@media only screen and (max-width:480px){.Toastify__toast-container{width:100vw;left:env(safe-area-inset-left);margin:0}.Toastify__toast-container--top-left,.Toastify__toast-container--top-center,.Toastify__toast-container--top-right{top:env(safe-area-inset-top);transform:translate(0)}.Toastify__toast-container--bottom-left,.Toastify__toast-container--bottom-center,.Toastify__toast-container--bottom-right{bottom:env(safe-area-inset-bottom);transform:translate(0)}.Toastify__toast-container--rtl{right:env(safe-area-inset-right);left:initial}.Toastify__toast{--toastify-toast-width: 100%;margin-bottom:0;border-radius:0}}.Toastify__toast-container[data-stacked=true]{width:var(--toastify-toast-width)}.Toastify__toast--stacked{position:absolute;width:100%;transform:translate3d(0,var(--y),0) scale(var(--s));transition:transform .3s}.Toastify__toast--stacked[data-collapsed] .Toastify__toast-body,.Toastify__toast--stacked[data-collapsed] .Toastify__close-button{transition:opacity .1s}.Toastify__toast--stacked[data-collapsed=false]{overflow:visible}.Toastify__toast--stacked[data-collapsed=true]:not(:last-child)>*{opacity:0}.Toastify__toast--stacked:after{content:"";position:absolute;left:0;right:0;height:calc(var(--g) * 1px);bottom:100%}.Toastify__toast--stacked[data-pos=top]{top:0}.Toastify__toast--stacked[data-pos=bot]{bottom:0}.Toastify__toast--stacked[data-pos=bot].Toastify__toast--stacked:before{transform-origin:top}.Toastify__toast--stacked[data-pos=top].Toastify__toast--stacked:before{transform-origin:bottom}.Toastify__toast--stacked:before{content:"";position:absolute;left:0;right:0;bottom:0;height:100%;transform:scaleY(3);z-index:-1}.Toastify__toast--rtl{direction:rtl}.Toastify__toast--close-on-click{cursor:pointer}.Toastify__toast-icon{margin-inline-end:10px;width:22px;flex-shrink:0;display:flex}.Toastify--animate{animation-fill-mode:both;animation-duration:.5s}.Toastify--animate-icon{animation-fill-mode:both;animation-duration:.3s}.Toastify__toast-theme--dark{background:var(--toastify-color-dark);color:var(--toastify-text-color-dark)}.Toastify__toast-theme--light,.Toastify__toast-theme--colored.Toastify__toast--default{background:var(--toastify-color-light);color:var(--toastify-text-color-light)}.Toastify__toast-theme--colored.Toastify__toast--info{color:var(--toastify-text-color-info);background:var(--toastify-color-info)}.Toastify__toast-theme--colored.Toastify__toast--success{color:var(--toastify-text-color-success);background:var(--toastify-color-success)}.Toastify__toast-theme--colored.Toastify__toast--warning{color:var(--toastify-text-color-warning);background:var(--toastify-color-warning)}.Toastify__toast-theme--colored.Toastify__toast--error{color:var(--toastify-text-color-error);background:var(--toastify-color-error)}.Toastify__progress-bar-theme--light{background:var(--toastify-color-progress-light)}.Toastify__progress-bar-theme--dark{background:var(--toastify-color-progress-dark)}.Toastify__progress-bar--info{background:var(--toastify-color-progress-info)}.Toastify__progress-bar--success{background:var(--toastify-color-progress-success)}.Toastify__progress-bar--warning{background:var(--toastify-color-progress-warning)}.Toastify__progress-bar--error{background:var(--toastify-color-progress-error)}.Toastify__progress-bar-theme--colored.Toastify__progress-bar--info,.Toastify__progress-bar-theme--colored.Toastify__progress-bar--success,.Toastify__progress-bar-theme--colored.Toastify__progress-bar--warning,.Toastify__progress-bar-theme--colored.Toastify__progress-bar--error{background:var(--toastify-color-transparent)}.Toastify__close-button{color:#fff;position:absolute;top:6px;right:6px;background:transparent;outline:none;border:none;padding:0;cursor:pointer;opacity:.7;transition:.3s ease;z-index:1}.Toastify__toast--rtl .Toastify__close-button{left:6px;right:unset}.Toastify__close-button--light{color:#000;opacity:.3}.Toastify__close-button>svg{fill:currentColor;height:16px;width:14px}.Toastify__close-button:hover,.Toastify__close-button:focus{opacity:1}@keyframes Toastify__trackProgress{0%{transform:scaleX(1)}to{transform:scaleX(0)}}.Toastify__progress-bar{position:absolute;bottom:0;left:0;width:100%;height:100%;z-index:1;opacity:.7;transform-origin:left}.Toastify__progress-bar--animated{animation:Toastify__trackProgress linear 1 forwards}.Toastify__progress-bar--controlled{transition:transform .2s}.Toastify__progress-bar--rtl{right:0;left:initial;transform-origin:right;border-bottom-left-radius:initial}.Toastify__progress-bar--wrp{position:absolute;overflow:hidden;bottom:0;left:0;width:100%;height:5px;border-bottom-left-radius:var(--toastify-toast-bd-radius);border-bottom-right-radius:var(--toastify-toast-bd-radius)}.Toastify__progress-bar--wrp[data-hidden=true]{opacity:0}.Toastify__progress-bar--bg{opacity:var(--toastify-color-progress-bgo);width:100%;height:100%}.Toastify__spinner{width:20px;height:20px;box-sizing:border-box;border:2px solid;border-radius:100%;border-color:var(--toastify-spinner-color-empty-area);border-right-color:var(--toastify-spinner-color);animation:Toastify__spin .65s linear infinite}@keyframes Toastify__bounceInRight{0%,60%,75%,90%,to{animation-timing-function:cubic-bezier(.215,.61,.355,1)}0%{opacity:0;transform:translate3d(3000px,0,0)}60%{opacity:1;transform:translate3d(-25px,0,0)}75%{transform:translate3d(10px,0,0)}90%{transform:translate3d(-5px,0,0)}to{transform:none}}@keyframes Toastify__bounceOutRight{20%{opacity:1;transform:translate3d(-20px,var(--y),0)}to{opacity:0;transform:translate3d(2000px,var(--y),0)}}@keyframes Toastify__bounceInLeft{0%,60%,75%,90%,to{animation-timing-function:cubic-bezier(.215,.61,.355,1)}0%{opacity:0;transform:translate3d(-3000px,0,0)}60%{opacity:1;transform:translate3d(25px,0,0)}75%{transform:translate3d(-10px,0,0)}90%{transform:translate3d(5px,0,0)}to{transform:none}}@keyframes Toastify__bounceOutLeft{20%{opacity:1;transform:translate3d(20px,var(--y),0)}to{opacity:0;transform:translate3d(-2000px,var(--y),0)}}@keyframes Toastify__bounceInUp{0%,60%,75%,90%,to{animation-timing-function:cubic-bezier(.215,.61,.355,1)}0%{opacity:0;transform:translate3d(0,3000px,0)}60%{opacity:1;transform:translate3d(0,-20px,0)}75%{transform:translate3d(0,10px,0)}90%{transform:translate3d(0,-5px,0)}to{transform:translateZ(0)}}@keyframes Toastify__bounceOutUp{20%{transform:translate3d(0,calc(var(--y) - 10px),0)}40%,45%{opacity:1;transform:translate3d(0,calc(var(--y) + 20px),0)}to{opacity:0;transform:translate3d(0,-2000px,0)}}@keyframes Toastify__bounceInDown{0%,60%,75%,90%,to{animation-timing-function:cubic-bezier(.215,.61,.355,1)}0%{opacity:0;transform:translate3d(0,-3000px,0)}60%{opacity:1;transform:translate3d(0,25px,0)}75%{transform:translate3d(0,-10px,0)}90%{transform:translate3d(0,5px,0)}to{transform:none}}@keyframes Toastify__bounceOutDown{20%{transform:translate3d(0,calc(var(--y) - 10px),0)}40%,45%{opacity:1;transform:translate3d(0,calc(var(--y) + 20px),0)}to{opacity:0;transform:translate3d(0,2000px,0)}}.Toastify__bounce-enter--top-left,.Toastify__bounce-enter--bottom-left{animation-name:Toastify__bounceInLeft}.Toastify__bounce-enter--top-right,.Toastify__bounce-enter--bottom-right{animation-name:Toastify__bounceInRight}.Toastify__bounce-enter--top-center{animation-name:Toastify__bounceInDown}.Toastify__bounce-enter--bottom-center{animation-name:Toastify__bounceInUp}.Toastify__bounce-exit--top-left,.Toastify__bounce-exit--bottom-left{animation-name:Toastify__bounceOutLeft}.Toastify__bounce-exit--top-right,.Toastify__bounce-exit--bottom-right{animation-name:Toastify__bounceOutRight}.Toastify__bounce-exit--top-center{animation-name:Toastify__bounceOutUp}.Toastify__bounce-exit--bottom-center{animation-name:Toastify__bounceOutDown}@keyframes Toastify__zoomIn{0%{opacity:0;transform:scale3d(.3,.3,.3)}50%{opacity:1}}@keyframes Toastify__zoomOut{0%{opacity:1}50%{opacity:0;transform:translate3d(0,var(--y),0) scale3d(.3,.3,.3)}to{opacity:0}}.Toastify__zoom-enter{animation-name:Toastify__zoomIn}.Toastify__zoom-exit{animation-name:Toastify__zoomOut}@keyframes Toastify__flipIn{0%{transform:perspective(400px) rotateX(90deg);animation-timing-function:ease-in;opacity:0}40%{transform:perspective(400px) rotateX(-20deg);animation-timing-function:ease-in}60%{transform:perspective(400px) rotateX(10deg);opacity:1}80%{transform:perspective(400px) rotateX(-5deg)}to{transform:perspective(400px)}}@keyframes Toastify__flipOut{0%{transform:translate3d(0,var(--y),0) perspective(400px)}30%{transform:translate3d(0,var(--y),0) perspective(400px) rotateX(-20deg);opacity:1}to{transform:translate3d(0,var(--y),0) perspective(400px) rotateX(90deg);opacity:0}}.Toastify__flip-enter{animation-name:Toastify__flipIn}.Toastify__flip-exit{animation-name:Toastify__flipOut}@keyframes Toastify__slideInRight{0%{transform:translate3d(110%,0,0);visibility:visible}to{transform:translate3d(0,var(--y),0)}}@keyframes Toastify__slideInLeft{0%{transform:translate3d(-110%,0,0);visibility:visible}to{transform:translate3d(0,var(--y),0)}}@keyframes Toastify__slideInUp{0%{transform:translate3d(0,110%,0);visibility:visible}to{transform:translate3d(0,var(--y),0)}}@keyframes Toastify__slideInDown{0%{transform:translate3d(0,-110%,0);visibility:visible}to{transform:translate3d(0,var(--y),0)}}@keyframes Toastify__slideOutRight{0%{transform:translate3d(0,var(--y),0)}to{visibility:hidden;transform:translate3d(110%,var(--y),0)}}@keyframes Toastify__slideOutLeft{0%{transform:translate3d(0,var(--y),0)}to{visibility:hidden;transform:translate3d(-110%,var(--y),0)}}@keyframes Toastify__slideOutDown{0%{transform:translate3d(0,var(--y),0)}to{visibility:hidden;transform:translate3d(0,500px,0)}}@keyframes Toastify__slideOutUp{0%{transform:translate3d(0,var(--y),0)}to{visibility:hidden;transform:translate3d(0,-500px,0)}}.Toastify__slide-enter--top-left,.Toastify__slide-enter--bottom-left{animation-name:Toastify__slideInLeft}.Toastify__slide-enter--top-right,.Toastify__slide-enter--bottom-right{animation-name:Toastify__slideInRight}.Toastify__slide-enter--top-center{animation-name:Toastify__slideInDown}.Toastify__slide-enter--bottom-center{animation-name:Toastify__slideInUp}.Toastify__slide-exit--top-left,.Toastify__slide-exit--bottom-left{animation-name:Toastify__slideOutLeft;animation-timing-function:ease-in;animation-duration:.3s}.Toastify__slide-exit--top-right,.Toastify__slide-exit--bottom-right{animation-name:Toastify__slideOutRight;animation-timing-function:ease-in;animation-duration:.3s}.Toastify__slide-exit--top-center{animation-name:Toastify__slideOutUp;animation-timing-function:ease-in;animation-duration:.3s}.Toastify__slide-exit--bottom-center{animation-name:Toastify__slideOutDown;animation-timing-function:ease-in;animation-duration:.3s}@keyframes Toastify__spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.selector-actividad-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:20px;padding:1rem}.actividad-card:before{content:"Servicio";position:absolute;top:-10px;left:10px;background-color:#00c6ff;color:#1e1e2f;font-size:.7rem;font-weight:700;padding:2px 6px;border-radius:4px}.actividad-card{background:linear-gradient(135deg,#2a2a3d,#1e1e2f);border:1px solid #00c6ff;border-radius:12px;padding:18px;text-align:center;color:#fff;box-shadow:0 4px 12px #00c6ff33;transition:transform .2s ease,box-shadow .3s ease;position:relative}.actividad-card:hover{transform:translateY(-4px);box-shadow:0 4px 12px #007bff4d}.actividad-avatar{width:80px;height:80px;border-radius:12px;object-fit:cover;object-position:center;margin-bottom:12px;box-shadow:0 0 8px #00c6ff4d}.actividad-card h4{margin:.5rem 0;color:#00c6ff;font-size:1.2rem;font-weight:600}.actividad-card p{margin:4px 0;font-size:.9rem;color:#bbb}.actividad-card button{margin-top:12px;padding:8px 14px;background-color:#00c6ff;color:#1e1e2f;border:none;border-radius:8px;cursor:pointer;font-weight:600;transition:background .2s ease}.actividad-card button:hover{background-color:#09c}.actividad-card.seleccionada{border:2px solid #00c6ff;box-shadow:0 0 10px #00c6ff66}.actividad-resumen{margin-top:1rem;padding:1.2rem;border:2px dashed #00c6ff;border-radius:12px;background-color:#1e1e2f;color:#fff;box-shadow:0 0 10px #00c6ff33}.actividad-resumen h3{margin-bottom:.5rem;color:#00c6ff;font-size:1.3rem}.actividad-resumen p{margin:6px 0;font-size:.95rem;color:#ccc}.actividad-resumen button{margin-top:12px;padding:8px 16px;background-color:#007bff;color:#fff;border:none;border-radius:6px;cursor:pointer;font-weight:500;transition:background .2s ease}.actividad-resumen button:hover{background-color:#0056b3}.mensaje-sin-actividades{text-align:center;margin-top:1rem;padding:1rem;background-color:#2a2a3d;color:#ff6b6b;border-radius:8px;font-weight:500;box-shadow:0 2px 6px #0000004d}:root{--bg-dark: #1e1e2f;--bg-card: #2a2a3d;--accent: #00c6ff;--text-primary: #ffffff;--text-secondary: #b0b0c0;--success: #4caf50;--danger: #ff6b6b}*{margin:0;padding:0;box-sizing:border-box}body{background-color:var(--bg-dark);color:var(--text-primary);font-family:Inter,system-ui,-apple-system,sans-serif;min-height:100vh;-webkit-font-smoothing:antialiased}h1,h2,h3{color:var(--accent);margin-bottom:1rem}button{cursor:pointer;border:none;font-family:inherit;transition:all .2s ease}img{max-width:100%;height:auto}.container{width:100%;max-width:1200px;margin:0 auto;padding:0 15px}.selector-profesional-grid{display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:1rem;justify-content:center}.profesional-card{width:160px;padding:.75rem;border:1px solid #444;border-radius:10px;text-align:center;cursor:pointer;background-color:#2a2a3d;color:#fff;transition:transform .2s ease,box-shadow .3s ease}.profesional-card:hover{box-shadow:0 0 12px #007bff66;transform:translateY(-3px)}.profesional-card.seleccionado{border:2px solid #00c6ff;background-color:#1e1e2f}.profesional-avatar{width:80px;height:80px;object-fit:cover;object-position:center;border-radius:50%;margin-bottom:.5rem;box-shadow:0 0 6px #0000004d}.profesional-actividad-label{font-size:.85rem;color:#ccc;margin-top:.3rem}:root{--hd-accent: #0f6e56;--hd-accent-mid: #1d9e75;--hd-accent-light: #e1f5ee;--hd-accent-soft: #9fe1cb;--hd-muted: #888780;--hd-muted-light: #b4b2a9;--hd-border: #e5e5e3;--hd-surface: #f6fdf9;--hd-radius: 14px}.horas-disponibles{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;padding:0}.hora-slot{border-radius:var(--hd-radius);padding:14px 12px 12px;border:1.5px solid transparent;background:#fff;transition:transform .12s ease,border-color .15s,background .15s;cursor:pointer;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none;min-height:100px;display:flex;flex-direction:column;gap:4px}.hora-slot:active{transform:scale(.97)}.hora-slot.libre{background:var(--hd-surface);border-color:var(--hd-accent-soft)}.hora-slot.libre:hover{border-color:var(--hd-accent-mid);background:var(--hd-accent-light)}.hora-slot.libre.elegida,.hora-slot.libre:focus-visible{background:var(--hd-accent-mid);border-color:var(--hd-accent);outline:none}.hora-slot.ocupado{background:#fafaf9;border-color:var(--hd-border);cursor:default;opacity:.55;pointer-events:none}.hora-slot .hora-inicio{font-size:20px;font-weight:700;line-height:1;color:#085041;display:block}.hora-slot.elegida .hora-inicio{color:#fff}.hora-slot.ocupado .hora-inicio{color:var(--hd-muted)}.hora-slot .hora-fin{font-size:11px;color:var(--hd-accent-mid);display:block;margin-bottom:6px}.hora-slot.elegida .hora-fin{color:#9fe1cb}.hora-slot.ocupado .hora-fin{color:var(--hd-muted-light)}.estado{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:600;padding:3px 9px;border-radius:99px;width:fit-content;margin-top:auto}.estado:before{content:"";width:6px;height:6px;border-radius:50%;flex-shrink:0}.estado-libre{background:var(--hd-accent-light);color:#085041}.estado-libre:before{background:var(--hd-accent-mid)}.hora-slot.elegida .estado-libre{background:#ffffff38;color:#fff}.hora-slot.elegida .estado-libre:before{background:#fff}.estado-ocupado{background:#f1efeb;color:var(--hd-muted)}.estado-ocupado:before{background:var(--hd-muted-light)}.acciones{margin-top:8px}.acciones button{width:100%;padding:9px 0;border-radius:99px;border:1.5px solid var(--hd-accent);background:transparent;color:var(--hd-accent);font-size:13px;font-weight:600;cursor:pointer;transition:background .12s,color .12s;letter-spacing:.01em}.acciones button:hover{background:var(--hd-accent-light)}.acciones button:active{transform:scale(.97)}.hora-slot.elegida .acciones button{background:#ffffff2e;border-color:#ffffffb3;color:#fff}.hora-slot.elegida .acciones button:hover{background:#ffffff47}.hd-leyenda{display:flex;gap:20px;margin-top:14px;padding-top:12px;border-top:.5px solid var(--hd-border)}.hd-leyenda-item{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--hd-muted)}.hd-leyenda-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.hd-leyenda-dot.libre{background:var(--hd-accent-mid)}.hd-leyenda-dot.ocupado{background:var(--hd-muted-light)}.horas-sin-resultados{text-align:center;padding:32px 16px;color:var(--hd-muted);font-size:14px}.modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#00000080;display:flex;justify-content:center;align-items:center;z-index:999}.modal-content{background:#fff;padding:2rem;border-radius:12px;max-width:400px;width:90%;box-shadow:0 10px 25px #0003;text-align:center}.modal-content h2{margin-bottom:1rem;color:#333}.modal-content input{width:100%;padding:10px 12px;margin:8px 0;border:1px solid #ccc;border-radius:8px;font-size:1rem;transition:border .2s ease}.modal-content input:focus{border-color:#007bff;outline:none}.modal-content button[type=submit]{background-color:#192ee6;color:#fff;padding:10px 16px;border:none;border-radius:8px;margin-top:12px;cursor:pointer;font-size:1rem;width:100%;transition:background .3s ease}.modal-content button[type=submit]:hover{background-color:#125a0f}.modal-content button:not([type=submit]){background:none;border:none;color:#007bff;margin-top:10px;cursor:pointer;font-size:.9rem;text-decoration:underline}.modal-content button:not([type=submit]):hover{color:#0056b3}.error{color:red;margin-top:10px;font-size:.9rem}.modal-footer{display:flex;flex-direction:column;gap:10px;margin-top:15px}.btn-link{background:none!important;border:none!important;color:#007bff!important;text-decoration:underline;cursor:pointer;font-size:.9rem}.btn-link:hover{color:#0056b3!important}:root{--cm-accent: #0F6E56;--cm-accent-mid: #1D9E75;--cm-accent-light: #E1F5EE;--cm-radius-full: 9999px}.cm-wrapper{display:flex;flex-direction:column;min-height:100dvh;max-width:480px;margin:0 auto;background:#fff;position:relative}.cm-header{padding:14px 20px 10px;background:#fff;position:sticky;top:0;z-index:10;border-bottom:.5px solid #e5e5e5}.cm-header-row{display:flex;align-items:center;gap:10px;margin-bottom:12px}.cm-back-btn{width:32px;height:32px;border-radius:50%;border:1px solid #d4d4d0;background:transparent;cursor:pointer;font-size:16px;display:flex;align-items:center;justify-content:center;color:#1a1a1a;flex-shrink:0;transition:background .15s}.cm-back-btn:hover{background:#f5f5f3}.cm-back-btn:disabled{opacity:.3;cursor:default}.cm-step-label{font-size:12px;color:#888780;text-transform:uppercase;letter-spacing:.07em;font-weight:500}.cm-progress-track{display:grid;grid-template-columns:repeat(4,1fr);gap:5px}.cm-progress-seg{height:3px;border-radius:var(--cm-radius-full);background:#e5e5e3;transition:background .3s ease}.cm-progress-seg.done{background:var(--cm-accent-mid)}.cm-progress-seg.active{background:var(--cm-accent)}.cm-step-header{padding:16px 20px 0}.cm-step-title{font-size:20px;font-weight:600;color:#1a1a1a;margin:0 0 4px}.cm-step-sub{font-size:14px;color:#888780;margin:0 0 14px}.cm-content{flex:1;padding:0 16px 100px;overflow-y:auto}.cm-calendario{margin-top:4px}.cm-dias-semana{display:grid;grid-template-columns:repeat(7,1fr);text-align:center;margin-bottom:6px}.cm-dia-label{font-size:12px;color:#888780;font-weight:500;padding:4px 0}.cm-dias-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:3px}.cm-dia{aspect-ratio:1;display:flex;align-items:center;justify-content:center;border-radius:50%;font-size:13px;font-weight:400;background:transparent;border:none;cursor:pointer;color:#1a1a1a;transition:background .15s,color .15s}.cm-dia:hover:not(.cm-dia--pasado):not(.cm-dia--selected){background:var(--cm-accent-light)}.cm-dia--empty{background:transparent;pointer-events:none}.cm-dia--pasado{color:#c5c3bb;cursor:default}.cm-dia--hoy{border:1.5px solid var(--cm-accent-mid);color:var(--cm-accent);font-weight:600}.cm-dia--selected{background:var(--cm-accent-mid);color:#fff;font-weight:600}.cm-summary-card{background:#f8f8f6;border-radius:14px;padding:14px 16px;margin-bottom:12px}.cm-summary-card--sm{margin-bottom:14px}.cm-summary-row{display:flex;justify-content:space-between;align-items:flex-start;padding:7px 0;border-bottom:.5px solid #ebebea;gap:12px}.cm-summary-row:last-child{border-bottom:none}.cm-summary-label{font-size:13px;color:#888780;white-space:nowrap}.cm-summary-value{font-size:13px;font-weight:500;color:#1a1a1a;text-align:right}.cm-horas-label{font-size:13px;color:#888780;margin:0 0 10px}.cm-loading{text-align:center;color:#888780;font-size:14px;padding:24px 0}.cm-footer{position:sticky;bottom:0;padding:12px 16px 24px;background:#fff;border-top:.5px solid #ebebea}.cm-btn-primary{width:100%;padding:15px;background:var(--cm-accent);color:#fff;border:none;border-radius:14px;font-size:16px;font-weight:600;cursor:pointer;transition:opacity .15s,transform .1s;letter-spacing:.01em}.cm-btn-primary:hover{opacity:.9}.cm-btn-primary:active{transform:scale(.985)}.cm-btn-primary:disabled{opacity:.35;cursor:default;transform:none}.cm-screen{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:32px 20px 40px;text-align:center}.cm-success-icon{width:64px;height:64px;border-radius:50%;background:var(--cm-accent-light);display:flex;align-items:center;justify-content:center;font-size:28px;color:var(--cm-accent);margin-bottom:16px}.cm-success-title{font-size:22px;font-weight:700;color:#1a1a1a;margin:0 0 6px}.cm-success-sub{font-size:15px;color:#888780;margin:0 0 24px}.cm-mes-nav{display:flex;justify-content:center;margin-bottom:14px}.cm-mes-pill{display:inline-flex;align-items:center;gap:16px;background:#0f6e56;border-radius:999px;padding:8px 20px}.cm-mes-titulo{color:#fff;font-weight:500;font-size:15px;text-transform:capitalize;min-width:130px;text-align:center}.cm-mes-btn{background:#fff3;color:#fff;border:none;border-radius:50%;width:30px;height:30px;font-size:18px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s}.cm-mes-btn:hover:not(:disabled){background:#ffffff59}.cm-mes-btn:disabled{opacity:.3;cursor:not-allowed}@media(min-width:600px){.cm-wrapper{min-height:auto;border-radius:20px;box-shadow:0 4px 32px #00000014;margin:32px auto}.cm-content{padding-bottom:120px}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.mis-reservas-container{max-width:600px;margin:0 auto;padding:24px 16px;background-color:var(--bg-dark);min-height:100vh}.reserva-lista{display:flex;flex-direction:column;gap:14px}.reserva-card{background-color:var(--bg-card);border:1px solid rgba(255,255,255,.05);border-radius:18px;padding:20px;box-shadow:0 4px 12px #0003;transition:all .3s cubic-bezier(.4,0,.2,1);animation:fadeInUp .4s ease backwards;-webkit-tap-highlight-color:transparent}.reserva-card:active{background-color:#232334;border-color:var(--accent);transform:scale(.97);box-shadow:inset 0 2px 10px #0000004d}.reserva-card h3{margin:0 0 10px;color:var(--accent);font-size:1.15rem;font-weight:700;letter-spacing:-.01em}.reserva-card p{margin:6px 0;font-size:14px;color:var(--text-secondary);line-height:1.5;display:flex;align-items:center;gap:6px}.confirmar-button{width:100%;margin-top:12px;height:46px;background:#228b221a;color:#1b5e20;border:1px solid rgba(34,139,34,.3);border-radius:12px;font-weight:700;font-size:13px;text-transform:uppercase;letter-spacing:.8px;transition:.2s ease;cursor:pointer}.confirmar-button:hover{background:#228b2226;border-color:#228b2280}.confirmar-button:active{background:#1b5e20;color:#fff;transform:scale(.95)}.confirmar-button:disabled{opacity:.6;cursor:not-allowed;filter:grayscale(1)}.liberar-button{width:100%;margin-top:18px;height:46px;background:#ff6b6b14;color:var(--danger);border:1px solid rgba(255,107,107,.2);border-radius:12px;font-weight:700;font-size:13px;text-transform:uppercase;letter-spacing:.8px;transition:.2s ease}.liberar-button:active{background:var(--danger);color:#fff;transform:scale(.95)}.volver-calendario{width:100%;margin:32px 0;height:52px;background:var(--accent);color:#1e1e2f;border:none;border-radius:14px;font-weight:800;font-size:15px;box-shadow:0 6px 20px #00c6ff40;transition:.2s}.volver-calendario:active{transform:translateY(2px);box-shadow:none}.alerta-reajuste{background:#00c6ff0a;border-left:3px solid var(--accent);padding:14px;margin:20px 0;border-radius:10px;color:var(--text-secondary);font-size:13px;line-height:1.4}.success-message,.error-message{padding:12px;border-radius:10px;text-align:center;font-weight:600;font-size:14px;margin:10px 0}.success-message{background:#4caf501a;color:var(--success)}.error-message{background:#ff6b6b1a;color:var(--danger)}.reserva-pasada{opacity:.35;filter:grayscale(1);pointer-events:none;background-color:#ffffff05;border:1px dashed rgba(255,255,255,.1)}:root{--nav-h: 62px;--nav-bg: #0f0f14;--nav-border: rgba(255, 255, 255, .07);--nav-text: #e8e6f0;--nav-muted: rgba(232, 230, 240, .45);--nav-accent: #7c6af7;--nav-accent-tic: #719ab6;--nav-accent-dim: rgba(124, 106, 247, .15);--nav-danger: #f07070;--nav-radius: 10px;--nav-font: "Outfit", "Segoe UI", sans-serif;--nav-transition: .18s cubic-bezier(.4, 0, .2, 1)}.navbar{position:sticky;top:0;z-index:1200;background:var(--nav-bg);border-bottom:1px solid var(--nav-border);font-family:var(--nav-font);-webkit-font-smoothing:antialiased}.navbar-container{max-width:1200px;margin:0 auto;height:var(--nav-h);padding:0 1.5rem;display:flex;align-items:center;gap:1.5rem}.navbar-logo{display:flex;align-items:center;gap:10px;background:none;border:none;cursor:pointer;padding:0;flex-shrink:0;text-decoration:none}.logo-img{width:36px;height:36px;border-radius:8px;object-fit:cover;border:1.5px solid rgba(124,106,247,.4)}.logo-text{display:flex;flex-direction:column;line-height:1.1}.logo-main{font-size:.95rem;font-weight:600;color:var(--nav-text);letter-spacing:.01em}.logo-sub{font-size:.72rem;color:var(--nav-accent);font-weight:500;letter-spacing:.08em;text-transform:uppercase}.logo-tic{font-size:.72rem;color:var(--nav-accent-tic);font-weight:500;letter-spacing:.08em;text-transform:uppercase}.navbar-links{display:flex;align-items:center;gap:.25rem;flex:1;margin-left:1rem}.nav-link{background:none;border:none;cursor:pointer;font-family:var(--nav-font);font-size:.875rem;font-weight:500;color:var(--nav-muted);padding:.4rem .75rem;border-radius:7px;transition:color var(--nav-transition),background var(--nav-transition);white-space:nowrap}.nav-link:hover{color:var(--nav-text);background:#ffffff0f}.navbar-actions{display:flex;align-items:center;gap:.75rem;margin-left:auto}.btn-login{padding:.45rem 1.1rem;background:var(--nav-accent-dim);border:1px solid rgba(124,106,247,.35);border-radius:8px;color:#b8b0ff;font-family:var(--nav-font);font-size:.875rem;font-weight:500;cursor:pointer;transition:background var(--nav-transition),border-color var(--nav-transition);white-space:nowrap}.btn-login:hover{background:#7c6af740;border-color:#7c6af799}.user-dropdown{position:relative}.avatar-btn{display:flex;align-items:center;gap:8px;background:#ffffff0a;border:1px solid var(--nav-border);border-radius:9px;padding:.35rem .7rem .35rem .4rem;cursor:pointer;font-family:var(--nav-font);color:var(--nav-text);transition:background var(--nav-transition),border-color var(--nav-transition)}.avatar-btn:hover{background:#ffffff14;border-color:#ffffff26}.avatar-initials{width:28px;height:28px;border-radius:6px;background:var(--nav-accent);color:#fff;font-size:.72rem;font-weight:600;display:flex;align-items:center;justify-content:center;letter-spacing:.03em;flex-shrink:0}.avatar-name{font-size:.875rem;font-weight:500;color:var(--nav-text)}.chevron{color:var(--nav-muted);transition:transform var(--nav-transition);flex-shrink:0}.chevron.open{transform:rotate(180deg)}.dropdown-menu{position:absolute;top:calc(100% + 10px);right:0;min-width:200px;background:#18181f;border:1px solid rgba(255,255,255,.1);border-radius:var(--nav-radius);padding:.4rem;box-shadow:0 12px 40px #00000080;animation:dropDown .16s ease;z-index:100}@keyframes dropDown{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.dropdown-header{display:flex;flex-direction:column;padding:.55rem .75rem .5rem}.dropdown-name{font-size:.875rem;font-weight:600;color:var(--nav-text)}.dropdown-role{font-size:.72rem;color:var(--nav-accent);text-transform:capitalize;letter-spacing:.05em;margin-top:1px}.dropdown-divider{height:1px;background:var(--nav-border);margin:.3rem 0}.dropdown-item{display:flex;align-items:center;gap:9px;width:100%;background:none;border:none;cursor:pointer;font-family:var(--nav-font);font-size:.875rem;color:var(--nav-muted);padding:.5rem .75rem;border-radius:7px;transition:background var(--nav-transition),color var(--nav-transition);text-align:left}.dropdown-item:hover{background:#ffffff0f;color:var(--nav-text)}.dropdown-item.danger{color:#f07070b3}.dropdown-item.danger:hover{background:#f070701a;color:var(--nav-danger)}.dropdown-icon{font-size:.85rem;width:16px;text-align:center;flex-shrink:0}.menu-toggle{display:none;flex-direction:column;justify-content:center;gap:5px;width:36px;height:36px;background:none;border:1px solid var(--nav-border);border-radius:8px;cursor:pointer;padding:8px;transition:background var(--nav-transition)}.menu-toggle:hover{background:#ffffff0f}.menu-toggle span{display:block;height:1.5px;background:var(--nav-text);border-radius:2px;transition:transform var(--nav-transition),opacity var(--nav-transition);transform-origin:center}.menu-toggle.open span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}.menu-toggle.open span:nth-child(2){opacity:0;transform:scaleX(0)}.menu-toggle.open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}.mobile-menu{display:none;flex-direction:column;background:#0f0f14;border-top:1px solid var(--nav-border);padding:.5rem 1rem 1rem;animation:slideDown .2s ease}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.mobile-menu.active{display:flex}.mobile-link{background:none;border:none;cursor:pointer;font-family:var(--nav-font);font-size:.95rem;font-weight:500;color:var(--nav-muted);padding:.7rem .5rem;text-align:left;border-bottom:1px solid var(--nav-border);transition:color var(--nav-transition)}.mobile-link:last-child{border-bottom:none}.mobile-link:hover{color:var(--nav-text)}.mobile-link.danger{color:#f07070b3}.mobile-link.danger:hover{color:var(--nav-danger)}.mobile-link.highlight{color:#b8b0ff;font-weight:600}@media(max-width:768px){.navbar-links{display:none}.menu-toggle{display:flex}}@media(max-width:480px){.navbar-container{padding:0 1rem}.avatar-name{display:none}}.login-privado{background-color:#f5f5f5;color:#333;padding:2rem;min-height:100vh;display:flex;flex-direction:column;align-items:center}.login-form{background-color:#fff;padding:1.5rem;border-radius:8px;box-shadow:0 2px 6px #0000001a;width:100%;max-width:400px}.login-form label{display:block;margin-top:1rem;font-weight:500}.login-form input,.login-form select{width:100%;padding:8px;margin-top:.3rem;border:1px solid #ccc;border-radius:4px}.login-form button{margin-top:1.5rem;width:100%;background-color:#00bcd4;color:#fff;border:none;padding:.6rem;border-radius:4px;cursor:pointer}.login-form button:hover{background-color:#0097a7}.reservas-section{margin-top:24px}.reservas-titulo{display:flex;align-items:center;gap:8px;font-size:15px;font-weight:700;color:var(--color-text, #1e1b4b);margin:0 0 14px}.reservas-titulo svg{width:18px;height:18px;color:var(--color-primary, #4f46e5)}.reservas-count{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;background:var(--color-primary, #4f46e5);color:#fff;border-radius:50%;font-size:11px;font-weight:700;margin-left:2px}.reservas-empty{display:flex;flex-direction:column;align-items:center;gap:8px;padding:32px 20px;text-align:center;color:var(--color-text-muted, #6b7280);background:var(--color-surface-2, #f0f2f9);border-radius:10px;border:1.5px dashed var(--color-border, #e4e7f0);margin-top:16px}.reservas-empty svg{width:36px;height:36px;opacity:.35}.reservas-empty p{margin:0;font-size:13px}.reservas-grid{display:flex;flex-direction:column;gap:10px}.reserva-card{background:var(--color-surface, #fff);border:1.5px solid var(--color-border, #e4e7f0);border-radius:10px;padding:14px 16px;display:flex;flex-direction:column;gap:10px;transition:box-shadow .2s,border-color .2s}.reserva-card:hover{box-shadow:0 2px 12px #4f46e514;border-color:#c7d2fe}.reserva-card.estado-confirmada{border-left:4px solid var(--color-primary, #4f46e5)}.reserva-card.estado-pendiente{border-left:4px solid var(--color-warning, #f59e0b)}.reserva-card.estado-bloqueada{border-left:4px solid var(--color-text-muted, #9ca3af);background:#fafafa}.reserva-card.estado-cancelada{border-left:4px solid var(--color-danger, #ef4444);opacity:.7}.reserva-hora{display:flex;align-items:center;gap:6px;color:var(--color-text, #1e1b4b)}.reserva-hora svg{width:15px;height:15px;color:var(--color-primary, #4f46e5);flex-shrink:0}.reserva-hora strong{font-size:15px;font-weight:700;letter-spacing:.01em}.reserva-detalle{display:flex;flex-direction:column;gap:3px}.reserva-actividad{font-size:14px;font-weight:600;color:var(--color-text, #1e1b4b);margin:0}.reserva-cliente{display:flex;align-items:center;gap:5px;font-size:13px;color:var(--color-text-muted, #6b7280);margin:0}.reserva-cliente svg{width:13px;height:13px;flex-shrink:0}.estado-badge{display:inline-flex;align-items:center;padding:2px 9px;border-radius:20px;font-size:11px;font-weight:600;width:fit-content;margin-top:2px}.estado-badge-confirmada{background:var(--color-primary-light, #ede9fe);color:var(--color-primary, #4f46e5)}.estado-badge-pendiente{background:var(--color-warning-light, #fffbeb);color:#92400e}.estado-badge-bloqueada{background:#f3f4f6;color:#374151}.estado-badge-cancelada{background:var(--color-danger-light, #fef2f2);color:var(--color-danger, #ef4444)}.motivo-bloqueo{font-size:12px;color:var(--color-warning, #f59e0b);margin:4px 0 0;font-weight:500}.bloqueo-inline{display:flex;flex-direction:column;gap:6px;padding:12px;background:var(--color-warning-light, #fffbeb);border:1.5px solid #fcd34d;border-radius:8px;animation:slideDown .18s ease}@keyframes slideDown{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.bloqueo-inline label{font-size:11px;font-weight:600;color:#92400e;text-transform:uppercase;letter-spacing:.05em}.bloqueo-inline input{padding:8px 10px;border:1.5px solid #fcd34d;border-radius:6px;font-size:13px;color:var(--color-text, #1e1b4b);background:#fff;outline:none;font-family:inherit;transition:border-color .18s}.bloqueo-inline input:focus{border-color:var(--color-warning, #f59e0b);box-shadow:0 0 0 3px #f59e0b26}.bloqueo-inline-acciones{display:flex;gap:6px;justify-content:flex-end}.btn-inline-cancelar{padding:5px 12px;border-radius:6px;border:1px solid #d1d5db;background:#fff;color:var(--color-text-muted, #6b7280);font-size:12px;font-weight:500;cursor:pointer;transition:background .15s}.btn-inline-cancelar:hover{background:#f3f4f6}.btn-inline-confirmar{padding:5px 12px;border-radius:6px;border:none;background:var(--color-warning, #f59e0b);color:#fff;font-size:12px;font-weight:600;cursor:pointer;transition:background .15s}.btn-inline-confirmar:hover{background:#d97706}.reserva-acciones{display:flex;gap:6px;flex-wrap:wrap;align-items:center;padding-top:4px;border-top:1px solid var(--color-border, #e4e7f0)}.reserva-acciones button{display:inline-flex;align-items:center;gap:5px;padding:6px 12px;border-radius:7px;font-size:12px;font-weight:600;cursor:pointer;border:1.5px solid transparent;transition:background .18s,color .18s,transform .1s;white-space:nowrap}.reserva-acciones button:active{transform:scale(.97)}.reserva-acciones button svg{width:13px;height:13px}.btn-mover{background:var(--color-primary-light, #ede9fe);color:var(--color-primary, #4f46e5);border-color:#c4b5fd!important}.btn-mover:hover{background:#ddd6fe}.btn-bloquear{background:#f3f4f6;color:#374151;border-color:#d1d5db!important}.btn-bloquear:hover{background:#e5e7eb}.btn-desbloquear{background:var(--color-success-light, #d1fae5);color:#065f46;border-color:#6ee7b7!important}.btn-desbloquear:hover{background:#a7f3d0}.btn-eliminar-reserva{background:var(--color-danger-light, #fef2f2);color:var(--color-danger, #ef4444);border-color:#fca5a5!important;margin-left:auto}.btn-eliminar-reserva:hover{background:#fee2e2;color:#dc2626}@media(max-width:500px){.reserva-acciones{justify-content:flex-start}.btn-eliminar-reserva{margin-left:0}}.agenda-tablero,.agenda-empty{--agenda-font: "DM Sans", sans-serif;--agenda-mono: "Syne", sans-serif;--agenda-bg: var(--color-surface, #fff);--agenda-surface2: var(--color-surface-2, #f0f2f9);--agenda-border: var(--color-border, #e4e7f0);--agenda-text: var(--color-text, #1e1b4b);--agenda-muted: var(--color-text-muted, #6b7280);--ficha-reservada-bg: #ede9fe;--ficha-reservada-borde: #7c3aed;--ficha-reservada-text: #3730a3;--ficha-confirmada-bg: #dbeafe;--ficha-confirmada-borde: #2563eb;--ficha-confirmada-text: #1e40af;--ficha-bloqueada-bg: #f3f4f6;--ficha-bloqueada-borde: #6b7280;--ficha-bloqueada-text: #374151;--ficha-cumplida-bg: #d1fae5;--ficha-cumplida-borde: #059669;--ficha-cumplida-text: #065f46;--ficha-cancelada-bg: #fee2e2;--ficha-cancelada-borde: #dc2626;--ficha-cancelada-text: #991b1b;--px-min: 2.2px;--eje-w: 56px;font-family:var(--agenda-font)}.agenda-empty{display:flex;flex-direction:column;align-items:center;gap:10px;padding:48px 20px;text-align:center;color:var(--agenda-muted);background:var(--agenda-surface2);border-radius:12px;border:1.5px dashed var(--agenda-border)}.agenda-empty svg{width:48px;height:48px;opacity:.3}.agenda-empty p{margin:0;font-size:14px;font-weight:500;color:var(--agenda-text)}.agenda-empty small{font-size:12px}.agenda-tablero{display:flex;flex-direction:column;gap:0}.agenda-leyenda{display:flex;align-items:center;gap:18px;padding:10px 0 16px;flex-wrap:wrap}.leyenda-item{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--agenda-muted)}.leyenda-dot{width:10px;height:10px;border-radius:3px;flex-shrink:0}.dot-libre{background:#e9f5ff;border:1.5px solid #93c5fd}.dot-reservada{background:var(--ficha-reservada-bg);border:1.5px solid var(--ficha-reservada-borde)}.dot-bloqueada{background:var(--ficha-bloqueada-bg);border:1.5px solid var(--ficha-bloqueada-borde)}.leyenda-drag{color:var(--agenda-muted);gap:4px}.leyenda-drag svg{width:14px;height:14px}.agenda-franjas{display:flex;flex-direction:column;gap:20px}.franja-tablero{background:var(--agenda-bg);border:1.5px solid var(--agenda-border);border-radius:12px;overflow:hidden;box-shadow:0 1px 4px #0000000d;transition:box-shadow .2s}.franja-tablero:hover{box-shadow:0 2px 12px #4f46e514}.franja-header{display:flex;align-items:center;justify-content:space-between;padding:10px 16px;background:var(--agenda-surface2);border-bottom:1px solid var(--agenda-border);gap:12px}.franja-header-info{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.franja-rango{font-family:var(--agenda-mono);font-size:15px;font-weight:600;color:var(--agenda-text);letter-spacing:-.01em}.franja-duracion{font-size:12px;color:var(--agenda-muted)}.franja-badge-reservas{padding:2px 8px;background:#ede9fe;color:#3730a3;border:1px solid #c4b5fd;border-radius:20px;font-size:11px;font-weight:600}.franja-header-acciones{display:flex;gap:4px;flex-shrink:0}.franja-btn-editar,.franja-btn-eliminar{display:flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:8px;border:1px solid var(--agenda-border);background:var(--agenda-bg);cursor:pointer;transition:background .15s,border-color .15s}.franja-btn-editar svg,.franja-btn-eliminar svg{width:14px;height:14px}.franja-btn-editar{color:#4f46e5}.franja-btn-editar:hover{background:#ede9fe;border-color:#c4b5fd}.franja-btn-eliminar{color:#ef4444}.franja-btn-eliminar:hover{background:#fef2f2;border-color:#fca5a5}.franja-timeline{display:flex;position:relative;min-height:60px;transition:background .15s}.franja-timeline.drop-target{background:#4f46e50a}.timeline-eje{position:relative;flex-shrink:0;border-right:1px solid var(--agenda-border);background:var(--agenda-surface2)}.timeline-marca{position:absolute;left:0;right:0;display:flex;align-items:flex-start;padding-left:8px;transform:translateY(-6px)}.marca-hora{font-family:var(--agenda-mono);font-size:11px;font-weight:600;color:var(--agenda-muted);white-space:nowrap;line-height:1}.timeline-area{flex:1;position:relative;overflow:hidden}.guia-linea{position:absolute;left:0;right:0;height:1px;background:var(--agenda-border);opacity:.6;pointer-events:none}.zona-pasada{position:absolute;top:0;left:0;right:0;background:repeating-linear-gradient(-45deg,transparent,transparent 4px,rgba(0,0,0,.03) 4px,rgba(0,0,0,.03) 8px);pointer-events:none;z-index:1}.linea-ahora{position:absolute;left:0;right:0;height:2px;background:#ef4444;z-index:10;pointer-events:none}.linea-ahora-dot{position:absolute;left:-4px;top:-4px;width:10px;height:10px;background:#ef4444;border-radius:50%;border:2px solid white;box-shadow:0 0 0 1px #ef4444}.drop-preview{position:absolute;left:4px;right:4px;height:44px;background:#4f46e51f;border:2px dashed #7c3aed;border-radius:8px;pointer-events:none;z-index:5}.ficha-reserva{position:absolute;left:6px;right:6px;border-radius:8px;border-left:3px solid;padding:5px 8px;cursor:grab;z-index:3;transition:box-shadow .15s,transform .1s,opacity .15s;overflow:hidden;display:flex;flex-direction:column;gap:2px;-webkit-user-select:none;user-select:none;box-shadow:0 1px 3px #00000014}.ficha-reserva:hover{box-shadow:0 4px 12px #0000001f;transform:translate(1px);z-index:4}.ficha-reserva:active{cursor:grabbing}.ficha-dragging{opacity:.4;transform:scale(.97)}.ficha-past{cursor:default;opacity:.55;filter:grayscale(.3)}.ficha-past:hover{transform:none;box-shadow:0 1px 3px #00000014}.ficha-reservada{background:var(--ficha-reservada-bg);border-color:var(--ficha-reservada-borde);color:var(--ficha-reservada-text)}.ficha-confirmada{background:var(--ficha-confirmada-bg);border-color:var(--ficha-confirmada-borde);color:var(--ficha-confirmada-text)}.ficha-bloqueada{background:var(--ficha-bloqueada-bg);border-color:var(--ficha-bloqueada-borde);color:var(--ficha-bloqueada-text)}.ficha-cumplida{background:var(--ficha-cumplida-bg);border-color:var(--ficha-cumplida-borde);color:var(--ficha-cumplida-text)}.ficha-cancelada{background:var(--ficha-cancelada-bg);border-color:var(--ficha-cancelada-borde);color:var(--ficha-cancelada-text)}.ficha-header{display:flex;align-items:center;justify-content:space-between;gap:4px}.ficha-hora{font-family:var(--agenda-mono);font-size:11px;font-weight:600;letter-spacing:-.01em;white-space:nowrap}.ficha-drag-icon{opacity:.5;flex-shrink:0}.ficha-drag-icon svg{width:12px;height:12px}.ficha-body{display:flex;flex-direction:column;gap:1px;min-width:0}.ficha-cliente{font-size:12px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ficha-actividad{font-size:11px;opacity:.75;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ficha-estado-dot{position:absolute;top:6px;right:6px;width:7px;height:7px;border-radius:50%;flex-shrink:0}.estado-dot-reservada{background:var(--ficha-reservada-borde)}.estado-dot-confirmada{background:var(--ficha-confirmada-borde)}.estado-dot-bloqueada{background:var(--ficha-bloqueada-borde)}.estado-dot-cumplida{background:var(--ficha-cumplida-borde)}.estado-dot-cancelada{background:var(--ficha-cancelada-borde)}.agenda-modal-overlay{position:fixed;inset:0;background:#0f0f2373;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.agenda-modal-confirm{background:var(--agenda-bg, #fff);border-radius:16px;padding:28px;width:100%;max-width:380px;text-align:center;box-shadow:0 20px 60px #0000002e;animation:modalIn .2s cubic-bezier(.34,1.56,.64,1)}@keyframes modalIn{0%{transform:scale(.9) translateY(10px);opacity:0}to{transform:scale(1) translateY(0);opacity:1}}.confirm-icon{width:48px;height:48px;background:#ede9fe;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 14px;color:#4f46e5}.confirm-icon svg{width:22px;height:22px}.agenda-modal-confirm h3{font-size:17px;font-weight:700;margin:0 0 16px;color:var(--agenda-text, #1e1b4b)}.confirm-detalles{background:var(--agenda-surface2, #f0f2f9);border-radius:10px;padding:12px 16px;text-align:left;margin-bottom:12px;display:flex;flex-direction:column;gap:8px}.confirm-fila{display:flex;align-items:center;justify-content:space-between;gap:8px}.confirm-fila span{font-size:12px;color:var(--agenda-muted, #6b7280);text-transform:uppercase;letter-spacing:.04em;font-weight:600;white-space:nowrap}.confirm-fila strong{font-size:13px;font-weight:600;color:var(--agenda-text, #1e1b4b);text-align:right}.hora-old{text-decoration:line-through;opacity:.6;font-family:var(--agenda-mono)}.hora-new{color:#059669!important;font-family:var(--agenda-mono);font-size:14px!important}.confirm-aviso{font-size:12px;color:var(--agenda-muted, #6b7280);margin:0 0 18px;line-height:1.5}.confirm-acciones{display:flex;gap:10px;justify-content:center}.confirm-acciones .btn-ghost,.confirm-acciones .btn-primary{flex:1;justify-content:center}@media(max-width:600px){.franja-header{flex-direction:column;align-items:flex-start}.franja-header-acciones{align-self:flex-end}.timeline-eje{width:44px}.marca-hora{font-size:10px}}.franja-recorte-panel{padding:12px 16px;background:var(--agenda-surface2);border-bottom:1px solid var(--agenda-border);display:flex;flex-direction:column;gap:8px}.recorte-label{font-size:13px;font-weight:500;color:var(--agenda-text);margin:0}.recorte-controles{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.recorte-campo{display:flex;flex-direction:column;gap:4px}.recorte-campo label{font-size:11px;font-weight:600;color:var(--agenda-muted);text-transform:uppercase;letter-spacing:.04em}.recorte-controles input[type=time]{padding:6px 10px;border:1px solid var(--agenda-border);border-radius:8px;font-size:13px;font-family:var(--agenda-mono);background:var(--agenda-bg);color:var(--agenda-text);transition:border-color .15s}.recorte-controles input[type=time]:focus{outline:none;border-color:#f59e0b;box-shadow:0 0 0 3px #f59e0b26}.recorte-error{font-size:12px;color:#ef4444;margin:0}.recorte-aviso{font-size:12px;color:var(--agenda-muted);margin:0;line-height:1.5}.btn-sm{padding:6px 14px;font-size:13px;height:32px;align-self:flex-end}.franja-btn-recortar{display:flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:8px;border:1px solid var(--agenda-border);background:var(--agenda-bg);cursor:pointer;color:#f59e0b;transition:background .15s,border-color .15s}.franja-btn-recortar svg{width:14px;height:14px}.franja-btn-recortar:hover{background:var(--color-background-tertiary);color:var(--color-text-primary)}.modal-mover-cita{background:var(--color-surface, #fff);border-radius:16px;width:100%;max-width:440px;box-shadow:0 20px 60px #0000002e;animation:modalIn .2s cubic-bezier(.34,1.56,.64,1);overflow:hidden}.modal-header-icon.mover-icon{background:var(--color-primary-light, #ede9fe);color:var(--color-primary, #4f46e5);width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.modal-header-icon.mover-icon svg{width:20px;height:20px}.mover-resumen{display:flex;flex-direction:column;gap:8px;padding:14px;background:var(--color-surface-2, #f0f2f9);border-radius:10px;margin-bottom:16px}.mover-resumen-fila{display:flex;align-items:center;justify-content:space-between;gap:12px}.mover-label{font-size:12px;font-weight:600;color:var(--color-text-muted, #6b7280);text-transform:uppercase;letter-spacing:.04em;white-space:nowrap}.mover-valor{font-size:13px;font-weight:500;color:var(--color-text, #1e1b4b);text-align:right}.hora-actual-badge{display:inline-flex;padding:2px 10px;background:var(--color-warning-light, #fffbeb);color:#92400e;border:1px solid #fcd34d;border-radius:20px;font-size:12px;font-weight:700}.rango-badge{display:inline-flex;padding:2px 10px;background:var(--color-primary-light, #ede9fe);color:var(--color-primary, #4f46e5);border:1px solid #c4b5fd;border-radius:20px;font-size:12px;font-weight:600}.mover-advertencia{display:flex;align-items:flex-start;gap:9px;padding:10px 13px;background:var(--color-warning-light, #fffbeb);border:1px solid #fcd34d;border-radius:8px;margin-bottom:16px}.mover-advertencia svg{width:16px;height:16px;flex-shrink:0;margin-top:1px;stroke:var(--color-warning, #f59e0b)}.mover-advertencia p{margin:0;font-size:12px;color:#92400e;line-height:1.5}.mover-input-group{display:flex;flex-direction:column;gap:6px}.mover-input-group label{font-size:12px;font-weight:600;color:var(--color-text-muted, #6b7280);text-transform:uppercase;letter-spacing:.05em}.mover-input-group input[type=time]{padding:10px 14px;border:1.5px solid var(--color-border, #e4e7f0);border-radius:8px;font-size:16px;font-weight:600;color:var(--color-text, #1e1b4b);background:var(--color-surface, #fff);outline:none;font-family:inherit;transition:border-color .18s,box-shadow .18s;width:100%}.mover-input-group input[type=time]:focus{border-color:var(--color-primary, #4f46e5);box-shadow:0 0 0 3px var(--color-primary-light, #ede9fe)}.mover-error{font-size:12px;color:var(--color-danger, #ef4444);margin:0;padding:6px 10px;background:var(--color-danger-light, #fef2f2);border-radius:6px;border:1px solid #fca5a5}:root{--color-bg: #f7f8fc;--color-surface: #ffffff;--color-surface-2: #f0f2f9;--color-border: #e4e7f0;--color-primary: #4f46e5;--color-primary-light: #ede9fe;--color-primary-dark: #3730a3;--color-danger: #ef4444;--color-danger-light: #fef2f2;--color-success: #10b981;--color-success-light: #d1fae5;--color-warning: #f59e0b;--color-warning-light: #fffbeb;--color-text: #1e1b4b;--color-text-muted: #6b7280;--color-text-light: #9ca3af;--sidebar-width: 220px;--sidebar-collapsed-width: 64px;--radius: 12px;--radius-sm: 8px;--shadow: 0 1px 3px rgba(0, 0, 0, .08), 0 4px 16px rgba(79, 70, 229, .06);--shadow-md: 0 4px 24px rgba(0, 0, 0, .1);--transition: .22s cubic-bezier(.4, 0, .2, 1)}.panel-profesional{display:flex;min-height:100vh;background:var(--color-bg);font-family:DM Sans,Segoe UI,sans-serif;color:var(--color-text)}.panel-main{flex:1;margin-left:var(--sidebar-width);padding:28px 32px;transition:margin-left var(--transition);max-width:100%;overflow-x:hidden}.panel-profesional.sidebar-collapsed .panel-main{margin-left:var(--sidebar-collapsed-width)}.sidebar-nav{position:fixed;top:0;left:0;height:100vh;width:var(--sidebar-width);background:var(--color-surface);border-right:1px solid var(--color-border);display:flex;flex-direction:column;padding:20px 12px 16px;z-index:100;transition:width var(--transition);box-shadow:2px 0 16px #4f46e50d;overflow:hidden}.sidebar-nav.collapsed{width:var(--sidebar-collapsed-width)}.sidebar-profile{display:flex;align-items:center;gap:12px;padding:8px 4px 4px;margin-bottom:4px}.sidebar-avatar,.sidebar-avatar-placeholder{width:40px;height:40px;border-radius:50%;object-fit:cover;flex-shrink:0;border:2px solid var(--color-primary-light)}.sidebar-avatar-placeholder{background:var(--color-primary);color:#fff;font-weight:700;font-size:16px;display:flex;align-items:center;justify-content:center}.sidebar-profile-info{display:flex;flex-direction:column;overflow:hidden}.sidebar-name{font-size:14px;font-weight:600;color:var(--color-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-role{font-size:11px;color:var(--color-text-muted);margin-top:1px}.sidebar-divider{height:1px;background:var(--color-border);margin:12px 4px}.sidebar-nav-items{flex:1;display:flex;flex-direction:column;gap:2px}.sidebar-nav-item{position:relative;display:flex;align-items:center;gap:12px;padding:10px;border-radius:var(--radius-sm);border:none;background:transparent;cursor:pointer;color:var(--color-text-muted);font-size:14px;font-weight:500;text-align:left;transition:background var(--transition),color var(--transition);white-space:nowrap;overflow:hidden}.sidebar-nav-item:hover{background:var(--color-primary-light);color:var(--color-primary)}.sidebar-nav-item.active{background:var(--color-primary-light);color:var(--color-primary);font-weight:600}.sidebar-active-bar{position:absolute;right:0;top:6px;bottom:6px;width:3px;background:var(--color-primary);border-radius:2px}.sidebar-icon{width:20px;height:20px;flex-shrink:0;display:flex;align-items:center;justify-content:center}.sidebar-icon svg{width:20px;height:20px}.sidebar-label{font-size:14px}.sidebar-collapse-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;margin:8px auto 0;border-radius:50%;border:1px solid var(--color-border);background:var(--color-surface);cursor:pointer;color:var(--color-text-muted);transition:background var(--transition),color var(--transition)}.sidebar-collapse-btn:hover{background:var(--color-primary-light);color:var(--color-primary)}.sidebar-collapse-btn svg{width:16px;height:16px}.section-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:20px;flex-wrap:wrap;gap:12px}.section-title{font-size:22px;font-weight:700;color:var(--color-text);margin:0}.section-subtitle{font-size:13px;color:var(--color-text-muted);margin:4px 0 0}.btn-primary{display:inline-flex;align-items:center;gap:7px;padding:9px 18px;background:var(--color-primary);color:#fff;border:none;border-radius:var(--radius-sm);font-size:14px;font-weight:600;cursor:pointer;transition:background var(--transition),transform .1s}.btn-primary:hover{background:var(--color-primary-dark);transform:translateY(-1px)}.btn-primary svg{width:16px;height:16px}.btn-ghost{display:inline-flex;align-items:center;gap:7px;padding:9px 18px;background:transparent;color:var(--color-text-muted);border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:14px;font-weight:500;cursor:pointer;transition:all var(--transition)}.btn-ghost:hover{background:var(--color-surface-2);color:var(--color-text)}.btn-danger{display:inline-flex;align-items:center;gap:7px;padding:9px 18px;background:var(--color-danger);color:#fff;border:none;border-radius:var(--radius-sm);font-size:14px;font-weight:600;cursor:pointer;transition:background var(--transition)}.btn-danger:hover{background:#dc2626}.btn-danger svg{width:16px;height:16px}.btn-disabled-soft{opacity:.7}.calendario-section{background:var(--color-surface);border-radius:var(--radius);padding:24px;box-shadow:var(--shadow);margin-bottom:24px}.calendario-leyenda{display:flex;gap:20px;margin-bottom:16px}.leyenda-item{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--color-text-muted)}.calendario-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}.calendario-dia-semana{text-align:center;font-size:11px;font-weight:600;color:var(--color-text-muted);padding:6px 0 10px;text-transform:uppercase;letter-spacing:.05em}.calendario-dia{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;padding:8px 4px;border-radius:var(--radius-sm);cursor:pointer;font-size:13px;font-weight:500;min-height:48px;transition:background var(--transition),color var(--transition);position:relative;border:2px solid transparent}.calendario-dia:not(.disabled):not(.empty):hover{background:var(--color-primary-light);color:var(--color-primary)}.calendario-dia.selected{background:var(--color-primary)!important;color:#fff!important;border-color:var(--color-primary-dark)}.calendario-dia.today{border-color:var(--color-primary)}.calendario-dia.disabled{opacity:.35;cursor:not-allowed}.calendario-dia.empty{cursor:default}.dia-dots{display:flex;gap:3px}.dot{width:6px;height:6px;border-radius:50%;display:inline-block}.dot-green{background:var(--color-success)}.dot-red{background:var(--color-danger)}.horas-section{background:var(--color-surface);border-radius:var(--radius);padding:24px;box-shadow:var(--shadow)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;color:var(--color-text-muted);gap:14px;text-align:center}.empty-state svg{width:48px;height:48px;opacity:.35}.empty-state p{font-size:15px;max-width:280px;line-height:1.6;margin:0}.section-placeholder{background:var(--color-surface);border-radius:var(--radius);min-height:300px;box-shadow:var(--shadow)}.modal-overlay{position:fixed;inset:0;background:#0f0f2373;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal-disponibilidad{background:var(--color-surface);border-radius:16px;width:100%;max-width:560px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0000002e;animation:modalIn .2s cubic-bezier(.34,1.56,.64,1)}@keyframes modalIn{0%{transform:scale(.92) translateY(12px);opacity:0}to{transform:scale(1) translateY(0);opacity:1}}.modal-header{display:flex;align-items:flex-start;gap:14px;padding:24px 24px 16px;border-bottom:1px solid var(--color-border)}.modal-header-icon{width:40px;height:40px;background:var(--color-primary-light);border-radius:10px;display:flex;align-items:center;justify-content:center;color:var(--color-primary);flex-shrink:0}.modal-header-icon svg{width:20px;height:20px}.modal-title{font-size:17px;font-weight:700;margin:0 0 2px;color:var(--color-text)}.modal-subtitle{font-size:12px;color:var(--color-text-muted);margin:0}.warning-subtitle{color:var(--color-warning)!important;font-weight:500}.modal-close-btn{margin-left:auto;width:32px;height:32px;border-radius:50%;border:none;background:transparent;cursor:pointer;color:var(--color-text-muted);display:flex;align-items:center;justify-content:center;transition:background var(--transition);flex-shrink:0}.modal-close-btn:hover{background:var(--color-surface-2)}.modal-close-btn svg{width:16px;height:16px}.modal-reservas-banner{display:flex;align-items:flex-start;gap:10px;margin:16px 24px 0;padding:12px 14px;background:var(--color-warning-light);border:1px solid #fcd34d;border-radius:var(--radius-sm);font-size:13px;color:#92400e;line-height:1.5}.modal-reservas-banner svg{width:18px;height:18px;flex-shrink:0;margin-top:1px;stroke:var(--color-warning)}.modal-reservas-banner p{margin:0}.modal-body{padding:20px 24px}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:20px}.form-field{display:flex;flex-direction:column;gap:6px}.form-field label{font-size:12px;font-weight:600;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em}.form-field input,.form-field select{padding:9px 12px;border:1.5px solid var(--color-border);border-radius:var(--radius-sm);font-size:14px;color:var(--color-text);background:var(--color-surface);outline:none;transition:border-color var(--transition);font-family:inherit}.form-field input:focus,.form-field select:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-light)}.reservas-reasignacion{border:1.5px solid var(--color-border);border-radius:var(--radius);padding:16px;background:var(--color-surface-2);margin-top:4px}.reasignacion-titulo{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:700;color:var(--color-text);margin:0 0 6px}.reasignacion-titulo svg{width:16px;height:16px;color:var(--color-primary)}.reasignacion-desc{font-size:12px;color:var(--color-text-muted);margin:0 0 14px;line-height:1.5}.reserva-reasignacion-card{display:flex;align-items:center;gap:12px;padding:12px;background:var(--color-surface);border-radius:var(--radius-sm);border:1.5px solid var(--color-border);margin-bottom:8px;transition:border-color var(--transition)}.reserva-reasignacion-card.valida{border-color:var(--color-success)}.reserva-reasignacion-card.invalida{border-color:var(--color-border)}.reserva-info{display:flex;align-items:center;gap:10px;flex:1;min-width:0}.reserva-avatar{width:36px;height:36px;border-radius:50%;background:var(--color-primary-light);color:var(--color-primary);font-weight:700;font-size:14px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.reserva-info>div{display:flex;flex-direction:column;gap:1px;min-width:0}.reserva-info strong{font-size:13px;color:var(--color-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.reserva-info span{font-size:11px;color:var(--color-text-muted)}.hora-actual{font-weight:500;color:var(--color-warning)!important}.reserva-nuevo-slot{display:flex;flex-direction:column;gap:4px;min-width:130px}.reserva-nuevo-slot label{font-size:11px;font-weight:600;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.04em}.reserva-nuevo-slot select{padding:7px 10px;border:1.5px solid var(--color-border);border-radius:var(--radius-sm);font-size:13px;color:var(--color-text);background:var(--color-surface);outline:none;font-family:inherit;transition:border-color var(--transition)}.reserva-nuevo-slot select.select-ok{border-color:var(--color-success)}.reserva-nuevo-slot select.select-warn{border-color:var(--color-warning)}.no-slots-warning{font-size:11px;color:var(--color-warning);margin:0}.slot-status{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}.slot-status.ok{background:var(--color-success-light);color:var(--color-success)}.slot-status.pending{background:var(--color-warning-light);color:var(--color-warning)}.slot-status svg{width:14px;height:14px}.advertencia-asignacion{padding:10px 14px;background:var(--color-danger-light);border:1px solid #fca5a5;border-radius:var(--radius-sm);font-size:13px;color:#991b1b;margin-top:8px}.modal-footer{display:flex;align-items:center;justify-content:flex-end;gap:10px;padding:16px 24px;border-top:1px solid var(--color-border)}.modal-confirm-delete{background:var(--color-surface);border-radius:16px;padding:32px;width:100%;max-width:400px;text-align:center;box-shadow:0 20px 60px #0000002e;animation:modalIn .2s cubic-bezier(.34,1.56,.64,1)}.modal-confirm-icon{width:56px;height:56px;background:var(--color-danger-light);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 16px;color:var(--color-danger)}.modal-confirm-icon svg{width:24px;height:24px}.modal-confirm-delete h3{font-size:18px;font-weight:700;margin:0 0 16px}.detalles-borrado{background:var(--color-surface-2);border-radius:var(--radius-sm);padding:12px 16px;text-align:left;margin-bottom:12px}.detalles-borrado p{margin:0 0 4px;font-size:13px;color:var(--color-text)}.detalles-borrado p:last-child{margin-bottom:0}.confirm-warning{font-size:12px;color:var(--color-text-muted);margin:0 0 20px}.modal-actions{display:flex;gap:10px;justify-content:center}@media(max-width:768px){.sidebar-nav{width:var(--sidebar-collapsed-width)}.sidebar-profile-info,.sidebar-label,.sidebar-active-bar{display:none}.panel-main{margin-left:var(--sidebar-collapsed-width);padding:16px}.form-grid{grid-template-columns:1fr}.reserva-reasignacion-card{flex-wrap:wrap}.section-header{flex-direction:column}}@media(max-width:480px){.calendario-grid{gap:2px}.calendario-dia{padding:6px 2px;font-size:12px;min-height:40px}}:root{--md-bg: #ffffff;--md-surface: #f8f9fb;--md-border: #e2e6ea;--md-text: #1a1d23;--md-text-muted: #6b7280;--md-primary: #2563eb;--md-primary-hover: #1d4ed8;--md-success: #16a34a;--md-success-bg: #f0fdf4;--md-success-border: #bbf7d0;--md-warning: #d97706;--md-warning-bg: #fffbeb;--md-warning-border: #fde68a;--md-danger: #dc2626;--md-danger-bg: #fef2f2;--md-changed: #2563eb;--md-changed-bg: #eff6ff;--md-radius: 12px;--md-radius-sm: 7px;--md-shadow: 0 20px 60px rgba(0, 0, 0, .18), 0 4px 16px rgba(0, 0, 0, .08)}.md-overlay{position:fixed;inset:0;background:#0000008c;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:16px;box-sizing:border-box}.md-panel{background:var(--md-bg);border-radius:var(--md-radius);box-shadow:var(--md-shadow);width:100%;max-width:580px;max-height:92vh;overflow-y:auto;display:flex;flex-direction:column;animation:md-slideUp .22s ease}@keyframes md-slideUp{0%{opacity:0;transform:translateY(18px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.md-panel::-webkit-scrollbar{width:5px}.md-panel::-webkit-scrollbar-track{background:transparent}.md-panel::-webkit-scrollbar-thumb{background:var(--md-border);border-radius:99px}.md-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px 16px;border-bottom:1px solid var(--md-border);gap:12px;position:sticky;top:0;background:var(--md-bg);z-index:2;border-radius:var(--md-radius) var(--md-radius) 0 0}.md-header-left{display:flex;align-items:center;gap:12px;flex:1;min-width:0}.md-icon{font-size:24px;flex-shrink:0}.md-title{margin:0;font-size:17px;font-weight:700;color:var(--md-text);line-height:1.2}.md-subtitle{margin:3px 0 0;font-size:12px;color:var(--md-warning);font-weight:500}.md-close{background:none;border:none;cursor:pointer;color:var(--md-text-muted);font-size:18px;padding:6px;border-radius:6px;line-height:1;transition:background .15s,color .15s;flex-shrink:0}.md-close:hover{background:var(--md-surface);color:var(--md-text)}.md-comparacion{display:grid;grid-template-columns:1fr 32px 1fr;gap:0;margin:0;padding:16px 24px;background:var(--md-surface);border-bottom:1px solid var(--md-border);align-items:center}.md-comp-col{background:var(--md-bg);border:1px solid var(--md-border);border-radius:var(--md-radius-sm);padding:12px 14px}.md-comp-actual{border-left:3px solid var(--md-text-muted)}.md-comp-nuevo{border-left:3px solid var(--md-border);transition:border-color .2s}.md-comp-nuevo.md-comp-changed{border-left-color:var(--md-primary);background:var(--md-changed-bg)}.md-comp-label{margin:0 0 8px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--md-text-muted)}.md-comp-data{display:flex;flex-direction:column;gap:5px}.md-comp-row{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--md-text);font-weight:500}.md-comp-row.md-changed{color:var(--md-primary);font-weight:700}.md-comp-icon{font-size:12px;flex-shrink:0}.md-comp-arrow{display:flex;align-items:center;justify-content:center;color:var(--md-text-muted)}.md-comp-arrow svg{width:18px;height:18px}.md-banner-warning{display:flex;align-items:flex-start;gap:10px;padding:12px 24px;background:var(--md-warning-bg);border-bottom:1px solid var(--md-warning-border);font-size:13px;color:var(--md-warning)}.md-banner-warning span{font-size:16px;flex-shrink:0;margin-top:1px}.md-banner-warning p{margin:0;line-height:1.5}.md-body{padding:20px 24px;display:flex;flex-direction:column;gap:20px}.md-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}.md-field{display:flex;flex-direction:column;gap:5px}.md-label{font-size:12px;font-weight:600;color:var(--md-text-muted);text-transform:uppercase;letter-spacing:.04em}.md-input{padding:9px 11px;border:1.5px solid var(--md-border);border-radius:var(--md-radius-sm);font-size:14px;color:var(--md-text);background:var(--md-bg);width:100%;box-sizing:border-box;transition:border-color .15s,box-shadow .15s;-webkit-appearance:none;appearance:none}.md-input:focus{outline:none;border-color:var(--md-primary);box-shadow:0 0 0 3px #2563eb1f}select.md-input{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2' stroke-linecap='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;padding-right:30px;cursor:pointer}.md-input.md-select-ok{border-color:var(--md-success)}.md-input.md-select-warn{border-color:var(--md-warning)}.md-reasignacion{display:flex;flex-direction:column;gap:12px;padding-top:4px;border-top:1px solid var(--md-border)}.md-reasig-titulo{margin:0;font-size:14px;font-weight:700;color:var(--md-text)}.md-reasig-desc{margin:-4px 0 0;font-size:12px;color:var(--md-text-muted);line-height:1.5}.md-reserva-card{display:grid;grid-template-columns:1fr 1fr auto;gap:12px;align-items:center;padding:12px 14px;border-radius:var(--md-radius-sm);border:1.5px solid var(--md-border);background:var(--md-surface);transition:border-color .2s,background .2s}.md-reserva-card.md-reserva-ok{border-color:var(--md-success-border);background:var(--md-success-bg)}.md-reserva-card.md-reserva-pending{border-color:var(--md-warning-border);background:var(--md-warning-bg)}.md-reserva-info{display:flex;align-items:center;gap:10px;min-width:0}.md-avatar{width:36px;height:36px;border-radius:50%;background:var(--md-primary);color:#fff;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;flex-shrink:0}.md-reserva-datos{display:flex;flex-direction:column;gap:1px;min-width:0}.md-reserva-datos strong{font-size:13px;color:var(--md-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.md-reserva-datos span{font-size:11px;color:var(--md-text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.md-hora-actual{font-size:11px!important;color:var(--md-text-muted)!important}.md-reserva-slot{display:flex;flex-direction:column;gap:4px;min-width:0}.md-slot-status{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;flex-shrink:0}.md-status-ok{background:var(--md-success-bg);color:var(--md-success);border:1.5px solid var(--md-success-border)}.md-status-pending{background:var(--md-warning-bg);color:var(--md-warning);border:1.5px solid var(--md-warning-border)}.md-no-slots{font-size:12px;color:var(--md-text-muted);margin:0;font-style:italic}.md-advertencia{padding:10px 14px;background:var(--md-danger-bg);border:1px solid #fecaca;border-radius:var(--md-radius-sm);font-size:13px;color:var(--md-danger);font-weight:500}.md-footer{display:flex;justify-content:flex-end;gap:10px;padding:16px 24px;border-top:1px solid var(--md-border);background:var(--md-bg);border-radius:0 0 var(--md-radius) var(--md-radius);position:sticky;bottom:0;z-index:2}.md-btn-cancelar{padding:9px 18px;border:1.5px solid var(--md-border);border-radius:var(--md-radius-sm);background:var(--md-bg);color:var(--md-text-muted);font-size:14px;font-weight:600;cursor:pointer;transition:background .15s,color .15s}.md-btn-cancelar:hover{background:var(--md-surface);color:var(--md-text)}.md-btn-guardar{padding:9px 20px;border:none;border-radius:var(--md-radius-sm);background:var(--md-primary);color:#fff;font-size:14px;font-weight:700;cursor:pointer;transition:background .15s,opacity .15s}.md-btn-guardar:hover{background:var(--md-primary-hover)}.md-btn-guardar.md-btn-soft{opacity:.65;cursor:not-allowed}@media(max-width:600px){.md-overlay{align-items:flex-end;padding:0;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);background:#00000073}.md-panel{max-width:100%;width:100%;max-height:92dvh;border-radius:20px 20px 0 0;box-shadow:0 -8px 40px #00000040;animation:md-slideUpMobile .32s cubic-bezier(.32,.72,0,1);padding-bottom:env(safe-area-inset-bottom);overflow-y:auto;-webkit-overflow-scrolling:touch}.md-panel:before{content:"";display:block;width:40px;height:4px;background:#0000002e;border-radius:99px;margin:12px auto 4px;flex-shrink:0}@keyframes md-slideUpMobile{0%{transform:translateY(100%)}to{transform:translateY(0)}}.md-header{padding:8px 20px 14px;position:sticky;top:0;background:inherit;z-index:10;border-bottom:1px solid rgba(0,0,0,.07)}.md-title{font-size:17px;font-weight:700;letter-spacing:-.3px}.md-body{padding:20px;overflow-y:auto}.md-comparacion{grid-template-columns:1fr;grid-template-rows:auto auto auto;padding:14px 16px;gap:10px;border-radius:14px}.md-comp-arrow{transform:rotate(90deg);justify-self:center;opacity:.4}.md-form-grid{grid-template-columns:1fr;gap:14px}.md-form-grid input,.md-form-grid select,.md-form-grid textarea{min-height:48px;font-size:16px;border-radius:12px;padding:12px 14px}.md-footer{padding:14px 20px;padding-bottom:calc(14px + env(safe-area-inset-bottom));flex-direction:column-reverse;gap:10px;position:sticky;bottom:0;background:inherit;border-top:1px solid rgba(0,0,0,.07)}.md-btn-cancelar,.md-btn-guardar{width:100%;min-height:50px;padding:13px 16px;font-size:16px;font-weight:600;border-radius:14px;text-align:center;letter-spacing:-.1px;transition:transform .1s ease,opacity .1s ease;-webkit-tap-highlight-color:transparent}.md-btn-cancelar:active,.md-btn-guardar:active{transform:scale(.97);opacity:.85}.md-reserva-card{grid-template-columns:1fr auto;grid-template-rows:auto auto;gap:10px;border-radius:16px;padding:14px}.md-reserva-info{grid-column:1;grid-row:1}.md-slot-status{grid-column:2;grid-row:1;align-self:start}.md-reserva-slot{grid-column:1 / -1;grid-row:2}.md-reserva-datos strong{font-size:13px}.md-comp-row{font-size:13px;line-height:1.5}}@media(max-width:380px){.md-title{font-size:15px}.md-body{padding:16px}.md-footer{padding:12px 16px;padding-bottom:calc(12px + env(safe-area-inset-bottom))}.md-btn-cancelar,.md-btn-guardar{min-height:48px;font-size:15px}}.md-overlay{position:fixed;inset:0;z-index:9999}.md-panel{position:relative;z-index:10000}.seccion-horarios{display:flex;flex-direction:column;gap:16px;padding:4px 0 32px}.sh-toolbar{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:10px}.sh-nav{display:flex;align-items:center;gap:6px}.sh-nav-btn{display:flex;align-items:center;justify-content:center;background:transparent;border:.5px solid var(--color-border-secondary, #ccc);border-radius:8px;padding:6px 10px;cursor:pointer;color:var(--color-text-primary);transition:background .15s}.sh-nav-btn:hover{background:var(--color-background-secondary)}.sh-nav-btn svg{width:14px;height:14px}.sh-hoy-btn{font-size:12px;padding:6px 12px;margin-left:2px}.sh-week-label{font-size:13px;font-weight:500;color:var(--color-text-primary);min-width:160px;text-align:center;padding:0 4px}.sh-btn-nueva{display:flex;align-items:center;gap:6px;background:transparent;border:.5px solid var(--color-border-secondary, #ccc);border-radius:8px;padding:7px 14px;cursor:pointer;font-size:13px;color:var(--color-text-primary);transition:background .15s}.sh-btn-nueva:hover{background:var(--color-background-secondary)}.sh-btn-nueva svg{width:14px;height:14px}.cal-semana-wrap{position:relative}.cal-loading{font-size:12px;color:var(--color-text-secondary);margin-bottom:6px}.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:6px}.cal-dia{display:flex;flex-direction:column;align-items:center;gap:4px;padding:8px 4px;border:.5px solid var(--color-border-tertiary, #e0e0e0);border-radius:10px;background:var(--color-background-primary);cursor:pointer;transition:background .15s,border-color .15s;font-family:inherit}.cal-dia:hover{background:var(--color-background-secondary)}.cal-dia--sel{border:1.5px solid #378ADD}.cal-dia-nombre{font-size:10px;font-weight:500;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-secondary)}.cal-dia-num{font-size:15px;font-weight:500;color:var(--color-text-primary);width:26px;height:26px;display:flex;align-items:center;justify-content:center;border-radius:50%}.cal-dia--hoy .cal-dia-num{background:#378add;color:#fff}.cal-dia-dots{display:flex;justify-content:center;gap:3px;min-height:7px}.cal-dot{display:block;width:5px;height:5px;border-radius:50%}.panel-dia{border:.5px solid var(--color-border-tertiary, #e0e0e0);border-radius:12px;background:var(--color-background-primary);overflow:hidden}.panel-dia-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:.5px solid var(--color-border-tertiary, #e0e0e0)}.panel-dia-header-texts{display:flex;flex-direction:column;gap:2px}.panel-dia-titulo{font-size:14px;font-weight:500;color:var(--color-text-primary)}.panel-dia-sub{font-size:12px;color:var(--color-text-secondary)}.panel-dia-badge{font-size:11px;font-weight:500;padding:3px 9px;border-radius:20px;background:#e6f1fb;color:#185fa5}.panel-dia-cards{display:flex;flex-direction:column;gap:0}.eje-horas{display:flex;align-items:flex-end;padding:8px 16px 0;gap:0}.eje-horas-offset{min-width:96px;flex-shrink:0}.eje-horas-track{flex:1;position:relative;height:18px;margin-right:60px}.eje-marca{position:absolute;transform:translate(-50%);font-size:10px;color:var(--color-text-secondary);white-space:nowrap;-webkit-user-select:none;user-select:none}.card-prof{border-top:.5px solid var(--color-border-tertiary, #e0e0e0)}.card-prof:first-child{border-top:none}.card-prof-header{display:flex;align-items:center;justify-content:space-between;padding:10px 16px;background:var(--color-background-secondary);border-bottom:.5px solid var(--color-border-tertiary, #e0e0e0)}.card-prof-info{display:flex;align-items:center;gap:10px}.card-prof-avatar{width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:500;flex-shrink:0}.card-prof-texts{display:flex;flex-direction:column;gap:1px}.card-prof-nombre{font-size:13px;font-weight:500;color:var(--color-text-primary)}.card-prof-meta{font-size:11px;color:var(--color-text-secondary)}.card-prof-btn-add{display:flex;align-items:center;gap:5px;background:transparent;border:.5px solid var(--color-border-secondary, #ccc);border-radius:8px;padding:4px 10px;cursor:pointer;font-size:12px;color:var(--color-text-primary);transition:background .15s;font-family:inherit}.card-prof-btn-add:hover{background:var(--color-background-primary)}.card-prof-btn-add svg{width:12px;height:12px}.card-prof-body{padding:10px 16px 12px;display:flex;flex-direction:column;gap:8px}.card-prof-empty{display:flex;align-items:center;justify-content:center;gap:6px;width:100%;padding:10px;border:.5px dashed var(--color-border-secondary, #ccc);border-radius:8px;background:transparent;cursor:pointer;font-size:12px;color:var(--color-text-secondary);transition:background .15s,color .15s;font-family:inherit}.card-prof-empty:hover{background:var(--color-background-secondary);color:var(--color-text-primary)}.card-prof-empty svg{width:13px;height:13px}.franja-fila{display:flex;align-items:center;gap:8px}.franja-fila-label{font-size:11px;color:var(--color-text-secondary);min-width:96px;text-align:right;flex-shrink:0;white-space:nowrap}.franja-track{flex:1;height:28px;position:relative;background:var(--color-background-secondary);border:.5px solid var(--color-border-tertiary, #e0e0e0);border-radius:4px;overflow:visible}.franja-guia{position:absolute;top:0;bottom:0;width:.5px;background:var(--color-border-tertiary, #e0e0e0);pointer-events:none}.franja-bar{position:absolute;top:0;height:100%;border-radius:4px;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:filter .15s,transform .1s;padding:0;min-width:4px;font-family:inherit}.franja-bar:hover{filter:brightness(.88);transform:scaleY(1.06)}.franja-bar:active{transform:scaleY(.96)}.franja-bar-label{font-size:11px;font-weight:500;color:#0009;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;padding:0 6px;pointer-events:none}.franja-acciones{display:flex;gap:4px;flex-shrink:0}.franja-accion-btn{display:flex;align-items:center;justify-content:center;background:transparent;border:.5px solid var(--color-border-tertiary, #e0e0e0);border-radius:6px;padding:4px;cursor:pointer;color:var(--color-text-secondary);transition:background .15s,color .15s,border-color .15s}.franja-accion-btn svg{width:13px;height:13px}.franja-accion-btn:hover{background:var(--color-background-secondary);color:var(--color-text-primary);border-color:var(--color-border-secondary)}.franja-accion-btn--danger:hover{background:#fcebeb;color:#a32d2d;border-color:#f09595}@media(max-width:640px){.cal-dia-nombre{font-size:9px}.cal-dia-num{font-size:13px}.sh-week-label{font-size:12px;min-width:120px}.franja-fila-label{min-width:72px;font-size:10px}.eje-horas-offset{min-width:72px}.eje-horas-track{margin-right:50px}}:root{--sidebar-bg: #0f1117;--sidebar-width: 220px;--sidebar-collapsed: 72px;--accent: #f5a623;--accent-soft: rgba(245, 166, 35, .12);--accent-2: #3b82f6;--text-primary: #1a1a2e;--text-secondary: #64748b;--surface: #ffffff;--surface-2: #f8fafc;--border: #e2e8f0;--danger: #ef4444;--success: #22c55e;--warning: #f59e0b;--radius: 12px;--shadow: 0 4px 24px rgba(0, 0, 0, .08);--shadow-lg: 0 8px 40px rgba(0, 0, 0, .14);--transition: .22s cubic-bezier(.4, 0, .2, 1)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}.panel-admin-shell{display:flex;min-height:100vh;background:var(--surface-2);font-family:DM Sans,sans-serif;color:var(--text-primary)}.sidebar-nav{position:fixed;left:0;top:62px;height:calc(100vh - 62px);width:var(--sidebar-width);background:var(--sidebar-bg);display:flex;flex-direction:column;z-index:1100;overflow:hidden;transition:width var(--transition)}.sidebar-logo{display:flex;align-items:center;gap:12px;padding:28px 20px 24px;border-bottom:1px solid rgba(255,255,255,.06)}.sidebar-logo-text{font-family:Syne,sans-serif;font-weight:800;font-size:1.15rem;color:var(--accent);letter-spacing:.04em;white-space:nowrap}.sidebar-menu{flex:1;padding:16px 10px;display:flex;flex-direction:column;gap:4px;overflow-y:auto}.sidebar-btn{position:relative;display:flex;align-items:center;gap:12px;width:100%;padding:12px 14px;background:transparent;border:none;border-radius:10px;cursor:pointer;transition:background var(--transition),transform var(--transition);text-align:left;color:#ffffff8c}.sidebar-btn:hover{background:#ffffff12;color:#ffffffd9;transform:translate(2px)}.sidebar-btn--active{background:var(--accent-soft);color:var(--accent)!important}.sidebar-btn--active:before{content:"";position:absolute;left:0;top:20%;bottom:20%;width:3px;background:var(--accent);border-radius:0 3px 3px 0}.sidebar-btn-icon{width:32px;height:32px;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:transform var(--transition)}.sidebar-btn-icon svg{width:22px;height:22px;stroke:currentColor;transition:stroke var(--transition),transform var(--transition)}.sidebar-btn:hover .sidebar-btn-icon svg{transform:scale(1.12)}.sidebar-btn--active .sidebar-btn-icon svg{filter:drop-shadow(0 0 6px rgba(245,166,35,.5))}.sidebar-logo-icon{flex-shrink:0;width:36px;height:36px;display:flex;align-items:center;justify-content:center;color:var(--accent)}.sidebar-logo-icon svg{width:26px;height:26px;stroke:currentColor}.sidebar-btn-label{font-size:.875rem;font-weight:500;white-space:nowrap}.sidebar-badge{position:absolute;top:-6px;right:-6px;background:var(--danger);color:#fff;font-size:.65rem;font-weight:700;min-width:18px;height:18px;border-radius:50%;display:flex;align-items:center;justify-content:center;padding:0 3px;line-height:1;pointer-events:none;animation:pulse-badge 2s infinite}@keyframes pulse-badge{0%,to{opacity:1;transform:scale(1)}50%{opacity:.8;transform:scale(1.05)}}.sidebar-footer{padding:16px 20px;border-top:1px solid rgba(255,255,255,.06)}.sidebar-version{font-size:.7rem;color:#fff3}.panel-admin-main{margin-left:var(--sidebar-width);flex:1;display:flex;flex-direction:column;min-height:100vh;transition:margin-left var(--transition)}.panel-topbar{position:sticky;top:0;left:var(--sidebar-width);width:calc(100% - var(--sidebar-width));z-index:1050;display:flex;align-items:center;justify-content:space-between;padding:0 32px;height:64px;background:#ffffffeb;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--border);transition:left var(--transition),width var(--transition);box-shadow:0 1px #0000000a}.topbar-title{font-family:Syne,sans-serif;font-size:1.1rem;font-weight:700;color:var(--text-primary)}.topbar-user{display:flex;align-items:center;gap:10px}.topbar-user-name{font-size:.875rem;font-weight:500;color:var(--text-secondary)}.topbar-badge{background:var(--accent);color:#000;font-size:.7rem;font-weight:700;padding:3px 10px;border-radius:20px;text-transform:uppercase;letter-spacing:.05em}.panel-content-area{flex:1;padding:32px}.seccion-contenido{animation:fadeSlideIn .3s ease}@keyframes fadeSlideIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.seccion-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:28px;flex-wrap:wrap;gap:12px}.seccion-header h2{font-family:Syne,sans-serif;font-size:1.5rem;font-weight:700;color:var(--text-primary)}.seccion-subtitle{font-size:.8rem;color:var(--text-secondary);background:var(--surface-2);padding:4px 12px;border-radius:20px;border:1px solid var(--border)}.empty-state{text-align:center;padding:60px 20px;color:var(--text-secondary)}.empty-state-icon{font-size:3.5rem;margin-bottom:16px;opacity:.6}.empty-state p{font-size:1.1rem;font-weight:500;color:var(--text-primary);margin-bottom:6px}.empty-state span{font-size:.875rem;color:var(--text-secondary)}.reportes-grid-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px;margin-bottom:28px}.reporte-card{background:var(--surface);border-radius:var(--radius);padding:24px;box-shadow:var(--shadow);border-left:4px solid transparent;transition:transform var(--transition),box-shadow var(--transition)}.reporte-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg)}.reporte-card span{font-size:.78rem;text-transform:uppercase;letter-spacing:.08em;color:var(--text-secondary);font-weight:600}.reporte-card h3{font-family:Syne,sans-serif;font-size:1.8rem;font-weight:700;margin-top:8px}.reporte-card.ingresos{border-left-color:var(--accent-2)}.reporte-card.ingresos h3{color:var(--accent-2)}.reporte-card.neta{border-left-color:var(--success)}.reporte-card.neta h3{color:var(--success)}.reporte-card.citas{border-left-color:var(--accent)}.reporte-card.citas h3{color:var(--accent)}.reportes-detalles-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-top:20px}.reporte-tabla-container{background:var(--surface);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow)}.reporte-tabla-container h4{font-family:Syne,sans-serif;font-size:.95rem;font-weight:700;margin-bottom:14px;padding-bottom:10px;border-bottom:1px solid var(--border)}.tabla-reportes-mini,.tabla-admin-moderna{width:100%;border-collapse:collapse;font-size:.875rem}.tabla-reportes-mini th,.tabla-admin-moderna th{text-align:left;padding:8px 12px;font-size:.75rem;text-transform:uppercase;letter-spacing:.07em;color:var(--text-secondary);border-bottom:2px solid var(--border)}.tabla-reportes-mini td,.tabla-admin-moderna td{padding:10px 12px;border-bottom:1px solid var(--border);color:var(--text-primary)}.tabla-reportes-mini tr:last-child td,.tabla-admin-moderna tr:last-child td{border-bottom:none}.tabla-admin-moderna tr:hover td{background:var(--surface-2)}.tabla-liquidacion{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}.tabla-liquidacion thead th{background:var(--surface-2);padding:14px 16px}.tabla-liquidacion tbody td{padding:14px 16px}.highlight-comision{color:var(--success)!important;font-weight:700}.filtros-container-admin{display:flex;gap:10px;flex-wrap:wrap}.select-periodo{padding:8px 14px;border:1.5px solid var(--border);border-radius:8px;font-family:DM Sans,sans-serif;font-size:.875rem;background:var(--surface);color:var(--text-primary);cursor:pointer;transition:border-color var(--transition)}.select-periodo:focus{outline:none;border-color:var(--accent)}.alerta-cobros-container{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}.alerta-header{background:linear-gradient(135deg,#1a1a2e,#16213e);padding:16px 20px;display:flex;align-items:center;gap:14px;flex-wrap:wrap}.alerta-header p{color:#fffc;font-size:.9rem}.pestaña-roja{background:var(--danger);color:#fff;font-size:.7rem;font-weight:800;letter-spacing:.1em;padding:4px 12px;border-radius:4px;animation:pulse-badge 2s infinite}.lista-cobros-scroll{max-height:450px;overflow-y:auto;padding:12px;display:flex;flex-direction:column;gap:10px}.card-cobro-urgente{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;background:var(--surface-2);border-radius:10px;border:1px solid var(--border);gap:14px;flex-wrap:wrap;transition:box-shadow var(--transition)}.card-cobro-urgente:hover{box-shadow:0 2px 12px #00000014}.info-cita{display:flex;flex-direction:column;gap:4px;font-size:.875rem}.fecha-badge{color:var(--text-secondary);font-size:.78rem}.acciones-cobro{display:flex;gap:8px;flex-wrap:wrap}.btn-pago{padding:7px 14px;border:none;border-radius:7px;font-size:.8rem;font-weight:600;cursor:pointer;transition:all var(--transition);color:#fff}.btn-pago.efectivo{background:#2d6a4f}.btn-pago.efectivo:hover{background:#1b4332}.btn-pago.nequi{background:#9333ea}.btn-pago.nequi:hover{background:#7c3aed}.btn-pago.davi{background:#dc2626}.btn-pago.davi:hover{background:#b91c1c}.btn-bloqueado{opacity:.4;cursor:not-allowed!important}.tarjetas-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:20px;margin-top:20px}.tarjeta-pro-ajustada{background:var(--surface);border-radius:var(--radius);padding:22px 18px;box-shadow:var(--shadow);text-align:center;transition:transform var(--transition),box-shadow var(--transition);position:relative}.tarjeta-pro-ajustada:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}.pro-avatar-wrapper{position:relative;width:72px;height:72px;margin:0 auto 12px}.pro-img-fixed{width:72px;height:72px;border-radius:50%;object-fit:cover;border:3px solid var(--border)}.pro-status-dot{position:absolute;bottom:3px;right:3px;width:13px;height:13px;border-radius:50%;border:2px solid var(--surface)}.pro-status-dot.dot-on{background:var(--success)}.pro-status-dot.dot-off{background:var(--text-secondary)}.tarjeta-pro-ajustada h4{font-family:Syne,sans-serif;font-size:.95rem;font-weight:700;margin-bottom:14px;color:var(--text-primary)}.comision-pro-box{margin-bottom:14px}.comision-pro-box label{font-size:.78rem;color:var(--text-secondary);display:block;margin-bottom:8px}.admin-slider-dinamico{width:100%;accent-color:var(--accent)}.btn-status-off,.btn-status-on{width:100%;padding:7px;border:none;border-radius:8px;font-size:.8rem;font-weight:600;cursor:pointer;transition:all var(--transition)}.btn-status-off{background:#fee2e2;color:var(--danger)}.btn-status-off:hover{background:var(--danger);color:#fff}.btn-status-on{background:#dcfce7;color:var(--success)}.btn-status-on:hover{background:var(--success);color:#fff}.form-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:12px;margin-bottom:20px;padding:20px;background:var(--surface-2);border-radius:10px;border:1px solid var(--border)}.form-vertical{display:flex;flex-direction:column;gap:10px}.form-grid input,.form-vertical input,.form-grid select{padding:10px 14px;border:1.5px solid var(--border);border-radius:8px;font-family:DM Sans,sans-serif;font-size:.875rem;background:var(--surface);color:var(--text-primary);transition:border-color var(--transition)}.form-grid input:focus,.form-vertical input:focus{outline:none;border-color:var(--accent)}.btn-save{padding:10px 20px;background:var(--accent);color:#000;border:none;border-radius:8px;font-family:DM Sans,sans-serif;font-weight:700;font-size:.875rem;cursor:pointer;transition:all var(--transition)}.btn-save:hover{background:#e8951f;transform:translateY(-1px)}.btn-cancel{padding:10px 20px;background:var(--surface-2);color:var(--text-secondary);border:1.5px solid var(--border);border-radius:8px;font-family:DM Sans,sans-serif;font-weight:600;font-size:.875rem;cursor:pointer;transition:all var(--transition)}.btn-cancel:hover{border-color:var(--danger);color:var(--danger)}.btn-print{padding:9px 18px;background:var(--surface);color:var(--text-primary);border:1.5px solid var(--border);border-radius:8px;font-family:DM Sans,sans-serif;font-weight:600;font-size:.875rem;cursor:pointer;transition:all var(--transition)}.btn-print:hover{background:var(--surface-2)}.btn-liquidar-ahora{padding:7px 14px;background:linear-gradient(135deg,var(--success) 0%,#16a34a 100%);color:#fff;border:none;border-radius:7px;font-weight:600;font-size:.8rem;cursor:pointer;transition:all var(--transition)}.btn-liquidar-ahora:hover{transform:translateY(-1px);box-shadow:0 4px 12px #22c55e4d}.tag-pagado{font-size:.8rem;color:var(--success);font-weight:600}.acciones-form-actividad{display:flex;gap:8px}.config-box{background:var(--surface);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow)}.config-box h4{font-family:Syne,sans-serif;font-size:.95rem;font-weight:700;margin-bottom:14px;padding-bottom:10px;border-bottom:1px solid var(--border)}.admin-split-grid{display:grid;grid-template-columns:1fr 1.4fr;gap:20px}.tabla-scroll-wrapper{overflow-y:auto}.btn-edit-mini{background:none;border:none;cursor:pointer;font-size:1rem;transition:transform var(--transition)}.btn-edit-mini:hover{transform:scale(1.2)}.status-badge{border:none;background:none;cursor:pointer;font-size:.8rem;font-weight:600;padding:3px 8px;border-radius:6px;transition:all var(--transition)}.status-badge.active{background:#dcfce7;color:var(--success)}.status-badge.inactive{background:#fee2e2;color:var(--danger)}.loading-admin{display:flex;align-items:center;justify-content:center;min-height:100vh;font-family:Syne,sans-serif;font-size:1.1rem;color:var(--text-secondary);background:var(--surface-2)}.modal-overlay-admin{position:fixed;inset:0;background:#0f1117b8;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;z-index:999;padding:20px;animation:overlayIn .2s ease}@keyframes overlayIn{0%{opacity:0}to{opacity:1}}.modal-container-pro{background:var(--surface);border-radius:18px;box-shadow:0 24px 64px #00000047;width:100%;max-width:560px;max-height:92vh;display:flex;flex-direction:column;overflow:hidden;animation:modalIn .28s cubic-bezier(.34,1.56,.64,1)}@keyframes modalIn{0%{opacity:0;transform:translateY(24px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-header-pro{display:flex;align-items:center;justify-content:space-between;padding:22px 28px 18px;border-bottom:1px solid var(--border);background:linear-gradient(135deg,var(--sidebar-bg) 0%,#16213e 100%)}.modal-header-pro h2{font-family:Syne,sans-serif;font-size:1.15rem;font-weight:700;color:#fff;letter-spacing:.01em}.btn-close-modal{background:#ffffff1a;border:none;color:#ffffffb3;width:32px;height:32px;border-radius:8px;font-size:1.3rem;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background var(--transition),color var(--transition)}.btn-close-modal:hover{background:#fff3;color:#fff}.modal-body-pro{flex:1;overflow-y:auto;padding:24px 28px;display:flex;flex-direction:column;gap:18px}.rango-fecha-badge{display:inline-flex;align-items:center;gap:6px;background:var(--accent-soft);border:1px solid rgba(245,166,35,.25);color:#b07d12;font-size:.82rem;font-weight:500;padding:7px 14px;border-radius:20px;align-self:flex-start}.info-barbero-box{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius);padding:14px 18px;display:flex;flex-direction:column;gap:6px;font-size:.9rem;color:var(--text-secondary)}.info-barbero-box strong{color:var(--text-primary);font-weight:600}.detalle-servicios-container{display:flex;flex-direction:column;gap:8px}.label-detalle{font-size:.78rem;font-weight:600;text-transform:uppercase;letter-spacing:.07em;color:var(--text-secondary)}.detalle-servicios-scroll{max-height:180px;overflow-y:auto;border:1px solid var(--border);border-radius:10px;background:var(--surface)}.detalle-servicios-scroll::-webkit-scrollbar{width:5px}.detalle-servicios-scroll::-webkit-scrollbar-track{background:transparent}.detalle-servicios-scroll::-webkit-scrollbar-thumb{background:var(--border);border-radius:10px}.tabla-detalle-mini{width:100%;border-collapse:collapse;font-size:.825rem}.tabla-detalle-mini th{position:sticky;top:0;background:var(--surface-2);padding:9px 12px;text-align:left;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--text-secondary);border-bottom:1px solid var(--border);z-index:1}.tabla-detalle-mini td{padding:9px 12px;border-bottom:1px solid var(--border);color:var(--text-primary)}.tabla-detalle-mini tbody tr:last-child td{border-bottom:none}.tabla-detalle-mini tbody tr:hover td{background:var(--surface-2)}.total-a-pagar-card{background:linear-gradient(135deg,#0f1117,#1a2744);border-radius:var(--radius);padding:18px 22px;display:flex;align-items:center;justify-content:space-between}.total-a-pagar-card span{font-size:.85rem;color:#fff9;font-weight:500}.total-a-pagar-card h3{font-family:Syne,sans-serif;font-size:1.7rem;font-weight:800;color:var(--accent)}.form-group-pro{display:flex;flex-direction:column;gap:7px}.form-group-pro label{font-size:.78rem;font-weight:600;text-transform:uppercase;letter-spacing:.07em;color:var(--text-secondary)}.select-moderno{padding:10px 36px 10px 14px;border:1.5px solid var(--border);border-radius:9px;font-family:DM Sans,sans-serif;font-size:.9rem;background:var(--surface);color:var(--text-primary);cursor:pointer;transition:border-color var(--transition),box-shadow var(--transition);appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%2364748b' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center}.select-moderno:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.textarea-moderna{padding:10px 14px;border:1.5px solid var(--border);border-radius:9px;font-family:DM Sans,sans-serif;font-size:.875rem;background:var(--surface);color:var(--text-primary);resize:vertical;min-height:80px;transition:border-color var(--transition),box-shadow var(--transition);line-height:1.5}.textarea-moderna:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.textarea-moderna::placeholder{color:#b0bec5}.modal-footer-pro{display:flex;align-items:center;justify-content:flex-end;gap:12px;padding:18px 28px;border-top:1px solid var(--border);background:var(--surface-2)}.btn-cancelar{padding:10px 22px;background:transparent;color:var(--text-secondary);border:1.5px solid var(--border);border-radius:9px;font-family:DM Sans,sans-serif;font-weight:600;font-size:.875rem;cursor:pointer;transition:all var(--transition)}.btn-cancelar:hover:not(:disabled){border-color:var(--danger);color:var(--danger)}.btn-cancelar:disabled{opacity:.5;cursor:not-allowed}.btn-confirmar-pago{padding:10px 24px;background:linear-gradient(135deg,var(--success) 0%,#16a34a 100%);color:#fff;border:none;border-radius:9px;font-family:DM Sans,sans-serif;font-weight:700;font-size:.875rem;cursor:pointer;transition:all var(--transition);box-shadow:0 4px 14px #22c55e4d}.btn-confirmar-pago:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 20px #22c55e66}.btn-confirmar-pago:disabled{opacity:.65;cursor:not-allowed;transform:none;box-shadow:none}.clientes-subtitle{font-size:.9rem;color:var(--text-secondary);margin-top:4px}.clientes-stat-row{display:flex;gap:12px}.stat-pill{padding:6px 14px;border-radius:20px;font-size:.8rem;font-weight:600;border:1px solid var(--border)}.stat-pill--gold{background:#fffcf0;color:#b07d12;border-color:#fde68a}.stat-pill--red{background:#fef2f2;color:#dc2626;border-color:#fecaca}.stat-pill--gray{background:#f8fafc;color:#64748b;border-color:var(--border)}.clientes-tabs-wrapper{margin-bottom:24px;border-bottom:1px solid var(--border)}.clientes-tabs{display:flex;gap:32px}.clientes-tab{padding:12px 4px;background:none;border:none;border-bottom:3px solid transparent;cursor:pointer;display:flex;align-items:center;gap:8px;transition:var(--transition);color:var(--text-secondary)}.clientes-tab--active{color:var(--text-primary);border-bottom-color:var(--tab-accent)}.tab-count{font-size:.75rem;padding:2px 8px;background:var(--surface-2);border-radius:10px;font-weight:700}.clientes-table-card{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}.tabla-clientes{width:100%;border-collapse:collapse}.tabla-clientes th{background:var(--surface-2);padding:16px;text-align:left;font-size:.75rem;text-transform:uppercase;color:var(--text-secondary);border-bottom:1px solid var(--border)}.tabla-clientes td{padding:14px 16px;border-bottom:1px solid var(--border);vertical-align:middle}.cliente-info-cell{display:flex;align-items:center;gap:12px}.cliente-avatar{width:40px;height:40px;border-radius:50%;background:var(--sidebar-bg);color:#fff;display:flex;align-items:center;justify-content:center;font-size:.85rem;font-weight:700;text-transform:uppercase}.rank-badge{background:var(--accent-soft);color:var(--accent);width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:8px;font-weight:800;font-size:.8rem}.visitas-chip{background:var(--surface-2);padding:4px 10px;border-radius:6px;font-weight:600}.estado-badge{padding:4px 10px;border-radius:20px;font-size:.75rem;font-weight:700}.estado-badge--on{background:#dcfce7;color:var(--success)}.estado-badge--off{background:#f1f5f9;color:var(--text-secondary)}.btn-accion{padding:6px 12px;border-radius:8px;font-size:.8rem;font-weight:600;cursor:pointer;transition:var(--transition);border:1px solid transparent}.btn-accion--desactivar{background:#fee2e2;color:var(--danger)}.btn-accion--desactivar:hover{background:var(--danger);color:#fff}.btn-accion--reactivar{background:#dcfce7;color:var(--success)}.btn-accion--reactivar:hover{background:var(--success);color:#fff}.clientes-cards-mobile{display:flex;flex-direction:column;padding:12px;gap:12px}.cliente-row-card{background:var(--surface-2);border-radius:var(--radius);padding:16px;display:flex;justify-content:space-between;align-items:center;border:1px solid var(--border)}.cliente-row-left{display:flex;align-items:center;gap:12px}.cliente-row-info{display:flex;flex-direction:column}.cliente-nombre{font-weight:600;color:var(--text-primary)}.cliente-visitas-label{font-size:.75rem;color:var(--text-secondary)}.text-center{text-align:center}@media(max-width:900px){:root{--sidebar-width: var(--sidebar-collapsed)}.sidebar-btn-label,.sidebar-logo-text,.sidebar-version{display:none}.sidebar-logo{justify-content:center;padding:20px 0}.sidebar-menu{padding:12px 8px}.sidebar-btn{justify-content:center;padding:12px}.sidebar-btn--active:before{display:none}.panel-content-area{padding:20px}.reportes-detalles-grid,.admin-split-grid{grid-template-columns:1fr}}@media(max-width:900px){.panel-topbar{left:var(--sidebar-collapsed);width:calc(100% - var(--sidebar-collapsed));padding:0 16px}.panel-content-area{padding:16px}.reportes-grid-cards{grid-template-columns:1fr}.tarjetas-grid{grid-template-columns:1fr 1fr}.form-grid{grid-template-columns:1fr}}.modal-overlay-admin{position:fixed;top:0;left:0;width:100vw;height:100vh;background-color:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;justify-content:center;align-items:center;z-index:9999}.modal-container-pro{background:#fff;width:95%;max-width:500px;max-height:90vh;border-radius:20px;display:flex;flex-direction:column;box-shadow:0 10px 30px #0000004d;overflow:hidden;animation:slideUp .3s ease-out}@keyframes slideUp{0%{transform:translateY(50px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-body-pro{padding:20px;overflow-y:auto;flex-grow:1}.detalle-servicios-scroll{width:100%;overflow-x:auto;border:1px solid #eee;border-radius:8px}
