@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";.odontograma-container{background:#fff;border-radius:12px;padding:20px;overflow-x:auto;box-shadow:0 4px 20px #0000000d}.odontograma-grid{flex-direction:column;gap:40px;min-width:1000px;display:flex}.odontograma-row{justify-content:center;gap:20px;display:flex}.cuadrante{gap:5px;display:flex}.diente-container{flex-direction:column;align-items:center;gap:5px;display:flex;position:relative}.diente-numero{color:#666;font-size:12px;font-weight:700}.diente-svg-wrapper{background:#fafafa;border:1px solid #eee;width:50px;height:50px;padding:2px}.diente-svg{width:100%;height:100%}.zona{stroke:#ccc;stroke-width:1px;cursor:pointer;transition:opacity .2s}.zona:hover{opacity:.7;stroke:#000}.diente-actions{gap:2px;display:flex}.btn-mini{cursor:pointer;background:#fff;border:1px solid #ddd;border-radius:3px;padding:2px 5px;font-size:10px}.btn-mini.active{color:#fff;background:#333;border-color:#333}.odontograma-menu{z-index:1000;background:#fff;border:1px solid #ddd;border-radius:8px;flex-direction:column;gap:5px;padding:10px;display:flex;position:fixed;box-shadow:0 5px 15px #0003}.menu-header{text-transform:uppercase;color:#999;margin-bottom:5px;font-size:11px}.odontograma-menu button{text-align:left;cursor:pointer;background:#f9f9f9;border:none;border-radius:4px;padding:8px 12px;font-size:13px}.odontograma-menu button:hover{background:#eee}.menu-close{color:#d00;margin-top:5px;background:#ffecec!important}.odontograma-legend{justify-content:center;gap:20px;margin-top:30px;font-size:14px;display:flex}.legend-item{align-items:center;gap:8px;display:flex}.box{border:1px solid #ccc;width:16px;height:16px}.box.red{background:#ff4d4d}.box.blue{background:#4d79ff}.box.cross{background:#fff;position:relative}.box.cross:after,.box.cross:before{content:"";background:#000;width:100%;height:1px;position:absolute;top:50%}.box.cross:after{transform:rotate(45deg)}.box.cross:before{transform:rotate(-45deg)}.line-dashed{border-top:2px dashed red;width:20px;height:2px}: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{height:100%;transition:left .3s;position:absolute;left:-260px;box-shadow:10px 0 30px #0000001a}.sidebar.open{left:0}.topbar{justify-content:space-between;padding:0 1rem}.page-content{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}}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}
