:root{--bg: #eef2ff;--surface: rgba(255, 255, 255, .8);--panel-border: rgba(15, 23, 42, .08);--ink: #0f172a;--muted: #475569;--muted-strong: #64748b;--role-patient: #0ea5e9;--role-medecin: #16a34a;--role-admin: #7c3aed;--shadow-lg: 0 30px 70px rgba(15, 23, 42, .12), 0 12px 30px rgba(15, 23, 42, .08);font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.5;font-weight:400;color:var(--muted);background:radial-gradient(circle at top left,rgba(59,130,246,.18),transparent 32%),radial-gradient(circle at bottom right,rgba(124,58,237,.16),transparent 30%),linear-gradient(180deg,#f8fafc 0%,var(--bg) 100%);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}html,body,#root{min-height:100%}body{margin:0}button,input{font:inherit}button{-webkit-tap-highlight-color:transparent}a{color:inherit}.login-shell{width:min(820px,calc(100% - 32px));min-height:calc(100vh - 32px);margin:16px auto;display:flex;align-items:center;position:relative;z-index:1}.login-panel{border:1px solid var(--panel-border);border-radius:28px;background:var(--surface);box-shadow:var(--shadow-lg);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.brand-mark{display:inline-flex;align-items:center;gap:10px;width:fit-content;padding:10px 16px;border-radius:999px;border:1px solid rgba(23,31,56,.08);background:#ffffffc2;color:var(--ink);font-size:.92rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase}.panel-header__eyebrow,.field span,.role-summary span{display:block;margin-bottom:6px;font-size:.78rem;text-transform:uppercase;letter-spacing:.14em;color:var(--muted-strong)}.meta-grid strong,.role-summary strong{display:block;color:var(--ink);font-weight:700}.login-panel{width:100%;padding:32px;display:flex;flex-direction:column;gap:24px;background:linear-gradient(180deg,#fffffff0,#f8fafce0),var(--surface)}.panel-header h2{margin:0;font-size:clamp(1.8rem,2vw,2.3rem);line-height:1.05;color:var(--ink)}.panel-actions{display:inline-flex;gap:8px;flex-wrap:wrap;margin-bottom:14px}.mode-tab{border:1px solid rgba(23,31,56,.12);border-radius:999px;padding:10px 14px;background:#ffffffdb;color:var(--muted);cursor:pointer;transition:transform .18s ease,border-color .18s ease,background-color .18s ease,color .18s ease}.mode-tab:hover{transform:translateY(-1px)}.mode-tab--active{border-color:#0f172a1f;background:linear-gradient(135deg,#0f172a,#334155);color:#fff}.panel-header p{margin-top:10px;max-width:56ch;color:var(--muted);line-height:1.65}.role-grid{display:grid;gap:14px}.role-card{text-align:left;width:100%;border:1px solid rgba(23,31,56,.1);border-radius:22px;background:linear-gradient(180deg,#fffffffa,#f9fafde6);padding:18px;color:inherit;cursor:pointer;transition:transform .18s ease,border-color .18s ease,box-shadow .18s ease}.role-card:hover{transform:translateY(-2px);box-shadow:0 16px 36px #0f172a1a}.role-card--selected{border-color:var(--role-accent);box-shadow:0 0 0 4px color-mix(in srgb,var(--role-accent) 18%,transparent)}.role-card__badge{display:inline-flex;align-items:center;justify-content:center;padding:8px 12px;border-radius:999px;background:color-mix(in srgb,var(--role-accent) 14%,white);color:var(--role-accent);font-size:.8rem;font-weight:700}.role-card__content h3{margin:14px 0 8px;font-size:1.1rem;color:var(--ink)}.role-card__content p,.role-summary p{margin:0;color:var(--muted);line-height:1.6}.role-card__cta{display:inline-flex;margin-top:16px;color:var(--role-accent);font-weight:700}.form-grid,.login-form{display:grid;gap:16px}.field{display:grid;gap:8px}.field input{width:100%;box-sizing:border-box;border:1px solid rgba(23,31,56,.12);border-radius:16px;padding:15px 16px;background:#ffffffeb;color:var(--ink);font:inherit;transition:border-color .18s ease,box-shadow .18s ease}.field input::placeholder{color:#94a3b8}.field input:focus{outline:none;border-color:#4f46e5;box-shadow:0 0 0 4px #4f46e51f}.role-summary{padding:18px;border-radius:20px;border:1px solid rgba(23,31,56,.1);background:#f4f7ffe6}.role-summary--notice{background:#fffaf0eb;border-color:#f59e0b33}.form-error{margin:0;padding:12px 14px;border-radius:14px;border:1px solid rgba(220,38,38,.25);background:#fef2f2eb;color:#b91c1c;font-weight:600}.primary-button{border:none;border-radius:16px;padding:15px 18px;background:linear-gradient(135deg,#0f172a,#334155);color:#fff;font:inherit;font-weight:700;cursor:pointer;transition:transform .18s ease,box-shadow .18s ease;box-shadow:0 16px 28px #0f172a2e}.secondary-button{border:1px solid rgba(23,31,56,.12);border-radius:16px;padding:14px 18px;background:#fffc;color:var(--ink);font:inherit;font-weight:600;cursor:pointer;transition:transform .18s ease,background-color .18s ease,border-color .18s ease}.secondary-button--link{text-decoration:none;text-align:center}.dashboard-shell{width:min(1080px,calc(100% - 32px));min-height:calc(100vh - 32px);margin:16px auto;display:flex;align-items:center;position:relative;z-index:1}.dashboard-panel{width:100%;border:1px solid var(--panel-border);border-radius:28px;padding:30px;background:linear-gradient(180deg,#fffffff5,#f8fafce6),var(--surface);box-shadow:var(--shadow-lg)}.dashboard-header{display:flex;justify-content:space-between;gap:16px;align-items:flex-start;margin-bottom:22px}.dashboard-eyebrow{display:block;margin-bottom:8px;font-size:.8rem;text-transform:uppercase;letter-spacing:.13em;color:var(--muted-strong)}.dashboard-header h1,.data-card h2{margin:0;color:var(--ink)}.dashboard-header p{margin:10px 0 0;max-width:62ch;color:var(--muted)}.dashboard-identity{display:inline-flex;align-items:center;gap:10px;margin-bottom:16px;padding:10px 14px;border-radius:16px;background:#f8fafce6;border:1px solid rgba(148,163,184,.2);color:var(--muted)}.dashboard-identity span{font-size:.8rem;text-transform:uppercase;letter-spacing:.12em}.dashboard-identity strong{color:var(--ink)}.dashboard-content{display:grid;gap:18px}.data-card{border:1px solid rgba(23,31,56,.1);border-radius:22px;padding:18px;background:#ffffffeb}.card-title-row{display:flex;justify-content:space-between;gap:12px;flex-wrap:wrap;align-items:center;margin-bottom:14px}.status-chip{border-radius:999px;padding:7px 10px;background:#0ea5e91f;color:#0369a1;font-size:.82rem;font-weight:700}.detail-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:10px 14px}.detail-grid p{margin:0}.primary-button--small{display:inline-flex;align-items:center;justify-content:center;text-decoration:none;padding:10px 14px;border-radius:12px;box-shadow:none;font-size:.94rem}.table-wrap{overflow-x:auto}table{width:100%;border-collapse:collapse;min-width:560px}th,td{text-align:left;padding:10px 8px;border-bottom:1px solid rgba(148,163,184,.26);font-size:.95rem}th{color:var(--ink)}.appointment-form{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px}.appointment-form .field--wide,.appointment-form .primary-button{grid-column:1 / -1}.secondary-button:hover{transform:translateY(-1px);border-color:#0f172a2e;background:#fffffff5}.primary-button:hover{transform:translateY(-1px);box-shadow:0 18px 32px #0f172a38}.primary-button:disabled{opacity:.75;cursor:not-allowed;transform:none;box-shadow:0 10px 18px #0f172a1f}.primary-button:focus-visible,.secondary-button:focus-visible,.mode-tab:focus-visible,.role-card:focus-visible{outline:3px solid rgba(79,70,229,.35);outline-offset:3px}@media(max-width:1024px){.login-shell{min-height:auto}.login-panel{padding:28px}.form-grid{gap:12px}}@media(max-width:640px){.login-shell,.dashboard-shell{width:min(100%,calc(100% - 20px));margin:10px auto}.dashboard-panel{padding:22px}.dashboard-header{flex-direction:column}}
