:root{--bg: #f6f7fb;--text: #111827;--muted: #6b7280;--card: #ffffff;--border: #e5e7eb;--primary: #4f46e5;--primary-strong: #4338ca;--success: #16a34a;--success-strong: #15803d;--danger: #dc2626}*{box-sizing:border-box}body,html,#root{height:100%;margin:0;color:var(--text);background:var(--bg);font-family:ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Arial,"Apple Color Emoji","Segoe UI Emoji"}.page{min-height:100%;padding:32px 16px 80px;display:flex;flex-direction:column;align-items:center}.card{width:100%;max-width:820px;background:var(--card);border:1px solid var(--border);border-radius:16px;padding:24px;box-shadow:0 6px 24px #0000000f}h1{margin:0 0 8px;font-size:24px}.subtle{color:var(--muted);margin:0 0 16px}.actions{display:flex;gap:8px;margin-bottom:8px}.form{display:grid;gap:12px}label{display:grid;gap:6px}label span{font-weight:600;font-size:14px}input[type=text],input:not([type]),input[type=email],textarea{width:100%;border:1px solid var(--border);border-radius:8px;padding:10px 12px;font-size:14px;outline:none}input:focus,textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px #4f46e51f}.btn{border:none;border-radius:10px;padding:10px 14px;font-weight:600;cursor:pointer}.btn.primary{background:var(--primary);color:#fff}.btn.primary:hover{background:var(--primary-strong)}.btn.success{background:var(--success);color:#fff}.btn.success:hover{background:var(--success-strong)}.btn:disabled{opacity:.6;cursor:not-allowed}.error{color:var(--danger);font-weight:600}.result{margin-top:16px;background:#f9fafb;border:1px solid var(--border);border-radius:12px;padding:16px}.scoreRow{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}.scoreLabel{font-weight:700}.scoreValue{font-size:20px;font-weight:800}.bar{width:100%;height:12px;background:#e5e7eb;border-radius:999px;overflow:hidden;margin-bottom:12px}.barFill{height:100%;background:linear-gradient(90deg,#22c55e,#84cc16);width:0%}.label{font-weight:700;margin-top:12px;margin-bottom:6px}.list{margin:0;padding-left:18px}.gap{color:#b91c1c}.summary{margin:6px 0 0;line-height:1.5}.saved{font-size:12px;color:var(--muted);margin-top:10px}.footer{margin-top:16px;color:var(--muted);font-size:12px}button{cursor:pointer}.btn-primary{display:inline-block;background:#0b5fff;color:#fff;padding:10px 14px;border-radius:8px;text-decoration:none;font-weight:600;transition:background .2s ease,transform .15s ease}.btn-primary:hover{background:#0846c7;transform:translateY(-1px)}.btn-ghost{display:inline-block;border:1px solid #cbd5e1;color:#0f172a;padding:10px 14px;border-radius:8px;text-decoration:none;font-weight:600;background:#fff;transition:background .2s ease,transform .15s ease}.btn-ghost:hover{background:#f1f5f9;transform:translateY(-1px)}.btn-small{padding:8px 12px;font-size:14px}.cardButtonsContainer{display:flex;gap:7px}form{display:flex;flex-direction:column;gap:0px}.btn-primary{background:#0b5fff;color:#fff;padding:10px 14px;border-radius:8px;border:none;cursor:pointer;font-weight:600;transition:background .2s ease,transform .15s ease}.btn-primary:hover{background:#084bcc;transform:translateY(-1px)}.btn-ghost{border:1px solid #cbd5e1;background:#fff;color:#0f172a;border-radius:8px;font-weight:600;cursor:pointer;padding:8px 12px;transition:background .2s ease,transform .15s ease}.btn-ghost:hover{background:#f8fafc;transform:translateY(-1px)}.app-shell{min-height:100dvh;display:grid;grid-template-rows:auto 1fr auto}.site-header{position:sticky;top:0;z-index:10;background:#fffc;-webkit-backdrop-filter:saturate(180%) blur(6px);backdrop-filter:saturate(180%) blur(6px);border-bottom:1px solid #e5e7eb}.site-header .shell{max-width:1100px;margin:0 auto;padding:10px 16px;display:flex;align-items:center;justify-content:space-between;font-family:Inter,system-ui,sans-serif}.brand{font-weight:800;color:#0f172a;text-decoration:none;letter-spacing:.2px}.nav a{margin-left:16px;text-decoration:none;color:#334155;font-weight:600;padding:6px 10px;border-radius:8px;transition:background .2s ease,color .2s ease}.nav a:hover{background:#f1f5f9}.nav a.active{color:#0b5fff;background:#eef2ff}.site-content{min-height:0}.site-footer{border-top:1px solid #e5e7eb;background:#fff}.site-footer .shell{max-width:1100px;margin:0 auto;padding:14px 16px;display:flex;align-items:center;justify-content:space-between;font-family:Inter,system-ui,sans-serif;color:#475569;font-size:14px}.footer-links{display:flex;gap:14px}.footer-links a{color:#475569;text-decoration:none}.footer-links a:hover{text-decoration:underline}.role-card{display:flex;flex-direction:column;height:100%}.cardButtonsContainer{display:flex;gap:8px;margin-top:auto}
