/* skills — humera Design rev01
   Tokens und Komponenten direkt aus dem Designboard (design/rev01).
   Regeln: „humera" klein · keine Versalien · Clash nur H1 · IBM Plex sonst ·
   Mitteltöne nur dekorativ · Status immer Farbe + Symbol + Text. */

:root {
  /* Flächen */
  --bg: #fbf8f3;          /* App-Hintergrund, warmes Off-White */
  --surface: #ffffff;     /* Karten/Flächen */
  --cream: #f2e6d8;       /* ruhiger Rahmen / Login-Bühne */
  --cream-soft: #f7f2eb;  /* sanfte Panels, Segment-Hintergrund */
  --field-readonly: #f7f4ee;

  /* Text */
  --ink: #384544;         /* Woodland */
  --ink-2: #48514f;
  --muted: #5c6766;
  --muted-2: #8b8170;
  --faint: #9b8f7e;

  /* Linien */
  --line: rgba(56, 69, 68, 0.10);
  --line-2: rgba(56, 69, 68, 0.14);
  --line-3: rgba(56, 69, 68, 0.20);
  --line-4: rgba(56, 69, 68, 0.28);

  /* Akzent */
  --accent: #db744b;      /* Portugal */
  --accent-ink: #b04a23;
  --accent-soft: rgba(219, 116, 75, 0.14);
  --accent-ring: 0 0 0 3px rgba(219, 116, 75, 0.14);
  --accent-tint: #fbefe8;

  /* Status */
  --sub-bg: #e7efea; --sub-bd: #cadad1; --sub-ink: #3f655d; --viridian: #5a867f;
  --draft-bg: #f8eedd; --draft-bd: #e7d4b4; --draft-ink: #8a5a26; --copper: #e6953f;
  --none-bg: #f1efea; --none-bd: #dcd7cc; --none-ring: #9aa39b;
  --stale-bg: #fbe7dd; --stale-bd: #f1c7b4; --stale-ink: #b04a23;
  --progress-empty: #e4ddd1;

  /* Admin (dunkel) */
  --adm-bg: #2e3938; --adm-side: #283230; --adm-card: #39443f; --adm-card-2: #323d3a;
  --adm-text: #e8edeb; --adm-cream: #f2e6d8; --adm-muted: #9fa9a6; --adm-line: rgba(255,255,255,0.06);

  /* Typo */
  --head: "Clash Display", "IBM Plex Sans", system-ui, sans-serif;
  --body: "IBM Plex Sans", system-ui, -apple-system, sans-serif;
  --mono: "IBM Plex Mono", ui-monospace, monospace;

  --r-card: 14px;
  --r-btn: 11px;
  --r-field: 10px;
  --maxw: 760px;
  --shadow-card: 0 2px 10px rgba(56, 69, 68, 0.05);
  --shadow-pop: 0 12px 40px rgba(56, 69, 68, 0.10);
}

* { box-sizing: border-box; text-transform: none !important; }

html, body { margin: 0; }
body {
  background: var(--bg);
  color: var(--ink);
  font-family: var(--body);
  font-weight: 400;
  font-size: 16px;
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
}

h1 { font-family: var(--head); font-weight: 500; font-size: 30px; line-height: 1.1; letter-spacing: -0.01em; color: var(--ink); margin: 0 0 8px; }
h2 { font-family: var(--body); font-weight: 600; font-size: 20px; line-height: 1.25; color: var(--ink); margin: 0 0 8px; }
h3 { font-family: var(--body); font-weight: 600; font-size: 15px; margin: 0 0 8px; }
p { margin: 0 0 14px; }
a { color: var(--accent); text-decoration: none; }
a:hover { text-decoration: underline; text-underline-offset: 3px; }
.muted { color: var(--muted); }
.faint { color: var(--faint); }
.lead { font-size: 16px; line-height: 1.6; color: var(--muted); }
.mono { font-family: var(--mono); }

/* ===== Shell / Topbar ===== */
.topbar {
  display: flex; align-items: center; justify-content: space-between;
  height: 62px; padding: 0 28px;
  background: var(--surface); border-bottom: 1px solid var(--line);
}
.topbar-brand { display: flex; align-items: center; gap: 10px; }
.topbar-brand img { height: 20px; width: auto; display: block; }
.topbar-brand .slash { font: 400 13px var(--mono); color: #b3a896; }
.topbar-right { display: flex; align-items: center; gap: 16px; }
.avatar {
  width: 30px; height: 30px; border-radius: 50%;
  background: #8cab9b; color: #fff;
  display: flex; align-items: center; justify-content: center;
  font: 500 13px var(--body); flex: none;
}
.user { display: flex; align-items: center; gap: 9px; }
.user-name { font: 500 14px var(--body); color: var(--ink); }

.wrap { max-width: var(--maxw); margin: 0 auto; padding: 48px 24px 72px; }
.wrap.narrow { max-width: 560px; }
.wrap.wide { max-width: 760px; }

/* ===== Language switch (segmented) ===== */
.langswitch { display: inline-flex; background: #f2ede5; border-radius: 8px; padding: 3px; gap: 0; }
.langswitch a, .langswitch span {
  font: 500 13px var(--body); color: var(--muted);
  padding: 6px 13px; border-radius: 6px; text-decoration: none; line-height: 1;
}
.langswitch a:hover { text-decoration: none; color: var(--ink); }
.langswitch .active, .langswitch a.active { background: var(--ink); color: #fff; }

/* ===== Buttons ===== */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 9px;
  font: 500 15px var(--body); border-radius: var(--r-btn);
  padding: 13px 24px; min-height: 44px; cursor: pointer; border: none;
  background: var(--accent); color: #fff; transition: background .15s ease;
}
.btn:hover { background: #c6633d; text-decoration: none; }
.btn.accent { background: var(--accent); color: #fff; }
.btn.secondary { background: var(--surface); color: var(--ink); border: 1.5px solid var(--line-4); }
.btn.secondary:hover { background: #faf7f1; border-color: var(--ink); }
.btn.tertiary { background: transparent; color: var(--accent); padding: 8px 4px; min-height: 0; }
.btn.tertiary:hover { background: transparent; text-decoration: underline; text-underline-offset: 3px; }
.btn.block { width: 100%; }
.btn:disabled, .btn.is-disabled { background: #f2ede5; color: var(--faint); cursor: not-allowed; }
.btn.ghost-link { background: transparent; color: var(--muted); padding: 8px 4px; min-height: 0; font-weight: 500; }
.btn.ghost-link:hover { background: transparent; color: var(--ink); }

/* ===== Cards / notice ===== */
.card {
  background: var(--surface); border: 1px solid var(--line);
  border-radius: var(--r-card); padding: 24px 26px; box-shadow: var(--shadow-card);
}
.card + .card { margin-top: 16px; }
.notice {
  display: flex; gap: 9px; align-items: flex-start;
  padding: 14px 16px; border-radius: var(--r-field);
  background: var(--cream-soft); border: 1px solid var(--line);
}
.notice .ico { flex: none; color: #8cab9b; font-size: 15px; line-height: 1.4; }
.notice p { margin: 0; font: 400 13px/1.55 var(--body); color: var(--muted-2); }

/* ===== Status badges ===== */
.badge {
  display: inline-flex; align-items: center; gap: 7px;
  font: 500 12.5px var(--body); border-radius: 999px;
  padding: 5px 12px 5px 10px; line-height: 1; white-space: nowrap;
}
.badge .dot { width: 8px; height: 8px; flex: none; }
.badge.submitted { background: var(--sub-bg); border: 1px solid var(--sub-bd); color: var(--sub-ink); }
.badge.submitted .dot { border-radius: 50%; background: var(--viridian); }
.badge.draft, .badge.started { background: var(--draft-bg); border: 1px solid var(--draft-bd); color: var(--draft-ink); }
.badge.draft .dot, .badge.started .dot { border-radius: 2px; background: var(--copper); }
.badge.none { background: var(--none-bg); border: 1px solid var(--none-bd); color: var(--muted); }
.badge.none .dot { border-radius: 50%; border: 1.5px solid var(--none-ring); background: transparent; box-sizing: border-box; }
.badge.stale { background: var(--stale-bg); border: 1px solid var(--stale-bd); color: var(--stale-ink); }
.badge.stale .dot { width: auto; height: auto; }

/* ===== Form fields ===== */
label.field-label { display: block; font: 500 13px var(--body); color: var(--muted); margin-bottom: 7px; }
input[type="text"], input[type="email"], select, textarea {
  width: 100%; font: 400 15px var(--body); color: var(--ink);
  background: var(--surface); border: 1.5px solid var(--line-3);
  border-radius: var(--r-field); padding: 12px 15px;
}
textarea { line-height: 1.5; resize: vertical; min-height: 84px; }
input:focus, select:focus, textarea:focus {
  outline: none; border-color: var(--accent); box-shadow: var(--accent-ring);
}
.field-readonly {
  display: flex; align-items: center; justify-content: space-between;
  font: 400 15px var(--body); color: var(--ink);
  background: var(--field-readonly); border: 1px solid var(--line);
  border-radius: var(--r-field); padding: 13px 15px;
}
.field-readonly .src { font: 400 12px var(--body); color: var(--faint); }

/* ===== Progress (segmented) ===== */
.progress { display: flex; align-items: center; gap: 14px; }
.progress .count { font: 500 13px var(--body); color: var(--ink); flex: none; }
.progress .est { font: 400 13px var(--body); color: var(--faint); flex: none; }
.segments { flex: 1; display: flex; gap: 5px; }
.segments .seg { flex: 1; height: 6px; border-radius: 3px; background: var(--progress-empty); }
.segments .seg.done { background: var(--viridian); }
.segments .seg.current { background: var(--accent); }

/* saved pill */
.saved-ind { display: inline-flex; align-items: center; gap: 8px; font: 400 13px var(--body); color: var(--muted); }
.saved-ind .tick { display: inline-flex; align-items: center; justify-content: center; width: 16px; height: 16px; border-radius: 50%; background: var(--viridian); color: #fff; font-size: 9px; }
.saved-ind.flash { animation: savedflash 2.2s ease; }
@keyframes savedflash { 0%,55% { opacity: 1; } 100% { opacity: .55; } }

/* ===== Campaign cards (overview) ===== */
.campaign-card { background: var(--surface); border: 1px solid var(--line-2); border-radius: 16px; padding: 28px 30px; box-shadow: var(--shadow-card); }
.campaign-head { display: flex; align-items: flex-start; justify-content: space-between; gap: 16px; margin-bottom: 18px; }
.campaign-title { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; margin-bottom: 6px; }
.campaign-title h2 { margin: 0; }
.campaign-sub { font: 400 14px var(--body); color: var(--muted-2); margin: 0; }
.campaign-card.compact { padding: 22px 30px; display: flex; align-items: center; justify-content: space-between; gap: 16px; border-radius: 16px; }

/* ===== Survey core ===== */
.survey-layout { display: flex; flex-direction: column; min-height: 100vh; }
.survey-shell { flex: 1; display: flex; min-height: 0; }
.survey-progress-bar { padding: 12px 28px 14px; background: var(--surface); border-bottom: 1px solid var(--line); }

#questions { display: flex; flex-direction: column; flex: 1; min-height: 0; }
.survey-body { display: flex; flex: 1; min-height: 0; }
.sec-nav { width: 268px; flex: none; border-right: 1px solid var(--line); padding: 26px 20px; background: var(--surface); }
.sec-nav-title { font: 600 12px var(--body); color: var(--faint); margin-bottom: 16px; }
.sec-nav-list { display: flex; flex-direction: column; gap: 3px; }
.sec-nav-item { display: flex; align-items: center; gap: 11px; padding: 10px 12px; border-radius: 9px; cursor: pointer; border: none; background: transparent; width: 100%; text-align: left; }
.sec-nav-item .marker { width: 18px; height: 18px; flex: none; border-radius: 50%; display: inline-flex; align-items: center; justify-content: center; font: 500 10px var(--body); }
.sec-nav-item .marker.done { background: var(--viridian); color: #fff; }
.sec-nav-item .marker.todo { border: 1.5px solid #cfc7b8; box-sizing: border-box; }
.sec-nav-item .label { font: 400 14px var(--body); color: var(--muted); }
.sec-nav-item.active { background: var(--accent-tint); }
.sec-nav-item.active .marker { background: var(--accent); color: #fff; }
.sec-nav-item.active .label { font-weight: 500; color: var(--ink); }
.sec-nav-item.done .label { color: var(--muted); }

.sec-panels { flex: 1; padding: 34px 48px; min-width: 0; }
.qsection { max-width: 640px; }
.qsection > .sec-title { font: 600 22px var(--body); color: var(--ink); margin: 0 0 4px; }
.qsection > .sec-intro { font: 400 15px/1.5 var(--body); color: var(--muted-2); margin: 0 0 30px; }

.question { margin-bottom: 30px; }
.question .q-text { font: 500 16px var(--body); color: var(--ink); margin-bottom: 8px; }
.question .q-help { font: 400 13px var(--body); color: var(--faint); margin-bottom: 14px; }

/* single-choice pills */
.pills { display: flex; flex-wrap: wrap; gap: 10px; }
.pill { position: relative; display: inline-flex; align-items: center; font: 400 14px var(--body); color: var(--muted); background: var(--surface); border: 1.5px solid var(--line-3); border-radius: var(--r-field); padding: 11px 18px; cursor: pointer; }
.pill input[type="radio"] { position: absolute; opacity: 0; pointer-events: none; }
.pill:has(input:checked), .pill.is-selected { color: var(--ink); font-weight: 500; border-color: var(--accent); box-shadow: var(--accent-ring); }

/* multi chips */
.chips { display: flex; flex-direction: column; gap: 10px; }
.chip { display: flex; align-items: center; gap: 12px; font: 400 15px var(--body); color: var(--ink); background: var(--surface); border: 1.5px solid var(--line-2); border-radius: 12px; padding: 14px 18px; cursor: pointer; }
.chip input[type="checkbox"] { position: absolute; opacity: 0; pointer-events: none; }
.chip .box { width: 21px; height: 21px; flex: none; border: 1.5px solid var(--line-4); border-radius: 6px; background: var(--surface); display: inline-flex; align-items: center; justify-content: center; color: #fff; font-size: 12px; }
.chip .box::after { content: "✓"; opacity: 0; }
.chip:has(input:checked), .chip.is-selected { border-color: var(--accent); }
.chip:has(input:checked) .box, .chip.is-selected .box { background: var(--accent); border-color: var(--accent); }
.chip:has(input:checked) .box::after, .chip.is-selected .box::after { opacity: 1; }
.chip-other { display: flex; align-items: center; gap: 10px; cursor: text; font: 500 13px var(--body); color: var(--muted); }
.chip-other input[type="text"] { flex: 1; max-width: 320px; padding: 8px 12px; font-size: 14px; border-width: 1.5px; }

/* hybrid skill cards */
.skills { display: flex; flex-direction: column; gap: 10px; }
.skill-card { background: var(--surface); border: 1.5px solid var(--line-2); border-radius: 12px; padding: 14px 18px; }
.skill-head { display: flex; align-items: center; gap: 12px; cursor: pointer; }
.skill-head input[type="checkbox"] { position: absolute; opacity: 0; pointer-events: none; }
.skill-box { width: 21px; height: 21px; flex: none; border: 1.5px solid var(--line-4); border-radius: 6px; background: var(--surface); display: inline-flex; align-items: center; justify-content: center; color: #fff; font-size: 12px; }
.skill-box::after { content: "✓"; opacity: 0; }
.skill-name { font: 400 15px var(--body); color: var(--ink); }
.skill-levels { display: none; gap: 7px; margin-top: 14px; }
.skill-card:has(.skill-head input:checked), .skill-card.is-selected { border-color: var(--accent); }
.skill-card:has(.skill-head input:checked) .skill-box, .skill-card.is-selected .skill-box { background: var(--accent); border-color: var(--accent); }
.skill-card:has(.skill-head input:checked) .skill-box::after, .skill-card.is-selected .skill-box::after { opacity: 1; }
.skill-card:has(.skill-head input:checked) .skill-name, .skill-card.is-selected .skill-name { font-weight: 500; }
.skill-card:has(.skill-head input:checked) .skill-levels, .skill-card.is-selected .skill-levels { display: flex; }
.lvl { flex: 1; text-align: center; font: 400 12.5px var(--body); color: var(--muted); background: var(--cream-soft); border: 1px solid var(--line); border-radius: 8px; padding: 9px 6px; cursor: pointer; position: relative; }
.lvl input[type="radio"] { position: absolute; opacity: 0; pointer-events: none; }
.lvl:has(input:checked), .lvl.is-selected { color: #fff; font-weight: 500; background: var(--accent); border-color: var(--accent); }

/* branch hint */
.branch-hint { display: flex; gap: 11px; align-items: flex-start; background: #f1f5f2; border: 1px solid #d8e4dc; border-left: 3px solid var(--viridian); border-radius: 10px; padding: 14px 16px; margin-top: 22px; }
.branch-hint .plus { color: var(--viridian); flex: none; font-size: 14px; margin-top: 1px; }
.branch-hint p { margin: 0; font: 400 13.5px/1.5 var(--body); color: #46615a; }

/* survey footer */
.survey-footer { height: 78px; border-top: 1px solid var(--line); background: var(--surface); display: flex; align-items: center; justify-content: space-between; padding: 0 48px; gap: 16px; }
.survey-footer .note { font: 400 13px var(--body); color: var(--faint); }

/* ===== Self view ===== */
.self-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.self-card { background: var(--surface); border: 1px solid var(--line); border-radius: var(--r-card); padding: 22px 24px; }
.self-card h3 { font: 600 14px var(--body); color: var(--ink); margin-bottom: 14px; }
.self-row { display: flex; align-items: center; justify-content: space-between; gap: 10px; padding: 4px 0; }
.self-row .name { font: 400 14px var(--body); color: var(--ink-2); }
.lvl-tag { font: 500 12px var(--body); border-radius: 6px; padding: 3px 9px; white-space: nowrap; }
.lvl-tag.l3 { color: var(--sub-ink); background: var(--sub-bg); }
.lvl-tag.l2 { color: var(--muted); background: var(--none-bg); }
.lvl-tag.l1 { color: var(--muted-2); background: #f5f2ec; }
.tagrow { display: flex; flex-wrap: wrap; gap: 8px; }
.tag { font: 400 13px var(--body); color: var(--ink-2); background: #f5f2ec; border: 1px solid rgba(56,69,68,0.08); border-radius: 999px; padding: 6px 13px; }

/* ===== Tables (admin light fallback / generic) ===== */
table.grid { width: 100%; border-collapse: collapse; background: var(--surface); border-radius: var(--r-card); overflow: hidden; }
table.grid th, table.grid td { text-align: left; padding: 11px 14px; border-bottom: 1px solid var(--line); font-size: 14px; }
table.grid th { font: 600 13px var(--body); color: var(--muted); background: rgba(56,69,68,0.04); }

/* page header row */
.page-head { display: flex; align-items: flex-start; justify-content: space-between; gap: 16px; margin-bottom: 26px; }

/* ===== Admin (dark, confidential) ===== */
.admin { min-height: 100vh; background: var(--adm-bg); color: var(--adm-text); display: flex; }
.admin a { color: #fcb194; }
.admin-side { width: 236px; flex: none; background: var(--adm-side); border-right: 1px solid var(--adm-line); padding: 24px 18px; display: flex; flex-direction: column; min-height: 100vh; }
.admin-side .brand { display: flex; align-items: center; gap: 10px; padding: 0 8px; margin-bottom: 26px; }
.admin-side .brand img { height: 20px; }
.confid { display: flex; align-items: center; gap: 8px; background: rgba(219,116,75,0.14); border: 1px solid rgba(219,116,75,0.32); border-radius: 8px; padding: 9px 11px; margin-bottom: 24px; font: 500 12px var(--body); color: #fcb194; }
.admin-nav { display: flex; flex-direction: column; gap: 3px; }
.admin-nav a { display: flex; align-items: center; gap: 11px; padding: 10px 11px; border-radius: 8px; color: #a9b3b0; font: 400 14px var(--body); }
.admin-nav a .d { width: 7px; height: 7px; border-radius: 2px; background: rgba(255,255,255,0.22); flex: none; }
.admin-nav a:hover { text-decoration: none; color: var(--adm-cream); }
.admin-nav a.active { background: rgba(255,255,255,0.07); color: var(--adm-cream); font-weight: 500; }
.admin-nav a.active .d { background: var(--accent); }
.admin-side .me { margin-top: auto; display: flex; align-items: center; gap: 9px; padding: 0 8px; }
.admin-side .me .nm { font: 500 13px var(--body); color: var(--adm-text); }
.admin-side .me .ro { font: 400 11px var(--body); color: #8a9794; }

.admin-main { flex: 1; padding: 30px 36px; min-width: 0; }
.admin-main h1 { color: var(--adm-cream); }
.admin-main h2 { color: var(--adm-cream); font-size: 15px; }
.admin-sub { font: 400 14px var(--body); color: var(--adm-muted); margin: 0; }
.admin-card { background: var(--adm-card); border: 1px solid var(--adm-line); border-radius: 13px; padding: 18px 20px; }
.stat-row { display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px; margin-bottom: 24px; }
.stat .lbl { font: 400 12.5px var(--body); color: var(--adm-muted); margin-bottom: 10px; display: flex; align-items: center; gap: 7px; }
.stat .num { font: 600 28px var(--body); color: var(--adm-cream); }
.stat .num small { font: 500 15px var(--body); color: var(--adm-muted); }
.stat .bar { height: 5px; border-radius: 3px; background: rgba(255,255,255,0.10); margin-top: 10px; overflow: hidden; }
.stat .bar > span { display: block; height: 100%; background: #8cab9b; }
.stat .d { width: 8px; height: 8px; flex: none; }
.stat .d.sub { border-radius: 50%; background: var(--viridian); }
.stat .d.dft { border-radius: 2px; background: var(--copper); }
.stat .d.non { border-radius: 50%; border: 1.5px solid #7d8a86; box-sizing: border-box; }

.admin-btn { font: 500 14px var(--body); color: var(--adm-text); background: rgba(255,255,255,0.06); border: 1px solid rgba(255,255,255,0.14); border-radius: 9px; padding: 10px 16px; cursor: pointer; display: inline-flex; align-items: center; gap: 8px; }
.admin-btn:hover { background: rgba(255,255,255,0.10); text-decoration: none; }
.admin-btn.accent { background: var(--accent); border: none; color: #fff; }
.admin-btn.accent:hover { background: #c6633d; }

table.admin-table { width: 100%; border-collapse: collapse; }
table.admin-table th, table.admin-table td { text-align: left; padding: 11px 14px; border-bottom: 1px solid var(--adm-line); font-size: 13.5px; color: var(--adm-text); }
table.admin-table th { font: 600 12px var(--body); color: var(--adm-muted); }

.flag { background: var(--adm-card-2); border: 1px solid var(--adm-line); border-left: 3px solid var(--copper); border-radius: 10px; padding: 13px 15px; }
.flag.crit { border-color: rgba(219,116,75,0.35); border-left-color: var(--accent); }
.flag-head { display: flex; align-items: center; justify-content: space-between; gap: 8px; margin-bottom: 4px; }
.flag-head .t { font: 600 13.5px var(--body); color: var(--adm-cream); }
.flag-tag { font: 500 11px var(--body); border-radius: 5px; padding: 3px 8px; color: #fff; background: var(--copper); }
.flag.crit .flag-tag { background: var(--accent); }
.flag p { margin: 0; font: 400 12.5px/1.45 var(--body); color: #b3bcb9; }

/* ===== Login stage ===== */
.login-stage { min-height: 100vh; background: var(--cream); position: relative; display: flex; align-items: center; justify-content: center; padding: 80px 20px; }
.login-top { position: absolute; top: 22px; left: 26px; right: 26px; display: flex; align-items: center; justify-content: space-between; }
.login-top img { height: 23px; width: auto; display: block; }
.login-top .langswitch { background: rgba(255, 255, 255, 0.7); }
.login-card { width: 100%; max-width: 480px; background: var(--surface); border-radius: 18px; box-shadow: var(--shadow-pop); padding: 48px 46px; }
.login-card .eyebrow { font: 400 13px var(--mono); color: var(--faint); margin-bottom: 18px; }
.login-card h1 { font-size: 34px; line-height: 1.1; margin-bottom: 14px; }
.login-card p.lead { margin-bottom: 30px; }
.ms-grid { display: inline-grid; grid-template-columns: 1fr 1fr; gap: 2px; width: 15px; height: 15px; }
.ms-grid span { background: #fff; }
.login-note { display: flex; gap: 9px; margin-top: 24px; padding-top: 22px; border-top: 1px solid var(--line); }
.login-note .ico { color: #8cab9b; flex: none; font-size: 15px; }
.login-note p { margin: 0; font: 400 13px/1.55 var(--body); color: var(--muted-2); }
.login-foot { position: absolute; bottom: 22px; left: 0; right: 0; text-align: center; font: 400 12px var(--body); color: var(--faint); }

/* ===== Profile form ===== */
.lang-choice { display: flex; gap: 10px; }
.lang-choice label { flex: 1; text-align: center; font: 400 14px var(--body); color: var(--muted); background: var(--surface); border: 1.5px solid var(--line-3); border-radius: var(--r-field); padding: 12px; cursor: pointer; position: relative; }
.lang-choice label input { position: absolute; opacity: 0; pointer-events: none; }
.lang-choice label:has(input:checked), .lang-choice label.is-selected { color: #fff; font-weight: 500; background: var(--ink); border-color: var(--ink); }
.stack { display: flex; flex-direction: column; gap: 22px; }
.row-end { display: flex; align-items: center; justify-content: space-between; gap: 16px; margin-top: 26px; }

/* ===== Confirmation / generic centered ===== */
.confirm-card { width: 100%; max-width: 360px; background: var(--surface); border-radius: 18px; box-shadow: var(--shadow-pop); padding: 40px 34px; text-align: center; margin: 0 auto; }
.confirm-ico { width: 58px; height: 58px; border-radius: 50%; background: var(--sub-bg); border: 1px solid var(--sub-bd); display: flex; align-items: center; justify-content: center; margin: 0 auto 22px; color: var(--viridian); font-size: 26px; }

/* ===== Responsive ===== */
@media (max-width: 820px) {
  #questions { flex-direction: column; }
  .sec-nav { width: auto; border-right: none; border-bottom: 1px solid var(--line); }
  .sec-nav-list { flex-direction: row; flex-wrap: wrap; }
  .sec-panels { padding: 24px 20px; }
  .skill-head { flex-wrap: wrap; }
  .skill-levels { flex-direction: column; }
  .lvl { text-align: left; }
  .self-grid, .stat-row { grid-template-columns: 1fr; }
  .admin { flex-direction: column; }
  .admin-side { width: auto; min-height: 0; flex-direction: row; flex-wrap: wrap; align-items: center; }
  .admin-side .me { margin-top: 0; }
  .survey-footer, .sec-panels { padding-left: 20px; padding-right: 20px; }
}
