@import url("https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;600;700&family=Inter:wght@300;400;500;600;700;800&display=swap");:root{--bg-primary:#050B20;--bg-secondary:#07102a;--bg-card:#0d1733;--bg-card-hover:#111e3d;--bg-glass:rgba(13,23,51,0.88);--border:rgba(224,230,237,0.08);--border-focus:rgba(0,242,254,0.45);--gradient-corxium:linear-gradient(135deg,#00F2FE,#4FACFE 50%,#F2128C);--gradient-corxium-soft:linear-gradient(135deg,rgba(0,242,254,0.18),rgba(79,172,254,0.12) 50%,rgba(242,18,140,0.08));--accent:#4FACFE;--accent-hover:#00F2FE;--accent-glow:rgba(79,172,254,0.28);--accent-light:rgba(79,172,254,0.10);--success:#10e8a0;--success-light:rgba(16,232,160,0.10);--warning:#f59e0b;--warning-light:rgba(245,158,11,0.10);--danger:#ff4d6d;--danger-light:rgba(255,77,109,0.10);--purple:#a78bfa;--purple-light:rgba(167,139,250,0.10);--text-primary:#E0E6ED;--text-secondary:#8fa3bb;--text-muted:#4e637a;--fdi-default:#0d1733;--fdi-label:rgba(224,230,237,0.55);--sidebar-width:280px;--content-max-width:1400px;--radius:0px;--radius-sm:0px;--radius-lg:0px;--shadow:0 12px 36px rgba(0,0,0,0.5);--shadow-glow:0 0 32px var(--accent-glow);--glow-cyan:0 0 24px rgba(0,242,254,0.35)}[data-theme=light]{--bg-primary:#eef1f7;--bg-secondary:#f5f7fc;--bg-card:#ffffff;--bg-card-hover:#edf0f9;--bg-glass:rgba(255,255,255,0.90);--border:rgba(5,11,32,0.10);--border-focus:rgba(79,172,254,0.55);--gradient-corxium:linear-gradient(135deg,#00F2FE,#4FACFE 50%,#F2128C);--gradient-corxium-soft:linear-gradient(135deg,rgba(0,242,254,0.12),rgba(79,172,254,0.08) 50%,rgba(242,18,140,0.05));--accent:#1a7fdc;--accent-hover:#0d6bc4;--accent-glow:rgba(26,127,220,0.20);--accent-light:rgba(26,127,220,0.08);--success:#059669;--success-light:rgba(5,150,105,0.10);--warning:#d97706;--warning-light:rgba(217,119,6,0.10);--danger:#dc2626;--danger-light:rgba(220,38,38,0.10);--purple:#7c3aed;--purple-light:rgba(124,58,237,0.10);--text-primary:#050B20;--text-secondary:#2a3e58;--text-muted:#5a7a99;--fdi-default:#d8deea;--fdi-label:#2a3e58;--shadow:0 4px 20px rgba(5,11,32,0.10);--shadow-glow:0 0 20px var(--accent-glow);--glow-cyan:0 0 16px rgba(79,172,254,0.25)}*,:after,:before{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;scroll-behavior:smooth}body{font-family:Inter,Segoe UI,-apple-system,BlinkMacSystemFont,sans-serif;background:var(--bg-primary);background-image:radial-gradient(circle at 2px 2px,var(--border) 1px,transparent 0);background-size:24px 24px;color:var(--text-primary);line-height:1.6;min-height:100vh;-webkit-font-smoothing:antialiased;overflow-x:hidden;width:100%}.dot-grid{background-image:radial-gradient(circle at 1px 1px,var(--border) 1px,transparent 0);background-size:20px 20px}a{color:inherit;text-decoration:none}button{cursor:pointer;font-family:inherit}input,select,textarea{font-family:inherit;outline:none}img{max-width:100%}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:0}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}h1,h2,h3,h4,h5,h6{font-family:Space Grotesk,Segoe UI,-apple-system,sans-serif;font-weight:700;line-height:1.1;color:var(--text-primary);letter-spacing:-.01em}.form-group{display:flex;flex-direction:column;gap:6px;width:100%}.form-label{font-size:.85rem;margin-left:2px}.form-input,.form-select,.form-textarea{font-size:.95rem;transition:all .2s}.form-textarea{min-height:100px}.form-label{font-size:.8rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.form-input,.form-select,.form-textarea{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);padding:10px 14px;font-size:.92rem;transition:border-color .2s,box-shadow .2s,background .2s;width:100%}.form-input::placeholder,.form-textarea::placeholder{color:var(--text-muted)}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-light);background:var(--bg-card-hover)}.form-select option{background:var(--bg-card);color:var(--text-primary)}.form-textarea{resize:vertical;min-height:90px}.form-error{font-size:.78rem;color:var(--danger)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 20px;border-radius:var(--radius-sm);font-weight:600;font-size:.9rem;border:none;transition:all .2s;white-space:nowrap}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--gradient-corxium);color:#050B20;box-shadow:0 4px 20px rgba(79,172,254,.35);font-weight:700;letter-spacing:.02em}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 32px rgba(0,242,254,.4);filter:brightness(1.06)}.btn-secondary{background:var(--bg-card);color:var(--text-secondary);border:1px solid var(--border)}.btn-secondary:hover:not(:disabled){background:var(--bg-card-hover);color:var(--text-primary)}.btn-danger{background:var(--danger-light);color:var(--danger);border:1px solid rgba(239,68,68,.2)}.btn-danger:hover:not(:disabled){background:rgba(239,68,68,.2)}.btn-success{background:var(--success-light);color:var(--success);border:1px solid rgba(16,185,129,.2)}.btn-success:hover:not(:disabled){background:rgba(16,185,129,.2)}.btn-ghost{background:transparent;color:var(--text-secondary);border:1px solid var(--border)}.btn-ghost:hover:not(:disabled){background:var(--bg-card);color:var(--text-primary)}.btn-sm{padding:6px 14px;font-size:.83rem}.btn-lg{padding:14px 28px;font-size:1rem}.btn-full{width:100%}.btn-icon{padding:8px;border-radius:var(--radius-sm)}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:24px;position:relative;overflow:hidden}.card:before{content:"";position:absolute;top:0;right:0;width:40px;height:40px;background:linear-gradient(225deg,var(--border) 0,transparent 50%);pointer-events:none}.card-hover:hover{transform:translateY(-4px);box-shadow:var(--shadow),var(--shadow-glow);border-color:rgba(79,172,254,.4)}.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:0;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em}.badge-blue{background:var(--accent-light);color:var(--accent)}.badge-green{background:var(--success-light);color:var(--success)}.badge-yellow{background:var(--warning-light);color:var(--warning)}.badge-red{background:var(--danger-light);color:var(--danger)}.badge-purple{background:var(--purple-light);color:var(--purple)}.badge-gray{background:var(--accent-light);color:var(--text-secondary)}.auth-container{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;background-color:var(--bg-primary);background-image:radial-gradient(circle at 2px 2px,var(--border) 1px,transparent 0),radial-gradient(ellipse 80% 80% at 50% -10%,rgba(0,242,254,.12),rgba(79,172,254,.06) 50%,transparent);background-size:24px 24px,100% 100%}.auth-card{width:100%;max-width:420px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:40px;box-shadow:var(--shadow)}.auth-logo{gap:12px;margin-bottom:32px}.auth-logo,.auth-logo-icon{display:flex;align-items:center;justify-content:center}.auth-logo-icon{width:48px;height:48px;background:var(--gradient-corxium);border-radius:var(--radius-sm);font-size:1.4rem;box-shadow:var(--shadow-glow)}.auth-logo-text{font-size:1.6rem;font-weight:800;color:var(--text-primary)}.auth-title{font-size:1.4rem;text-align:center;margin-bottom:6px}.auth-subtitle{color:var(--text-secondary);font-size:.88rem;text-align:center;margin-bottom:28px}.auth-form{display:flex;flex-direction:column;gap:16px}.auth-footer{text-align:center;margin-top:20px;font-size:.88rem;color:var(--text-secondary)}.auth-link{color:var(--accent);font-weight:600}.auth-link:hover{text-decoration:underline}.dashboard{display:flex;min-height:100vh}.sidebar{width:var(--sidebar-width);background:var(--bg-secondary);border-right:1px solid var(--border);position:fixed;top:0;left:0;bottom:0;z-index:100;transition:transform .3s ease}.sidebar,.sidebar-logo{display:flex;flex-direction:column}.sidebar-logo{align-items:center;gap:12px;padding:32px 20px;border-bottom:1px solid var(--border);background:var(--gradient-corxium-soft)}.sidebar-logo-icon{width:36px;height:36px;background:var(--gradient-corxium);border-radius:0;display:flex;align-items:center;justify-content:center;font-size:1rem;flex-shrink:0;box-shadow:var(--glow-cyan)}.sidebar-logo-text{font-size:1.2rem;font-weight:700;letter-spacing:.02em;font-family:Space Grotesk,sans-serif}.sidebar-nav{flex:1 1;padding:16px 12px;display:flex;flex-direction:column;gap:4px}.nav-item{display:flex;align-items:center;gap:12px;padding:11px 12px;border-radius:var(--radius-sm);color:var(--text-secondary);font-size:.9rem;font-weight:500;transition:all .2s;border:1px solid transparent}.nav-item:hover{background:var(--bg-card);color:var(--text-primary);border-color:var(--border)}.nav-item.active{background:var(--gradient-corxium-soft);color:var(--accent);border-color:rgba(79,172,254,.25)}.nav-item .nav-icon{flex-shrink:0}.nav-section-label{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);padding:12px 12px 4px}.sidebar-footer{padding:16px 12px;border-top:1px solid var(--border)}.sidebar-user{gap:12px;padding:10px 12px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg-card)}.sidebar-avatar,.sidebar-user{display:flex;align-items:center}.sidebar-avatar{width:36px;height:36px;border-radius:0;background:var(--gradient-corxium);justify-content:center;font-weight:700;font-size:.9rem;color:#fff;flex-shrink:0}.sidebar-user-info{flex:1 1;min-width:0}.sidebar-user-name{font-size:.87rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-user-role{font-size:.73rem;color:var(--text-muted)}.main-content{flex:1 1;margin-left:var(--sidebar-width);min-height:100vh;display:flex;flex-direction:column;min-width:0}.topbar{height:64px;background:var(--bg-secondary);border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 28px;gap:16px;position:sticky;top:0;z-index:80;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.topbar-title{font-size:1.15rem;font-weight:700;flex:1 1;letter-spacing:-.01em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.page-content{flex:1 1;padding:32px;width:100%;max-width:var(--content-max-width);margin:0 auto;position:relative;z-index:1}.brand-footer{margin-top:auto;padding:24px 32px;display:flex;flex-direction:column;align-items:center;gap:12px;border-top:1px solid var(--border);background:var(--bg-secondary)}.powered-by{font-size:.75rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.1em}.footer-logo{height:24px;width:auto;opacity:.8;transition:opacity .3s;object-fit:contain}.footer-logo:hover{opacity:1}.sidebar-toggle{display:none;background:none;border:1px solid var(--border);border-radius:var(--radius-sm);padding:6px;color:var(--text-primary)}.sidebar-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:90}.page-header{justify-content:space-between;margin-bottom:24px;gap:16px;flex-wrap:wrap}.page-header,.page-header-info{display:flex;align-items:center}.page-header-info{gap:12px;flex:1 1;min-width:0}.page-header-actions{display:flex;gap:10px;align-items:center}.page-title{font-size:1.5rem;font-weight:800;word-break:break-word;max-width:100%}.page-subtitle{color:var(--text-secondary);font-size:.88rem;margin-top:2px}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:20px;margin-bottom:28px}.stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:20px;display:flex;align-items:center;gap:16px;transition:border-color .2s,transform .2s}.stat-card:hover{border-color:rgba(79,172,254,.3);transform:translateY(-2px);box-shadow:0 8px 28px rgba(0,242,254,.08)}.stat-icon{width:48px;height:48px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:1.3rem;flex-shrink:0}.stat-value{font-size:1.8rem;font-weight:800;line-height:1}.stat-label{font-size:.82rem;color:var(--text-secondary);margin-top:2px}.patients-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}.patient-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:20px;cursor:pointer;transition:all .2s}.patient-card:hover{border-color:rgba(79,172,254,.3);transform:translateY(-2px);box-shadow:0 8px 28px rgba(0,242,254,.1)}.patient-avatar{width:48px;height:48px;border-radius:0;background:var(--gradient-corxium);display:flex;align-items:center;justify-content:center;font-size:1.2rem;font-weight:700;color:#fff;margin-bottom:12px}.patient-name{font-size:1rem;font-weight:700;margin-bottom:4px}.patient-meta{font-size:.82rem;color:var(--text-secondary);display:flex;gap:12px;flex-wrap:wrap}.patient-meta-item{display:flex;align-items:center;gap:4px}.search-bar{position:relative;width:100%;max-width:500px}@media (max-width:768px){.search-bar{max-width:100%}}.search-bar input{width:100%;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);padding:9px 14px 9px 40px;color:var(--text-primary);font-size:.9rem;transition:border-color .2s}.search-bar input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-light)}.search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--text-muted);pointer-events:none}.dental-map-container{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:24px;overflow:auto}.dental-map-title{font-size:1rem;font-weight:700;margin-bottom:16px}.dental-chart{width:100%;max-width:700px;margin:0 auto;display:block}.tooth-group{cursor:pointer;transition:opacity .15s}.tooth-group:hover{opacity:.8}.dental-legend{display:flex;gap:16px;flex-wrap:wrap;margin-top:20px;padding-top:20px;border-top:1px solid var(--border)}.legend-item{display:flex;align-items:center;gap:6px;font-size:.8rem;color:var(--text-secondary)}.legend-dot{width:10px;height:10px;border-radius:0;flex-shrink:0;box-shadow:0 0 4px rgba(0,0,0,.2)}.needs-treatment rect{stroke:var(--accent);stroke-width:1.5px;animation:tooth-pulse 2s ease-in-out infinite}@keyframes tooth-pulse{0%,to{stroke-opacity:1}50%{stroke-opacity:.3}}.recorder-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:28px}.recorder-controls{gap:16px;margin-bottom:24px}.record-btn,.recorder-controls{display:flex;align-items:center;justify-content:center}.record-btn{width:72px;height:72px;border-radius:0;border:none;font-size:1.6rem;cursor:pointer;transition:all .2s;position:relative}.record-btn-idle{background:linear-gradient(135deg,var(--danger),#b91c1c);box-shadow:0 4px 20px rgba(239,68,68,.35);color:#fff}.record-btn-idle:hover{transform:scale(1.08);box-shadow:0 6px 28px rgba(239,68,68,.5)}.record-btn-recording{background:linear-gradient(135deg,#dc2626,#991b1b);color:#fff;animation:pulse-record 1.5s infinite}@keyframes pulse-record{0%,to{box-shadow:0 0 0 0 rgba(239,68,68,.4)}50%{box-shadow:0 0 0 16px rgba(239,68,68,0)}}.waveform{display:flex;align-items:center;justify-content:center;gap:3px;height:40px;margin-bottom:16px}.wave-bar{width:4px;background:var(--accent);border-radius:0;animation:wave 1.2s ease-in-out infinite}.wave-bar:nth-child(2){animation-delay:.1s}.wave-bar:nth-child(3){animation-delay:.2s}.wave-bar:nth-child(4){animation-delay:.3s}.wave-bar:nth-child(5){animation-delay:.4s}.wave-bar:nth-child(6){animation-delay:.3s}.wave-bar:nth-child(7){animation-delay:.2s}.wave-bar:nth-child(8){animation-delay:.1s}.wave-bar:nth-child(9){animation-delay:0s}@keyframes wave{0%,to{height:6px}50%{height:32px}}.transcription-box{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);padding:16px;min-height:120px;font-size:.92rem;line-height:1.7;color:var(--text-primary);white-space:pre-wrap;word-break:break-word;overflow-wrap:break-word}.transcription-placeholder{color:var(--text-muted)}.report-section{margin-bottom:24px}.report-section-title{font-size:.85rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-secondary);margin-bottom:12px;display:flex;align-items:center;gap:8px}.report-content{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);padding:16px;font-size:.9rem;line-height:1.8;white-space:pre-line}.table-container{overflow-x:auto;border-radius:var(--radius);border:1px solid var(--border)}table{width:100%;border-collapse:collapse}thead{background:var(--gradient-corxium-soft)}th{padding:12px 16px;text-align:left;font-size:.78rem;font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.06em;font-family:Space Grotesk,sans-serif}td,th{border-bottom:1px solid var(--border)}td{padding:14px 16px;font-size:.9rem}tr:last-child td{border-bottom:none}tr:hover td{background:var(--bg-card-hover)}.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.7);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;padding:24px;z-index:200;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:28px;width:100%;max-width:560px;max-height:90vh;overflow-y:auto;animation:slideUp .25s ease}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}.modal-title{font-size:1.2rem;font-weight:700}.empty-state{text-align:center;padding:60px 24px;color:var(--text-secondary)}.empty-state-icon{font-size:3rem;margin-bottom:16px;opacity:.4}.empty-state h3{font-size:1.1rem;margin-bottom:8px;color:var(--text-primary)}.empty-state p{font-size:.88rem}.spinner{width:24px;height:24px;border:3px solid var(--border);border-top:3px solid #00f2fe;border-radius:50%;animation:spin .7s linear infinite;flex-shrink:0}@keyframes spin{to{transform:rotate(1turn)}}.loading-overlay{justify-content:center;padding:60px;color:var(--text-secondary)}.loading-overlay,.toast{display:flex;align-items:center;gap:12px}.toast{position:fixed;bottom:24px;right:24px;background:var(--bg-card);border-radius:0;padding:16px 20px;font-size:.92rem;font-weight:500;box-shadow:0 10px 40px rgba(0,0,0,.2);z-index:1000;animation:toastIn .4s cubic-bezier(.16,1,.3,1);max-width:400px;border:1px solid var(--border);border-left:4px solid var(--accent)}@keyframes toastIn{0%{transform:translateX(100%) scale(.9);opacity:0}to{transform:translateX(0) scale(1);opacity:1}}.toast-success{border-left-color:var(--success)}.toast-error{border-left-color:var(--danger)}.toast-info{border-left-color:var(--accent)}@media (max-width:1200px){:root{--sidebar-width:240px}}@media (max-width:768px){.sidebar{transform:translateX(-100%);width:280px}.sidebar.open{transform:translateX(0);box-shadow:4px 0 30px rgba(0,0,0,.4)}.sidebar-overlay.open{display:block}.sidebar-toggle{display:flex}.main-content{margin-left:0}.page-content{padding:20px 16px}.topbar{padding:0 16px;height:60px;border-bottom:1px solid var(--border)}.topbar-title{font-size:1rem}.modal{padding:20px;width:95%}.patients-grid{grid-template-columns:1fr}.stats-grid{grid-template-columns:1fr 1fr;gap:12px}.auth-card{padding:32px 20px}.page-header{gap:12px;margin-bottom:24px}.page-header-actions{width:100%;flex-wrap:wrap}.page-header-actions .btn{flex:1 1;justify-content:center;min-width:140px;font-size:.88rem;padding:10px}.table-container{border:none!important}table.responsive-table,table.responsive-table tbody,table.responsive-table td,table.responsive-table th,table.responsive-table tr{display:block;width:100%}table.responsive-table thead{display:none}table.responsive-table tr{margin-bottom:12px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-card);padding:8px 0}table.responsive-table td{border:none;border-bottom:1px solid rgba(255,255,255,.03);position:relative;padding:10px 16px 10px 45%;min-height:40px;display:flex;align-items:center;justify-content:flex-end;text-align:right!important}table.responsive-table td:last-child{border-bottom:none}table.responsive-table td:before{content:attr(data-label);position:absolute;left:16px;top:50%;transform:translateY(-50%);font-weight:700;font-size:.75rem;color:var(--text-secondary);text-transform:uppercase;white-space:nowrap;text-align:left}table.responsive-table td .btn{width:100%;margin-top:4px;justify-content:center}table.responsive-table td:last-child{flex-wrap:wrap;align-items:center}}@media (max-width:480px){.stats-grid{grid-template-columns:1fr}.page-header{flex-direction:column;align-items:stretch;gap:16px}.page-header-info{width:100%;overflow:hidden}.page-header-actions{margin-top:4px;flex-direction:column;width:100%}.page-header-actions .btn{width:100%;flex:none;margin-bottom:4px}.topbar{padding:0 12px}}.grid-1{grid-template-columns:1fr}.grid-1,.grid-2{display:grid;gap:16px}.grid-2{grid-template-columns:1fr 1fr}.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.grid-responsive{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:16px}@media (max-width:992px){.grid-3{grid-template-columns:1fr 1fr}}@media (max-width:640px){.grid-2,.grid-3,.grid-responsive{grid-template-columns:minmax(0,1fr)}}.mb-24{margin-bottom:24px}.mb-16{margin-bottom:16px}.w-full{width:100%}@media (max-width:640px){.hide-mobile{display:none!important}}.flex-center{justify-content:center}.flex-between,.flex-center{display:flex;align-items:center}.flex-between{justify-content:space-between;gap:12px;flex-wrap:wrap}.grid-2-col{display:grid;grid-template-columns:1fr 1fr;gap:24px}@media (max-width:1024px){.grid-2-col{grid-template-columns:minmax(0,1fr)!important}}@media (max-width:380px){.page-content{padding:16px 12px}.card{padding:16px}.stat-card{padding:12px}.patient-card{padding:16px}.btn{padding:8px 12px;font-size:.82rem}.page-title{font-size:1.25rem}}.divider{height:1px;background:var(--border);margin:20px 0}.tabs{display:flex;gap:4px;background:var(--bg-secondary);border-radius:0;padding:4px;margin-bottom:24px}.tab-btn{flex:1 1;padding:8px 16px;border:none;border-radius:0;background:transparent;color:var(--text-secondary);font-size:.88rem;font-weight:600;transition:all .2s;cursor:pointer}.tab-btn.active{background:var(--bg-card)}.tab-btn.active,.tab-btn:hover:not(.active){color:var(--text-primary)}.audio-player{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);padding:12px 16px;display:flex;align-items:center;gap:12px;min-width:0}.audio-player audio{flex:1 1;height:32px;filter:invert(.8);min-width:60px;max-width:100%}.cond-caries{fill:#ef4444}.cond-fractura{fill:#f59e0b}.cond-extraccion{fill:#6b7280}.cond-ausente{fill:#374151}.cond-corona{fill:#8b5cf6}.cond-endodoncia{fill:#ec4899}.cond-restauracion{fill:#10b981}.cond-sellante{fill:#06b6d4}.cond-implante{fill:#3b82f6}.cond-observacion{fill:#f59e0b}.cond-default,.cond-saludable{fill:var(--fdi-default)}@media print{body{background:#fff!important;color:#000!important}#generate-report-btn,.audio-player,.btn,.sidebar,.sidebar-overlay,.sidebar-toggle,.topbar{display:none!important}.main-content{margin:0!important}.main-content,.page-content{padding:0!important}.card,.dental-map-container,.table-container{border:1px solid #ddd!important;box-shadow:none!important;background:#fff!important;break-inside:avoid;margin-bottom:20px!important;page-break-inside:avoid}.dental-map-container svg{max-width:100%!important;filter:none!important}.badge,h1,h2,h3,h4{color:#000!important}.badge{border:1px solid #ccc!important;background:#f0f0f0!important}.badge-blue{background:#eef2ff!important;color:#312e81!important;border-color:#c7d2fe!important}.badge-green{background:#ecfdf5!important;color:#065f46!important;border-color:#a7f3d0!important}.text-muted,.text-secondary{color:#555!important}.tooth-group rect,[data-theme=light] .tooth-group rect{stroke:#999!important}.print-only{display:block!important}}.print-only{display:none}