:root{--primary: #4361EE;--primary-light: #e0e7ff;--primary-dark: #3451d1;--success: #10b981;--success-light: #d1fae5;--danger: #ef4444;--danger-light: #fee2e2;--warning: #f59e0b;--warning-light: #fef3c7;--info: #3b82f6;--bg: #f8fafc;--bg-alt: #f1f5f9;--surface: #ffffff;--text: #1e293b;--text-muted: #64748b;--border: #e2e8f0;--shadow: 0 1px 3px rgba(0, 0, 0, .1), 0 1px 2px rgba(0, 0, 0, .06);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -2px rgba(0, 0, 0, .05);--accent: #2563eb;--accent-soft: #dbeafe}body[data-theme=nutricionista]{--accent: #ec4899;--accent-soft: #fce7f3;--primary: #ec4899;--primary-dark: #db2777;--primary-light: #fce7f3}body[data-theme=kinesiologo]{--accent: #0f766e;--accent-soft: #ccfbf1;--primary: #0f766e;--primary-dark: #0d6461;--primary-light: #ccfbf1}body[data-theme=enfermero]{--accent: #1e40af;--accent-soft: #dbeafe;--primary: #1e40af;--primary-dark: #1e3a8a;--primary-light: #dbeafe}body[data-theme=psicologo]{--accent: #059669;--accent-soft: #d1fae5;--primary: #059669;--primary-dark: #047857;--primary-light: #d1fae5}body[data-theme=medico]{--accent: #4361EE;--accent-soft: #e0e7ff;--primary: #4361EE;--primary-dark: #3451d1;--primary-light: #e0e7ff}*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;color:var(--text);background:var(--bg);line-height:1.6}h1,h2,h3,h4,h5,h6{font-weight:600;margin:0;line-height:1.2}h1{font-size:2rem}h2{font-size:1.5rem}h3{font-size:1.25rem}h4{font-size:1rem}h5{font-size:.9rem}p{margin:0}.topbar{display:flex;justify-content:space-between;align-items:center;padding:12px 24px;background:var(--surface);border-bottom:1px solid var(--border);box-shadow:var(--shadow);position:sticky;top:0;z-index:100}.logo-section{display:flex;align-items:center;gap:1rem}.logo-image{height:45px;width:auto;display:block}.topbar h1{font-size:1.3rem;color:var(--primary);margin:0;font-weight:700}.topbar p{margin:2px 0 0;color:var(--text-muted);font-size:.75rem;text-transform:uppercase;letter-spacing:.5px}.top-actions{display:flex;align-items:center;gap:12px}.footerbar{position:sticky;bottom:0;z-index:90;background:var(--surface);border-top:1px solid var(--border);box-shadow:0 -1px 3px #00000014;padding:10px 24px;display:flex;align-items:center;justify-content:center;gap:12px}.footerbar>.footer-legend{max-width:1400px;width:100%;margin-left:auto;margin-right:auto}.footer-actions{display:flex;align-items:center;gap:10px}.footer-legend{margin:0;color:var(--text-muted);font-size:.75rem;text-transform:uppercase;letter-spacing:.5px;white-space:nowrap;width:100%;text-align:center}.user-pill{background:var(--bg-alt);border:1px solid var(--border);border-radius:20px;padding:6px 12px;font-size:.85rem;font-weight:500;color:var(--text);transition:all .2s}.user-pill:hover{background:var(--primary-light);border-color:var(--primary)}.app-shell{max-width:1400px;margin:0 auto;padding:20px 24px}.content{padding:0;width:100%}.clean-content{width:100%}.screen{display:none}.screen.active{display:block;animation:fadeIn .2s ease-in}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.card{background:var(--surface);border:1px solid var(--border);border-radius:12px;box-shadow:var(--shadow);padding:20px;margin-bottom:16px;transition:all .2s}.card:hover{box-shadow:var(--shadow-lg)}.login-card{max-width:420px;margin:60px auto;padding:32px 24px}.login-card h3{margin-bottom:8px;color:var(--text)}.login-card p{color:var(--text-muted);margin-bottom:20px;font-size:.9rem}.login-card form{display:flex;flex-direction:column}.login-card form .primary{margin-top:8px}.login-card form .text-link{margin-top:8px;align-self:flex-start}.login-switch{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-top:16px;padding-top:16px;border-top:1px solid var(--border);color:var(--text-muted);font-size:.9rem}.reset-panel{margin-top:16px;padding:16px;background:var(--bg-alt);border:1px solid var(--border);border-radius:10px;display:grid;gap:12px}.reset-panel h4{margin:0 0 4px;font-size:.95rem}.msg-box{margin-bottom:12px;border-left:4px solid var(--primary);background:var(--primary-light);border-radius:8px;padding:12px 14px;color:var(--primary-dark);font-size:.9rem;animation:slideDown .3s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}label{display:flex;flex-direction:column;gap:6px;margin-bottom:14px;font-weight:500;color:var(--text);font-size:.9rem}input,select,textarea{width:100%;border:1px solid var(--border);border-radius:8px;padding:10px 12px;font:inherit;background:var(--surface);color:var(--text);transition:all .2s}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light)}input:disabled,select:disabled,textarea:disabled{background:var(--bg-alt);color:var(--text-muted);cursor:not-allowed}textarea{min-height:100px;resize:vertical;font-family:inherit}button{cursor:pointer;border-radius:8px;border:none;padding:10px 16px;font-weight:600;font-size:.9rem;transition:all .2s;display:inline-flex;align-items:center;justify-content:center;gap:6px;margin-top:12px}button:disabled{opacity:.6;cursor:not-allowed}.primary{background:var(--primary);color:#fff}.primary:hover:not(:disabled){background:var(--primary-dark);box-shadow:var(--shadow-lg);transform:translateY(-1px)}.primary:active:not(:disabled){transform:translateY(0)}.ghost{background:var(--surface);border:1px solid var(--border);color:var(--text)}.ghost:hover:not(:disabled){background:var(--bg-alt);border-color:var(--primary);color:var(--primary)}.text-link{background:transparent;border:none;color:var(--primary);padding:8px 0;font-weight:600;text-align:left;font-size:.9rem}.text-link:hover{text-decoration:underline;color:var(--primary-dark)}.screen-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;gap:12px;flex-wrap:wrap}.screen-head h2{margin:0}.inline-controls{display:flex;gap:10px;flex-wrap:wrap;align-items:center}.workspace-nav{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:16px;border-bottom:2px solid var(--border)}.workspace-link{background:transparent;border:none;border-bottom:3px solid transparent;color:var(--text-muted);padding:10px 14px;margin-bottom:-2px;font-weight:500;font-size:.9rem;transition:all .2s}.workspace-link:hover{color:var(--primary)}.workspace-link.active{color:var(--primary);border-bottom-color:var(--primary)}.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:14px;margin-bottom:16px}.kpi{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:16px;transition:all .2s}.kpi:hover{border-color:var(--primary);box-shadow:var(--shadow-lg)}.kpi span{color:var(--text-muted);display:block;font-size:.8rem;font-weight:500;text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px}.kpi strong{font-size:1.8rem;color:var(--primary)}.patient-list{display:grid;gap:12px}.patient-item{display:flex;justify-content:space-between;align-items:center;background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:14px;transition:all .2s;cursor:pointer}.patient-item:hover{border-color:var(--primary);box-shadow:var(--shadow-lg)}.patient-item h4{margin:0 0 4px;color:var(--text)}.patient-item p{margin:0;color:var(--text-muted);font-size:.85rem}.empty-msg{color:var(--text-muted);text-align:center;padding:40px 20px;font-size:.95rem}.appointments-list{display:flex;flex-direction:column;gap:12px}.admin-users-list{margin-top:12px}.admin-tab-bar{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:10px;margin-bottom:16px}.admin-tab{margin-top:0;border:1px solid var(--border);background:var(--surface);color:var(--text);border-radius:12px;padding:12px 14px;display:flex;align-items:center;gap:10px;justify-content:flex-start;font-weight:600}.admin-tab:hover{border-color:var(--primary);box-shadow:var(--shadow)}.admin-tab.active{border-color:var(--primary);background:linear-gradient(135deg,var(--primary-light),#fff);color:var(--primary-dark)}.admin-tab-icon{font-size:1rem}.invite-layout{display:grid;grid-template-columns:2fr 1fr;gap:16px;align-items:start}.invite-main-card{position:relative;overflow:hidden}.invite-main-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--primary),var(--accent))}.invite-card-header{display:flex;gap:12px;align-items:flex-start;margin-bottom:14px}.invite-card-icon{width:40px;height:40px;border-radius:10px;display:grid;place-items:center;background:var(--primary-light);font-size:1.1rem}.invite-card-header p.meta{margin-top:4px}.invite-flow-banner{display:flex;flex-wrap:wrap;gap:8px;padding:10px;border:1px dashed var(--border);border-radius:10px;background:var(--bg-alt);margin-bottom:14px}.invite-flow-step{display:inline-flex;align-items:center;gap:8px;font-size:.82rem;color:var(--text-muted)}.invite-flow-num{width:22px;height:22px;border-radius:999px;display:grid;place-items:center;font-weight:700;color:var(--primary-dark);background:var(--primary-light);border:1px solid #c7d2fe}.invite-flow-arrow{color:#94a3b8}.invite-form{display:grid;gap:12px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}.form-row-single{display:grid;grid-template-columns:1fr}.form-field{display:grid;gap:6px}.field-label{font-weight:600;font-size:.88rem;color:var(--text)}.field-hint{font-size:.78rem;color:var(--text-muted)}.field-warning{border:1px solid #fbd38d;background:#fffbeb;color:#92400e;border-radius:8px;padding:10px;font-size:.85rem}.invite-submit-btn{margin-top:4px;width:100%}.invite-side-info{display:grid;gap:12px}.invite-side-info .card{margin-bottom:0}.info-list{margin:8px 0 0;padding-left:18px;display:grid;gap:6px;color:var(--text-muted);font-size:.88rem}.specialty-chips{margin-top:10px;display:flex;flex-wrap:wrap;gap:8px}.specialty-chip{border:1px solid #c7d2fe;background:#eef2ff;color:#3730a3;border-radius:999px;padding:5px 10px;font-size:.78rem;font-weight:600}.users-list-header{display:flex;align-items:center;justify-content:space-between;gap:12px}.users-count{border:1px solid var(--border);background:var(--bg-alt);color:var(--text-muted);border-radius:999px;padding:4px 10px;font-size:.8rem;font-weight:600}.role-badge{display:inline-flex;align-items:center;justify-content:center;border-radius:999px;padding:4px 10px;font-size:.75rem;border:1px solid var(--border);background:var(--bg-alt);color:var(--text-muted)}.role-badges{display:flex;flex-wrap:wrap;gap:6px}.role-badge--admin{border-color:#fbcfe8;background:#fdf2f8;color:#9d174d}.role-badge--professional{border-color:#bfdbfe;background:#eff6ff;color:#1d4ed8}.role-badge--patient{border-color:#bbf7d0;background:#f0fdf4;color:#166534}.status-pill{display:inline-flex;align-items:center;border-radius:999px;padding:4px 10px;font-size:.75rem;font-weight:600;border:1px solid var(--border)}.status-pill--active{border-color:#bbf7d0;color:#166534;background:#f0fdf4}.status-pill--pending{border-color:#fde68a;color:#92400e;background:#fffbeb}.status-pill--inactive{border-color:#fecaca;color:#991b1b;background:#fef2f2}.btn-danger-ghost:hover:not(:disabled){border-color:#fca5a5;color:#b91c1c;background:#fef2f2}.btn-success-ghost:hover:not(:disabled){border-color:#86efac;color:#166534;background:#f0fdf4}.specialty-add-form{display:grid;grid-template-columns:1fr auto;gap:10px;align-items:end}.specialty-add-form button{margin-top:0}.appointment-item{display:grid;grid-template-columns:140px 1fr auto;gap:14px;align-items:center;border:1px solid var(--border);border-radius:10px;padding:14px;background:var(--surface);transition:all .2s}.appointment-item:hover{border-color:var(--primary);box-shadow:var(--shadow-lg)}.apt-time{font-weight:700;color:var(--primary);font-size:.85rem}.apt-info h4{margin:0 0 4px}.apt-info p{margin:2px 0 0;color:var(--text-muted);font-size:.85rem}.apt-estado{font-size:.85rem;font-weight:500}.apt-actions{display:flex;gap:8px;justify-content:flex-end;align-items:center}.apt-status-badge{display:inline-block;padding:4px 8px;border-radius:6px;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.apt-status-badge.scheduled{background:var(--info);color:#fff}.apt-status-badge.confirmed{background:var(--success);color:#fff}.apt-status-badge.completed{background:#6366f1;color:#fff}.apt-status-badge.cancelled{background:var(--danger);color:#fff}.apt-status-badge.noshow{background:var(--warning);color:#fff}.calendar-grid{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:10px;margin-bottom:14px}.calendar-weekday{text-align:center;font-weight:700;color:var(--text-muted);font-size:.8rem;text-transform:uppercase;padding:8px 0;letter-spacing:.5px}.calendar-cell{min-height:140px;border:1px solid var(--border);border-radius:10px;padding:10px;background:var(--surface);display:flex;flex-direction:column;gap:6px;transition:all .2s}.calendar-cell:hover{box-shadow:var(--shadow-lg);border-color:var(--primary)}.calendar-cell.empty{background:var(--bg-alt);border-style:dashed}.calendar-day-number{font-weight:700;font-size:.9rem;color:var(--text)}.cal-badge{border:none;border-radius:6px;padding:4px 8px;text-align:left;font-size:.7rem;line-height:1.3;color:#fff;font-weight:600;transition:transform .2s}.cal-badge:hover{transform:scale(1.02)}.status-scheduled{background:var(--info)}.status-confirmed{background:var(--success)}.status-completed{background:#6366f1}.status-cancelled{background:var(--danger)}.status-noshow{background:var(--warning)}@media(max-width:1024px){.kpi-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.appointment-item{grid-template-columns:1fr;gap:10px}.invite-layout{grid-template-columns:1fr}}@media(max-width:640px){.topbar{flex-direction:row;align-items:center;justify-content:space-between;padding:12px 16px}.top-actions{width:100%;justify-content:space-between}.footerbar{padding:10px 12px;flex-direction:column;align-items:stretch;gap:8px}.footer-actions{flex-wrap:wrap;gap:8px}.footer-legend{text-align:right}.app-shell{padding:16px 12px}.kpi-grid,.admin-tab-bar,.form-row{grid-template-columns:1fr}.invite-flow-step{width:100%}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-box{background:var(--surface, #fff);border-radius:12px;padding:28px;width:min(540px,95vw);max-height:85vh;overflow-y:auto;display:flex;flex-direction:column;gap:16px;box-shadow:0 8px 32px #0000002e}.modal-head{display:flex;align-items:center;justify-content:space-between}.modal-head h4{margin:0;font-size:1.1rem}.modal-footer{display:flex;justify-content:flex-end;gap:10px;margin-top:8px}.slots-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:10px;margin-top:8px}.slot-btn{display:flex;flex-direction:column;align-items:flex-start;gap:4px;padding:10px 12px;border:1.5px solid var(--border, #e2e8f0);border-radius:8px;background:var(--surface, #fff);cursor:pointer;transition:border-color .15s,background .15s;font-size:.85rem}.slot-btn:hover{border-color:var(--primary, #4f46e5);background:var(--primary-light, #eef2ff)}.slot-btn.selected{border-color:var(--primary, #4f46e5);background:var(--primary-light, #eef2ff);font-weight:600}.slot-time{font-size:1rem;font-weight:700;color:var(--text-primary, #1e293b)}.slot-meta{font-size:.75rem;color:var(--text-muted, #64748b);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.card-header-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.card-header-row h4{margin:0}button.sm{padding:6px 14px;font-size:.82rem}button.danger{color:#dc2626;border-color:#fca5a5}button.danger:hover{background:#fef2f2}.meta-label{font-size:.82rem;font-weight:600;color:var(--text-muted, #64748b);text-transform:uppercase;letter-spacing:.04em;margin-bottom:4px}.specialty-add-form{grid-template-columns:1fr}.login-card{margin:40px 16px;padding:24px 16px}.calendar-cell{min-height:100px}button{padding:8px 12px;font-size:.85rem}}
