@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&family=Share+Tech+Mono&display=swap";*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--accent: #0ea5e9;--accent-dim: #0ea5e912;--accent-mid: #0ea5e930;--text: #0f172a;--text-muted: #64748b;--text-light: #94a3b8;--border: #e2e8f0;--border-sharp:#cbd5e1;--bg: #f8fafc;--white: #ffffff;--success: #10b981;--danger: #ef4444;--radius-sm: 4px;--radius: 8px;--shadow: 0 2px 16px rgba(0,0,0,.06);--font-mono: "Share Tech Mono", "Courier New", monospace}body{font-family:Inter,system-ui,sans-serif;background:var(--bg);color:var(--text);min-height:100vh}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem 1rem;background:linear-gradient(135deg,#f0fdff,#faf5ff,#f0fdf4);position:relative;overflow:hidden}.auth-page:before{content:"";position:fixed;inset:0;background-image:linear-gradient(rgba(14,165,233,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(14,165,233,.05) 1px,transparent 1px);background-size:40px 40px;pointer-events:none;z-index:0}.auth-card{background:var(--white);border:1.5px solid var(--border-sharp);border-radius:var(--radius);box-shadow:var(--shadow);padding:2.5rem 2rem;width:100%;max-width:440px;position:relative;z-index:1}.auth-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--accent);border-radius:var(--radius) var(--radius) 0 0}.auth-logo{display:flex;align-items:center;gap:.75rem;margin-bottom:2rem}.auth-logo-icon{width:42px;height:42px;background:var(--accent);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:1.25rem}.auth-logo h1{font-size:1.5rem;font-weight:700;color:var(--text);letter-spacing:-.5px}.auth-logo span{font-size:.72rem;color:var(--text-muted);font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.08em;display:block}.auth-title{font-size:1.2rem;font-weight:700;margin-bottom:.25rem;color:var(--text)}.auth-subtitle{color:var(--text-muted);font-size:.875rem;margin-bottom:1.75rem;font-family:var(--font-mono);font-size:.78rem;letter-spacing:.02em}.form-group{margin-bottom:1rem}.form-label{display:block;font-size:.78rem;font-weight:600;margin-bottom:.4rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;font-family:var(--font-mono)}.form-input{width:100%;padding:.65rem .9rem;border:1.5px solid var(--border);border-radius:var(--radius-sm);font-size:.95rem;font-family:inherit;outline:none;background:var(--white);color:var(--text);transition:border-color .2s,box-shadow .2s}.form-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-dim)}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}select.form-input{cursor:pointer}.btn{width:100%;padding:.75rem;border:none;border-radius:var(--radius-sm);font-size:.9rem;font-weight:700;cursor:pointer;transition:all .2s;margin-top:.5rem;letter-spacing:.04em;text-transform:uppercase;font-family:var(--font-mono)}.btn:active{transform:scale(.98)}.btn-primary{background:var(--accent);color:var(--white)}.btn-primary:hover{filter:brightness(1.08)}.btn-primary:disabled{opacity:.5;cursor:not-allowed;transform:none;box-shadow:none}.btn-sm{width:auto;padding:.4rem 1rem;font-size:.75rem}.btn-outline{background:transparent;border:1.5px solid var(--border-sharp);color:var(--text-muted)}.btn-outline:hover{border-color:var(--accent);color:var(--accent)}.alert{padding:.65rem 1rem;border-radius:var(--radius-sm);font-size:.82rem;margin-bottom:1rem;font-family:var(--font-mono);border-left:3px solid}.alert-error{background:#fff5f5;color:var(--danger);border-color:var(--danger)}.alert-success{background:#f0fdf9;color:var(--success);border-color:var(--success)}.divider{display:flex;align-items:center;gap:.75rem;margin:1.25rem 0;color:var(--text-light);font-size:.72rem;text-transform:uppercase;letter-spacing:.1em;font-family:var(--font-mono)}.divider:before,.divider:after{content:"";flex:1;height:1px;background:linear-gradient(90deg,transparent,var(--border),transparent)}.auth-footer{text-align:center;margin-top:1.5rem;font-size:.8rem;color:var(--text-muted);font-family:var(--font-mono)}.auth-footer a{color:var(--accent);text-decoration:none;font-weight:600}.auth-footer a:hover{text-decoration:underline}.dashboard-page{min-height:100vh;background:var(--bg);background-image:linear-gradient(rgba(14,165,233,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(14,165,233,.04) 1px,transparent 1px);background-size:40px 40px}.dashboard{max-width:920px;margin:0 auto;padding:2rem 1.5rem}.dashboard-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;padding-bottom:1.25rem;border-bottom:1px solid var(--border)}.dashboard-header h2{font-size:1.35rem;font-weight:700}.dashboard-header h2 span{color:var(--accent)}.qr-card{background:var(--white);border:1.5px solid var(--border-sharp);border-radius:var(--radius);padding:2.5rem 2rem;text-align:center;margin-bottom:1.5rem;box-shadow:var(--shadow);position:relative;overflow:hidden}.qr-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--accent)}.qr-card h3{font-size:1rem;font-weight:700;margin-bottom:.4rem;text-transform:uppercase;letter-spacing:.08em;font-family:var(--font-mono);color:var(--text-muted)}.qr-card p{color:var(--text-muted);font-size:.85rem;margin-bottom:1.5rem}.token-display{display:inline-flex;align-items:center;justify-content:center;gap:.75rem;background:var(--accent-dim);border:1.5px solid var(--accent-mid);border-radius:var(--radius-sm);padding:1rem 2rem;font-family:var(--font-mono);font-size:2rem;font-weight:700;color:var(--text);letter-spacing:.15em}.token-hint{margin-top:1rem;font-size:.75rem;color:var(--text-light);font-family:var(--font-mono)}.badge{display:inline-block;padding:.2rem .65rem;border-radius:3px;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;font-family:var(--font-mono)}.badge-paciente{background:var(--accent-dim);color:var(--accent);border:1px solid var(--accent-mid)}.badge-medico{background:#f0fdf4;color:#16a34a;border:1px solid #bbf7d0}.badge-admin{background:#fef9ec;color:#b45309;border:1px solid #fde68a}.token-input-section{display:flex;flex-direction:column;align-items:center;gap:1rem}.token-input-section .form-input{max-width:280px;text-align:center;font-family:var(--font-mono);font-size:1.1rem;letter-spacing:.1em;text-transform:uppercase;padding:.8rem 1rem}.token-input-section .btn{max-width:280px}
