@import"https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700&display=swap";:root{--bg-primary: #F0F9FF;--bg-secondary: #FFFFFF;--bg-tertiary: #F8FAFC;--text-primary: #0F172A;--text-secondary: #475569;--text-muted: #64748b;--accent: #0284C7;--accent-light: #E0F2FE;--accent-hover: #0369A1;--accent-glow: rgba(2, 132, 199, .15);--border-color: #E2E8F0;--card-shadow: 0 10px 25px -5px rgba(2, 132, 199, .08), 0 8px 10px -6px rgba(2, 132, 199, .08);--input-focus-shadow: 0 0 0 4px rgba(2, 132, 199, .15);--danger: #EF4444;--danger-light: #FEE2E2;--success: #10B981;--success-light: #D1FAE5;--warning: #F59E0B;--warning-light: #FEF3C7;--transition-smooth: all .25s cubic-bezier(.4, 0, .2, 1);--border-radius-lg: 16px;--border-radius-md: 12px;--border-radius-sm: 8px}*{box-sizing:border-box;margin:0;padding:0}body{font-family:Outfit,sans-serif;background-color:var(--bg-primary);color:var(--text-primary);line-height:1.5;overflow-x:hidden;-webkit-font-smoothing:antialiased}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-primary)}::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:var(--border-radius-sm)}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.dashboard-container{display:flex;flex-direction:column;min-height:100vh;padding:1.5rem;gap:1.5rem;max-width:1600px;margin:0 auto}.hero-header{display:grid;grid-template-columns:1fr 1.5fr;align-items:center;background:linear-gradient(135deg,#FFFFFF 0%,var(--accent-light) 100%);border:1px solid var(--border-color);box-shadow:var(--card-shadow);border-radius:var(--border-radius-lg);padding:1.5rem 2rem;gap:2rem;position:relative;overflow:hidden}.hero-header:before{content:"";position:absolute;top:-50%;right:-20%;width:400px;height:400px;background:radial-gradient(circle,rgba(2,132,199,.1) 0%,transparent 75%);pointer-events:none}.clinic-info{display:flex;align-items:center;gap:1.25rem}.logo-icon{font-size:2.75rem;background:#fff;padding:.75rem;border-radius:var(--border-radius-md);border:1px solid var(--border-color);box-shadow:0 4px 6px -1px #0000000d}.clinic-info h1{font-size:1.75rem;font-weight:700;letter-spacing:-.025em;color:var(--accent)}.subdomain-indicator{font-size:.9rem;color:var(--text-secondary);margin-top:.25rem}.subdomain-indicator code{color:var(--accent-hover);background:#0284c714;padding:.15rem .4rem;border-radius:4px;font-weight:600}.active-patient-card{display:flex;align-items:center;justify-content:space-between;background:#fff;border-radius:var(--border-radius-md);padding:1.25rem 1.5rem;border:1px solid var(--border-color);box-shadow:0 4px 12px #0284c70d}.patient-main-info{display:flex;align-items:center;gap:1rem}.avatar{font-size:2rem;background:var(--accent-light);border-radius:50%;width:50px;height:50px;display:flex;align-items:center;justify-content:center;border:2px solid #FFFFFF;box-shadow:0 2px 8px #0000000d}.patient-main-info h3{font-size:1.25rem;font-weight:700;color:var(--text-primary)}.patient-main-info p{font-size:.85rem;color:var(--text-secondary)}.patient-alerts{display:flex;flex-wrap:wrap;gap:.5rem;max-width:250px}.alert-badge{background:var(--danger-light);color:var(--danger);border:1px solid rgba(239,68,68,.15);padding:.25rem .75rem;font-size:.8rem;font-weight:700;border-radius:20px}.patient-financial{display:flex;flex-direction:column;align-items:flex-end}.financial-label{font-size:.8rem;color:var(--text-muted);font-weight:500}.financial-amount{font-size:1.5rem;font-weight:700;color:var(--accent-hover)}.main-layout{display:grid;grid-template-columns:300px 1fr;gap:1.5rem}.sidebar{background:#fff;border:1px solid var(--border-color);box-shadow:var(--card-shadow);border-radius:var(--border-radius-lg);padding:1.5rem;display:flex;flex-direction:column;gap:1.5rem;align-self:start}.sidebar h2{font-size:.9rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.075em}.nav-menu{display:flex;flex-direction:column;gap:.4rem}.nav-menu button{background:transparent;border:none;color:var(--text-secondary);text-align:left;padding:.85rem 1rem;font-family:inherit;font-size:1rem;font-weight:600;cursor:pointer;border-radius:var(--border-radius-md);transition:var(--transition-smooth);display:flex;align-items:center;gap:.75rem}.nav-menu button:hover{background:var(--bg-primary);color:var(--accent-hover);transform:translate(4px)}.nav-menu button.active{background:var(--accent);color:#fff;box-shadow:0 4px 15px #0284c740}.patients-list-panel{border-top:1px solid var(--border-color);padding-top:1.5rem;display:flex;flex-direction:column;gap:1rem}.patients-list-panel h3{font-size:.95rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;display:flex;justify-content:space-between;align-items:center}.btn-add-small{background:var(--accent-light);color:var(--accent-hover);border:none;width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.1rem;font-weight:700;cursor:pointer;transition:var(--transition-smooth)}.btn-add-small:hover{background:var(--accent);color:#fff}.patients-list{display:flex;flex-direction:column;gap:.5rem;max-height:350px;overflow-y:auto;padding-right:.25rem}.patient-list-item{display:flex;justify-content:space-between;align-items:center;padding:.85rem;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--border-radius-sm);cursor:pointer;transition:var(--transition-smooth)}.patient-list-item:hover{background:var(--accent-light);border-color:var(--accent)}.patient-list-item.selected{background:var(--accent-light);border-color:var(--accent);box-shadow:0 2px 8px #0284c71a}.patient-name{font-size:.95rem;font-weight:600;color:var(--text-primary)}.status-tag{font-size:.65rem;text-transform:uppercase;font-weight:700;padding:.15rem .5rem;border-radius:20px}.status-tag.activo{background:var(--success-light);color:var(--success)}.status-tag.pendiente_vinculacion{background:var(--warning-light);color:var(--warning)}.content-area{background:#fff;border:1px solid var(--border-color);box-shadow:var(--card-shadow);border-radius:var(--border-radius-lg);padding:2.25rem;min-height:600px}.tab-pane h2{font-size:1.85rem;font-weight:700;color:var(--text-primary);margin-bottom:.25rem;letter-spacing:-.02em}.tab-description{color:var(--text-secondary);font-size:1rem;margin-bottom:2rem}.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.25rem;margin-bottom:1.5rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-size:.85rem;font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.form-control,select,textarea{font-family:inherit;font-size:1rem;padding:.75rem 1rem;border:1px solid var(--border-color);border-radius:var(--border-radius-sm);background-color:var(--bg-tertiary);color:var(--text-primary);transition:var(--transition-smooth);width:100%}.form-control:focus,select:focus,textarea:focus{outline:none;border-color:var(--accent);background-color:#fff;box-shadow:var(--input-focus-shadow)}.btn-primary{font-family:inherit;background-color:var(--accent);color:#fff;border:none;font-weight:700;font-size:1rem;padding:.85rem 1.5rem;border-radius:var(--border-radius-sm);cursor:pointer;transition:var(--transition-smooth);display:inline-flex;align-items:center;justify-content:center;gap:.5rem;box-shadow:0 4px 10px #0284c733}.btn-primary:hover{background-color:var(--accent-hover);box-shadow:0 6px 15px #0284c74d;transform:translateY(-1px)}.btn-secondary{font-family:inherit;background-color:var(--accent-light);color:var(--accent-hover);border:1px solid rgba(2,132,199,.15);font-weight:700;font-size:1rem;padding:.85rem 1.5rem;border-radius:var(--border-radius-sm);cursor:pointer;transition:var(--transition-smooth);display:inline-flex;align-items:center;justify-content:center;gap:.5rem}.btn-secondary:hover{background-color:var(--accent);color:#fff}.btn-danger{font-family:inherit;background-color:var(--danger-light);color:var(--danger);border:1px solid rgba(239,68,68,.15);font-weight:700;font-size:1rem;padding:.85rem 1.5rem;border-radius:var(--border-radius-sm);cursor:pointer;transition:var(--transition-smooth)}.btn-danger:hover{background-color:var(--danger);color:#fff}.sub-tabs{display:flex;gap:.5rem;border-bottom:2px solid var(--border-color);margin-bottom:2rem;padding-bottom:.25rem;overflow-x:auto}.sub-tab-btn{background:transparent;border:none;padding:.75rem 1.25rem;font-family:inherit;font-size:1rem;font-weight:600;color:var(--text-secondary);cursor:pointer;position:relative;transition:var(--transition-smooth);white-space:nowrap}.sub-tab-btn:hover{color:var(--accent)}.sub-tab-btn.active{color:var(--accent);font-weight:700}.sub-tab-btn.active:after{content:"";position:absolute;bottom:-6px;left:0;right:0;height:3px;background-color:var(--accent);border-radius:3px 3px 0 0}.form-card{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--border-radius-md);padding:1.5rem;margin-bottom:1.5rem}.form-card h3{font-size:1.2rem;font-weight:700;margin-bottom:1rem;color:var(--accent-hover);display:flex;align-items:center;gap:.5rem}.check-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1rem}.checkbox-label{display:flex;align-items:center;gap:.75rem;font-size:1rem;font-weight:500;cursor:pointer;padding:.5rem;border-radius:var(--border-radius-sm);transition:var(--transition-smooth)}.checkbox-label:hover{background:var(--bg-primary)}.checkbox-label input{width:18px;height:18px;accent-color:var(--accent)}.odontogram-visual{display:flex;flex-direction:column;gap:2rem;align-items:center;background:var(--bg-tertiary);border-radius:var(--border-radius-lg);padding:2rem;border:1px solid var(--border-color);width:100%;overflow-x:auto}.odontogram-row{display:flex;gap:1.15rem;min-width:600px}.tooth-container{display:flex;flex-direction:column;align-items:center;gap:.5rem}.tooth-number{font-size:.9rem;font-weight:700;color:var(--text-secondary)}.tooth-graphic{position:relative;width:48px;height:48px;border:2px solid var(--text-muted);border-radius:4px;cursor:pointer;background:#fff;transition:var(--transition-smooth)}.tooth-graphic.selected{border-color:var(--accent);box-shadow:0 0 8px #0284c766}.tooth-surface{position:absolute;background:#fff;border:1px solid #CBD5E1;transition:var(--transition-smooth)}.tooth-surface.top{top:0;left:0;right:0;height:13px;clip-path:polygon(0 0,100% 0,75% 100%,25% 100%)}.tooth-surface.left{top:0;bottom:0;left:0;width:13px;clip-path:polygon(0 0,100% 25%,100% 75%,0 100%)}.tooth-surface.center{top:13px;bottom:13px;left:13px;right:13px;border:1px solid #94A3B8;background:#f1f5f9}.tooth-surface.right{top:0;bottom:0;right:0;width:13px;clip-path:polygon(0 25%,100% 0,100% 100%,0 75%)}.tooth-surface.bottom{bottom:0;left:0;right:0;height:13px;clip-path:polygon(25% 0,75% 0,100% 100%,0 100%)}.tooth-surface.active-CARIES{background:#ef4444!important}.tooth-surface.active-RESTAURADO{background:#3b82f6!important}.tooth-surface.active-AUSENTE{background:#64748b!important}.tooth-graphic.cond-EXTRACCION{background:#f87171!important;opacity:.6}.odontogram-legends{display:flex;gap:1.5rem;margin-top:1rem;flex-wrap:wrap;justify-content:center}.legend-item{display:flex;align-items:center;gap:.5rem;font-size:.9rem;font-weight:600}.legend-color{width:20px;height:20px;border-radius:4px;border:1px solid var(--border-color)}.progress-dual-container{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem;margin-bottom:2rem}.progress-card{background:#fff;border:1px solid var(--border-color);box-shadow:0 4px 6px -1px #00000005;border-radius:var(--border-radius-md);padding:1.25rem 1.5rem}.progress-card h4{font-size:1rem;font-weight:700;color:var(--text-secondary);margin-bottom:.75rem}.progress-bar-bg{width:100%;height:12px;background:var(--bg-primary);border-radius:6px;overflow:hidden;margin-bottom:.5rem;border:1px solid var(--border-color)}.progress-bar-fill{height:100%;background:var(--accent);border-radius:6px;transition:width .5s ease-out}.progress-bar-fill.real{background:var(--success)}.progress-text{font-size:.85rem;font-weight:600;color:var(--text-muted)}.grid-two-columns{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:1.5rem}.clinical-data-box,.photos-timeline-box{background:#fff;border:1px solid var(--border-color);box-shadow:0 2px 8px #00000005;border-radius:var(--border-radius-md);padding:1.5rem}.clinical-data-box h3,.photos-timeline-box h3{font-size:1.2rem;font-weight:700;color:var(--accent-hover);margin-bottom:1.25rem;border-bottom:1px solid var(--border-color);padding-bottom:.5rem}.star-input-group{display:flex;flex-direction:column;gap:.5rem;margin-top:1rem}.star-btn{background:none;border:none;font-size:1.5rem;cursor:pointer;color:#cbd5e1;transition:var(--transition-smooth)}.star-btn.active{color:var(--warning)}.photo-gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:1rem;margin-top:1rem}.photo-item{aspect-ratio:1;border-radius:var(--border-radius-sm);border:2px dashed var(--text-muted);display:flex;flex-direction:column;align-items:center;justify-content:center;font-size:.8rem;text-align:center;color:var(--text-secondary);cursor:pointer;transition:var(--transition-smooth);background:var(--bg-tertiary);padding:.5rem}.photo-item:hover{border-color:var(--accent);color:var(--accent-hover);background:var(--accent-light)}.photo-item img{width:100%;height:100%;object-fit:cover;border-radius:6px}.photo-item.filled{border-style:solid;border-color:var(--border-color);padding:0}.financial-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1.5rem;margin-bottom:2rem}.stat-card{background:#fff;border:1px solid var(--border-color);box-shadow:var(--card-shadow);border-radius:var(--border-radius-md);padding:1.5rem;display:flex;flex-direction:column;gap:.5rem}.stat-card h4{font-size:.95rem;font-weight:700;color:var(--text-muted);text-transform:uppercase}.stat-value{font-size:2rem;font-weight:700}.stat-value.income{color:var(--success)}.stat-value.pending{color:var(--accent-hover)}.cash-control-box{background:var(--accent-light);border:1px solid rgba(2,132,199,.15);border-radius:var(--border-radius-md);padding:1.5rem;margin-bottom:2rem;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}.cash-info-text h3{font-size:1.2rem;font-weight:700;color:var(--accent-hover)}.cash-info-text p{font-size:.9rem;color:var(--text-secondary)}.table-responsive{width:100%;overflow-x:auto;border:1px solid var(--border-color);border-radius:var(--border-radius-md);background:#fff;margin-top:1rem;box-shadow:0 2px 5px #00000003}table{width:100%;border-collapse:collapse;text-align:left}th{background-color:var(--bg-tertiary);color:var(--text-secondary);font-weight:700;padding:1rem;font-size:.85rem;text-transform:uppercase;border-bottom:2px solid var(--border-color)}td{padding:1rem;border-bottom:1px solid var(--border-color);font-size:.95rem;color:var(--text-primary);font-weight:500}tr:last-child td{border-bottom:none}tr:hover td{background-color:var(--bg-primary)}.appointments-list{display:flex;flex-direction:column;gap:1rem}.appointment-card{display:flex;align-items:center;gap:1.5rem;background:#fff;border:1px solid var(--border-color);border-radius:var(--border-radius-md);padding:1.25rem 1.5rem;box-shadow:0 2px 4px #00000003;transition:var(--transition-smooth)}.appointment-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0284c70d}.appt-time{font-size:1.35rem;font-weight:700;color:var(--accent-hover);background:var(--accent-light);padding:.5rem 1rem;border-radius:var(--border-radius-sm);min-width:110px;text-align:center}.appt-detail h4{font-size:1.15rem;font-weight:700;color:var(--text-primary)}.appt-detail p{font-size:.9rem;color:var(--text-secondary);margin-top:.15rem}.appt-status{margin-left:auto;font-weight:700;font-size:.8rem;padding:.25rem .75rem;border-radius:20px;text-transform:uppercase}.appointment-card.confirmed{border-left:5px solid var(--success)}.appointment-card.confirmed .appt-status{background:var(--success-light);color:var(--success)}.appointment-card.pending{border-left:5px solid var(--warning)}.appointment-card.pending .appt-status{background:var(--warning-light);color:var(--warning)}.appointment-card.cancelled{border-left:5px solid var(--danger);opacity:.7}.appointment-card.cancelled .appt-status{background:var(--danger-light);color:var(--danger)}.auth-wrapper{display:flex;align-items:center;justify-content:center;min-height:80vh;padding:1.5rem}.auth-card{background:#fff;border:1px solid var(--border-color);box-shadow:var(--card-shadow);border-radius:var(--border-radius-lg);padding:2.5rem;width:100%;max-width:480px;display:flex;flex-direction:column;gap:1.5rem}.auth-logo{font-size:3rem;text-align:center}.auth-card h2{font-size:1.75rem;font-weight:700;text-align:center;color:var(--accent)}.auth-card p{font-size:.95rem;color:var(--text-secondary);text-align:center}.auth-toggle{text-align:center;font-size:.95rem;font-weight:600;color:var(--text-secondary);margin-top:.5rem}.auth-toggle-link{color:var(--accent);cursor:pointer;text-decoration:underline;transition:var(--transition-smooth)}.auth-toggle-link:hover{color:var(--accent-hover)}.landing-hero{text-align:center;padding:4rem 1.5rem;max-width:900px;margin:0 auto;display:flex;flex-direction:column;gap:1.5rem}.landing-hero h1{font-size:3.25rem;font-weight:800;color:var(--text-primary);line-height:1.2}.landing-hero h1 span{color:var(--accent)}.landing-hero p{font-size:1.25rem;color:var(--text-secondary);line-height:1.6}.landing-actions{display:flex;gap:1rem;justify-content:center;margin-top:1rem}.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:2rem;margin:2rem 0}.feature-card{background:#fff;border:1px solid var(--border-color);box-shadow:0 4px 6px #00000003;border-radius:var(--border-radius-md);padding:2rem;text-align:center;transition:var(--transition-smooth)}.feature-card:hover{transform:translateY(-5px);box-shadow:var(--card-shadow)}.feature-icon{font-size:2.5rem;margin-bottom:1rem}.feature-card h3{font-size:1.25rem;font-weight:700;margin-bottom:.75rem}.feature-card p{font-size:.95rem;color:var(--text-secondary);line-height:1.5}.patient-dashboard{display:flex;flex-direction:column;gap:2rem}.clinic-selection-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem;margin-top:1rem}.clinic-card{background:#fff;border:1px solid var(--border-color);box-shadow:var(--card-shadow);border-radius:var(--border-radius-md);padding:1.5rem;cursor:pointer;transition:var(--transition-smooth);display:flex;flex-direction:column;gap:.75rem}.clinic-card:hover{border-color:var(--accent);transform:translateY(-2px)}.clinic-card h3{font-size:1.25rem;color:var(--accent-hover);font-weight:700}.clinic-card p{font-size:.9rem;color:var(--text-secondary)}.clinic-card .subdomain-badge{align-self:flex-start;background-color:var(--accent-light);color:var(--accent-hover);font-size:.8rem;font-weight:700;padding:.2rem .6rem;border-radius:4px}.fade-in{animation:fadeIn .35s ease-out forwards}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
