@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap";@import "https://fonts.googleapis.com/css2?family=Outfit:wght@400;500;600;700;800;900&display=swap";.odonto-wrapper{gap:1.5rem;animation:.5s ease-out fadeInOdonto;display:flex}@keyframes fadeInOdonto{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.odonto-toolbar{flex-direction:column;flex:0 0 220px;gap:1rem;max-height:calc(100vh - 120px);display:flex;position:sticky;top:1rem;overflow-y:auto}.odonto-toolbar::-webkit-scrollbar{width:4px}.odonto-toolbar::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px}.toolbar-section{background:#fff;border:1px solid #e2e8f0;border-radius:14px;padding:1rem;box-shadow:0 2px 8px #00000008}.toolbar-section-title{text-transform:uppercase;letter-spacing:.08em;color:#94a3b8;align-items:center;gap:.4rem;margin-bottom:.75rem;font-size:.7rem;font-weight:800;display:flex}.color-mode-group{flex-direction:column;gap:.4rem;display:flex}.color-mode-btn{cursor:pointer;color:#475569;background:#fff;border:2px solid #e2e8f0;border-radius:10px;align-items:center;gap:.6rem;padding:.6rem .75rem;font-family:inherit;font-size:.8rem;font-weight:700;transition:all .2s;display:flex}.color-mode-btn:hover{background:#f8fafc;transform:translate(2px)}.color-mode-btn .color-dot{border:2px solid #0000001a;border-radius:50%;flex-shrink:0;width:14px;height:14px}.color-mode-btn.active-rojo{color:#dc2626;background:#fef2f2;border-color:#ef4444}.color-mode-btn.active-rojo .color-dot{background:#ef4444;box-shadow:0 0 8px #ef444466}.color-mode-btn.active-azul{color:#2563eb;background:#eff6ff;border-color:#3b82f6}.color-mode-btn.active-azul .color-dot{background:#3b82f6;box-shadow:0 0 8px #3b82f666}.color-mode-btn.active-verde{color:#16a34a;background:#f0fdf4;border-color:#22c55e}.color-mode-btn.active-verde .color-dot{background:#22c55e;box-shadow:0 0 8px #22c55e66}.dot-rojo{background:#ef4444}.dot-azul{background:#3b82f6}.dot-verde{background:#22c55e}.tool-grid{flex-direction:column;gap:.3rem;display:flex}.tool-btn{cursor:pointer;color:#475569;text-align:left;background:0 0;border:1px solid #0000;border-radius:8px;align-items:center;gap:.5rem;width:100%;padding:.5rem .6rem;font-family:inherit;font-size:.78rem;font-weight:600;transition:all .15s;display:flex}.tool-btn:hover{color:#0f172a;background:#f1f5f9}.tool-btn.active{color:#fff;background:#0f172a;border-color:#0f172a;box-shadow:0 2px 8px #0f172a33}.tool-code{color:#64748b;text-align:center;background:#f1f5f9;border-radius:4px;flex-shrink:0;min-width:26px;padding:1px 5px;font-size:.65rem;font-weight:800}.tool-btn.active .tool-code{color:#fff;background:#ffffff26}.tool-divider{border:none;border-top:1px solid #f1f5f9;margin:.25rem 0}.tool-btn-eraser{cursor:pointer;color:#dc2626;background:#fef2f2;border:1px dashed #e2e8f0;border-radius:8px;align-items:center;gap:.5rem;width:100%;padding:.55rem .6rem;font-family:inherit;font-size:.78rem;font-weight:700;transition:all .15s;display:flex}.tool-btn-eraser:hover{background:#fee2e2;border-color:#fca5a5}.tool-btn-eraser.active{color:#fff;background:#dc2626;border-color:#dc2626}.odonto-main{flex-direction:column;flex:1;gap:1.5rem;min-width:0;display:flex}.odonto-chart-card{background:#fff;border:1px solid #e2e8f0;border-radius:18px;padding:2rem;overflow-x:auto;box-shadow:0 4px 20px #00000008}.odonto-chart-header{border-bottom:1px solid #f1f5f9;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:1rem;display:flex}.odonto-chart-title{color:#0f172a;align-items:center;gap:.5rem;font-family:Outfit,sans-serif;font-size:1.1rem;font-weight:800;display:flex}.odonto-active-tool-badge{border-radius:100px;align-items:center;gap:.5rem;padding:.4rem 1rem;font-size:.78rem;font-weight:700;display:flex}.odonto-active-tool-badge.rojo{color:#dc2626;background:#fef2f2;border:1px solid #fecaca}.odonto-active-tool-badge.azul{color:#2563eb;background:#eff6ff;border:1px solid #bfdbfe}.odonto-active-tool-badge.verde{color:#16a34a;background:#f0fdf4;border:1px solid #bbf7d0}.odonto-active-tool-badge.borrar{color:#ea580c;background:#fff7ed;border:1px solid #fed7aa}.odonto-grid{flex-direction:column;gap:2rem;min-width:780px;display:flex}.odonto-row{justify-content:center;gap:2px;display:flex;position:relative}.odonto-row:after{content:"";background:#cbd5e1;width:2px;position:absolute;top:-4px;bottom:-4px;left:50%}.odonto-row.upper{border-bottom:2px solid #e2e8f0;padding-bottom:.75rem}.odonto-row.lower{padding-top:.75rem}.odonto-cuadrante{gap:3px;display:flex}.tooth-unit{cursor:pointer;flex-direction:column;align-items:center;gap:3px;width:48px;transition:transform .15s;display:flex;position:relative}.tooth-unit:hover{z-index:2;transform:scale(1.08)}.tooth-unit.selected{z-index:3;transform:scale(1.12)}.tooth-number{color:#64748b;font-size:.65rem;font-weight:800;transition:color .15s}.tooth-unit:hover .tooth-number{color:#0f172a}.tooth-unit.selected .tooth-number{color:#0ea5e9}.tooth-svg-wrap{background:#f8fafc;border:2px solid #0000;border-radius:6px;width:42px;height:42px;padding:1px;transition:border-color .15s,box-shadow .15s;position:relative}.tooth-unit:hover .tooth-svg-wrap{border-color:#94a3b8}.tooth-unit.selected .tooth-svg-wrap{border-color:#0ea5e9;box-shadow:0 0 0 3px #0ea5e926}.tooth-svg-wrap svg{width:100%;height:100%;display:block}.tooth-zone{stroke:#cbd5e1;stroke-width:1.5px;cursor:pointer;fill:#fff;transition:opacity .15s}.tooth-zone:hover{opacity:.75;stroke:#475569;stroke-width:2px}.tooth-overlay-icon{pointer-events:none;letter-spacing:-.02em;justify-content:center;align-items:center;font-size:.55rem;font-weight:900;line-height:1;display:flex;position:absolute;inset:0}.tooth-general-code{white-space:nowrap;pointer-events:none;border-radius:3px;padding:0 3px;font-size:.55rem;font-weight:900;line-height:1.3;position:absolute;bottom:-2px;left:50%;transform:translate(-50%)}.tooth-general-code.rojo{color:#dc2626;background:#fef2f2;border:1px solid #fecaca}.tooth-general-code.azul{color:#2563eb;background:#eff6ff;border:1px solid #bfdbfe}.tooth-general-code.verde{color:#16a34a;background:#f0fdf4;border:1px solid #bbf7d0}.tooth-absent-overlay{pointer-events:none;position:absolute;inset:2px}.tooth-absent-overlay line{stroke-width:4px}.tooth-absent-overlay line.rojo{stroke:#ef4444}.tooth-absent-overlay line.azul{stroke:#3b82f6}.tooth-absent-overlay line.verde{stroke:#22c55e}.tooth-crown-overlay{pointer-events:none;position:absolute;inset:2px}.tooth-crown-overlay circle{stroke-width:2.5px;fill:none}.tooth-crown-overlay circle.rojo{stroke:#ef4444}.tooth-crown-overlay circle.azul{stroke:#3b82f6}.tooth-crown-overlay circle.verde{stroke:#22c55e}.tooth-conducto-overlay{pointer-events:none;position:absolute;inset:2px}.odonto-references{background:#fff;border:1px solid #e2e8f0;border-radius:14px;padding:1.25rem;box-shadow:0 2px 8px #00000008}.ref-title{text-transform:uppercase;letter-spacing:.06em;color:#0f172a;border-bottom:2px solid #f1f5f9;margin-bottom:1rem;padding-bottom:.5rem;font-size:.75rem;font-weight:800}.ref-grid{grid-template-columns:1fr 1fr 1fr;gap:.5rem 1rem;display:grid}.ref-item{color:#475569;align-items:center;gap:.4rem;font-size:.78rem;font-weight:500;display:flex}.ref-code{color:#94a3b8;min-width:20px;font-size:.6rem;font-weight:800}.ref-symbol{color:#0f172a;background:#f8fafc;border:1px solid #e2e8f0;border-radius:4px;flex-shrink:0;justify-content:center;align-items:center;width:22px;height:22px;font-size:.85rem;font-weight:900;display:flex}.ref-color-legend{border-top:1px solid #f1f5f9;gap:1rem;margin-top:1rem;padding-top:.75rem;display:flex}.ref-color-item{align-items:center;gap:.4rem;font-size:.72rem;font-weight:700;display:flex}.ref-color-dot{border-radius:50%;width:10px;height:10px}.ref-color-dot.rojo{background:#ef4444}.ref-color-dot.azul{background:#3b82f6}.ref-color-dot.verde{background:#22c55e}.odonto-nota-section{background:#fff;border:1px solid #e2e8f0;border-radius:14px;padding:1.25rem}.odonto-nota-form{align-items:flex-end;gap:.75rem;display:flex}.odonto-nota-input{color:#0f172a;background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;outline:none;flex:1;padding:.65rem .875rem;font-family:inherit;font-size:.9rem;transition:all .2s}.odonto-nota-input:focus{background:#fff;border-color:#0ea5e9;box-shadow:0 0 0 3px #0ea5e91a}.odonto-nota-btn{color:#fff;cursor:pointer;white-space:nowrap;background:linear-gradient(135deg,#0ea5e9,#0284c7);border:none;border-radius:10px;align-items:center;gap:.4rem;padding:.65rem 1.25rem;font-family:inherit;font-size:.85rem;font-weight:700;transition:all .2s;display:flex}.odonto-nota-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #0ea5e940}.zone-fill-rojo{fill:#fca5a5!important}.zone-fill-azul{fill:#93c5fd!important}.zone-fill-verde{fill:#86efac!important}@media (width<=1200px){.odonto-wrapper{flex-direction:column}.odonto-toolbar{flex-flow:wrap;flex:auto;max-height:none;position:static}.toolbar-section{flex:200px}}@media (width<=768px){.odonto-chart-card{padding:1rem}.ref-grid{grid-template-columns:1fr}.odonto-nota-form{flex-direction:column}.tooth-unit{width:38px}.tooth-svg-wrap{width:34px;height:34px}}.odonto-saving-badge{color:#22c55e;background:#f0fdf4;border:1px solid #bbf7d0;border-radius:100px;align-items:center;gap:.4rem;padding:.3rem .75rem;font-size:.72rem;font-weight:600;animation:1.5s infinite pulseGreen;display:flex}@keyframes pulseGreen{0%,to{opacity:1}50%{opacity:.6}}.tooth-tooltip{color:#fff;white-space:nowrap;z-index:100;pointer-events:none;background:#0f172a;border-radius:8px;padding:.5rem .75rem;font-size:.72rem;font-weight:600;position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%);box-shadow:0 4px 12px #0003}.tooth-tooltip:after{content:"";border:5px solid #0000;border-top-color:#0f172a;position:absolute;top:100%;left:50%;transform:translate(-50%)}.tooth-active-procedures-list{flex-direction:column;align-items:center;gap:2px;width:100%;min-height:38px;margin-top:4px;display:flex}.tooth-proc-badge{white-space:nowrap;text-align:center;text-overflow:ellipsis;border:1px solid #0000;border-radius:4px;max-width:100%;padding:1px 3px;font-size:.55rem;font-weight:800;line-height:1.1;overflow:hidden}.tooth-proc-badge.rojo{color:#dc2626;background:#fef2f2;border-color:#fca5a5}.tooth-proc-badge.azul{color:#2563eb;background:#eff6ff;border-color:#bfdbfe}.tooth-proc-badge.verde{color:#16a34a;background:#f0fdf4;border-color:#bbf7d0}.odonto-section-divider{color:#64748b;text-transform:uppercase;letter-spacing:.05em;align-items:center;gap:.75rem;width:100%;min-width:780px;margin:1.5rem 0 1rem;font-family:Outfit,sans-serif;font-size:.8rem;font-weight:800;display:flex}.odonto-section-divider:after{content:"";background:#cbd5e1;flex:1;height:1px}.odonto-grid.child-grid{gap:1.5rem}.odonto-grid.child-grid .odonto-row{justify-content:center}:root{--color-primary:#0891b2;--color-primary-hover:#06b6d4;--color-bg:#f8fafc;--color-surface:#fff;--color-text-main:#0f172a;--color-text-muted:#64748b;--color-danger:#dc2626;--color-success:#059669;--color-warning:#d97706;--color-warning-bg:#fef3c7;--color-danger-bg:#fee2e2;--color-border:#e2e8f0;--shadow-sm:0 1px 2px 0 #0000000d;--shadow-md:0 4px 6px -1px #0000001a, 0 2px 4px -2px #0000001a;--shadow-lg:0 10px 15px -3px #0000001a, 0 4px 6px -4px #0000001a;--radius-none:0px;--radius-lg:24px;--glass-bg:#ffffffd9;--glass-border:#fff6;--gradient-primary:linear-gradient(135deg, #0ea5e9 0%, #2dd4bf 100%);--gradient-success:linear-gradient(135deg, #22c55e 0%, #10b981 100%);--gradient-warning:linear-gradient(135deg, #f59e0b 0%, #d97706 100%);--gradient-danger:linear-gradient(135deg, #ef4444 0%, #dc2626 100%);--gradient-purple:linear-gradient(135deg, #6366f1 0%, #a855f7 100%)}*{box-sizing:border-box;margin:0;padding:0}body{background-color:var(--color-bg);color:var(--color-text-main);-webkit-font-smoothing:antialiased;font-family:Inter,sans-serif;overflow-x:hidden}.app-layout{height:100vh;display:flex;position:relative;overflow:hidden}.sidebar{background-color:var(--color-surface);border-right:1px solid var(--color-border);z-index:40;flex-direction:column;width:280px;transition:all .3s;display:flex}.main-container{flex-direction:column;flex:1;width:100%;display:flex;overflow-x:hidden}.topbar{background-color:var(--color-surface);border-bottom:1px solid var(--color-border);justify-content:flex-end;align-items:center;gap:1rem;height:64px;padding:0 2rem;display:flex}.page-content{-webkit-overflow-scrolling:touch;flex:1;padding:2rem;overflow-y:auto}@media (width<=1024px){.grid-cols-4{grid-template-columns:repeat(2,1fr)}}@media (width<=768px){.sidebar{z-index:100;height:100vh;transition:left .3s;position:fixed;left:-280px;box-shadow:10px 0 30px #0000001a}.sidebar.open{left:0}.topbar{justify-content:space-between;padding:0 1rem}.page-content{width:100%;padding:1rem}.grid-cols-2,.grid-cols-3,.grid-cols-4{grid-template-columns:1fr;gap:1rem}.page-title{flex-direction:column;align-items:flex-start;gap:1rem;font-size:1.5rem}.btn{width:100%;padding:.75rem 1rem}.table-container{border-left:none;border-right:none;border-radius:0;width:calc(100% + 2rem);margin-left:-1rem;margin-right:-1rem}table{min-width:800px}th,td{padding:.75rem!important}}h1{font-size:clamp(1.5rem,5vw,2.25rem)}h2{font-size:clamp(1.25rem,4vw,1.875rem)}h3{font-size:clamp(1.1rem,3vw,1.5rem)}.page-title{justify-content:space-between;align-items:center;width:100%;margin-bottom:1.5rem;display:flex}.card{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-none);box-shadow:var(--shadow-sm);padding:1.5rem}.btn{border-radius:var(--radius-none);cursor:pointer;border:1px solid #0000;justify-content:center;align-items:center;gap:.5rem;padding:.5rem 1rem;font-family:inherit;font-size:.875rem;font-weight:500;transition:all .2s;display:inline-flex}.btn-primary{background-color:var(--color-primary);color:#fff}.btn-primary:hover{background-color:var(--color-primary-hover)}.btn-secondary{color:var(--color-text-main);border-color:var(--color-border);background-color:#fff}.btn-secondary:hover{background-color:var(--color-bg)}.btn-danger{background-color:var(--color-danger);color:#fff}.form-group{margin-bottom:1rem}.form-label{color:var(--color-text-main);margin-bottom:.5rem;font-size:.875rem;font-weight:500;display:block}.form-control{border:1px solid var(--color-border);border-radius:var(--radius-none);width:100%;color:var(--color-text-main);background-color:#fff;padding:.5rem .75rem;font-family:inherit;font-size:.875rem;transition:border-color .2s}.form-control:focus{border-color:var(--color-primary);box-shadow:0 0 0 1px var(--color-primary);outline:none}.grid-cols-2{grid-template-columns:repeat(2,1fr);gap:1rem;display:grid}.table-container{border:1px solid var(--color-border);background:#fff;width:100%;overflow-x:auto}table{border-collapse:collapse;text-align:left;width:100%}th{background-color:var(--color-bg);color:var(--color-text-muted);border-bottom:1px solid var(--color-border);padding:.75rem 1rem;font-size:.875rem;font-weight:600}td{border-bottom:1px solid var(--color-border);vertical-align:middle;padding:1rem;font-size:.875rem}tbody tr:hover{background-color:var(--color-bg)}.badge{border-radius:9999px;align-items:center;padding:.25rem .625rem;font-size:.75rem;font-weight:600;display:inline-flex}.badge-success{color:var(--color-success);background-color:#d1fae5}.badge-warning{background-color:var(--color-warning-bg);color:var(--color-warning)}.badge-danger{background-color:var(--color-danger-bg);color:var(--color-danger)}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:50;background-color:#0f172a99;justify-content:center;align-items:center;animation:.2s ease-out fadeIn;display:flex;position:fixed;inset:0}.modal-content{background-color:var(--color-surface);border-radius:var(--radius-none);width:100%;max-width:600px;max-height:90vh;box-shadow:var(--shadow-lg);flex-direction:column;display:flex;overflow-y:auto}.modal-header{border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;display:flex}.modal-body{padding:1.5rem}.modal-footer{border-top:1px solid var(--color-border);background-color:var(--color-bg);justify-content:flex-end;gap:.75rem;padding:1rem 1.5rem;display:flex}.alert-banner{border-left:4px solid;align-items:flex-start;gap:.75rem;margin-bottom:1.5rem;padding:1rem 1.5rem;display:flex}.alert-danger{background-color:var(--color-danger-bg);border-color:var(--color-danger);color:#991b1b}.alert-warning{background-color:var(--color-warning-bg);border-color:var(--color-warning);color:#92400e}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.grid-cols-4{grid-template-columns:repeat(4,1fr);gap:1.5rem;display:grid}.grid-cols-3{grid-template-columns:repeat(3,1fr);gap:1.5rem;display:grid}.card-premium{background:var(--color-surface);border:1px solid var(--color-border);transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 10px 25px -5px #00000008}.card-premium:hover{transform:translateY(-5px);box-shadow:0 20px 35px -10px #00000014}.card-glass{background:var(--glass-bg);-webkit-backdrop-filter:blur(12px);border:1px solid var(--glass-border);box-shadow:0 8px 32px #1f26870d}.floating{animation:3s ease-in-out infinite float}@keyframes float{0%{transform:translateY(0)}50%{transform:translateY(-8px)}to{transform:translateY(0)}}.icon-box-glow{box-shadow:0 0 20px #0ea5e933}.badge-pill{text-transform:uppercase;letter-spacing:.05em;border-radius:30px;padding:.4rem 1rem;font-size:.7rem;font-weight:700}.icon-box{border-radius:12px;justify-content:center;align-items:center;width:48px;height:48px;display:flex}.text-gradient{background:var(--gradient-primary);-webkit-text-fill-color:transparent;-webkit-background-clip:text}
