.top-navbar{width:95%;max-width:1150px;margin:15px auto;height:60px;background-color:#ffffffbf;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.8);border-radius:50px;position:sticky;top:15px;z-index:1000;display:flex;align-items:center;box-shadow:0 10px 40px #0000000f,0 2px 10px #0000000a}.navbar-container{max-width:1200px;width:100%;margin:0 auto;padding:0 20px;display:flex;justify-content:space-between;align-items:center}.navbar-brand a{text-decoration:none}.navbar-brand h1{font-size:1.25rem;font-weight:400;letter-spacing:-.5px;color:var(--sage-700)}.navbar-brand span{font-weight:700;color:var(--sage-400)}.navbar-links{list-style:none;padding:0;margin:0;display:flex;gap:8px}.navbar-links a{text-decoration:none;color:var(--sage-muted);padding:8px 16px;border-radius:8px;font-size:.9rem;font-weight:500;transition:all .2s ease;display:flex;align-items:center;gap:8px}.navbar-links a:hover{background-color:var(--sage-50);color:var(--sage-700)}.navbar-links a.nav-item-inicio:hover,.navbar-links a.nav-item-inicio.active-link{color:#3b82f6}.navbar-links a.nav-item-agenda:hover,.navbar-links a.nav-item-agenda.active-link{color:#f97316}.navbar-links a.nav-item-pacientes:hover,.navbar-links a.nav-item-pacientes.active-link{color:#8b5cf6}.navbar-links a.nav-item-obras:hover,.navbar-links a.nav-item-obras.active-link{color:#14b8a6}.navbar-links a.nav-item-prestaciones:hover,.navbar-links a.nav-item-prestaciones.active-link{color:#ec4899}.navbar-links a.active-link{background-color:var(--sage-100);color:var(--sage-700);font-weight:600}.icon{font-size:1rem}.navbar-actions{display:flex;align-items:center;margin-left:10px;border-left:1px solid var(--sage-200);padding-left:15px;gap:12px}.user-info{font-size:.9rem;font-weight:600;color:var(--sage-600);text-transform:capitalize}.btn-logout{background:transparent;border:none;color:var(--sage-400);cursor:pointer;padding:8px;border-radius:50%;transition:all .2s;display:flex;align-items:center;justify-content:center}.btn-logout:hover{background:#fff1f0;color:#e74c3c;transform:scale(1.1)}.hamburger-btn,.nav-overlay,.nav-drawer{display:none}@media(max-width:768px){.top-navbar{border-radius:20px;height:54px;margin:10px auto;width:94%}.navbar-container{flex-direction:row;padding:0 14px}.navbar-links{display:none}.hamburger-btn{display:flex;align-items:center;justify-content:center;background:transparent;border:none;color:var(--sage-500);cursor:pointer;padding:6px;border-radius:8px;transition:background .2s;order:-1}.hamburger-btn:hover{background:var(--sage-50)}.navbar-actions{border-left:none;padding-left:0;gap:8px;margin-left:0}.nav-overlay{display:block;position:fixed;inset:0;background:#00000059;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:1998;opacity:0;pointer-events:none;transition:opacity .3s ease}.nav-overlay.open{opacity:1;pointer-events:all}.nav-drawer{display:flex;flex-direction:column;position:fixed;top:0;left:0;height:100dvh;width:270px;background:#fffffff5;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-right:1px solid var(--sage-100);box-shadow:4px 0 30px #0000001f;z-index:1999;transform:translate(-100%);transition:transform .3s cubic-bezier(.4,0,.2,1);padding:0}.nav-drawer.open{transform:translate(0)}.nav-drawer-header{display:flex;align-items:center;justify-content:space-between;padding:20px 18px 16px;border-bottom:1px solid var(--sage-100)}.nav-drawer-title{font-size:1.05rem;color:var(--sage-600);font-weight:400;letter-spacing:-.3px}.nav-drawer-title strong{font-weight:700;color:var(--sage-400);margin-left:2px}.nav-drawer-close{background:none;border:none;color:var(--sage-400);cursor:pointer;padding:6px;border-radius:8px;display:flex;align-items:center;transition:background .2s}.nav-drawer-close:hover{background:var(--sage-50)}.nav-drawer-links{list-style:none;padding:12px 10px;margin:0;display:flex;flex-direction:column;gap:4px;flex:1;overflow-y:auto}.nav-drawer-links a{text-decoration:none;color:var(--sage-muted);padding:12px 14px;border-radius:10px;font-size:.95rem;font-weight:500;display:flex;align-items:center;gap:12px;transition:all .2s ease}.nav-drawer-links a:hover{background-color:var(--sage-50);color:var(--sage-700)}.nav-drawer-links a.active-link{background-color:var(--sage-100);color:var(--sage-700);font-weight:600}.nav-drawer-links a.nav-item-inicio.active-link{color:#3b82f6}.nav-drawer-links a.nav-item-agenda.active-link{color:#f97316}.nav-drawer-links a.nav-item-pacientes.active-link{color:#8b5cf6}.nav-drawer-links a.nav-item-obras.active-link{color:#14b8a6}.nav-drawer-links a.nav-item-prestaciones.active-link{color:#ec4899}.nav-drawer-footer{padding:16px 18px;border-top:1px solid var(--sage-100);display:flex;align-items:center;gap:10px}.nav-drawer-footer .user-info{font-size:.85rem;color:var(--sage-400)}}.modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#0006;display:flex;justify-content:center;align-items:flex-start;padding-top:80px;z-index:10000;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}.modal-content{background:#fff;padding:30px;border-radius:20px;text-align:center;max-width:400px;width:90%;box-shadow:0 10px 25px #0003;animation:slideUp .3s ease-out;position:relative;max-height:90vh;overflow-y:auto}.modal-icon{font-size:50px;margin-bottom:15px}.modal-btn{margin-top:20px;padding:10px 25px;border:none;background-color:var(--sage-400);color:#fff;border-radius:8px;cursor:pointer;font-weight:700;transition:all .2s}.modal-btn:hover{background-color:var(--sage-500)}.modal-content.custom-content{max-width:600px;text-align:left;padding:30px}.modal-close-icon{position:absolute;top:15px;right:15px;background:none;border:none;color:var(--sage-400);cursor:pointer;padding:5px;border-radius:50%;transition:all .2s;display:flex;align-items:center;justify-content:center}.modal-close-icon:hover{background-color:var(--sage-50);color:var(--sage-600)}.modal-custom-title{margin-top:0;margin-bottom:20px;color:var(--sage-700);font-size:1.3rem;border-bottom:1px solid var(--sage-100);padding-bottom:10px}.modal-custom-body{color:var(--sage-text);line-height:1.6}@keyframes slideUp{0%{transform:translateY(-10px);opacity:0}to{transform:translateY(0);opacity:1}}.dashboard-container{width:100%;max-width:1200px;margin:0 auto;display:flex;flex-direction:column;gap:30px;animation:fadeIn .4s ease-in-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px}.stat-card{background:#fff;border-radius:var(--radius-card);padding:24px;display:flex;align-items:center;gap:20px;box-shadow:var(--shadow-md);border:1px solid var(--sage-100);transition:transform .2s ease,box-shadow .2s ease}.stat-card.clickable{cursor:pointer}.stat-card:hover,.stat-card.clickable:hover{transform:translateY(-3px);box-shadow:0 8px 15px -3px #0000001a}.stat-icon{width:56px;height:56px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:24px;background:#fff;border:1px solid #e3eceb;color:#7a8a8c;transition:all .2s ease}.stat-card:hover .stat-icon.primary{border-color:#2ecc71;color:#2ecc71}.stat-card.clickable:hover .stat-icon.tertiary{border-color:#3498db;color:#3498db}.stat-content{display:flex;flex-direction:column}.stat-title{font-size:.85rem;font-weight:600;color:var(--sage-muted);text-transform:uppercase;letter-spacing:.5px}.stat-value{font-size:2rem;font-weight:700;color:var(--sage-text);line-height:1.2}.dashboard-section{background:#fff;border-radius:var(--radius-card);padding:30px;box-shadow:var(--shadow-sm);border:1px solid var(--sage-100);display:flex;flex-direction:column;gap:20px}.section-head{display:flex;justify-content:space-between;align-items:center;border-bottom:2px solid var(--sage-50);padding-bottom:16px}.section-head h3{font-size:1.25rem;color:var(--sage-700);margin:0;display:flex;align-items:center;gap:10px}.badge-count{background:var(--sage-400);color:#fff;border-radius:20px;padding:4px 12px;font-size:.8rem;font-weight:600}.turnos-lista{display:flex;flex-direction:column;gap:12px}.turno-item{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;background:var(--sage-50);border-radius:12px;border-left:4px solid var(--sage-400);transition:background .2s}.turno-item:hover{background:var(--sage-100)}.turno-info{display:flex;align-items:center;gap:20px}.turno-hora{font-size:1.15rem;font-weight:700;color:var(--sage-700);min-width:70px}.turno-detalles{display:flex;flex-direction:column}.turno-paciente{font-weight:600;font-size:1rem;color:var(--text-main);text-transform:uppercase}.turno-prestacion{font-size:.85rem;color:var(--sage-500)}.turno-empty{text-align:center;padding:40px;color:var(--sage-muted);font-size:1.1rem;background:var(--sage-50);border-radius:12px;border:1px dashed var(--sage-200)}.btn-whatsapp-dashboard{background:#fff;border:1px solid #e3eceb;color:#7a8a8c;padding:8px 16px;border-radius:8px;cursor:pointer;transition:all .2s;font-size:.95rem;display:flex;align-items:center;justify-content:center;gap:8px;text-decoration:none}.btn-whatsapp-dashboard:hover{border-color:#25d366;color:#25d366;transform:translateY(-2px);box-shadow:0 4px 8px #0000000d}.app-actions{display:flex;gap:16px;margin-top:10px}.btn-action-outline{display:flex;align-items:center;gap:8px;padding:12px 24px;border-radius:10px;font-weight:600;font-size:.9rem;border:2px solid var(--sage-400);color:var(--sage-500);background:transparent;cursor:pointer;transition:all .2s ease;text-decoration:none;text-transform:uppercase}.btn-action-outline:hover{background:var(--sage-400);color:#fff}@media(max-width:768px){.turno-item{flex-direction:column;align-items:flex-start;gap:16px}.btn-whatsapp-dashboard{width:100%;justify-content:center}}.fc{width:100%;font-family:inherit}.fc .fc-toolbar-title{font-size:1.25rem!important;color:var(--sage-700);font-weight:600}.fc .fc-button-primary{background-color:#fff!important;border:1px solid var(--sage-200)!important;color:var(--sage-700)!important;font-weight:500!important;text-transform:capitalize!important;box-shadow:0 4px 10px #00000008!important;border-radius:50px!important;padding:8px 16px!important;transition:all .2s ease!important}.fc .fc-button-primary:hover{background-color:var(--sage-50)!important;border-color:var(--sage-300)!important;transform:translateY(-1px)!important;box-shadow:0 6px 12px #0000000f!important}.fc .fc-button-primary:not(:disabled).fc-button-active,.fc .fc-button-primary:not(:disabled):active{background-color:var(--sage-400)!important;border-color:var(--sage-400)!important;color:#fff!important}.fc th{background-color:var(--sage-50);padding:10px 0!important;color:var(--sage-600);font-weight:600;font-size:.85rem;border:1px solid var(--sage-100)!important}.fc td{border:1px solid var(--sage-50)!important}.fc-event{border-radius:8px!important;border:1px solid rgba(0,0,0,.05)!important;padding:4px 6px!important;font-size:.8rem!important;cursor:pointer;box-shadow:0 2px 5px #00000014!important;transition:transform .2s,box-shadow .2s,filter .2s,height .2s,min-height .2s!important;overflow:hidden!important}.fc-event:hover{transform:translateY(-2px)!important;box-shadow:0 8px 16px #0003!important;filter:brightness(.97)!important;z-index:100!important;height:max-content!important;min-height:100%!important;overflow:visible!important}.fc-timegrid-event-harness:has(.fc-event:hover){z-index:50!important;overflow:visible!important}.fc-bg-event{opacity:.35!important;border-radius:4px!important}.fc-event-over-cancelled{box-shadow:inset -10px 0 #d4a5a5bf!important;border-right:none!important}.fc-event-main{display:flex;flex-direction:column;gap:2px}.fc-event-title{font-weight:700;line-height:1.25;white-space:normal!important;word-break:break-word;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.fc-event:hover .fc-event-title{-webkit-line-clamp:unset!important;display:block!important;overflow:visible!important}.fc-event:hover .fc-event-main{overflow:visible!important}.fc-event-time{font-weight:600;opacity:.85;font-size:.75rem}.fc .fc-highlight{background:#6a99722e!important;border:2px dashed var(--sage-400)!important;border-radius:6px!important}.fc .fc-event-mirror{background:var(--sage-400)!important;opacity:.75!important;border-radius:6px!important;border:none!important;font-size:.8rem!important;font-weight:600!important;color:#fff!important;box-shadow:0 4px 12px #6a997259!important}.fc .fc-timegrid-now-indicator-line{border-color:var(--sage-500)!important;border-width:2px!important}.fc .fc-timegrid-now-indicator-arrow{border-top-color:var(--sage-500)!important;border-bottom-color:var(--sage-500)!important}@media(max-width:768px){.fc .fc-toolbar{flex-direction:column;gap:8px;margin-bottom:20px!important}.fc .fc-toolbar-title{font-size:1.1rem!important}.fc-header-toolbar{padding:0 5px}.fc .fc-button{padding:6px 10px!important;font-size:.8rem!important}.modal-form-container{padding:20px;width:95%}.modal-title{font-size:1.1rem;margin-bottom:15px}.searchable-dropdown{max-height:180px}}.input-error{border-color:#e53e3e!important;box-shadow:0 0 0 3px #e53e3e1f!important;background:#fff5f5!important}.field-error-msg{display:flex;align-items:center;gap:5px;margin-top:5px;color:#c53030;font-size:.8rem;font-weight:500;animation:fadeInDropdown .2s ease-out}.searchable-select-wrapper{position:relative;width:100%}.searchable-select-input{width:100%;padding:10px 14px;border:1px solid var(--sage-200);border-radius:var(--radius-input);font-size:.95rem;font-family:inherit;color:var(--sage-800);background:#fff;outline:none;transition:border-color .2s,box-shadow .2s;box-sizing:border-box}.searchable-select-input:focus{border-color:var(--sage-400);box-shadow:0 0 0 3px #8bb6c426}.searchable-select-input::placeholder{color:var(--sage-400)}.searchable-dropdown{position:absolute;top:calc(100% + 4px);left:0;right:0;background:#fff;border:1px solid var(--sage-200);border-radius:var(--radius-input);box-shadow:0 8px 24px #2c332e1f;list-style:none;margin:0;padding:4px 0;max-height:220px;overflow-y:auto;z-index:10000;animation:fadeInDropdown .15s ease-out}@keyframes fadeInDropdown{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.searchable-option{padding:10px 14px;font-size:.9rem;color:var(--sage-700);cursor:pointer;transition:background .15s}.searchable-option:hover{background:var(--sage-50);color:var(--sage-900)}.searchable-option.selected{background:var(--sage-100);color:var(--sage-800);font-weight:600}.searchable-no-results{padding:10px 14px;font-size:.88rem;color:var(--sage-400);font-style:italic;cursor:default}.patient-links{margin-top:30px;padding-top:25px;border-top:1px solid #f0f4f4}.links-grid{display:grid;grid-template-columns:1fr 1fr;gap:15px;margin-top:15px}@media(max-width:768px){.input-row,.links-grid{grid-template-columns:1fr}}.input-row-inner{display:grid;grid-template-columns:2fr 1fr;gap:20px}@media(max-width:1024px){.input-row-inner,.nomenclador-inputs{grid-template-columns:1fr;gap:12px}}.nomenclador-inputs{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-top:12px}.nomenclador-inputs input{padding:10px 14px!important;font-size:.82rem!important;background-color:var(--sage-50)!important;border:1px solid var(--sage-100)!important;border-radius:8px!important;text-transform:uppercase}.nomenclador-inputs input:focus{background-color:#fff!important;border-color:var(--sage-400)!important}.label-destacado{font-weight:600;color:var(--sage-700);margin-bottom:8px;font-size:.95rem}.prestaciones-selector-container{display:flex;flex-direction:column;gap:12px;max-height:450px;overflow-y:auto;padding:16px;background:#fdfdfd;border:1px solid var(--sage-100);border-radius:var(--radius-card);margin-top:15px;box-shadow:inset 0 2px 4px #00000005}.prestacion-option{display:flex;flex-direction:column;justify-content:center;padding:24px;min-height:95px;background:#fff;border:1px solid var(--border-input);border-radius:12px;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.prestacion-option:hover{border-color:var(--sage-300);background:var(--sage-50);transform:translateY(-1px)}.prestacion-option.selected{background-color:#fff;border-color:var(--sage-400);border-width:1.5px;box-shadow:0 10px 15px -3px #87a38f1a,0 4px 6px -2px #87a38f0d}.prestacion-option.selected:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background-color:var(--sage-400)}.prestacion-header-info{display:flex;justify-content:space-between;align-items:center;width:100%}.option-info{display:flex;flex-direction:column;gap:4px;align-items:flex-start}.option-name{font-size:.95rem;font-weight:700;color:var(--sage-700);text-transform:uppercase}.option-price{font-size:.75rem;color:var(--sage-500);font-weight:500}.option-check{width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:var(--sage-100);color:var(--sage-500);font-size:.8rem;transition:all .3s;border:1px solid transparent}.prestacion-option.selected .option-check{background:var(--sage-400);color:#fff;transform:scale(1.1)}.prestaciones-selector-container::-webkit-scrollbar{width:5px}.prestaciones-selector-container::-webkit-scrollbar-thumb{background:var(--sage-200);border-radius:10px}@media(max-width:768px){.input-row{grid-template-columns:1fr}}*{box-sizing:border-box}:root{--sage-50: #f7f9f7;--sage-100: #e8ece9;--sage-200: #d1dad3;--sage-300: #adbdb1;--sage-400: #87a38f;--sage-500: #6b8473;--sage-text: #2c332e;--sage-muted: #6b7280;--bg-color: var(--sage-50);--accent-color: var(--sage-400);--text-main: var(--sage-text);--white: #ffffff;--border-input: #e2e8f0;--radius-card: 16px;--radius-input: 10px;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -1px rgba(0, 0, 0, .06)}body{margin:0;font-family:Outfit,sans-serif;background-color:var(--bg-color);color:var(--text-main);-webkit-font-smoothing:antialiased}.main-content{max-width:1000px;margin:0 auto;padding:40px 20px;min-height:calc(100vh - 80px);display:flex;flex-direction:column;align-items:center;animation:pageFadeIn .4s ease-out forwards}.main-content-2{max-width:1600px;width:95%;margin:0 auto;padding:40px 20px;min-height:calc(100vh - 80px);display:flex;flex-direction:column;align-items:center;animation:pageFadeIn .4s ease-out forwards}@keyframes pageFadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.form-card{background:var(--white);padding:40px;border-radius:var(--radius-card);border:1px solid #edf2f1;box-shadow:var(--shadow-sm);width:100%;max-width:800px;box-sizing:border-box}.form-card-2{background:var(--white);padding:40px;border-radius:var(--radius-card);border:1px solid #edf2f1;box-shadow:var(--shadow-sm);width:100%;max-width:100%;box-sizing:border-box}.section-header{margin-bottom:15px;text-align:left;width:100%;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:15px}.header-titles{display:flex;flex-direction:column}.section-header h2{color:var(--sage-700);font-weight:700;font-size:1.3rem;margin-bottom:4px;text-transform:uppercase;margin-top:0}.section-header p{color:var(--sage-muted);font-size:.85rem;margin:0;text-transform:uppercase;letter-spacing:.5px}.input-group,.form-group{display:flex;flex-direction:column;gap:8px;margin-bottom:24px;width:100%;align-items:stretch}.input-group label,.form-group label{font-size:.75rem;color:var(--sage-500);font-weight:600;margin-left:0;text-transform:uppercase;letter-spacing:.5px}.input-group input,.input-group select,.input-custom,.select-custom,textarea{width:100%;padding:12px 16px;border:1px solid var(--border-input);border-radius:var(--radius-input);background-color:#fff;color:var(--text-main);outline:none;font-size:.95rem;transition:all .2s ease;font-family:inherit;text-transform:uppercase}input[type=email]{text-transform:none}.input-group input:focus,.select-custom:focus{border-color:var(--accent-color);box-shadow:0 0 0 3px #87a38f26}.button-group-abm{display:flex;gap:16px;margin-top:24px;width:100%}.input-row{display:grid;grid-template-columns:1fr 1fr;gap:32px;width:100%;margin:0;align-items:start}@media(max-width:1024px){.input-row{grid-template-columns:1fr;gap:16px}}.btn-save{flex:2;background-color:var(--sage-400);color:#fff;border:none;padding:14px 24px;border-radius:50px;font-weight:600;font-size:.9rem;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 12px #87a38f40;text-transform:uppercase}.btn-new{background-color:var(--text-main);color:#fff;border:none;padding:8px 18px;border-radius:50px;font-weight:500;font-size:.85rem;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 10px #00000014;display:inline-flex;align-items:center;gap:6px;text-transform:uppercase;letter-spacing:.5px}.btn-new:hover{background-color:#000;transform:translateY(-2px);box-shadow:0 6px 15px #0000001f}.btn-save:hover{background-color:var(--sage-500)}.btn-cancel{flex:1;background-color:transparent;color:var(--sage-muted);border:1px solid var(--border-input);padding:14px 24px;border-radius:50px;font-weight:600;font-size:.9rem;cursor:pointer;transition:all .2s ease;text-transform:uppercase}.btn-cancel:hover{background-color:var(--sage-50);border-color:var(--sage-200);color:var(--sage-700)}.button-group-header{display:flex;gap:12px;justify-content:flex-end;margin-bottom:20px;width:100%}.button-group-header .btn-save,.button-group-header .btn-cancel,.button-group-header .btn-delete-header{padding:8px 20px;font-size:.8rem;width:auto;flex:none}.btn-delete-header{background-color:transparent;color:#dc2626;border:1px solid #fee2e2;border-radius:50px;font-weight:600;cursor:pointer;transition:all .2s;text-transform:uppercase}.btn-delete-header:hover{background-color:#fef2f2;border-color:#dc2626}.custom-table{width:100%;border-collapse:separate;border-spacing:0;margin-top:10px}.custom-table th{text-align:left;padding:12px 16px;font-size:.85rem;font-weight:600;color:var(--sage-500);background-color:var(--sage-50);border-bottom:1px solid var(--sage-100)}.custom-table td{padding:16px;font-size:.95rem;border-bottom:1px solid var(--sage-50);text-transform:uppercase}.custom-table tr:last-child td{border-bottom:none}@media(max-width:768px){.main-content,.main-content-2{padding:15px 10px 80px;width:100%}.form-card,.form-card-2{padding:20px 15px;border-radius:12px}.section-header h2{font-size:1.4rem}.button-group-abm{flex-direction:column;gap:12px}.btn-save,.btn-cancel{width:100%;flex:none}}.table-responsive{width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch;margin-bottom:1rem}.table-responsive::-webkit-scrollbar{height:4px}.table-responsive::-webkit-scrollbar-thumb{background:var(--sage-200);border-radius:10px}.pagination-container{display:flex;justify-content:center;align-items:center;gap:8px;margin-top:30px;padding:15px;border-top:1px solid var(--sage-50)}.btn-pagination{padding:8px 16px;border-radius:50px;border:1px solid var(--sage-100);background-color:#fff;color:var(--sage-600);font-size:.85rem;font-weight:600;cursor:pointer;transition:all .2s ease;text-transform:uppercase;letter-spacing:.5px;display:flex;align-items:center;gap:5px}.btn-pagination:hover:not(:disabled){border-color:var(--sage-300);background-color:var(--sage-50);color:var(--sage-800);transform:translateY(-1px)}.btn-pagination:disabled{opacity:.4;cursor:not-allowed;background-color:var(--sage-50)}.btn-page-number{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:50%;border:1px solid var(--sage-100);background-color:#fff;color:var(--sage-600);font-size:.85rem;font-weight:600;cursor:pointer;transition:all .2s ease}.btn-page-number:hover{border-color:var(--sage-300);background-color:var(--sage-50)}.btn-page-number.active{background-color:var(--sage-400);border-color:var(--sage-400);color:#fff;box-shadow:0 4px 10px #87a38f33}.split-layout{display:flex;gap:30px;width:100%;align-items:flex-start}.split-left{flex:0 0 350px;position:sticky;top:40px}.split-right{flex:1}@media(max-width:1024px){.split-layout{flex-direction:column}.split-left{flex:none;width:100%;position:static}}.paciente-selector-container{width:100%;margin-bottom:24px;padding-bottom:16px;border-bottom:1px solid var(--sage-100)}.paciente-info-badge{margin-top:12px;padding:12px 20px;background-color:var(--sage-50);border-radius:var(--radius-input);display:flex;justify-content:space-between;align-items:center;color:var(--sage-700);font-size:.9rem}.btn-historial-link{background:none;border:none;color:var(--sage-400);font-weight:600;cursor:pointer;font-size:.85rem;text-decoration:none;transition:color .2s}.btn-historial-link:hover{color:var(--sage-500);text-decoration:underline}.odontograma-render{display:flex;justify-content:center;width:100%}.odontograma-grid{display:grid;grid-template-columns:1fr 1fr;gap:32px 24px;margin-top:24px}.cuadrante{display:flex;gap:8px}.diente-container{display:flex;flex-direction:column;align-items:center}.diente-numero{font-size:.7rem;color:var(--sage-500);margin-bottom:4px;font-weight:600}.diente-svg{width:36px;height:36px;display:flex;flex-direction:column;border:1px solid var(--sage-100);background:#fff;padding:1px}.cara{flex:1;border:1px solid #f0f0f0;cursor:pointer;transition:all .2s}.cara:hover{box-shadow:inset 0 0 0 2px #87a38f33}.fila-media{display:flex;height:33.3%}.superior,.inferior{height:33.3%}.sano{background-color:#fff}.caries{background-color:#fecaca}.restaurado{background-color:#bae6fd}.odontograma-legend{display:flex;justify-content:center;gap:24px;margin-bottom:32px;padding:12px 24px;background:var(--sage-50);border-radius:var(--radius-input)}.legend-item{display:flex;align-items:center;gap:8px;font-size:.85rem;color:var(--sage-600);font-weight:500}.box{width:14px;height:14px;border:1px solid var(--sage-200);border-radius:3px}@media(max-width:900px){.odontograma-grid{grid-template-columns:1fr}}.table-container{width:100%;margin-top:20px;overflow-x:auto}.search-input{width:100%;max-width:400px;padding:12px 20px;border:1px solid #e3eceb;border-radius:10px;background-color:#fcfdfe;font-size:.95rem;outline:none;transition:all .3s ease}.search-input:focus{border-color:#8ab6c4;box-shadow:0 0 0 4px #8ab6c41a}.custom-table th{padding:15px;color:#7a8a8c;font-weight:600;font-size:.85rem;text-transform:uppercase;letter-spacing:.5px;border-bottom:2px solid #f0f4f4}.custom-table td{padding:18px 15px;color:#4a5a5c;border-bottom:1px solid #f0f4f4;font-size:.95rem}.custom-table tr:hover{background-color:#f8fbfb}.actions-cell{display:flex;gap:10px}.btn-action{background:#fff;border:1px solid #e3eceb;color:#7a8a8c;padding:8px;border-radius:8px;cursor:pointer;transition:all .2s;font-size:1rem;display:flex;align-items:center;justify-content:center}.btn-action:hover{transform:translateY(-2px);box-shadow:0 4px 8px #0000000d}.btn-action.edit:hover{border-color:#3498db;color:#3498db}.btn-action.history:hover{border-color:#f39c12;color:#f39c12}.btn-action.odontograma:hover{border-color:#9b59b6;color:#9b59b6}.btn-action.whatsapp:hover{border-color:#25d366;color:#25d366}.empty-row{text-align:center;padding:40px!important;color:#a0b0b2;font-style:italic}.loading-state{display:flex;justify-content:center;align-items:center;height:300px;color:#7a8a8c;font-weight:500}.status-badge{padding:5px 12px;border-radius:20px;font-size:.8rem;font-weight:600}.status-badge.active{background-color:#e6f7ed;color:#2ecc71}.status-badge.inactive{background-color:#fbeaea;color:#e74c3c}.row-inactive td{color:#a0b0b2;background-color:#fafcfc}.btn-action.deactivate{color:#e74c3c;border-color:#fadbd8;background:#fff}.btn-action.deactivate:hover{border-color:#e74c3c;color:#e74c3c}.btn-action.activate{color:#2ecc71;border-color:#abebc6;background:#fff}.btn-action.activate:hover{border-color:#2ecc71;color:#2ecc71}.patient-details-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}.detail-item{display:flex;flex-direction:column;gap:5px}.detail-item label{font-size:.7rem;color:var(--sage-400);text-transform:uppercase;font-weight:600;letter-spacing:.5px}.detail-item p{margin:0;font-size:.95rem;color:var(--sage-700);font-weight:500}.btn-text-link{background:none;border:none;padding:0;color:var(--sage-600);font-weight:600;cursor:pointer;text-decoration:underline transparent;transition:all .2s;font-family:inherit;text-align:left;text-transform:uppercase}.btn-text-link:hover{color:var(--sage-400);text-decoration-color:var(--sage-400)}@media(max-width:600px){.patient-details-grid{grid-template-columns:1fr;gap:15px}}.table-container{width:100%;margin-top:20px;overflow-x:auto;border-radius:var(--radius-card);border:1px solid var(--sage-100)}.table-controls{margin-bottom:25px;display:flex;justify-content:flex-start}.search-input{width:100%;max-width:400px;padding:12px 20px;border:1px solid var(--border-input);border-radius:var(--radius-input);background-color:#fff;font-size:.95rem;outline:none;transition:all .2s ease;font-family:inherit}.search-input:focus{border-color:var(--sage-400);box-shadow:0 0 0 3px #87a38f1a}.custom-table{width:100%;border-collapse:collapse;text-align:left}.custom-table th{padding:16px;color:var(--sage-600);font-weight:600;font-size:.8rem;text-transform:uppercase;letter-spacing:.05em;background-color:var(--sage-50);border-bottom:1px solid var(--sage-100)}.custom-table td{padding:16px;color:var(--sage-text);border-bottom:1px solid var(--sage-50);font-size:.95rem}.custom-table tr:hover:not(.row-inactive){background-color:#fafbfb}.actions-cell{display:flex;gap:8px}.btn-action{background:#fff;border:1px solid var(--sage-100);padding:8px;border-radius:8px;cursor:pointer;transition:all .2s;font-size:.9rem;display:flex;align-items:center;justify-content:center}.btn-action:hover{background-color:var(--sage-50);border-color:var(--sage-300);transform:translateY(-1px)}.badge{background-color:var(--sage-100);color:var(--sage-700);padding:4px 10px;border-radius:12px;font-size:.75rem;font-weight:600;display:inline-block}.status-badge{padding:4px 10px;border-radius:6px;font-size:.75rem;font-weight:600;letter-spacing:.02em}.status-badge.active{background-color:#ecfdf5;color:#059669}.status-badge.inactive{background-color:#fef2f2;color:#dc2626}.row-inactive td{color:var(--sage-300)}.loading-state{padding:60px;text-align:center;color:var(--sage-500);font-weight:500}.login-exit{animation:loginExitAnim .55s ease-in forwards;pointer-events:none}@keyframes loginExitAnim{0%{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(1.03)}}.login-wrapper{position:fixed;inset:0;display:flex;z-index:99999;overflow:hidden;font-family:Inter,sans-serif}.login-brand-panel{flex:1.1;background:linear-gradient(155deg,#1a3a4a,#1e5f74,#2a8fa8 80%,#3ab5c9);display:flex;flex-direction:column;align-items:center;justify-content:center;position:relative;overflow:hidden;padding:60px}.login-brand-panel:before,.login-brand-panel:after{content:"";position:absolute;border-radius:50%;background:#ffffff0d}.login-brand-panel:before{width:500px;height:500px;bottom:-200px;left:-150px}.login-brand-panel:after{width:300px;height:300px;top:-80px;right:-80px}.login-brand-logo{width:260px;height:auto;object-fit:contain;border-radius:20px;position:relative;z-index:2;animation:floatIn .8s ease-out;background:#ffffff1a;padding:18px;border:1px solid rgba(255,255,255,.22);box-shadow:0 8px 32px #00000047,0 0 0 1px #ffffff14,inset 0 1px #ffffff2e;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}.login-brand-tagline{position:relative;z-index:2;margin-top:30px;text-align:center;color:#ffffffb3;font-size:.8rem;letter-spacing:3px;text-transform:uppercase;font-weight:400}.login-form-panel{flex:.9;background:#f8faf9;display:flex;align-items:center;justify-content:center;padding:60px 50px;position:relative}.login-form-inner{width:100%;max-width:360px;animation:slideInRight .5s ease-out}.login-form-title{font-size:2rem;font-weight:700;color:#1a3a4a;margin:0 0 6px}.login-form-subtitle{font-size:.85rem;color:#6b8a91;margin:0 0 40px;font-weight:400}.form-group-login{display:flex;flex-direction:column;margin-bottom:22px}.form-group-login label{font-size:.72rem;color:#4a6a72;font-weight:700;margin-bottom:8px;text-transform:uppercase;letter-spacing:1px}.form-group-login input{padding:15px 18px;border:1.5px solid #e0eaec;background:#fff;border-radius:14px;font-size:.95rem;color:#1a3a4a;outline:none;font-family:inherit;transition:all .25s;box-shadow:0 2px 8px #00000008}.form-group-login input:focus{border-color:#2a8fa8;box-shadow:0 0 0 4px #2a8fa81f}.form-group-login input::placeholder{color:#b0c4ca}.btn-login{width:100%;padding:16px;background:linear-gradient(135deg,#1e5f74,#2a8fa8);color:#fff;border:none;border-radius:14px;font-weight:700;font-size:.9rem;text-transform:uppercase;cursor:pointer;letter-spacing:1.5px;transition:all .25s ease;box-shadow:0 8px 20px #1e5f7459;display:flex;justify-content:center;align-items:center;margin-top:10px}.btn-login:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 14px 28px #1e5f7473}.btn-login:active{transform:translateY(0)}.btn-login:disabled{opacity:.7;cursor:not-allowed}.login-error{background:#fff1f0;border:1px solid #fadbd8;color:#e74c3c;padding:12px 16px;border-radius:12px;font-size:.85rem;font-weight:600;margin-bottom:20px;display:flex;align-items:center;gap:8px;animation:fadeIn .3s ease}.login-footer-note{margin-top:30px;text-align:center;font-size:.75rem;color:#a0b8be;letter-spacing:.5px}@keyframes floatIn{0%{opacity:0;transform:translateY(30px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes slideInRight{0%{opacity:0;transform:translate(30px)}to{opacity:1;transform:translate(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.spin{animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@media(max-width:768px){.login-wrapper{flex-direction:column}.login-brand-panel{flex:0 0 auto;padding:28px 30px 24px;min-height:unset}.login-brand-logo{width:170px;padding:14px;border-radius:16px}.login-brand-tagline{margin-top:12px;font-size:.65rem;letter-spacing:2px}.login-form-panel{flex:1;padding:32px 24px}.login-form-title{font-size:1.6rem}.login-form-subtitle{margin-bottom:28px}}.app-footer{position:fixed;bottom:0;left:0;right:0;padding:10px 20px;border-top:1px solid var(--sage-100);text-align:center;background:#f7f9f7d9;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);z-index:100}.app-container{padding-bottom:44px}.footer-text{margin:0;font-size:.73rem;color:var(--sage-300);letter-spacing:.4px;font-weight:400;text-transform:uppercase}.footer-author{color:var(--sage-400);font-weight:600}.footer-email{color:var(--sage-300);text-decoration:none;transition:color .2s}.footer-email:hover{color:var(--sage-500);text-decoration:underline}@media(max-width:768px){.app-footer{padding:14px 16px;margin-bottom:0}.footer-text{font-size:.65rem}}.hero-fixed-container{position:fixed;top:0;left:0;width:100vw;height:100vh;background:linear-gradient(155deg,#1a3a4a,#1e5f74,#2a8fa8 80%,#3ab5c9);display:flex;flex-direction:column;justify-content:center;align-items:center;z-index:9999;overflow:hidden;animation:splashFadeIn .4s ease-out}@keyframes splashFadeIn{0%{opacity:0}to{opacity:1}}.hero-logo-wrapper{display:flex;flex-direction:column;justify-content:center;align-items:center;gap:30px}.hero-main-logo{width:220px;height:auto;object-fit:contain;border-radius:20px;background:#ffffff1a;padding:18px;border:1px solid rgba(255,255,255,.22);box-shadow:0 8px 32px #00000047,0 0 0 1px #ffffff14,inset 0 1px #ffffff2e;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}.splash-spinner{width:32px;height:32px;border:3px solid rgba(255,255,255,.25);border-top-color:#ffffffe6;border-radius:50%;animation:spinnerRound .8s linear infinite}@keyframes spinnerRound{to{transform:rotate(360deg)}}.pulse-softly{animation:softPulse 2.5s cubic-bezier(.4,0,.6,1) infinite}@keyframes softPulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(.97);opacity:.85}}@media(max-width:768px){.hero-main-logo{width:160px;padding:14px;border-radius:16px}}
