*,:before,:after,::backdrop{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:#3b82f680;--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }*,:before,:after{box-sizing:border-box;border:0 solid #e5e7eb}:before,:after{--tw-content:""}html,:host{-webkit-text-size-adjust:100%;tab-size:4;font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent;font-family:ui-sans-serif,system-ui,sans-serif,Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol,Noto Color Emoji;line-height:1.5}body{line-height:inherit;margin:0}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-feature-settings:normal;font-variation-settings:normal;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-feature-settings:inherit;font-variation-settings:inherit;font-family:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:#0000;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{margin:0;padding:0;list-style:none}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder{opacity:1;color:#9ca3af}textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif}body{--tw-bg-opacity:1;background-color:rgb(243 244 246/var(--tw-bg-opacity,1));--tw-text-opacity:1;color:rgb(17 24 39/var(--tw-text-opacity,1));min-width:320px;min-height:100vh;margin:0;line-height:1.5}#root{width:100%;min-height:100vh}*{box-sizing:border-box}button{cursor:pointer}:focus-visible{outline-offset:2px;outline:2px solid #2563eb}.btn{border-radius:.5rem;padding:.5rem 1rem;font-weight:500;transition-property:all;transition-duration:.2s;transition-timing-function:cubic-bezier(.4,0,.2,1)}.btn-primary{--tw-bg-opacity:1;background-color:rgb(37 99 235/var(--tw-bg-opacity,1));--tw-text-opacity:1;color:rgb(255 255 255/var(--tw-text-opacity,1))}.btn-primary:hover{--tw-bg-opacity:1;background-color:rgb(29 78 216/var(--tw-bg-opacity,1))}.btn-primary:focus{--tw-ring-offset-shadow:var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow:var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow,0 0 #0000);--tw-ring-opacity:1;--tw-ring-color:rgb(59 130 246/var(--tw-ring-opacity,1));--tw-ring-offset-width:2px}.btn-secondary{--tw-bg-opacity:1;background-color:rgb(229 231 235/var(--tw-bg-opacity,1));--tw-text-opacity:1;color:rgb(31 41 55/var(--tw-text-opacity,1))}.btn-secondary:hover{--tw-bg-opacity:1;background-color:rgb(209 213 219/var(--tw-bg-opacity,1))}.input{--tw-border-opacity:1;border-width:1px;border-color:rgb(209 213 219/var(--tw-border-opacity,1));border-radius:.5rem;width:100%;padding:.5rem .75rem;transition-property:all;transition-duration:.15s;transition-timing-function:cubic-bezier(.4,0,.2,1)}.input:focus{--tw-border-opacity:1;border-color:rgb(59 130 246/var(--tw-border-opacity,1));--tw-ring-offset-shadow:var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow:var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow,0 0 #0000);--tw-ring-opacity:1;--tw-ring-color:rgb(59 130 246/var(--tw-ring-opacity,1))}.badge{border-radius:9999px;align-items:center;padding:.125rem .625rem;font-size:.75rem;font-weight:500;line-height:1rem;display:inline-flex}.border{border-width:1px}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.login-page{background:linear-gradient(135deg,#1f2937 0%,#111827 50%,#0a0a0a 100%);min-height:100vh;display:flex;position:relative;overflow:hidden}.login-page:before{content:"";pointer-events:none;background:radial-gradient(at 20%,#ff8c0026 0%,#0000 50%),radial-gradient(at 80% 20%,#ff6b001a 0%,#0000 40%),radial-gradient(at 60% 80%,#ff8c0014 0%,#0000 40%);position:absolute;inset:0}.login-page:after{content:"";pointer-events:none;background-image:radial-gradient(#ffffff0d 1px,#0000 1px);background-size:40px 40px;position:absolute;inset:0}.login-features{z-index:1;flex-direction:column;flex:1;justify-content:center;max-width:600px;padding:60px;display:flex;position:relative}.login-features h2{color:#fff;margin:0 0 16px;font-size:2.5rem;font-weight:800;line-height:1.2}.login-features h2 span{color:#ff8c00}.login-features>p{color:#9ca3af;margin:0 0 40px;font-size:1.1rem;line-height:1.6}.feature-list{flex-direction:column;gap:24px;display:flex}.feature-item{align-items:flex-start;gap:16px;display:flex}.feature-icon{color:#ff8c00;background:#ff8c0026;border:1px solid #ff8c004d;border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;display:flex}.feature-text h4{color:#fff;margin:0 0 4px;font-size:1rem;font-weight:600}.feature-text p{color:#9ca3af;margin:0;font-size:.9rem;line-height:1.4}.login-panel{z-index:1;flex:1;justify-content:center;align-items:center;padding:40px;display:flex;position:relative}.login-card{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#fffffffa;border-radius:20px;width:100%;max-width:420px;padding:40px;box-shadow:0 20px 60px #0000004d,0 0 0 1px #ffffff1a}.login-brand{text-align:center;margin-bottom:32px}.login-icon{color:#fff;background:linear-gradient(135deg,#ff8c00 0%,#cc7000 100%);border-radius:18px;justify-content:center;align-items:center;width:72px;height:72px;margin:0 auto 16px;display:flex;box-shadow:0 8px 24px #ff8c0059}.login-brand h1{color:#1f2937;margin:0 0 4px;font-size:1.6rem;font-weight:700}.login-brand p{color:#6b7280;margin:0;font-size:.95rem}.login-form{flex-direction:column;gap:18px;display:flex}.login-error{color:#dc2626;text-align:center;background:#fef2f2;border:1px solid #fecaca;border-radius:10px;justify-content:center;align-items:center;gap:8px;padding:12px 16px;font-size:.9rem;display:flex}.form-group{flex-direction:column;gap:6px;display:flex}.form-group label{color:#374151;font-size:.85rem;font-weight:600}.form-group input{border:1px solid #e5e7eb;border-radius:10px;padding:14px 16px;font-size:1rem;transition:all .2s;color:#1f2937!important;-webkit-text-fill-color:#1f2937!important;background:#f9fafb!important}.form-group input:focus{border-color:#ff8c00;outline:none;box-shadow:0 0 0 3px #ff8c001a;color:#1f2937!important;-webkit-text-fill-color:#1f2937!important;background:#fff!important}.form-group input::placeholder{color:#9ca3af}.btn-login{color:#fff;cursor:pointer;background:linear-gradient(135deg,#ff8c00 0%,#cc7000 100%);border:none;border-radius:10px;margin-top:8px;padding:16px;font-size:1rem;font-weight:600;transition:all .2s;box-shadow:0 4px 12px #ff8c0040}.btn-login:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 8px 20px #ff8c0059}.btn-login:disabled{opacity:.6;cursor:not-allowed}.btn-toggle{color:#ff8c00;cursor:pointer;text-align:center;background:0 0;border:none;padding:8px;font-size:.9rem;font-weight:500}.btn-toggle:hover{color:#cc7000}.login-footer{text-align:center;border-top:1px solid #e5e7eb;margin-top:24px;padding-top:24px}.login-footer p{color:#9ca3af;margin:0;font-size:.8rem}@media (width<=1024px){.login-page{flex-direction:column}.login-features{text-align:center;max-width:none;padding:40px 30px 20px}.login-features h2{font-size:1.8rem}.login-features>p{margin-bottom:24px}.feature-list{flex-flow:wrap;justify-content:center}.feature-item{flex:1;min-width:200px;max-width:280px}.login-panel{padding:20px 20px 40px}.login-card{max-width:100%}}@media (width<=480px){.login-features{padding:30px 20px 10px}.login-features h2{font-size:1.5rem}.feature-icon{width:40px;height:40px}.login-card{padding:28px 20px}.login-icon{width:60px;height:60px}}:root{--color-bg:#0a0a0a;--color-surface:#111;--color-card:#161616;--color-card-alt:#1c1c1c;--color-border:#252525;--color-border-lt:#2e2e2e;--color-accent:#ff8c00;--color-accent-dk:#cc7000;--color-accent-bg:#ff8c001f;--color-accent-bg-hv:#ff8c0038;--color-accent-glow:#ff8c0066;--color-text:#fff;--color-text-muted:#9a9a9a;--color-text-dim:#666;--color-green:#22c55e;--color-red:#ef4444;--color-yellow:#f59e0b;--color-blue:#3b82f6;--radius-sm:8px;--radius-md:14px;--radius-lg:20px;--radius-xl:28px;--radius-full:99px;--shadow-card:0 4px 24px #0006;--shadow-glow:0 0 40px #ff8c0026;--shadow-glow-sm:0 0 20px #ff8c004d;--container:1200px;--section-pad:100px}*{box-sizing:border-box;margin:0;padding:0}body{background:var(--color-bg);color:var(--color-text);min-height:100vh;font-family:"Exo 2",-apple-system,BlinkMacSystemFont,sans-serif;line-height:1.6;overflow-x:hidden}body:before{content:"";pointer-events:none;z-index:-2;background:radial-gradient(at 0 0,#ff8c000d 0,#0000 50%),radial-gradient(at 100% 100%,#ff8c000d 0,#0000 50%);position:fixed;inset:0}.cursor-glow{pointer-events:none;z-index:-1;background:radial-gradient(circle,#ff8c0014 0%,#0000 70%);border-radius:50%;width:400px;height:400px;transition:opacity .3s;position:fixed;transform:translate(-50%,-50%)}h1,h2,h3,h4,h5,h6{color:var(--color-text);font-family:"Exo 2",sans-serif;font-weight:700;line-height:1.1}h1{font-size:clamp(2.4rem,5.5vw,4rem);font-weight:900}h2{font-size:clamp(2rem,5vw,3.2rem);font-weight:900}h3{font-size:1.5rem;font-weight:700}h4{font-size:1.25rem;font-weight:600}p,span,div,input,textarea{font-family:Open Sans,-apple-system,sans-serif}.text-muted{color:var(--color-text-muted);font-size:.875rem}.text-dim{color:var(--color-text-dim);font-size:.82rem}.shine-text{color:#0000;background:linear-gradient(90deg,#ff8c00 0%,orange 25%,#fff 50%,orange 75%,#ff8c00 100%) 0 0/200%;-webkit-background-clip:text;background-clip:text;animation:4s linear infinite shine-text}@keyframes shine-text{0%{background-position:-200%}to{background-position:200%}}.app-container{flex-direction:column;max-width:1400px;min-height:100vh;margin:0 auto;padding:0 24px;display:flex}.navbar{z-index:100;-webkit-backdrop-filter:blur(16px)saturate(180%);backdrop-filter:blur(16px)saturate(180%);border-radius:var(--radius-lg);background:#0f0f0fd9;border:1px solid #ff8c0026;justify-content:space-between;align-items:center;width:calc(100% - 40px);max-width:1300px;height:70px;margin:20px auto 30px;padding:0 28px;transition:all .3s;display:flex;position:sticky;top:20px;box-shadow:0 4px 30px #00000080}.navbar.scrolled{background:#0f0f0ff2;border-color:#ff8c0040;box-shadow:0 8px 40px #0009}.navbar-brand{color:var(--color-text);cursor:pointer;align-items:center;gap:12px;font-family:"Exo 2",sans-serif;font-size:1.25rem;font-weight:800;transition:transform .2s;display:flex}.navbar-brand:hover{transform:scale(1.02)}.brand-icon{background:var(--color-accent-bg);border-radius:var(--radius-sm);width:36px;height:36px;color:var(--color-accent);border:1px solid #ff8c0040;justify-content:center;align-items:center;display:flex}.brand-text span{color:var(--color-accent)}.navbar-actions{align-items:center;gap:16px;display:flex}.btn{border-radius:var(--radius-sm);cursor:pointer;white-space:nowrap;border:none;justify-content:center;align-items:center;gap:8px;font-family:"Exo 2",sans-serif;font-size:.9rem;font-weight:600;transition:all .2s cubic-bezier(.16,1,.3,1);display:inline-flex}.btn-primary{color:#000;box-shadow:var(--shadow-glow-sm);background:linear-gradient(90deg,#ff8c00 0%,#ffc400 50%,#ff8c00 100%) 0 0/200%;padding:12px 24px;animation:2s linear infinite shine-button}@keyframes shine-button{to{background-position:200%}}.btn-primary:hover{transform:translateY(-2px)scale(1.02);box-shadow:0 0 40px #ff8c0080}.btn-primary:active{transform:translateY(0)scale(1)}.btn-outline{border:1.5px solid var(--color-border-lt);color:var(--color-text);background:0 0;padding:12px 24px}.btn-outline:hover{border-color:var(--color-accent);color:var(--color-accent);background:var(--color-accent-bg)}.btn-secondary{background:var(--color-card);border:1px solid var(--color-border);color:var(--color-text);padding:10px 18px}.btn-secondary:hover{background:var(--color-card-alt);border-color:var(--color-border-lt)}.btn-ghost{color:var(--color-text-muted);background:0 0;padding:10px 16px}.btn-ghost:hover{color:var(--color-text);background:#ffffff0d}.btn-icon{border-radius:var(--radius-sm);width:40px;height:40px;padding:0;font-size:1.1rem}.btn-sm{padding:8px 14px;font-size:.85rem}.app-main{flex-direction:column;flex:1;gap:24px;padding:20px 0;display:flex}.calendar-header{justify-content:space-between;align-items:center;margin-bottom:10px;padding:0 8px;display:flex}.calendar-title{align-items:center;gap:16px;display:flex}.calendar-month{color:var(--color-text);text-transform:capitalize;font-family:"Exo 2",sans-serif;font-size:1.75rem;font-weight:800}.calendar-nav{align-items:center;gap:10px;display:flex}.view-toggle{background:var(--color-card);border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:4px;display:flex}.view-toggle button{color:var(--color-text-muted);border-radius:calc(var(--radius-sm) - 2px);cursor:pointer;background:0 0;border:none;padding:8px 16px;font-size:.85rem;font-weight:500;transition:all .15s}.view-toggle button.active{background:var(--color-accent);color:#000}.view-toggle button:not(.active):hover{color:var(--color-text)}.today-badge{background:var(--color-accent-bg);border-radius:var(--radius-full);color:var(--color-accent);border:1px solid #ff8c0040;align-items:center;gap:6px;padding:4px 10px;font-family:"Exo 2",sans-serif;font-size:.72rem;font-weight:700;display:inline-flex}.today-badge:before{content:"";background:var(--color-accent);border-radius:50%;width:6px;height:6px;animation:2s infinite pulse-dot}@keyframes pulse-dot{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.8)}}.calendar-container{background:var(--color-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);overflow:hidden}.calendario-semanal{grid-template-columns:80px repeat(7,1fr);min-height:600px;display:grid}.dias-header{display:contents}.hora-header{background:var(--color-surface);border-bottom:1px solid var(--color-border);border-right:1px solid var(--color-border)}.dia-header{text-align:center;background:var(--color-surface);border-bottom:1px solid var(--color-border);border-right:1px solid var(--color-border);padding:16px 8px}.dia-header:last-child{border-right:none}.dia-header.hoy{background:var(--color-accent-bg)}.dia-header.domingo{color:var(--color-text-muted)}.dia-nombre{color:var(--color-text-muted);text-transform:uppercase;letter-spacing:1px;font-size:.75rem;font-weight:600}.dia-numero{border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;margin-top:4px;font-family:"Exo 2",sans-serif;font-size:1.25rem;font-weight:700;display:inline-flex}.dia-header.hoy .dia-numero{background:var(--color-accent);color:#000}.cuerpo-semana,.hora-row{display:contents}.hora-label{text-align:right;color:var(--color-text-dim);border-right:1px solid var(--color-border);border-bottom:1px solid var(--color-border);background:#ffffff05;padding:8px;font-size:.75rem}.casilla-dia{border-right:1px solid var(--color-border);border-bottom:1px solid var(--color-border);cursor:pointer;background:#1a1c1e;min-height:70px;transition:background .15s;position:relative}.casilla-dia:hover{background:#ff8c0014}.casilla-dia.hoy{background:#1d1914}.cita-en-calendario{border-radius:var(--radius-sm);cursor:pointer;z-index:1;border-left:3px solid #9ca3af;min-height:50px;padding:6px 8px;font-size:.75rem;transition:all .15s;display:block;position:absolute;top:2px;left:2px;right:2px;overflow:hidden;color:#fff!important;background:#9ca3af40!important}.cita-en-calendario.cita-agendada{background:#ff6b0059!important;border-left-color:#ff6b00!important}.cita-en-calendario.cita-pendiente{background:#ff6b0040!important;border-left-color:#ff6b00!important}.cita-en-calendario.cita-confirmada{background:#10b98140!important;border-left-color:#10b981!important}.cita-en-calendario.cita-en_progreso{background:#3b82f640!important;border-left-color:#3b82f6!important}.cita-en-calendario.cita-completada{background:#6366f140!important;border-left-color:#6366f1!important}.cita-en-calendario.cita-cancelada{opacity:.7;background:#ef444440!important;border-left-color:#ef4444!important}.cita-en-calendario:hover{z-index:2;transform:translateY(-2px);box-shadow:0 4px 12px #0000004d}.cita-en-calendario .cita-hora{color:#ffffffb3;font-family:"Exo 2",sans-serif;font-size:.7rem;font-weight:700}.cita-en-calendario .cita-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:6px;margin-bottom:4px;display:flex}.cita-status-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px;box-shadow:0 0 4px}.cita-estado-badge{text-transform:uppercase;white-space:nowrap;border-radius:10px;flex-shrink:0;margin-left:6px;padding:3px 8px;font-size:.6rem;font-weight:700}.cita-header>.cita-hora{flex-shrink:0}.cita-en-calendario .cita-cliente{white-space:nowrap;text-overflow:ellipsis;font-weight:600;overflow:hidden}.cita-en-calendario .cita-tipo{opacity:.8;font-size:.65rem}.mes-container{background:var(--color-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);padding:20px}.mes-dias-nombres{grid-template-columns:repeat(7,1fr);gap:8px;margin-bottom:12px;display:grid}.mes-dia-nombre{text-align:center;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:1px;padding:8px 0;font-size:.7rem;font-weight:600}.mes-grid{flex-direction:column;gap:8px;display:flex}.mes-semana{grid-template-columns:repeat(7,1fr);gap:8px;display:grid}.mes-dia{aspect-ratio:1;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;flex-direction:column;padding:8px;transition:all .2s;display:flex}.mes-dia:hover{border-color:var(--color-border-lt);background:var(--color-card-alt)}.mes-dia.hoy{background:var(--color-accent-bg);border-color:#ff8c004d}.mes-dia.otro-mes{opacity:.4}.mes-numero{color:var(--color-text-muted);border-radius:50%;justify-content:center;align-items:center;width:28px;height:28px;font-family:"Exo 2",sans-serif;font-size:.9rem;font-weight:700;display:flex}.mes-numero.hoy{background:var(--color-accent);color:#000}.mes-citas{flex-direction:column;flex:1;gap:3px;margin-top:4px;display:flex}.mes-cita{white-space:nowrap;text-overflow:ellipsis;cursor:pointer;border-radius:4px;padding:3px 6px;font-size:.65rem;font-weight:600;transition:all .15s;overflow:hidden}.mes-cita:hover{filter:brightness(1.15);transform:translate(2px)}.mes-mas{color:var(--color-text-dim);text-align:center;padding:2px 0;font-size:.65rem}.modal-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:1000;background:#000c;justify-content:center;align-items:center;padding:24px;animation:.2s fade-in;display:flex;position:fixed;inset:0}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.modal-content{background:var(--color-card);border:1px solid var(--color-border);border-radius:var(--radius-xl);flex-direction:column;width:100%;max-width:580px;max-height:90vh;animation:.3s cubic-bezier(.16,1,.3,1) slide-up;display:flex;overflow:hidden;box-shadow:0 25px 50px -12px #00000080}@keyframes slide-up{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-header{background:var(--color-surface);border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;padding:20px 24px;display:flex}.modal-header h2{font-size:1.25rem;font-weight:700}.modal-header .btn-cerrar{border:1px solid var(--color-border);color:var(--color-text-muted);border-radius:var(--radius-sm);cursor:pointer;background:0 0;justify-content:center;align-items:center;width:36px;height:36px;font-size:1.25rem;transition:all .15s;display:flex}.modal-header .btn-cerrar:hover{background:var(--color-card);color:var(--color-text);border-color:var(--color-border-lt)}.modal-body{padding:24px;overflow-y:auto}.modal-actions{border-top:1px solid var(--color-border);justify-content:flex-end;gap:12px;margin-top:20px;padding-top:20px;display:flex}.form-group{margin-bottom:20px}.form-group label{color:var(--color-text-muted);margin-bottom:8px;font-family:"Exo 2",sans-serif;font-size:.85rem;font-weight:600;display:block}.form-group input,.form-group select,.form-group textarea{background:var(--color-card-alt);border:1.5px solid var(--color-border);border-radius:var(--radius-sm);width:100%;color:var(--color-text);padding:12px 14px;font-size:.95rem;transition:all .15s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--color-accent);outline:none;box-shadow:0 0 0 3px #ff8c001a}.form-group input::-moz-placeholder{color:var(--color-text-dim)}.form-group textarea::-moz-placeholder{color:var(--color-text-dim)}.form-group input::placeholder,.form-group textarea::placeholder{color:var(--color-text-dim)}.form-row{grid-template-columns:1fr 1fr;gap:16px;display:grid}.address-autocomplete{width:100%;position:relative}.address-autocomplete input{background:var(--color-card-alt);border:1.5px solid var(--color-border);border-radius:var(--radius-sm);width:100%;color:var(--color-text);padding:12px 40px 12px 14px;font-size:.95rem;transition:all .15s}.address-autocomplete input:focus{border-color:var(--color-accent);outline:none;box-shadow:0 0 0 3px #ff8c001a}.address-loading{position:absolute;top:50%;right:12px;transform:translateY(-50%)}.spinner{border:2px solid var(--color-border);border-top-color:var(--color-accent);border-radius:50%;width:16px;height:16px;animation:.8s linear infinite spin;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.address-suggestions{background:var(--color-card-alt);border:1px solid var(--color-border);border-radius:var(--radius-md);z-index:1000;max-height:250px;margin:0;padding:0;list-style:none;position:absolute;top:calc(100% + 4px);left:0;right:0;overflow-y:auto;box-shadow:0 10px 40px #0006}.address-suggestion-item{cursor:pointer;border-bottom:1px solid var(--color-border);align-items:flex-start;gap:10px;padding:12px 14px;transition:all .15s;display:flex}.address-suggestion-item:last-of-type{border-bottom:none}.address-suggestion-item:hover{background:var(--color-accent-bg);border-color:#ff8c0033}.suggestion-icon{flex-shrink:0;font-size:1rem}.suggestion-text{color:var(--color-text-muted);font-size:.85rem;line-height:1.4}.address-suggestion-item:hover .suggestion-text{color:var(--color-text)}.address-footer{background:var(--color-surface);border-top:1px solid var(--color-border);padding:10px 14px}.address-footer small{color:var(--color-text-dim);font-size:.75rem}.direccion-field .helper-text{color:var(--color-text-dim);margin-top:6px;font-size:.75rem;display:block}.detalle-header{align-items:center;gap:16px;margin-bottom:24px;display:flex}.detalle-avatar{background:linear-gradient(135deg, var(--color-accent), var(--color-accent-dk));color:#000;width:56px;height:56px;box-shadow:var(--shadow-glow-sm);border-radius:50%;justify-content:center;align-items:center;font-family:"Exo 2",sans-serif;font-size:1.5rem;font-weight:800;display:flex}.detalle-titulo{flex:1}.detalle-titulo h3{margin-bottom:6px;font-size:1.3rem;font-weight:700}.badge{border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:.5px;align-items:center;gap:6px;padding:5px 12px;font-family:"Exo 2",sans-serif;font-size:.75rem;font-weight:700;display:inline-flex}.badge-pendiente{color:var(--color-yellow);background:#f59e0b26;border:1px solid #f59e0b4d}.badge-confirmada{color:var(--color-green);background:#22c55e26;border:1px solid #22c55e4d}.badge-en_progreso{background:var(--color-accent-bg);color:var(--color-accent);border:1px solid #ff8c004d}.badge-completada{color:var(--color-blue);background:#3b82f626;border:1px solid #3b82f64d}.badge-cancelada{color:var(--color-red);background:#ef444426;border:1px solid #ef44444d}.detalle-grid{grid-template-columns:repeat(2,1fr);gap:16px;margin-bottom:24px;display:grid}.detalle-item{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);align-items:center;gap:12px;padding:14px;transition:all .15s;display:flex}.detalle-item:hover{border-color:var(--color-border-lt);background:var(--color-card-alt)}.detalle-item.full-width{grid-column:1/-1}.icon-container{background:var(--color-accent-bg);border-radius:var(--radius-sm);width:40px;height:40px;color:var(--color-accent);border:1px solid #ff8c0040;flex-shrink:0;justify-content:center;align-items:center;font-size:1.1rem;display:flex}.detalle-item .content{min-width:0}.detalle-item .content .label{color:var(--color-text-muted);margin-bottom:2px;font-size:.75rem;font-weight:500}.detalle-item .content .value{color:var(--color-text);font-size:.95rem;font-weight:600}.detalle-item .content a.value{color:var(--color-accent);text-decoration:none}.detalle-item .content a.value:hover{text-decoration:underline}.detalle-notas{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:16px}.detalle-notas h4{color:var(--color-text-muted);align-items:center;gap:8px;margin-bottom:10px;font-size:.85rem;display:flex}.detalle-notas p{color:var(--color-text);white-space:pre-wrap;margin:0;font-size:.9rem;line-height:1.6}.confirmacion-body{text-align:center;padding:32px 24px}.confirmacion-icon{margin-bottom:20px;font-size:4rem}.confirmacion-body h3{color:var(--color-red);margin-bottom:12px;font-size:1.25rem;font-weight:700}.confirmacion-body p{color:var(--color-text-muted);font-size:.95rem;line-height:1.5}.empty-state{text-align:center;color:var(--color-text-muted);flex-direction:column;justify-content:center;align-items:center;padding:60px 24px;display:flex}.empty-state-icon{opacity:.5;margin-bottom:20px;font-size:4rem}.empty-state h3{color:var(--color-text);margin-bottom:8px;font-size:1.25rem;font-weight:600}.empty-state p{color:var(--color-text-muted);font-size:.9rem}.lista-citas{max-height:calc(100vh - 200px);padding:16px;overflow-y:auto}.cita-card{cursor:pointer;background:#fff;border:2px solid #0000;border-radius:12px;margin-bottom:12px;padding:16px;transition:all .2s;box-shadow:0 2px 8px #00000014}.cita-card:hover{border-color:var(--color-primary);transform:translateY(-2px);box-shadow:0 4px 16px #ff6b0026}.cita-card.today{border-left:4px solid var(--color-primary);background:linear-gradient(135deg,#fff 0%,#fff7ed 100%)}.cita-badge{color:#fff;text-transform:uppercase;letter-spacing:.5px;border-radius:6px;margin-bottom:8px;padding:4px 10px;font-size:.75rem;font-weight:600;display:inline-block}.cita-info{margin-top:8px}.cita-fecha{color:var(--color-text-muted);margin-bottom:4px;font-size:.85rem;font-weight:600}.cita-cliente{color:var(--color-text);margin-bottom:4px;font-size:1rem;font-weight:600}.cita-direccion{color:var(--color-text-muted);font-size:.85rem;line-height:1.4}.text-center{text-align:center}.mx-auto{margin-left:auto;margin-right:auto}.max-w-md{max-width:400px}.loading-container{min-height:400px;color:var(--color-text-muted);flex-direction:column;justify-content:center;align-items:center;display:flex}.loading-container .spinner{width:40px;height:40px;margin-bottom:16px}.loading-container p{font-size:.9rem}.app-footer{text-align:center;color:var(--color-text-dim);border-top:1px solid var(--color-border);margin-top:auto;padding:24px;font-size:.8rem}.app-footer span{color:var(--color-accent)}.app-with-sidebar{gap:1.5rem;padding:1rem;flex-direction:row!important}.app-with-sidebar .sidebar{flex-direction:column;flex-shrink:0;gap:1rem;width:280px;display:flex}.app-with-sidebar .calendar-column{flex-direction:column;flex:1;min-width:0;display:flex}.mini-calendario{border-radius:var(--radius-xl);-webkit-backdrop-filter:blur(10px);background:#14141499;border:1px solid #ff8c001a;padding:1rem}.mini-header{justify-content:space-between;align-items:center;margin-bottom:.75rem;display:flex}.mini-nav{color:var(--color-text-dim);cursor:pointer;border-radius:var(--radius-sm);transition:all .2s var(--ease-out);background:0 0;border:none;padding:.25rem .5rem;font-size:1.25rem}.mini-nav:hover{color:var(--color-accent);background:#ff8c001a}.mini-mes{color:var(--color-text);text-transform:capitalize;font-size:.875rem;font-weight:500}.mini-dias-nombres{grid-template-columns:repeat(7,1fr);gap:2px;margin-bottom:.5rem;display:grid}.mini-dia-nombre{text-align:center;color:var(--color-text-dim);text-transform:uppercase;letter-spacing:.05em;padding:.25rem 0;font-size:.625rem}.mini-grid{flex-direction:column;gap:2px;display:flex}.mini-semana{grid-template-columns:repeat(7,1fr);gap:2px;display:grid}.mini-dia{aspect-ratio:1;border-radius:var(--radius-sm);cursor:pointer;transition:all .2s var(--ease-out);color:var(--color-text-dim);justify-content:center;align-items:center;font-size:.75rem;display:flex;position:relative}.mini-dia.hoy{color:var(--color-accent);font-weight:600}.mini-dia.activo{background:linear-gradient(135deg, var(--gradient-1), var(--gradient-2));color:#000;font-weight:600;box-shadow:0 0 10px #ff8c0066}.mini-dia.activo:hover{background:linear-gradient(135deg, var(--gradient-2), var(--gradient-1))}.mini-dia.otro-mes{color:var(--color-text-muted);opacity:.5}.mini-dia.con-cita:after{content:"";background:var(--color-accent);width:4px;height:4px;box-shadow:0 0 5px var(--color-accent);border-radius:50%;position:absolute;bottom:2px}.filters-card,.legend-card{border-radius:var(--radius-xl);-webkit-backdrop-filter:blur(10px);background:#14141499;border:1px solid #ff8c001a;padding:1rem}.filters-header{color:var(--color-text);border-bottom:1px solid #ff8c001a;align-items:center;gap:.5rem;margin-bottom:1rem;padding-bottom:.5rem;font-size:.875rem;font-weight:500;display:flex}.filter-group{margin-bottom:1rem}.filter-group:last-child{margin-bottom:0}.filter-label{color:var(--color-text-dim);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.375rem;font-size:.75rem;display:block}.filter-select{border-radius:var(--radius-lg);width:100%;color:var(--color-text);cursor:pointer;appearance:none;transition:all .2s var(--ease-out);background:#ff8c000d url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24'%3E%3Cpath fill='%23FF8C00' d='M7 10l5 5 5-5z'/%3E%3C/svg%3E") right .75rem center no-repeat;border:1px solid #ff8c0033;padding:.625rem .875rem;font-size:.875rem}.filter-select:hover,.filter-select:focus{border-color:var(--color-accent);background:#ff8c001a;outline:none}.filter-select option{background:var(--color-surface);color:var(--color-text)}.btn-full{width:100%}.legend-grid{flex-direction:column;gap:.5rem;display:flex}.legend-item{color:var(--color-text-dim);align-items:center;gap:.625rem;font-size:.75rem;display:flex}.legend-dot{border-radius:50%;width:8px;height:8px;box-shadow:0 0 5px}.reveal{opacity:0;transition:opacity .5s,transform .5s cubic-bezier(.16,1,.3,1);transform:translateY(20px)}.reveal.visible{opacity:1;transform:none}.reveal-delay-1{transition-delay:.1s}.reveal-delay-2{transition-delay:.2s}.reveal-delay-3{transition-delay:.3s}.app{background:#f5f5f5;flex-direction:column;min-height:100vh;display:flex}.app-header{background:#fff;border-bottom:1px solid #e5e7eb;justify-content:space-between;align-items:center;padding:16px 24px;display:flex;box-shadow:0 2px 8px #0000000d}.header-brand{align-items:center;gap:12px;display:flex}.brand-icon{color:#fff;background:#ff8c00;border-radius:8px;justify-content:center;align-items:center;width:40px;height:40px;display:flex}.header-brand h1{color:#1f2937;margin:0;font-size:1.25rem;font-weight:700}.header-brand p{color:#6b7280;margin:0;font-size:.85rem}.header-controls{align-items:center;gap:16px;display:flex}.header-user{background:#f3f4f6;border-radius:8px;align-items:center;gap:10px;padding:6px 12px;display:flex}.header-user-email{color:#374151;text-overflow:ellipsis;white-space:nowrap;max-width:180px;font-size:.85rem;font-weight:500;overflow:hidden}.btn-logout{color:#6b7280;cursor:pointer;background:0 0;border:1px solid #e5e7eb;border-radius:6px;align-items:center;gap:6px;padding:6px 12px;font-size:.85rem;font-weight:500;transition:all .2s;display:flex}.btn-logout:hover{color:#dc2626;background:#fef2f2;border-color:#fecaca}.vista-toggle{background:#f3f4f6;border-radius:8px;padding:4px;display:flex}.vista-btn{color:#6b7280;cursor:pointer;background:0 0;border:none;border-radius:6px;padding:8px 20px;font-size:.9rem;font-weight:600;transition:all .2s}.vista-btn.active{color:#1f2937;background:#fff;box-shadow:0 2px 4px #0000001a}.vista-btn:hover:not(.active){color:#1f2937}.app-content{flex:1;height:calc(100vh - 73px);display:flex;overflow:hidden}.sidebar{background:#f9fafb;border-right:1px solid #e5e7eb;width:320px;min-width:320px;padding:16px;overflow-y:auto}.sidebar::-webkit-scrollbar{width:6px}.sidebar::-webkit-scrollbar-track{background:0 0}.sidebar::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:3px}.mini-calendario{background:#fff;border-radius:8px;margin-bottom:16px;padding:16px}.mini-calendario-header h3{color:#1f2937;text-transform:capitalize;margin:0 0 12px;font-size:1rem;font-weight:700}.mini-calendario-grid{grid-template-columns:repeat(7,1fr);gap:4px;display:grid}.mini-dia-header{text-align:center;color:#6b7280;padding:4px;font-size:.75rem;font-weight:600}.mini-dia{aspect-ratio:1;cursor:pointer;color:#374151;background:0 0;border:none;border-radius:4px;font-size:.85rem;transition:all .2s}.mini-dia:hover{background:#f3f4f6}.mini-dia.today{border:2px solid #ff8c00;font-weight:700}.mini-dia.selected{color:#fff;background:#ff8c00;font-weight:700}.sidebar-card{background:#fff;border-radius:8px;margin-bottom:16px;padding:16px}.sidebar-card-title{color:#1f2937;margin:0 0 12px;font-size:.9rem;font-weight:700}.filtros{flex-direction:column;gap:12px;display:flex}.filtro-group{flex-direction:column;gap:4px;display:flex}.filtro-group label{color:#6b7280;font-size:.8rem;font-weight:600}.filtro-group select{color:#1f2937;background:#fff;border:1px solid #e5e7eb;border-radius:6px;width:100%;padding:8px 12px;font-size:.9rem;font-weight:500}.filtro-group select option{color:#1f2937;background:#fff;padding:8px}.btn-full{justify-content:center;width:100%}.leyenda{flex-direction:column;gap:8px;display:flex}.leyenda-item{color:#374151;align-items:center;gap:8px;font-size:.85rem;display:flex}.leyenda-dot{border-radius:50%;flex-shrink:0;width:12px;height:12px}.lista-citas-card{max-height:none}.lista-citas{flex-direction:column;gap:8px;max-height:400px;padding-right:4px;display:flex;overflow-y:auto}.lista-citas::-webkit-scrollbar{width:6px}.lista-citas::-webkit-scrollbar-track{background:#f3f4f6;border-radius:3px}.lista-citas::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:3px}.lista-citas::-webkit-scrollbar-thumb:hover{background:#9ca3af}.lista-vacia{text-align:center;color:#9ca3af;flex-direction:column;justify-content:center;align-items:center;padding:30px 20px;display:flex}.lista-vacia svg{opacity:.5;width:40px;height:40px;margin-bottom:12px}.lista-vacia p{margin:0;font-size:.85rem}.lista-cita-item{cursor:pointer;background:#fff;border:1px solid #e5e7eb;border-radius:6px;gap:10px;padding:10px;transition:all .2s;display:flex}.lista-cita-item:hover{border-color:#ff8c00;transform:translate(2px);box-shadow:0 2px 8px #ff8c0026}.lista-cita-estado{border-radius:2px;flex-shrink:0;width:4px;min-height:100%}.lista-cita-info{flex:1;min-width:0}.lista-cita-fecha{color:#6b7280;margin-bottom:3px;font-size:.75rem;font-weight:600}.lista-cita-cliente{color:#1f2937;white-space:nowrap;text-overflow:ellipsis;margin-bottom:2px;font-size:.9rem;font-weight:600;overflow:hidden}.lista-cita-direccion{color:#9ca3af;white-space:nowrap;text-overflow:ellipsis;font-size:.8rem;overflow:hidden}.calendario-main{background:#f9fafb;flex:1;padding:20px;overflow-y:auto}.calendario-nav{background:#fff;border-radius:8px;justify-content:space-between;align-items:center;margin-bottom:20px;padding:16px;display:flex;box-shadow:0 2px 8px #0000000d}.calendario-nav h2{color:#1f2937;text-transform:capitalize;margin:0;font-size:1.25rem;font-weight:700}.calendario-nav-buttons{align-items:center;gap:8px;display:flex}.semana-grid{background:#fff;border-radius:8px;flex-direction:column;display:flex;overflow:hidden;box-shadow:0 2px 8px #0000000d}.semana-header{border-bottom:2px solid #e5e7eb;grid-template-columns:repeat(6,1fr);display:grid}.semana-dia-header{text-align:center;color:#6b7280;padding:12px;font-size:.9rem;font-weight:600}.semana-dia-header.today{color:#ff8c00;background:#fff7ed}.semana-dia-num{margin-top:4px;font-size:1.5rem;font-weight:700}.semana-dia-header.today .semana-dia-num{color:#ff8c00}.semana-body{grid-template-columns:repeat(6,1fr);min-height:400px;display:grid}.semana-dia{border-right:1px solid #e5e7eb;min-height:300px;padding:12px}.semana-dia:last-child{border-right:none}.semana-dia.today{background:#fff7ed}.semana-empty{min-height:100px;margin-bottom:8px}.btn-add-dia{color:#9ca3af;cursor:pointer;background:0 0;border:2px dashed #e5e7eb;border-radius:6px;width:100%;padding:8px;font-size:.85rem;font-weight:600;transition:all .2s}.btn-add-dia:hover{color:#ff8c00;background:#ff8c000d;border-color:#ff8c00}.cita-card{cursor:pointer;border-left:4px solid;border-radius:6px;margin-bottom:8px;padding:10px;transition:all .2s}.cita-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.cita-card-header{justify-content:space-between;align-items:center;margin-bottom:6px;display:flex}.cita-hora{color:#374151;font-size:.8rem;font-weight:700}.cita-estado-badge{color:#fff;text-transform:uppercase;border-radius:3px;padding:2px 6px;font-size:.7rem;font-weight:600}.cita-card-body{margin-top:4px}.cita-nombre{color:#1f2937;margin-bottom:2px;font-size:.9rem;font-weight:600}.cita-direccion{color:#6b7280;white-space:nowrap;text-overflow:ellipsis;font-size:.8rem;overflow:hidden}.mes-grid{background:#fff;border-radius:8px;grid-template-columns:repeat(7,1fr);gap:8px;padding:16px;display:grid;box-shadow:0 2px 8px #0000000d}.mes-grid-header{text-align:center;color:#6b7280;text-transform:uppercase;padding:8px;font-size:.85rem;font-weight:600}.mes-grid-day{cursor:pointer;background:#fff;border:1px solid #e5e7eb;border-radius:6px;min-height:100px;padding:8px;transition:all .2s}.mes-grid-day:hover{border-color:#ff8c00}.mes-grid-day.today{background:#fff7ed;border-width:2px;border-color:#ff8c00}.mes-grid-day.empty{cursor:default;background:#f9fafb;border-color:#0000}.mes-grid-day-num{color:#374151;margin-bottom:4px;font-size:.9rem;font-weight:600}.mes-grid-day.today .mes-grid-day-num{color:#ff8c00;font-weight:700}.mes-grid-event{color:#fff;white-space:nowrap;text-overflow:ellipsis;cursor:pointer;border-radius:3px;margin-bottom:2px;padding:3px 6px;font-size:.75rem;overflow:hidden}.mes-grid-more{color:#6b7280;font-size:.7rem;font-weight:600}.loading{color:#6b7280;justify-content:center;align-items:center;padding:60px;font-size:1.1rem;font-weight:600;display:flex}@media (width<=1024px){.app-with-sidebar{padding:.75rem;flex-direction:column!important}.app-with-sidebar .sidebar{flex-flow:wrap;gap:.75rem;width:100%}.mini-calendario{flex:1;min-width:280px;max-width:350px}.filters-card,.legend-card{flex:1;min-width:200px}.navbar{width:calc(100% - 30px);margin:10px 15px 20px;padding:0 20px}.calendario-semanal{grid-template-columns:60px repeat(7,1fr)}.cita-en-calendario{padding:4px 6px}.cita-en-calendario .cita-cliente{color:#fff;white-space:nowrap;text-overflow:ellipsis;margin-bottom:2px;font-size:.75rem;font-weight:600;overflow:hidden}.navbar{height:60px;padding:0 16px}.navbar-brand{font-size:1.1rem}.brand-icon{width:32px;height:32px}.calendar-header{flex-direction:column;gap:16px}.calendar-title{justify-content:center;width:100%}.calendar-month{font-size:1.25rem}.form-row,.detalle-grid{grid-template-columns:1fr}.modal-content{max-height:calc(100vh - 32px);margin:16px}.calendar-container{border-radius:var(--radius-md)}.calendario-semanal{min-width:700px;overflow-x:auto}}@media (width<=480px){.btn{padding:10px 16px;font-size:.85rem}.btn-primary{padding:12px 20px}.modal-header h2{font-size:1.1rem}.mes-semana{gap:4px}.mes-dia{border-radius:var(--radius-sm);padding:4px}}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--color-surface);border-radius:4px}::-webkit-scrollbar-thumb{background:var(--color-border-lt);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--color-text-dim)}
