:root {
  color-scheme: dark;
  --bg: #061322;
  --surface: #0b1a2b;
  --surface-2: #10243a;
  --line: #25384e;
  --text: #f4f7fb;
  --muted: #9aa9bd;
  --blue: #3f8cff;
  --blue-2: #2877e8;
  --success: #49a2ff;
  font-family: Inter, system-ui, sans-serif;
}

* { box-sizing: border-box; }

body {
  margin: 0;
  min-width: 320px;
  min-height: 100vh;
  color: var(--text);
  background:
    radial-gradient(circle at 80% -10%, rgba(55, 132, 230, .12), transparent 35%),
    var(--bg);
}

button, select { font: inherit; }
button { color: inherit; }

.app-shell {
  width: min(100%, 520px);
  margin: 0 auto;
  padding: max(28px, env(safe-area-inset-top)) 16px 112px;
}

.hero {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 24px;
}

h1, h2, p { margin: 0; }
h1 { font-size: clamp(24px, 6.4vw, 30px); line-height: 1.08; letter-spacing: -.04em; white-space: nowrap; }
.hero p { max-width: 250px; margin-top: 10px; color: var(--muted); font-size: 14px; line-height: 1.5; }
h2 { font-size: 20px; letter-spacing: -.025em; }

.language-control {
  display: flex;
  align-items: center;
  min-height: 48px;
  padding: 0 10px;
  border: 1px solid var(--line);
  border-radius: 14px;
  background: rgba(13, 30, 49, .85);
}

.language-control select {
  max-width: 96px;
  border: 0;
  outline: 0;
  color: var(--text);
  background: transparent;
  appearance: none;
}

.language-control .material-symbols-rounded { font-size: 21px; }

.plan-panel, .topic-list {
  border: 1px solid var(--line);
  border-radius: 20px;
  background: rgba(11, 26, 43, .82);
}

.plan-panel { padding: 20px 16px 16px; }
.progress-copy { margin-top: 20px; color: var(--blue); font-size: 16px; }
.progress-track { height: 6px; margin: 12px 0 14px; overflow: hidden; border-radius: 8px; background: #1b2c40; }
.progress-track span { display: block; width: 40%; height: 100%; border-radius: inherit; background: linear-gradient(90deg, var(--blue), #5aa1ff); transition: width .3s ease; }

.steps { position: relative; }
.steps::before {
  content: "";
  position: absolute;
  top: 28px;
  bottom: 28px;
  left: 22px;
  width: 2px;
  background: #52657d;
}

.step-row {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: 46px 1fr 28px;
  align-items: center;
  min-height: 64px;
  width: 100%;
  padding: 0;
  border: 0;
  text-align: left;
  background: transparent;
  cursor: pointer;
}

.step-number {
  display: grid;
  place-items: center;
  width: 46px;
  height: 46px;
  border: 2px solid #52657d;
  border-radius: 50%;
  color: #c8d2df;
  background: var(--surface);
}

.step-row.current .step-number { border-color: #5ba0ff; background: var(--blue-2); color: white; box-shadow: 0 0 0 5px rgba(63, 140, 255, .12); }
.step-row.done .step-number { color: var(--blue); }
.step-label { padding: 0 12px; color: var(--muted); font-size: 14px; line-height: 1.35; }
.step-row.current .step-label { color: var(--text); font-weight: 600; }
.step-icon { color: var(--muted); font-size: 24px; }
.step-row.done .step-icon { color: var(--blue); }

.primary-button {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  width: 100%;
  min-height: 52px;
  margin-top: 12px;
  border: 0;
  border-radius: 14px;
  background: linear-gradient(135deg, var(--blue), #2f7ce8);
  font-size: 15px;
  font-weight: 600;
  cursor: pointer;
}

.topics { margin-top: 24px; }
.topics h2 { margin: 0 0 14px 4px; }
.topic-list { padding: 2px 16px; }
.topic-row {
  display: grid;
  grid-template-columns: 46px 1fr 24px;
  align-items: center;
  min-height: 72px;
  border-bottom: 1px solid var(--line);
  cursor: pointer;
}
.topic-row:last-child { border-bottom: 0; }
.topic-icon { display: grid; place-items: center; width: 42px; height: 42px; border-radius: 12px; color: var(--blue); background: rgba(63, 140, 255, .12); }
.topic-copy { padding: 0 10px; }
.topic-copy strong { display: block; font-size: 14px; }
.topic-copy span { display: block; margin-top: 4px; color: var(--muted); font-size: 12px; line-height: 1.3; }
.topic-row > .material-symbols-rounded { color: var(--muted); }

.bottom-nav {
  position: fixed;
  z-index: 10;
  right: 0;
  bottom: 0;
  left: 0;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  padding: 8px max(8px, env(safe-area-inset-right)) max(10px, env(safe-area-inset-bottom)) max(8px, env(safe-area-inset-left));
  border-top: 1px solid var(--line);
  background: rgba(7, 21, 37, .96);
  backdrop-filter: blur(18px);
}

.nav-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  min-height: 60px;
  border: 0;
  background: transparent;
  color: var(--muted);
  font-size: 11px;
}
.nav-item .material-symbols-rounded { font-size: 27px; }
.nav-item.active { color: var(--blue); }

dialog {
  width: min(calc(100% - 20px), 500px);
  margin: auto auto 0;
  padding: 18px 20px max(26px, env(safe-area-inset-bottom));
  border: 1px solid var(--line);
  border-radius: 22px 22px 0 0;
  color: var(--text);
  background: var(--surface);
}
dialog::backdrop { background: rgba(0, 8, 18, .68); backdrop-filter: blur(4px); }
.sheet-handle { width: 42px; height: 4px; margin: 0 auto 22px; border-radius: 4px; background: #52657d; }
.close-button { position: absolute; top: 12px; right: 12px; border: 0; background: transparent; }
#sheet-content h2 { padding-right: 30px; }
#sheet-content p { margin-top: 12px; color: var(--muted); line-height: 1.6; }
.sheet-action { width: 100%; margin-top: 22px; padding: 14px; border: 1px solid var(--line); border-radius: 12px; background: var(--surface-2); }
.guide-kicker { color: var(--blue) !important; font-size: 12px; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; }
.guide-intro { font-size: 15px; }
.guide section { margin-top: 24px; }
.guide h3 { margin: 0 0 12px; font-size: 15px; }
.guide ol { margin: 0; padding-left: 22px; color: #dce5f1; }
.guide ol li { padding: 5px 0 5px 4px; line-height: 1.5; }
.check-list { display: grid; gap: 9px; margin: 0; padding: 0; list-style: none; color: #dce5f1; }
.check-list li { display: flex; align-items: flex-start; gap: 9px; line-height: 1.45; }
.check-list .material-symbols-rounded { color: var(--blue); font-size: 20px; }
.guide aside { margin-top: 24px; padding: 14px; border-left: 3px solid var(--blue); border-radius: 0 12px 12px 0; background: rgba(63, 140, 255, .09); }
.guide aside p { margin-top: 6px !important; font-size: 13px; }
.guide-actions { margin-top: 24px; }
.guide-actions .primary-button { margin-bottom: 10px; }
.guide-actions .sheet-action { display: flex; align-items: center; justify-content: center; gap: 8px; margin-top: 9px; color: var(--text); cursor: pointer; }
.link-button { text-decoration: none; }
.profile-form { display: grid; gap: 18px; margin-top: 22px; }
.profile-form label { display: grid; gap: 8px; color: var(--muted); font-size: 13px; }
.profile-form input, .profile-form select { width: 100%; min-height: 48px; padding: 0 12px; border: 1px solid var(--line); border-radius: 12px; outline: none; color: var(--text); background: var(--surface-2); }
.saved-list { margin-top: 18px; }
.saved-row { display: flex; align-items: center; justify-content: space-between; width: 100%; min-height: 54px; padding: 0; border: 0; border-bottom: 1px solid var(--line); text-align: left; background: transparent; cursor: pointer; }

#toast {
  position: fixed;
  z-index: 20;
  right: 18px;
  bottom: 92px;
  left: 18px;
  max-width: 460px;
  margin: auto;
  padding: 12px 16px;
  border-radius: 12px;
  background: #e7f1ff;
  color: #0a2b54;
  opacity: 0;
  transform: translateY(10px);
  pointer-events: none;
  transition: .2s ease;
}
#toast.show { opacity: 1; transform: translateY(0); }

@media (min-width: 700px) {
  .app-shell { padding-top: 42px; }
  .bottom-nav { width: 520px; right: auto; left: 50%; transform: translateX(-50%); border-right: 1px solid var(--line); border-left: 1px solid var(--line); border-radius: 18px 18px 0 0; }
}

/* Integration assistant v2 */
input, textarea { font: inherit; }
.hidden { display: none !important; }
.page-heading { display: grid; grid-template-columns: auto minmax(0, 1fr); align-items: center; min-width: 0; }
.page-heading p { grid-column: 1 / -1; }
.page-heading h1 { white-space: normal; overflow-wrap: anywhere; }
.page-heading .icon-button:not(.hidden) + h1 { padding-left: 8px; }
.icon-button {
  display: grid;
  place-items: center;
  width: 38px;
  height: 38px;
  padding: 0;
  border: 0;
  border-radius: 10px;
  color: var(--muted);
  background: transparent;
  cursor: pointer;
}

.eyebrow {
  color: #8abaff !important;
  font-size: 12px !important;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.welcome-card {
  display: grid;
  grid-template-columns: 1fr 112px;
  align-items: center;
  gap: 14px;
  padding: 22px;
  border: 1px solid #294361;
  border-radius: 22px;
  background: linear-gradient(145deg, rgba(22, 51, 82, .96), rgba(10, 28, 47, .96));
  box-shadow: 0 18px 48px rgba(0, 7, 18, .22);
}
.welcome-card h2 { margin-top: 7px; font-size: 22px; line-height: 1.2; }
.personal-profile-line { display: block; margin-top: 8px; color: var(--muted); font-weight: 700; }
.status-pill {
  display: inline-flex;
  margin-top: 14px;
  padding: 7px 10px;
  border: 1px solid rgba(95, 159, 255, .3);
  border-radius: 999px;
  color: #b9d4ff;
  background: rgba(48, 122, 232, .13);
  font-size: 12px;
}
.progress-ring {
  display: grid;
  place-content: center;
  width: 104px;
  height: 104px;
  border-radius: 50%;
  text-align: center;
  background:
    radial-gradient(circle closest-side, #10263d 78%, transparent 80% 99%),
    conic-gradient(var(--blue) var(--progress), #2b3e54 0);
}
.progress-ring strong { font-size: 21px; }
.progress-ring span { margin-top: 2px; color: var(--muted); font-size: 10px; }

.onboarding-screen {
  min-height: calc(100vh - 180px);
  display: grid;
  align-items: center;
  padding: 6px 0 30px;
}
.onboarding-card {
  display: grid;
  gap: 16px;
  padding: 18px;
  border: 1px solid var(--line);
  border-radius: 28px;
  background: linear-gradient(180deg, rgba(25, 45, 70, .96), rgba(8, 19, 34, .98));
  box-shadow: 0 20px 60px rgba(0, 0, 0, .28);
}
.onboarding-progress-head {
  display: flex;
  justify-content: space-between;
  color: var(--muted);
  font-weight: 800;
  font-size: 13px;
}
.onboarding-progress {
  height: 8px;
  overflow: hidden;
  border-radius: 999px;
  background: rgba(255, 255, 255, .08);
}
.onboarding-progress span {
  display: block;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, #5b8cff, #74d6b0);
  transition: width .25s ease;
}
.onboarding-copy h2 {
  margin: 6px 0 8px;
  font-size: clamp(26px, 8vw, 34px);
  line-height: 1.05;
}
.onboarding-copy p:not(.eyebrow) { margin: 0; color: var(--muted); font-weight: 700; line-height: 1.45; }
.onboarding-options,
.onboarding-levels { display: grid; gap: 10px; }
.onboarding-options.two,
.personal-action-grid,
.onboarding-summary { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.onboarding-levels { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.onboarding-option {
  min-height: 76px;
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: 10px;
  align-items: center;
  padding: 14px;
  border: 1px solid var(--line);
  border-radius: 18px;
  color: var(--text);
  background: rgba(19, 39, 61, .84);
  text-align: left;
}
.onboarding-option strong { display: block; line-height: 1.2; }
.onboarding-option small { display: block; margin-top: 4px; color: var(--muted); font-weight: 700; line-height: 1.25; }
.onboarding-option > .material-symbols-rounded:first-child {
  display: grid;
  place-items: center;
  width: 38px;
  height: 38px;
  border-radius: 14px;
  color: var(--blue);
  background: rgba(83, 139, 255, .16);
}
.onboarding-option .selected-icon { opacity: 0; color: #74d6b0; }
.onboarding-option.active {
  border-color: rgba(91, 140, 255, .9);
  background: rgba(42, 82, 132, .72);
  box-shadow: inset 0 0 0 1px rgba(91, 140, 255, .24);
}
.onboarding-option.active .selected-icon { opacity: 1; }
.onboarding-field {
  display: grid;
  gap: 8px;
  color: var(--muted);
  font-weight: 800;
}
.onboarding-field input {
  width: 100%;
  border: 1px solid var(--line);
  border-radius: 16px;
  padding: 14px;
  color: var(--text);
  background: rgba(7, 18, 31, .72);
  font: inherit;
}
.onboarding-actions {
  display: grid;
  grid-template-columns: 1fr 1fr 1.35fr;
  gap: 8px;
}
.onboarding-actions button { min-height: 48px; justify-content: center; }
.ghost-button {
  border: 1px solid transparent;
  border-radius: 15px;
  color: var(--muted);
  background: transparent;
  font-weight: 900;
}
.onboarding-final { display: grid; gap: 12px; text-align: center; }
.onboarding-final > .material-symbols-rounded {
  width: 64px;
  height: 64px;
  display: grid;
  place-items: center;
  justify-self: center;
  border-radius: 22px;
  color: #74d6b0;
  background: rgba(116, 214, 176, .14);
  font-size: 34px;
}
.onboarding-final h2 { margin: 0; font-size: 30px; line-height: 1.1; }
.onboarding-final p { margin: 0; color: var(--muted); font-weight: 700; }
.onboarding-summary { display: grid; gap: 8px; margin-top: 8px; text-align: left; }
.onboarding-summary span {
  padding: 12px;
  border: 1px solid var(--line);
  border-radius: 16px;
  background: rgba(7, 18, 31, .62);
}
.onboarding-summary small { display: block; color: var(--muted); font-weight: 800; }
.onboarding-summary strong { display: block; margin-top: 4px; }

.dashboard-personalized { display: grid; gap: 12px; }
.personal-action-grid { display: grid; gap: 10px; }
.personal-action-card {
  display: grid;
  gap: 8px;
  min-height: 118px;
  padding: 14px;
  border: 1px solid var(--line);
  border-radius: 18px;
  color: var(--text);
  background: rgba(18, 37, 58, .82);
  text-align: left;
}
.personal-action-card .material-symbols-rounded {
  width: 38px;
  height: 38px;
  display: grid;
  place-items: center;
  border-radius: 14px;
  color: var(--blue);
  background: rgba(83, 139, 255, .16);
}
.personal-action-card small { color: var(--blue-light); font-weight: 900; }
.personal-barmer-cta {
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: 12px;
  align-items: center;
  padding: 14px;
  border: 1px solid rgba(116, 214, 176, .45);
  border-radius: 20px;
  color: #ecfff7;
  background: linear-gradient(135deg, rgba(30, 113, 91, .72), rgba(35, 77, 130, .72));
  text-decoration: none;
}
.personal-barmer-cta .material-symbols-rounded:first-child {
  width: 42px;
  height: 42px;
  display: grid;
  place-items: center;
  border-radius: 16px;
  background: rgba(255, 255, 255, .12);
}
.personal-barmer-cta small { display: block; margin-top: 3px; color: rgba(236, 255, 247, .78); font-weight: 700; }

@media (max-width: 380px) {
  .onboarding-options.two,
  .onboarding-levels,
  .personal-action-grid,
  .onboarding-summary { grid-template-columns: 1fr; }
  .onboarding-actions { grid-template-columns: 1fr; }
}

.notice-card, .next-step-card, .status-card, .support-card {
  display: grid;
  grid-template-columns: 44px 1fr 24px;
  align-items: center;
  gap: 10px;
  width: 100%;
  margin-top: 14px;
  padding: 15px;
  border: 1px solid var(--line);
  border-radius: 16px;
  text-align: left;
  color: var(--text);
  background: var(--surface);
  cursor: pointer;
}
.notice-card > .material-symbols-rounded:first-child { color: #ffbc69; }
.notice-card small, .next-step-card small, .support-card small {
  display: block;
  margin-top: 4px;
  color: var(--muted);
  font-size: 11px;
}
.notice-card > .material-symbols-rounded:last-child,
.next-step-card > .material-symbols-rounded:last-child,
.support-card > .material-symbols-rounded:last-child { color: var(--muted); }

.section-block { margin-top: 26px; }
.section-heading {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin: 0 4px 12px;
}
.section-heading button {
  padding: 5px;
  border: 0;
  color: var(--blue);
  background: transparent;
  font-size: 12px;
  cursor: pointer;
}

.next-step-card { margin-top: 0; grid-template-columns: 48px 1fr 24px; padding: 17px; }
.next-step-card > .material-symbols-rounded:first-child,
.support-card > .material-symbols-rounded:first-child {
  display: grid;
  place-items: center;
  width: 44px;
  height: 44px;
  border-radius: 13px;
  color: var(--blue);
  background: rgba(63, 140, 255, .12);
}

.quick-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 9px;
}
.quick-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 9px;
  min-height: 92px;
  padding: 10px 6px;
  border: 1px solid var(--line);
  border-radius: 15px;
  color: var(--text);
  background: linear-gradient(145deg, rgba(16, 36, 58, .96), rgba(9, 26, 44, .96));
  cursor: pointer;
}
.quick-card .material-symbols-rounded { color: var(--blue); font-size: 27px; }
.quick-card strong { font-size: 10px; line-height: 1.25; text-align: center; }

.menu-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 10px;
}
.menu-card {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: space-between;
  gap: 14px;
  min-height: 112px;
  padding: 14px;
  border: 1px solid var(--line);
  border-radius: 16px;
  text-align: left;
  color: var(--text);
  background: rgba(11, 26, 43, .86);
  cursor: pointer;
}
.menu-card .material-symbols-rounded {
  display: grid;
  place-items: center;
  width: 38px;
  height: 38px;
  border-radius: 11px;
  color: var(--blue);
  background: rgba(63, 140, 255, .11);
}
.menu-card strong { font-size: 12px; line-height: 1.3; }

.horizontal-cards {
  display: grid;
  grid-auto-flow: column;
  grid-auto-columns: minmax(145px, 1fr);
  gap: 10px;
  overflow-x: auto;
  padding-bottom: 4px;
  scrollbar-width: none;
}
.recommend-card {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  min-height: 126px;
  padding: 15px;
  border: 1px solid var(--line);
  border-radius: 16px;
  text-align: left;
  color: var(--text);
  background: var(--surface);
}
.recommend-card .material-symbols-rounded { color: var(--blue); font-size: 30px; }
.recommend-card strong { margin-top: auto; font-size: 13px; }
.recommend-card small { margin-top: 5px; color: var(--muted); }

.status-card {
  grid-template-columns: 46px 1fr auto;
  margin-top: 0;
}
.status-card > .material-symbols-rounded { color: var(--blue); font-size: 30px; }
.status-card small, .status-card strong { display: block; }
.status-card small { color: var(--muted); font-size: 11px; }
.status-card strong { margin-top: 4px; }
.status-card button {
  padding: 8px;
  border: 0;
  color: var(--blue);
  background: transparent;
  font-size: 11px;
}

.journey-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}
.journey-card {
  display: flex;
  flex-direction: column;
  min-height: 228px;
  padding: 15px;
  border: 1px solid var(--line);
  border-radius: 18px;
  background: linear-gradient(155deg, rgba(17, 39, 64, .95), rgba(9, 25, 42, .95));
}
.journey-card-head { display: flex; align-items: center; justify-content: space-between; gap: 8px; }
.path-badge {
  padding: 5px 7px;
  border: 1px solid rgba(93, 155, 248, .25);
  border-radius: 999px;
  color: #a9c9f7;
  background: rgba(63, 140, 255, .08);
  font-size: 9px;
  white-space: nowrap;
}
.journey-card h3 { margin: 15px 0 0; font-size: 15px; line-height: 1.25; }
.journey-card p {
  margin-top: 8px;
  color: var(--muted);
  font-size: 11px;
  line-height: 1.45;
}
.path-card-progress {
  height: 4px;
  margin-top: 14px;
  overflow: hidden;
  border-radius: 999px;
  background: #23374d;
}
.path-card-progress span {
  display: block;
  height: 100%;
  border-radius: inherit;
  background: var(--blue);
}
.path-progress-copy { margin-top: 6px; color: var(--muted); font-size: 9px; }
.path-open {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  width: 100%;
  margin-top: auto;
  padding: 11px 0 0;
  border: 0;
  border-top: 1px solid var(--line);
  color: #8abaff;
  background: transparent;
  font-size: 11px;
  font-weight: 600;
  cursor: pointer;
}
.path-open .material-symbols-rounded { font-size: 19px; }
.detail-lead { color: var(--muted); font-size: 13px; line-height: 1.55; }
.compact-action { min-height: 46px; margin-top: 15px; }

.path-page { display: grid; gap: 22px; }
.path-hero {
  padding: 19px;
  border: 1px solid #294361;
  border-radius: 21px;
  background: linear-gradient(145deg, rgba(22, 51, 82, .96), rgba(10, 28, 47, .96));
}
.path-hero-copy {
  display: grid;
  grid-template-columns: 48px 1fr;
  align-items: center;
  gap: 12px;
}
.path-hero-copy h2 { margin-top: 4px; font-size: 23px; line-height: 1.15; }
.path-hero > p { margin-top: 14px; color: #bfccdc; font-size: 12px; line-height: 1.55; }
.path-progress-summary {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
  margin-top: 17px;
}
.path-progress-summary > div {
  padding: 11px;
  border: 1px solid rgba(87, 145, 221, .24);
  border-radius: 13px;
  background: rgba(5, 20, 36, .28);
}
.path-progress-summary strong, .path-progress-summary small { display: block; }
.path-progress-summary strong { font-size: 18px; }
.path-progress-summary small { margin-top: 3px; color: var(--muted); font-size: 9px; }
.path-hero .progress-track { margin-bottom: 0; }

.path-toolbar {
  display: grid;
  gap: 11px;
}
.priority-filters {
  display: grid;
  grid-template-columns: repeat(4, max-content);
  gap: 7px;
  overflow-x: auto;
  padding-bottom: 2px;
  scrollbar-width: none;
}
.priority-filters button {
  min-height: 38px;
  padding: 0 13px;
  border: 1px solid var(--line);
  border-radius: 999px;
  color: var(--muted);
  background: var(--surface);
  font-size: 11px;
  cursor: pointer;
}
.priority-filters button.active {
  border-color: rgba(76, 147, 255, .6);
  color: white;
  background: rgba(63, 140, 255, .2);
}
.reset-path-button {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 7px;
  min-height: 42px;
  border: 1px solid rgba(255, 119, 131, .27);
  border-radius: 12px;
  color: #ff9ca6;
  background: rgba(255, 91, 107, .06);
  font-size: 11px;
  cursor: pointer;
}
.reset-path-button .material-symbols-rounded { font-size: 19px; }

.path-section { display: grid; gap: 11px; }
.path-section-heading {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  margin: 0 3px;
}
.path-section-heading > div { display: flex; align-items: center; gap: 9px; }
.path-section-heading .material-symbols-rounded { color: var(--blue); font-size: 21px; }
.path-section-heading h3 { margin: 0; font-size: 16px; }
.path-section-heading small {
  padding: 5px 8px;
  border-radius: 999px;
  color: #aec9ed;
  background: rgba(63, 140, 255, .1);
  font-size: 9px;
}
.path-step-list { display: grid; gap: 10px; }
.path-step-card {
  padding: 15px;
  border: 1px solid var(--line);
  border-radius: 17px;
  background: rgba(11, 26, 43, .9);
  transition: border-color .2s ease, opacity .2s ease;
}
.path-step-card.done {
  border-color: rgba(83, 184, 139, .3);
  background: rgba(21, 61, 54, .34);
}
.path-step-top { display: flex; align-items: center; justify-content: space-between; gap: 8px; }
.priority-badge, .category-badge {
  display: inline-flex;
  padding: 5px 8px;
  border-radius: 999px;
  font-size: 9px;
  font-weight: 700;
}
.priority-badge.high { color: #ff9ca6; background: rgba(255, 91, 107, .12); }
.priority-badge.medium { color: #ffca83; background: rgba(255, 177, 73, .12); }
.priority-badge.low { color: #9dc3f9; background: rgba(63, 140, 255, .12); }
.category-badge { color: var(--muted); background: #14273d; font-weight: 500; }
.path-step-card h4 { margin: 13px 0 0; font-size: 15px; line-height: 1.35; }
.path-step-card.done h4 { color: #a9c5ba; text-decoration: line-through; }
.path-step-card > p { margin-top: 7px; color: var(--muted); font-size: 11px; line-height: 1.55; }
.step-documents {
  margin-top: 13px;
  border: 1px solid var(--line);
  border-radius: 12px;
  background: rgba(16, 36, 58, .62);
}
.step-documents summary {
  display: flex;
  align-items: center;
  gap: 7px;
  padding: 11px;
  color: #c8d8eb;
  font-size: 11px;
  cursor: pointer;
  list-style: none;
}
.step-documents summary::-webkit-details-marker { display: none; }
.step-documents summary .material-symbols-rounded { color: var(--blue); font-size: 18px; }
.step-documents ul { display: grid; gap: 7px; margin: 0; padding: 0 12px 12px 30px; color: var(--muted); font-size: 10px; line-height: 1.4; }
.step-document-link {
  display: flex;
  align-items: center;
  gap: 7px;
  margin-top: 9px;
  padding: 7px 0;
  border: 0;
  color: #8abaff;
  background: transparent;
  font-size: 10px;
  font-weight: 700;
  cursor: pointer;
}
.step-document-link .material-symbols-rounded { font-size: 18px; }
.step-tip {
  display: grid;
  grid-template-columns: 22px 1fr;
  gap: 7px;
  margin-top: 12px;
  padding: 10px;
  border-radius: 11px;
  background: rgba(63, 140, 255, .07);
}
.step-tip .material-symbols-rounded { color: #ffbf62; font-size: 18px; }
.step-tip p { color: #b8c7da; font-size: 10px; line-height: 1.5; }
.step-complete-button {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  width: 100%;
  min-height: 45px;
  margin-top: 13px;
  border: 1px solid rgba(75, 145, 248, .35);
  border-radius: 12px;
  color: #c5dcff;
  background: rgba(63, 140, 255, .1);
  font-size: 11px;
  font-weight: 700;
  cursor: pointer;
}
.step-complete-button.done {
  border-color: rgba(83, 184, 139, .35);
  color: #9dd8bf;
  background: rgba(68, 173, 126, .1);
}
.step-complete-button .material-symbols-rounded { font-size: 20px; }
.path-empty { margin-top: 0; }

.document-library .section-heading > div { display: grid; gap: 5px; }
.document-category-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}
.document-category-card {
  display: flex;
  flex-direction: column;
  min-height: 246px;
  padding: 15px;
  border: 1px solid var(--line);
  border-radius: 18px;
  background: linear-gradient(155deg, rgba(17, 39, 64, .95), rgba(9, 25, 42, .95));
}
.document-category-head { display: flex; align-items: center; justify-content: space-between; gap: 8px; }
.document-category-card h3 { margin: 15px 0 0; font-size: 15px; }
.document-category-card p { margin-top: 8px; color: var(--muted); font-size: 11px; line-height: 1.45; }
.document-card-meta {
  display: flex;
  justify-content: space-between;
  gap: 8px;
  margin-top: auto;
  padding-top: 14px;
  color: var(--muted);
  font-size: 9px;
}
.document-card-meta strong { color: #b8d3fa; }
.document-category-page { display: grid; gap: 22px; }
.document-detail-list { display: grid; gap: 10px; }
.document-detail-card {
  overflow: hidden;
  border: 1px solid var(--line);
  border-radius: 17px;
  background: rgba(11, 26, 43, .9);
}
.document-detail-card.done {
  border-color: rgba(83, 184, 139, .3);
  background: rgba(21, 61, 54, .34);
}
.document-detail-card summary {
  display: grid;
  grid-template-columns: 34px minmax(0, 1fr) auto 20px;
  align-items: center;
  gap: 9px;
  padding: 14px;
  cursor: pointer;
  list-style: none;
}
.document-detail-card summary::-webkit-details-marker { display: none; }
.document-ready-icon { color: var(--blue); font-size: 24px; }
.document-detail-card.done .document-ready-icon { color: #65c89c; }
.document-detail-card summary strong, .document-detail-card summary small { display: block; }
.document-detail-card summary strong { font-size: 13px; line-height: 1.35; }
.document-detail-card.done summary strong { color: #a9c5ba; }
.document-detail-card summary small {
  margin-top: 5px;
  overflow: hidden;
  color: var(--muted);
  font-size: 9px;
  line-height: 1.4;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.document-detail-card .expand-icon { color: var(--muted); transition: transform .2s ease; }
.document-detail-card details[open] .expand-icon { transform: rotate(180deg); }
.document-detail-body {
  display: grid;
  gap: 17px;
  padding: 0 14px 14px;
  border-top: 1px solid var(--line);
}
.document-detail-body > section:first-child { padding-top: 14px; }
.document-detail-body h4 { margin: 0 0 8px; color: #d9e4f2; font-size: 11px; }
.document-detail-body section > p { color: var(--muted); font-size: 10px; line-height: 1.55; }
.mistake-list {
  display: grid;
  gap: 7px;
  margin: 0;
  padding-left: 18px;
  color: #d5a7ad;
  font-size: 10px;
  line-height: 1.45;
}
.upload-later-button {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 7px;
  min-height: 42px;
  border: 1px dashed #425a75;
  border-radius: 11px;
  color: var(--muted);
  background: transparent;
  font-size: 10px;
  cursor: pointer;
}
.upload-later-button .material-symbols-rounded { font-size: 18px; }

.journey-list { margin-top: 10px; }
.journey-step {
  display: grid;
  grid-template-columns: 42px 1fr 22px;
  align-items: center;
  gap: 10px;
  width: 100%;
  min-height: 72px;
  padding: 8px 0;
  border: 0;
  border-bottom: 1px solid var(--line);
  text-align: left;
  color: var(--text);
  background: transparent;
}
.journey-step:last-child { border-bottom: 0; }
.journey-step .step-number {
  width: 38px;
  height: 38px;
  border-width: 1px;
  font-size: 13px;
}
.journey-step.done .step-number { border-color: var(--blue); background: rgba(63, 140, 255, .14); }
.journey-step strong, .journey-step small { display: block; }
.journey-step strong { font-size: 13px; line-height: 1.35; }
.journey-step small { margin-top: 5px; color: var(--muted); font-size: 10px; }
.journey-step.done strong { color: #9eabc0; text-decoration: line-through; }

.content-list {
  overflow: hidden;
  border: 1px solid var(--line);
  border-radius: 18px;
  background: rgba(11, 26, 43, .82);
}
.content-card, .resource-card {
  display: grid;
  grid-template-columns: 46px 1fr 24px;
  align-items: center;
  gap: 10px;
  width: 100%;
  min-height: 76px;
  padding: 12px 14px;
  border: 0;
  border-bottom: 1px solid var(--line);
  text-align: left;
  color: var(--text);
  background: transparent;
}
.content-card:last-child, .resource-card:last-child { border-bottom: 0; }
.content-card { cursor: pointer; }
.card-icon, .detail-icon {
  display: grid;
  place-items: center;
  width: 42px;
  height: 42px;
  border-radius: 12px;
  color: var(--blue);
  background: rgba(63, 140, 255, .12);
}
.content-card strong, .content-card small { display: block; }
.content-card strong { font-size: 13px; }
.content-card small { max-width: 270px; margin-top: 5px; overflow: hidden; color: var(--muted); font-size: 10px; text-overflow: ellipsis; white-space: nowrap; }
.content-card > .material-symbols-rounded:last-child { color: var(--muted); }
.resource-card { grid-template-columns: 46px 1fr; }
.resource-card strong { font-size: 14px; }
.resource-card p { margin-top: 6px; color: var(--muted); font-size: 12px; line-height: 1.5; }

dialog { max-height: min(86vh, 760px); overflow-y: auto; }
.detail-view > h2 { margin-top: 14px; }
.detail-view h3 { margin: 24px 0 12px; font-size: 14px; }
.detail-view aside {
  margin-top: 22px;
  padding: 14px;
  border-left: 3px solid var(--blue);
  border-radius: 0 12px 12px 0;
  background: rgba(63, 140, 255, .09);
}
.detail-view aside p { font-size: 12px; }
.phrase-card, .copy-box {
  padding: 15px;
  border: 1px solid var(--line);
  border-radius: 14px;
  background: var(--surface-2);
}
.phrase-card strong { font-size: 17px; line-height: 1.5; }
.phrase-card p { font-size: 13px; }
.phrase-card button, .copy-box button {
  display: flex;
  align-items: center;
  gap: 6px;
  margin-top: 12px;
  padding: 0;
  border: 0;
  color: var(--blue);
  background: transparent;
}
.chips { display: flex; flex-wrap: wrap; gap: 8px; }
.chips span { padding: 8px 10px; border: 1px solid var(--line); border-radius: 999px; color: #cdd8e7; background: var(--surface-2); font-size: 12px; }
.copy-box { display: flex; align-items: center; justify-content: space-between; gap: 10px; }
.copy-box button { margin: 0; }
.letter-body {
  margin: 0;
  padding: 15px;
  overflow: auto;
  border: 1px solid var(--line);
  border-radius: 14px;
  white-space: pre-wrap;
  color: #dce5f1;
  background: var(--surface-2);
  font: 12px/1.65 Inter, sans-serif;
}

.top-action { margin: 0 0 16px; }
.section-heading > small { color: var(--muted); font-size: 10px; }
.reminders-page { display: grid; gap: 14px; padding-bottom: 12px; }
.reminders-hero {
  display: grid;
  gap: 12px;
  padding: 18px;
  overflow: hidden;
  border: 1px solid rgba(74, 148, 255, .22);
  border-radius: 20px;
  background:
    radial-gradient(circle at 90% 10%, rgba(54, 132, 255, .2), transparent 42%),
    linear-gradient(145deg, rgba(16, 42, 72, .98), rgba(8, 25, 44, .98));
  box-shadow: 0 18px 42px rgba(0, 7, 18, .22);
}
.reminders-hero > div { display: flex; align-items: center; gap: 12px; }
.reminders-hero h2 { margin-top: 3px; font-size: 18px; }
.reminders-hero > p { color: #aebfd2; font-size: 11px; line-height: 1.55; }
.reminders-hero .primary-button { margin: 0; }
.reminder-stats { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 7px; }
.reminder-stats article {
  display: grid;
  justify-items: center;
  gap: 3px;
  min-width: 0;
  padding: 11px 4px;
  border: 1px solid var(--line);
  border-radius: 14px;
  background: var(--surface);
}
.reminder-stats .material-symbols-rounded { color: #76adfa; font-size: 18px; }
.reminder-stats article.high .material-symbols-rounded { color: #ffbe5c; }
.reminder-stats article.overdue .material-symbols-rounded { color: #ff788b; }
.reminder-stats article.done .material-symbols-rounded { color: #69d6ad; }
.reminder-stats strong { font-size: 16px; }
.reminder-stats small { overflow: hidden; color: var(--muted); font-size: 8px; text-overflow: ellipsis; white-space: nowrap; }
.reminder-warning {
  display: grid;
  grid-template-columns: 24px 1fr;
  gap: 9px;
  padding: 12px;
  border: 1px solid rgba(255, 193, 84, .2);
  border-radius: 14px;
  color: #efd69d;
  background: rgba(108, 74, 16, .13);
}
.reminder-warning .material-symbols-rounded { color: #ffbd59; font-size: 20px; }
.reminder-warning p { font-size: 9px; line-height: 1.5; }
.reminder-tools { display: grid; gap: 10px; }
.reminder-filters {
  flex-wrap: nowrap;
  padding-bottom: 2px;
  overflow-x: auto;
  scrollbar-width: none;
}
.reminder-filters::-webkit-scrollbar { display: none; }
.reminder-filters button { flex: 0 0 auto; white-space: nowrap; }
.reminder-sort {
  display: grid;
  grid-template-columns: 26px 1fr;
  align-items: center;
  padding: 0 11px;
  border: 1px solid var(--line);
  border-radius: 13px;
  color: #87b8fa;
  background: var(--surface);
}
.reminder-sort select { min-height: 42px; border: 0; outline: none; color: #cfdded; background: transparent; font-size: 10px; }
.reminder-list { display: grid; gap: 10px; }
.reminder-card {
  position: relative;
  display: grid;
  gap: 10px;
  padding: 14px;
  overflow: hidden;
  border: 1px solid var(--line);
  border-left: 3px solid #6e9fdc;
  border-radius: 16px;
  background: linear-gradient(145deg, rgba(13, 34, 58, .98), rgba(8, 25, 43, .98));
}
.reminder-card.priority-high { border-left-color: #ffb950; }
.reminder-card.priority-low { border-left-color: #73c8aa; }
.reminder-card.overdue { border-color: rgba(255, 99, 122, .36); border-left-color: #ff637a; background: linear-gradient(145deg, rgba(62, 25, 38, .72), rgba(18, 24, 39, .98)); }
.reminder-card.done { opacity: .65; border-left-color: #62c89f; }
.reminder-card.done h3 { text-decoration: line-through; }
.reminder-card-head { display: grid; grid-template-columns: 38px minmax(0, 1fr) 30px; align-items: start; gap: 9px; }
.reminder-type-icon {
  display: grid;
  place-items: center;
  width: 36px;
  height: 36px;
  border-radius: 11px;
  color: #88b9ff;
  background: rgba(65, 139, 245, .11);
}
.reminder-card h3 { margin-top: 5px; font-size: 13px; line-height: 1.35; }
.reminder-badges { display: flex; flex-wrap: wrap; gap: 5px; }
.reminder-badges span { padding: 3px 6px; border-radius: 999px; font-size: 7px; font-weight: 700; }
.reminder-badges .priority { color: #ffcf80; background: rgba(255, 181, 61, .1); }
.reminder-badges .status { color: #9cc6ff; background: rgba(60, 139, 248, .1); }
.reminder-card.overdue .reminder-badges .status { color: #ff96a5; background: rgba(255, 88, 113, .12); }
.reminder-card.done .reminder-badges .status { color: #78ddb6; background: rgba(76, 196, 148, .12); }
.reminder-check { padding: 0; border: 0; color: var(--blue); background: transparent; }
.reminder-check .material-symbols-rounded { font-size: 25px; }
.reminder-description { color: #b9c9db; font-size: 10px; line-height: 1.5; }
.reminder-datetime { display: flex; align-items: center; flex-wrap: wrap; gap: 6px; color: #a9bfd7; }
.reminder-datetime .material-symbols-rounded { color: #6ba4ee; font-size: 16px; }
.reminder-datetime strong { color: #dce7f5; font-size: 10px; }
.reminder-datetime span, .reminder-datetime small { font-size: 9px; }
.reminder-datetime small { margin-left: auto; color: #7991aa; }
.reminder-note {
  display: grid;
  grid-template-columns: 18px 1fr;
  gap: 7px;
  padding: 9px;
  border-radius: 10px;
  color: #a9bdd3;
  background: rgba(255, 255, 255, .025);
}
.reminder-note .material-symbols-rounded { color: #7896b9; font-size: 16px; }
.reminder-note p { font-size: 9px; line-height: 1.45; }
.reminder-connections { display: flex; flex-wrap: wrap; gap: 6px; }
.reminder-connections button {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  min-height: 30px;
  padding: 0 8px;
  border: 1px solid rgba(87, 150, 235, .16);
  border-radius: 9px;
  color: #9bc4fa;
  background: rgba(46, 108, 193, .07);
  font-size: 8px;
}
.reminder-connections .material-symbols-rounded { font-size: 14px; }
.reminder-barmer-button {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 7px;
  min-height: 40px;
  padding: 0 10px;
  border-radius: 11px;
  color: white;
  text-align: center;
  text-decoration: none;
  background: linear-gradient(135deg, #119a78, #2778d8);
  font-size: 9px;
  font-weight: 700;
}
.reminder-barmer-button .material-symbols-rounded { font-size: 17px; }
.reminder-card-actions { display: grid; grid-template-columns: 1fr 1fr; gap: 7px; }
.reminder-card-actions button {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 5px;
  min-height: 34px;
  border: 1px solid var(--line);
  border-radius: 9px;
  color: #9fc5f7;
  background: var(--surface-2);
  font-size: 8px;
}
.reminder-card-actions button.danger { color: #ff9aa8; border-color: rgba(255, 90, 113, .16); }
.reminder-card-actions .material-symbols-rounded { font-size: 15px; }
.recommended-reminders {
  display: grid;
  gap: 11px;
  padding: 15px;
  border: 1px solid rgba(82, 145, 229, .18);
  border-radius: 17px;
  background: rgba(13, 35, 59, .72);
}
.recommended-reminders .section-heading { align-items: end; }
.recommended-reminders h2 { margin-top: 3px; font-size: 13px; }
.recommended-reminder-list { display: grid; gap: 7px; }
.recommended-reminder-list article {
  display: grid;
  grid-template-columns: 30px 1fr;
  align-items: center;
  gap: 8px;
  padding: 8px;
  border-radius: 10px;
  background: rgba(255, 255, 255, .025);
}
.recommended-reminder-list .material-symbols-rounded { color: #76aef8; font-size: 19px; }
.recommended-reminder-list strong { display: block; font-size: 9px; }
.recommended-reminder-list small { display: block; margin-top: 3px; color: var(--muted); font-size: 8px; line-height: 1.4; }
.recommended-reminders .secondary-button { margin: 0; }
.reminder-footer-actions { display: grid; gap: 8px; }
.reminder-footer-actions .secondary-button, .danger-button {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 7px;
  min-height: 42px;
  margin: 0;
  border: 1px solid var(--line);
  border-radius: 11px;
}
.danger-button { color: #ff98a7; border-color: rgba(255, 91, 115, .18); background: rgba(100, 25, 38, .12); }
.reminder-form-view .eyebrow { color: #72aefb; }
.reminder-form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.empty-state { padding: 42px 20px; border: 1px dashed var(--line); border-radius: 18px; text-align: center; color: var(--muted); }
.empty-state .material-symbols-rounded { font-size: 38px; }

.profile-page { padding-bottom: 10px; }
.avatar {
  display: grid;
  place-items: center;
  width: 78px;
  height: 78px;
  margin: 0 auto 22px;
  border: 3px solid rgba(90, 161, 255, .35);
  border-radius: 50%;
  color: white;
  background: linear-gradient(135deg, #397ee5, #6aa9ff);
  font-size: 28px;
  font-weight: 700;
}
.form-grid, .profile-form { display: grid; gap: 14px; }
.form-grid label, .profile-form label {
  display: grid;
  gap: 7px;
  color: var(--muted);
  font-size: 11px;
}
.form-grid input, .form-grid select, .profile-form input, .profile-form select, .profile-form textarea {
  width: 100%;
  min-height: 48px;
  padding: 10px 12px;
  border: 1px solid var(--line);
  border-radius: 12px;
  outline: none;
  color: var(--text);
  background: var(--surface-2);
}
.profile-form textarea { resize: vertical; }
.profile-page { display: grid; gap: 13px; }
.profile-prompt-card,
.profile-summary-card,
.readiness-card,
.profile-preview-recommendations,
.profile-form-card,
.information-disclaimer,
.visa-reminder-suggestion {
  border: 1px solid var(--line);
  border-radius: 17px;
  background: var(--surface);
}
.profile-prompt-card {
  display: grid;
  grid-template-columns: 38px minmax(0, 1fr);
  gap: 10px;
  padding: 15px;
  border-color: rgba(63, 140, 255, .32);
  background: linear-gradient(145deg, rgba(28, 64, 108, .7), rgba(8, 27, 47, .96));
}
.profile-prompt-card > .material-symbols-rounded {
  display: grid;
  place-items: center;
  width: 38px;
  height: 38px;
  border-radius: 12px;
  color: #a8ceff;
  background: rgba(63, 140, 255, .15);
}
.profile-prompt-card h2 { margin-top: 4px; font-size: 15px; line-height: 1.35; }
.profile-prompt-card p:not(.eyebrow) { margin-top: 6px; color: var(--muted); font-size: 9px; line-height: 1.45; }
.profile-prompt-card .primary-button { grid-column: 1 / -1; margin: 2px 0 0; }
.personal-profile-line { display: block; margin-top: 8px; color: var(--muted); font-size: 9px; }
.personal-recommendation-list { display: grid; gap: 8px; }
.personal-recommendation-card {
  display: grid;
  grid-template-columns: 34px minmax(0, 1fr);
  gap: 10px;
  padding: 12px;
  border: 1px solid rgba(255, 181, 72, .19);
  border-radius: 14px;
  background: rgba(20, 38, 60, .72);
}
.personal-recommendation-card > .material-symbols-rounded { color: #ffc36f; font-size: 25px; }
.personal-recommendation-card h3 { margin-top: 4px; font-size: 11px; }
.personal-recommendation-card p { margin-top: 5px; color: var(--muted); font-size: 9px; line-height: 1.45; }
.recommendation-priority { color: #ffca85; font-size: 7px; font-weight: 800; text-transform: uppercase; letter-spacing: .08em; }
.recommendation-action {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  min-height: 33px;
  margin-top: 9px;
  padding: 7px 9px;
  border: 1px solid rgba(63, 140, 255, .25);
  border-radius: 9px;
  color: #b9d7ff;
  text-decoration: none;
  background: rgba(63, 140, 255, .09);
  font-size: 8px;
  font-weight: 700;
}
.recommendation-action.external { color: #b9f2df; border-color: rgba(48, 202, 154, .28); background: rgba(31, 157, 119, .1); }
.recommendation-action .material-symbols-rounded { font-size: 15px; }
.information-disclaimer {
  display: grid;
  grid-template-columns: 22px 1fr;
  gap: 8px;
  padding: 11px;
  color: #b9c9d9;
  background: rgba(14, 34, 56, .7);
}
.information-disclaimer .material-symbols-rounded { color: #82b8ff; font-size: 18px; }
.information-disclaimer p { font-size: 8px; line-height: 1.45; }
.profile-summary-card {
  display: grid;
  grid-template-columns: 54px minmax(0, 1fr);
  gap: 11px;
  padding: 15px;
  border-color: rgba(63, 140, 255, .28);
  background: linear-gradient(145deg, rgba(28, 60, 99, .72), rgba(8, 27, 47, .96));
}
.profile-avatar {
  display: grid;
  place-items: center;
  width: 54px;
  height: 54px;
  border: 2px solid rgba(126, 183, 255, .36);
  border-radius: 17px;
  color: #fff;
  background: linear-gradient(135deg, #397ee5, #6aa9ff);
  font-size: 21px;
  font-weight: 800;
}
.profile-summary-copy h2 { margin-top: 3px; font-size: 17px; }
.profile-summary-copy > p:last-child { margin-top: 5px; color: var(--muted); font-size: 9px; }
.profile-badges { grid-column: 1 / -1; display: flex; flex-wrap: wrap; gap: 6px; }
.profile-badges span {
  max-width: 100%;
  padding: 5px 8px;
  border-radius: 999px;
  color: #a9d0ff;
  background: rgba(63, 140, 255, .11);
  font-size: 7px;
  font-weight: 700;
  overflow-wrap: anywhere;
}
.readiness-card { display: grid; gap: 11px; padding: 14px; }
.readiness-head { display: flex; justify-content: space-between; align-items: end; gap: 10px; }
.readiness-head h2 { margin-top: 3px; color: #79c7ff; font-size: 23px; }
.readiness-head > span { color: var(--muted); font-size: 8px; }
.readiness-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 6px; }
.readiness-grid > span {
  display: flex;
  align-items: center;
  gap: 5px;
  min-width: 0;
  color: #7f92a7;
  font-size: 8px;
}
.readiness-grid > span.done { color: #80d8bc; }
.readiness-grid .material-symbols-rounded { font-size: 15px; }
.profile-preview-recommendations { display: grid; gap: 8px; padding: 13px; }
.profile-preview-recommendations article {
  display: grid;
  grid-template-columns: 24px minmax(0, 1fr);
  gap: 8px;
  padding: 9px;
  border: 1px solid rgba(255, 181, 72, .16);
  border-radius: 11px;
  background: rgba(255, 181, 72, .035);
}
.profile-preview-recommendations article > .material-symbols-rounded { color: #ffc36f; font-size: 19px; }
.profile-preview-recommendations strong { font-size: 9px; }
.profile-preview-recommendations p { margin-top: 3px; color: var(--muted); font-size: 8px; line-height: 1.4; }
.profile-form-card { display: grid; gap: 10px; padding: 13px; }
.profile-form-section {
  display: grid;
  gap: 11px;
  padding: 12px;
  border: 1px solid rgba(37, 56, 78, .85);
  border-radius: 14px;
  background: rgba(7, 24, 41, .46);
}
.profile-form-heading { display: grid; grid-template-columns: 28px 1fr; gap: 8px; align-items: center; }
.profile-form-heading > .material-symbols-rounded {
  display: grid;
  place-items: center;
  width: 28px;
  height: 28px;
  border-radius: 9px;
  color: #8dc0ff;
  background: rgba(63, 140, 255, .1);
  font-size: 17px;
}
.profile-form-heading h3 { font-size: 11px; }
.profile-form-heading p { margin-top: 2px; color: var(--muted); font-size: 8px; }
.profile-form-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 9px; }
.profile-form-grid label {
  display: grid;
  gap: 6px;
  min-width: 0;
  color: var(--muted);
  font-size: 8px;
}
.profile-form-grid input,
.profile-form-grid select {
  width: 100%;
  min-width: 0;
  min-height: 42px;
  padding: 9px 10px;
  border: 1px solid var(--line);
  border-radius: 10px;
  outline: none;
  color: var(--text);
  background: var(--surface-2);
  font-size: 9px;
}
.profile-form-grid select { text-overflow: ellipsis; }
.profile-check-grid,
.profile-goals-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 7px; }
.profile-check-option {
  display: grid;
  grid-template-columns: 20px minmax(0, 1fr) 18px;
  align-items: center;
  gap: 6px;
  min-height: 42px;
  padding: 9px;
  border: 1px solid var(--line);
  border-radius: 11px;
  color: #b8c9da;
  background: var(--surface);
  cursor: pointer;
}
.profile-check-option input { position: absolute; opacity: 0; pointer-events: none; }
.profile-check-option > .material-symbols-rounded:first-of-type { color: #7caef0; font-size: 17px; }
.profile-check-option strong { font-size: 8px; line-height: 1.3; }
.profile-check-option .checkmark { color: #526579; font-size: 16px; }
.profile-check-option:has(input:checked) { border-color: rgba(55, 198, 154, .35); background: rgba(38, 160, 124, .08); }
.profile-check-option:has(input:checked) .checkmark { color: #66d3ae; }
.profile-form-actions { display: grid; gap: 8px; }
.profile-form-actions .primary-button,
.profile-form-actions .secondary-button,
.profile-form-actions .danger-button { width: 100%; }
.visa-reminder-suggestion {
  display: grid;
  grid-template-columns: 34px minmax(0, 1fr);
  gap: 9px;
  padding: 13px;
  border-color: rgba(255, 181, 72, .22);
  background: rgba(255, 181, 72, .045);
}
.visa-reminder-suggestion > .material-symbols-rounded { color: #ffc36f; font-size: 25px; }
.visa-reminder-suggestion h3 { margin-top: 3px; font-size: 11px; }
.visa-reminder-suggestion p:not(.eyebrow) { margin-top: 4px; color: var(--muted); font-size: 8px; line-height: 1.4; }
.visa-reminder-suggestion .secondary-button { grid-column: 1 / -1; margin: 0; }

.emergency-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.emergency-card {
  display: flex;
  flex-direction: column;
  min-height: 126px;
  padding: 15px;
  border: 1px solid var(--line);
  border-radius: 16px;
  color: var(--text);
  text-decoration: none;
  background: var(--surface);
}
.emergency-card .material-symbols-rounded { color: #ff6f7d; }
.emergency-card strong { margin-top: auto; font-size: 20px; }
.emergency-card small { margin-top: 5px; color: var(--muted); line-height: 1.35; }
.support-card { text-decoration: none; }
.help-guide-list { display: grid; gap: 10px; }
.help-guide-card {
  display: grid;
  grid-template-columns: 46px 1fr;
  gap: 11px;
  padding: 14px;
  border: 1px solid var(--line);
  border-radius: 16px;
  background: var(--surface);
}
.help-guide-card strong { font-size: 13px; line-height: 1.35; }
.help-guide-card p { margin-top: 6px; color: var(--muted); font-size: 11px; line-height: 1.5; }
.contact-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.contact-button {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  min-height: 52px;
  border-radius: 14px;
  color: white;
  text-decoration: none;
  font-size: 13px;
  font-weight: 700;
}
.contact-button.telegram { background: #2a8bf2; }
.contact-button.whatsapp { background: #209e61; }
.help-center-page, .help-detail-page { display: grid; gap: 13px; padding-bottom: 12px; }
.help-sos-hero, .help-detail-hero {
  display: grid;
  gap: 10px;
  padding: 16px;
  border: 1px solid rgba(255, 91, 115, .27);
  border-radius: 18px;
  background: linear-gradient(145deg, rgba(90, 29, 43, .58), rgba(8, 27, 47, .96));
}
.help-sos-hero > div {
  display: grid;
  grid-template-columns: 42px 1fr;
  gap: 10px;
  align-items: center;
}
.help-sos-hero > div > .material-symbols-rounded {
  display: grid;
  place-items: center;
  width: 42px;
  height: 42px;
  border-radius: 13px;
  color: #fff;
  background: linear-gradient(135deg, #e33d58, #ff7a6e);
  font-size: 24px;
}
.help-sos-hero h2 { margin-top: 3px; font-size: 18px; }
.help-sos-hero > p { color: #c8d4e1; font-size: 9px; line-height: 1.5; }
.help-section, .help-detail-section {
  display: grid;
  gap: 11px;
  padding: 13px;
  border: 1px solid var(--line);
  border-radius: 17px;
  background: rgba(12, 31, 51, .78);
}
.sos-label {
  padding: 5px 8px;
  border-radius: 999px;
  color: #ff9aaa;
  background: rgba(255, 91, 115, .1);
  font-size: 8px;
}
.help-emergency-grid { display: grid; gap: 9px; }
.help-emergency-card {
  display: grid;
  gap: 8px;
  padding: 13px;
  border: 1px solid rgba(255, 91, 115, .22);
  border-radius: 14px;
  background: rgba(68, 23, 37, .16);
}
.help-emergency-card.priority-medium { border-color: rgba(255, 181, 72, .22); background: rgba(91, 62, 20, .1); }
.help-emergency-card > div:first-child { display: flex; align-items: center; gap: 8px; }
.help-emergency-card > div:first-child .material-symbols-rounded { color: #ff8092; font-size: 23px; }
.help-emergency-card > div:first-child strong { color: #ff9aaa; font-size: 17px; }
.help-emergency-card h3 { font-size: 11px; }
.help-emergency-card > p { color: var(--muted); font-size: 8px; line-height: 1.45; }
.help-emergency-card blockquote {
  display: grid;
  gap: 3px;
  margin: 0;
  padding: 9px;
  border-left: 3px solid #ff7388;
  border-radius: 0 9px 9px 0;
  background: rgba(5, 18, 32, .48);
}
.help-emergency-card blockquote strong { font-size: 9px; }
.help-emergency-card blockquote span { color: var(--muted); font-size: 8px; }
.help-emergency-card > a {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  min-height: 39px;
  border-radius: 10px;
  color: #fff;
  text-decoration: none;
  background: linear-gradient(135deg, #d93954, #f05f61);
  font-size: 9px;
  font-weight: 800;
}
.help-emergency-card.priority-medium > a { background: linear-gradient(135deg, #b47621, #d49a3c); }
.help-tools { display: grid; gap: 9px; }
.help-filters { display: flex; gap: 6px; margin: 0 -2px; padding: 0 2px 3px; overflow-x: auto; scrollbar-width: none; }
.help-filters::-webkit-scrollbar { display: none; }
.help-filters button { flex: 0 0 auto; white-space: nowrap; }
.help-personal-label {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 8px 10px;
  border-radius: 10px;
  color: #9dc8ff;
  background: rgba(63, 140, 255, .08);
  font-size: 8px;
}
.help-personal-label .material-symbols-rounded { font-size: 16px; }
.help-situation-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 9px; }
.help-situation-grid > .empty-state { grid-column: 1 / -1; }
.help-situation-card {
  display: flex;
  flex-direction: column;
  min-width: 0;
  padding: 12px;
  border: 1px solid var(--line);
  border-radius: 15px;
  background: var(--surface);
}
.help-situation-card > div:first-child { display: flex; justify-content: space-between; align-items: start; gap: 7px; }
.help-situation-card h3 { margin-top: 10px; font-size: 11px; line-height: 1.35; }
.help-situation-card > p { margin-top: 5px; color: var(--muted); font-size: 8px; line-height: 1.45; }
.help-category-tags { display: flex; flex-wrap: wrap; gap: 4px; margin: 8px 0; }
.help-category-tags span { padding: 4px 6px; border-radius: 999px; color: #92bfff; background: rgba(63, 140, 255, .08); font-size: 6px; font-weight: 700; }
.help-situation-card .path-open { margin-top: auto; }
.help-profile-alert {
  display: grid;
  grid-template-columns: 30px minmax(0, 1fr);
  gap: 8px;
  padding: 12px;
  border: 1px solid rgba(55, 198, 154, .27);
  border-radius: 14px;
  background: rgba(33, 137, 106, .09);
}
.help-profile-alert > .material-symbols-rounded { color: #69dbb9; font-size: 24px; }
.help-profile-alert strong { font-size: 10px; }
.help-profile-alert p { margin-top: 4px; color: var(--muted); font-size: 8px; line-height: 1.4; }
.help-profile-alert > a, .help-profile-alert > button {
  grid-column: 1 / -1;
  min-height: 38px;
  padding: 9px;
  border: 0;
  border-radius: 10px;
  color: #fff;
  text-align: center;
  text-decoration: none;
  background: linear-gradient(135deg, #149d7b, #2e79d8);
  font-size: 8px;
  font-weight: 800;
}
.help-profile-alert.visa { border-color: rgba(255, 181, 72, .24); background: rgba(255, 181, 72, .05); }
.help-profile-alert.visa > .material-symbols-rounded { color: #ffc36f; }
.help-profile-alert.visa > button { background: linear-gradient(135deg, #b47621, #d38b35); }
.help-request-form { display: grid; gap: 10px; }
.help-request-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 9px; }
.help-request-form label {
  display: grid;
  gap: 6px;
  min-width: 0;
  color: var(--muted);
  font-size: 8px;
}
.help-request-form input, .help-request-form select, .help-request-form textarea, .letter-check-card textarea {
  width: 100%;
  min-width: 0;
  min-height: 42px;
  padding: 9px 10px;
  border: 1px solid var(--line);
  border-radius: 10px;
  outline: none;
  color: var(--text);
  background: var(--surface-2);
  font-size: 9px;
}
.help-request-form textarea, .letter-check-card textarea { resize: vertical; line-height: 1.5; }
.help-request-history { display: grid; gap: 7px; }
.help-request-history article { padding: 10px; border: 1px solid var(--line); border-radius: 11px; background: var(--surface); }
.help-request-history article > div { display: flex; align-items: center; gap: 7px; }
.help-request-history strong { font-size: 9px; }
.help-request-history article > div > button {
  display: grid;
  place-items: center;
  width: 27px;
  height: 27px;
  margin-left: auto;
  padding: 0;
  border: 1px solid rgba(255, 91, 115, .18);
  border-radius: 8px;
  color: #ff8d9d;
  background: rgba(255, 91, 115, .06);
}
.help-request-history article > div > button .material-symbols-rounded { font-size: 16px; }
.help-request-history p { margin-top: 6px; color: #c0cfde; font-size: 8px; line-height: 1.4; }
.help-request-history small { display: block; margin-top: 6px; color: var(--muted); font-size: 7px; }
.help-contact-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 9px; }
.help-contact-card {
  display: flex;
  flex-direction: column;
  min-width: 0;
  padding: 12px;
  border: 1px solid var(--line);
  border-radius: 15px;
  background: var(--surface);
}
.help-contact-card h3 { margin-top: 9px; font-size: 11px; }
.help-contact-card > p { margin-top: 5px; color: var(--muted); font-size: 8px; line-height: 1.45; }
.help-contact-card > div { display: grid; gap: 4px; margin: 8px 0; }
.help-contact-card > div a { color: #91bfff; font-size: 7px; overflow-wrap: anywhere; }
.help-contact-card > a:last-child, .help-contact-card > button {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 4px;
  min-height: 35px;
  margin-top: auto;
  padding: 7px;
  border: 1px solid rgba(63, 140, 255, .23);
  border-radius: 9px;
  color: #b9d7ff;
  text-align: center;
  text-decoration: none;
  background: rgba(63, 140, 255, .08);
  font-size: 7px;
  font-weight: 800;
}
.help-contact-card.barmer { border-color: rgba(55, 198, 154, .26); }
.help-contact-card.barmer > a:last-child { color: #b9f2df; border-color: rgba(55, 198, 154, .24); background: rgba(55, 198, 154, .08); }
.letter-check-card label { display: grid; gap: 6px; color: var(--muted); font-size: 8px; }
.letter-check-card > div:last-child { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; }
.letter-check-card .primary-button, .letter-check-card .secondary-button { margin: 0; }
.help-legal-warning {
  display: grid;
  grid-template-columns: 22px 1fr;
  gap: 8px;
  padding: 11px;
  border: 1px solid rgba(255, 181, 72, .2);
  border-radius: 13px;
  color: #e2c99f;
  background: rgba(255, 181, 72, .045);
}
.help-legal-warning .material-symbols-rounded { color: #ffc36f; font-size: 19px; }
.help-legal-warning p { font-size: 8px; line-height: 1.45; }

/* Alman Group services */
.services-page, .service-detail-page { display: grid; gap: 13px; padding-bottom: 12px; }
.services-hero, .services-section, .service-detail-section, .service-detail-hero {
  display: grid;
  gap: 11px;
  padding: 14px;
  border: 1px solid var(--line);
  border-radius: 18px;
  background: rgba(12, 31, 51, .82);
}
.services-hero {
  border-color: rgba(63, 140, 255, .28);
  background: linear-gradient(145deg, rgba(25, 72, 127, .44), rgba(8, 27, 47, .96));
}
.services-hero > div:first-child { display: grid; grid-template-columns: 44px minmax(0, 1fr); gap: 10px; align-items: center; }
.services-hero > div:first-child > .material-symbols-rounded {
  display: grid; place-items: center; width: 44px; height: 44px; border-radius: 14px;
  color: white; background: linear-gradient(135deg, #3f8cff, #7259e8); font-size: 25px;
}
.services-hero h2 { margin-top: 3px; font-size: 19px; }
.services-hero > p { color: #c5d3e2; font-size: 9px; line-height: 1.55; }
.services-hero-actions { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; }
.services-hero-actions .primary-button, .services-hero-actions .secondary-button { min-height: 42px; margin: 0; font-size: 8px; }
.secondary-button {
  display: flex; align-items: center; justify-content: center; gap: 7px; min-height: 42px; padding: 9px 11px;
  border: 1px solid var(--line); border-radius: 11px; color: #bcd8fa; background: var(--surface-2); font-weight: 700; cursor: pointer;
}
.service-profile-alert {
  display: grid; grid-template-columns: 32px minmax(0, 1fr); gap: 9px; padding: 12px;
  border: 1px solid rgba(55, 198, 154, .27); border-radius: 15px; background: rgba(33, 137, 106, .09);
}
.service-profile-alert > .material-symbols-rounded { color: #69dbb9; font-size: 25px; }
.service-profile-alert strong { font-size: 10px; }
.service-profile-alert p { margin-top: 4px; color: var(--muted); font-size: 8px; line-height: 1.4; }
.service-profile-alert a {
  grid-column: 1 / -1; padding: 10px; border-radius: 10px; color: white; text-align: center;
  text-decoration: none; background: linear-gradient(135deg, #149d7b, #2e79d8); font-size: 8px; font-weight: 800;
}
.service-filter-row { display: flex; gap: 6px; margin: 0 -2px; padding: 0 2px 3px; overflow-x: auto; scrollbar-width: none; }
.service-filter-row::-webkit-scrollbar { display: none; }
.filter-chip {
  display: flex; align-items: center; gap: 5px; flex: 0 0 auto; min-height: 34px; padding: 7px 9px;
  border: 1px solid var(--line); border-radius: 999px; color: var(--muted); white-space: nowrap;
  background: var(--surface); font-size: 7px; font-weight: 700; cursor: pointer;
}
.filter-chip .material-symbols-rounded { font-size: 15px; }
.filter-chip.active { color: white; border-color: rgba(63, 140, 255, .55); background: rgba(63, 140, 255, .18); }
.service-card-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 9px; }
.service-card-grid > .empty-state { grid-column: 1 / -1; }
.service-card {
  display: flex; flex-direction: column; min-width: 0; padding: 12px; border: 1px solid var(--line);
  border-radius: 15px; background: var(--surface);
}
.service-card.barmer { border-color: rgba(55, 198, 154, .35); background: linear-gradient(145deg, rgba(23, 94, 78, .19), var(--surface)); }
.service-card-top { display: flex; flex-wrap: wrap; align-items: center; gap: 5px; }
.service-provider, .service-category {
  display: inline-flex; width: max-content; max-width: 100%; padding: 4px 6px; border-radius: 999px;
  color: #9dc8ff; background: rgba(63, 140, 255, .09); font-size: 6px; font-weight: 800;
}
.service-category { color: #cabfff; background: rgba(126, 96, 223, .11); }
.service-card h3 { margin-top: 9px; font-size: 11px; line-height: 1.32; }
.service-card > p { margin-top: 5px; color: var(--muted); font-size: 8px; line-height: 1.45; }
.service-card-meta { display: grid; grid-template-columns: 1fr 1fr; gap: 6px; margin: 10px 0; }
.service-card-meta span {
  display: grid; gap: 2px; min-width: 0; padding: 7px; border-radius: 9px; background: rgba(19, 43, 69, .78);
}
.service-card-meta small { color: var(--muted); font-size: 6px; }
.service-card-meta strong { font-size: 8px; line-height: 1.25; overflow-wrap: anywhere; }
.service-card .path-open { margin-top: auto; }
.service-card-grid.compact { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.free-services-block { border-color: rgba(55, 198, 154, .23); }
.employer-services-block { border-color: rgba(151, 120, 255, .23); }
.service-useful-links { display: grid; gap: 7px; }
.service-useful-links a {
  display: grid; grid-template-columns: 26px minmax(0, 1fr); gap: 7px; align-items: center; padding: 9px;
  border: 1px solid var(--line); border-radius: 11px; color: inherit; text-decoration: none; background: var(--surface);
}
.service-useful-links .material-symbols-rounded { color: var(--blue); font-size: 18px; }
.service-useful-links span { display: grid; gap: 2px; }
.service-useful-links strong { font-size: 8px; }
.service-useful-links small { color: var(--muted); font-size: 7px; line-height: 1.35; }
.services-section .section-heading > a { color: #9dc8ff; font-size: 8px; }
.service-request-form { display: grid; gap: 10px; }
.service-request-form > label, .service-request-grid label {
  display: grid; gap: 6px; min-width: 0; color: var(--muted); font-size: 8px;
}
.service-request-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 9px; }
.service-request-form input, .service-request-form select, .service-request-form textarea {
  width: 100%; min-width: 0; min-height: 42px; padding: 9px 10px; border: 1px solid var(--line);
  border-radius: 10px; outline: none; color: var(--text); background: var(--surface-2); font-size: 9px;
}
.service-request-form textarea { resize: vertical; line-height: 1.5; }
.service-request-history { display: grid; gap: 7px; }
.service-request-history article { padding: 10px; border: 1px solid var(--line); border-radius: 11px; background: var(--surface); }
.service-request-history article > div { display: flex; align-items: center; gap: 7px; }
.service-request-history article > div > span { padding: 4px 6px; border-radius: 999px; color: #81dbbe; background: rgba(55, 198, 154, .09); font-size: 6px; }
.service-request-history strong { font-size: 9px; }
.service-request-history button { display: grid; place-items: center; width: 27px; height: 27px; margin-left: auto; padding: 0; border: 1px solid rgba(255, 91, 115, .18); border-radius: 8px; color: #ff8d9d; background: rgba(255, 91, 115, .06); }
.service-request-history button .material-symbols-rounded { font-size: 16px; }
.service-request-history p { margin-top: 6px; color: #c0cfde; font-size: 8px; line-height: 1.4; }
.service-request-history small { display: block; margin-top: 6px; color: var(--muted); font-size: 7px; }
.service-disclaimer {
  display: grid; grid-template-columns: 23px 1fr; gap: 8px; padding: 11px; border: 1px solid rgba(255, 181, 72, .2);
  border-radius: 13px; color: #e2c99f; background: rgba(255, 181, 72, .045);
}
.service-disclaimer .material-symbols-rounded { color: #ffc36f; font-size: 19px; }
.service-disclaimer p { font-size: 8px; line-height: 1.45; }
.service-detail-hero { border-color: rgba(63, 140, 255, .28); background: linear-gradient(145deg, rgba(25, 72, 127, .35), rgba(8, 27, 47, .96)); }
.service-provider-line { display: flex; flex-wrap: wrap; gap: 6px; }
.service-provider-line span, .service-provider-line em { padding: 5px 8px; border-radius: 999px; color: #9dc8ff; background: rgba(63, 140, 255, .1); font-size: 7px; font-style: normal; font-weight: 800; }
.service-provider-line em { color: #cabfff; background: rgba(126, 96, 223, .12); }
.service-detail-hero h2 { font-size: 20px; line-height: 1.25; }
.service-detail-hero > p { color: #c5d3e2; font-size: 9px; line-height: 1.55; }
.service-detail-facts { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; }
.service-detail-facts span { display: grid; gap: 3px; padding: 10px; border: 1px solid rgba(63, 140, 255, .12); border-radius: 11px; background: rgba(10, 27, 46, .62); }
.service-detail-facts small { color: var(--muted); font-size: 7px; }
.service-detail-facts strong { font-size: 11px; }
.service-price-note { padding: 8px 9px; border-radius: 9px; color: #d6c79e !important; background: rgba(255, 181, 72, .06); font-size: 7px !important; }
.service-main-action {
  display: flex; align-items: center; justify-content: center; gap: 7px; width: 100%; min-height: 45px; padding: 10px;
  border: 0; border-radius: 11px; color: white; text-decoration: none; background: linear-gradient(135deg, var(--blue), #7259e8);
  font-size: 9px; font-weight: 800; cursor: pointer;
}
.service-main-action.barmer { background: linear-gradient(135deg, #149d7b, #2e79d8); }
.service-secondary-apply { margin: 0; }
.service-detail-section ul { display: grid; gap: 7px; margin: 0; padding: 0; list-style: none; }
.service-detail-section li { display: grid; grid-template-columns: 19px minmax(0, 1fr); gap: 6px; align-items: start; color: #d1dce8; font-size: 8px; line-height: 1.45; }
.service-detail-section li .material-symbols-rounded { color: #64b1ff; font-size: 16px; }
.service-detail-section.positive li .material-symbols-rounded { color: #69dbb9; }
.service-detail-section.negative li .material-symbols-rounded { color: #ff8d9d; }
.service-detail-section.warning li .material-symbols-rounded { color: #ffc36f; }
.service-process-list { display: grid; gap: 7px; }
.service-process-list article { display: grid; grid-template-columns: 25px minmax(0, 1fr); gap: 8px; align-items: center; padding: 9px; border: 1px solid var(--line); border-radius: 11px; background: var(--surface); }
.service-process-list article > span { display: grid; place-items: center; width: 25px; height: 25px; border-radius: 8px; color: white; background: var(--blue-2); font-size: 8px; font-weight: 800; }
.service-process-list strong { font-size: 8px; line-height: 1.35; }
.service-result-card { display: grid; grid-template-columns: 38px minmax(0, 1fr); gap: 9px; align-items: center; padding: 13px; border: 1px solid rgba(55, 198, 154, .24); border-radius: 15px; background: rgba(33, 137, 106, .08); }
.service-result-card > .material-symbols-rounded { color: #69dbb9; font-size: 28px; }
.service-result-card h3 { margin-top: 3px; font-size: 10px; line-height: 1.4; }
.service-related > div:not(.path-section-heading) { display: grid; gap: 6px; }
.service-related > div > strong { font-size: 8px; }
.service-related > div > span { display: flex; flex-wrap: wrap; gap: 5px; }
.service-related button {
  display: flex; align-items: center; gap: 5px; min-height: 33px; padding: 7px 8px; border: 1px solid var(--line);
  border-radius: 9px; color: #a9ceff; background: var(--surface); font-size: 7px; cursor: pointer;
}
.service-related button .material-symbols-rounded { font-size: 15px; }
.help-detail-hero { grid-template-columns: 44px minmax(0, 1fr); }
.help-detail-hero > p, .help-detail-hero > .priority-badge { grid-column: 1 / -1; }
.help-detail-hero h2 { margin-top: 3px; font-size: 17px; line-height: 1.25; }
.help-detail-hero > p { color: var(--muted); font-size: 9px; line-height: 1.5; }
.help-detail-hero > .priority-badge { width: max-content; }
.help-step-list { display: grid; gap: 7px; }
.help-step-list article {
  display: grid;
  grid-template-columns: 24px minmax(0, 1fr) auto;
  gap: 8px;
  padding: 10px;
  border: 1px solid var(--line);
  border-radius: 11px;
  background: var(--surface);
}
.help-step-list article > span {
  display: grid;
  place-items: center;
  width: 24px;
  height: 24px;
  border-radius: 8px;
  color: #a9d0ff;
  background: rgba(63, 140, 255, .11);
  font-size: 9px;
  font-weight: 800;
}
.help-step-list article strong { font-size: 9px; }
.help-step-list article p { margin-top: 4px; color: var(--muted); font-size: 8px; line-height: 1.4; }
.help-step-list article em { color: #ff9aaa; font-size: 7px; font-style: normal; font-weight: 800; }
.help-step-list article.important { border-color: rgba(255, 91, 115, .2); }
.help-phrase-list { display: grid; gap: 7px; }
.help-phrase-list article {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 30px;
  gap: 5px 8px;
  padding: 10px;
  border: 1px solid var(--line);
  border-radius: 11px;
  background: var(--surface);
}
.help-phrase-list strong { font-size: 9px; line-height: 1.4; }
.help-phrase-list p { color: var(--muted); font-size: 8px; line-height: 1.4; }
.help-phrase-list button { grid-column: 2; grid-row: 1 / 3; border: 0; color: var(--blue); background: transparent; }
.help-related > div:not(.path-section-heading) { display: grid; gap: 6px; }
.help-related > div > strong { color: var(--muted); font-size: 7px; text-transform: uppercase; letter-spacing: .06em; }
.help-related > div > span { display: flex; flex-wrap: wrap; gap: 6px; }
.help-related button {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  min-height: 32px;
  padding: 7px 8px;
  border: 1px solid var(--line);
  border-radius: 9px;
  color: #b9d7ff;
  background: var(--surface);
  font-size: 7px;
}
.help-related button .material-symbols-rounded { font-size: 15px; }
.help-reminder-link { width: 100%; justify-content: center; }
.help-main-cta {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  min-height: 44px;
  padding: 10px;
  border: 0;
  border-radius: 12px;
  color: #fff;
  text-decoration: none;
  background: linear-gradient(135deg, #367fdc, #4a9aff);
  font-size: 9px;
  font-weight: 800;
}
.help-main-cta.barmer { background: linear-gradient(135deg, #139e7d, #2e79d8); }

.german-step-link { color: #75b6ff; }
.german-library .section-heading { align-items: end; }
.german-topic-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 11px;
}
.german-topic-card {
  display: flex;
  flex-direction: column;
  min-height: 244px;
  padding: 15px;
  border: 1px solid var(--line);
  border-radius: 18px;
  background: linear-gradient(145deg, rgba(15, 37, 59, .96), rgba(8, 25, 43, .96));
}
.german-topic-head, .german-topic-meta, .lesson-meta-row, .lesson-phrase-heading {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
}
.lesson-level {
  padding: 5px 8px;
  border: 1px solid rgba(63, 140, 255, .3);
  border-radius: 999px;
  color: #9dc5ff;
  background: rgba(63, 140, 255, .09);
  font-size: 9px;
  font-weight: 700;
}
.german-topic-card h3 { margin: 14px 0 0; font-size: 15px; }
.german-topic-card > p {
  margin: 7px 0 12px;
  color: var(--muted);
  font-size: 10px;
  line-height: 1.45;
}
.german-topic-meta {
  margin-top: auto;
  color: var(--muted);
  font-size: 9px;
}
.german-topic-meta strong { color: #cfe0f5; }
.german-topic-card .path-open { margin-top: 8px; }
.german-lesson-page { display: grid; gap: 18px; }
.german-lesson-hero { margin-bottom: 0; }
.lesson-meta-row {
  margin-top: 15px;
  color: var(--muted);
  font-size: 10px;
}
.lesson-meta-row strong { color: #8dbdff; }
.german-toolbar { margin: 0; }
.german-filters { overflow-x: auto; scrollbar-width: none; }
.german-filters::-webkit-scrollbar { display: none; }
.german-filters button { flex: 0 0 auto; }
.lesson-section { display: grid; gap: 11px; }
.lesson-section .path-section-heading { margin: 0; }
.lesson-phrase-list, .vocabulary-list, .quiz-list { display: grid; gap: 10px; }
.lesson-phrase-card {
  padding: 15px;
  border: 1px solid var(--line);
  border-radius: 17px;
  background: var(--surface);
}
.lesson-phrase-card.learned {
  border-color: rgba(73, 162, 255, .45);
  background: linear-gradient(145deg, rgba(22, 56, 84, .9), rgba(10, 31, 51, .95));
}
.lesson-phrase-heading { min-height: 24px; }
.lesson-phrase-heading > .material-symbols-rounded { color: var(--blue); font-size: 21px; }
.important-phrase {
  padding: 4px 7px;
  border-radius: 999px;
  color: #ff9fb0;
  background: rgba(255, 91, 115, .1);
  font-size: 8px;
  font-weight: 700;
  text-transform: uppercase;
}
.lesson-phrase-card > strong { display: block; margin-top: 9px; font-size: 16px; line-height: 1.45; }
.lesson-phrase-card > p { margin-top: 6px; color: #c5d2e2; font-size: 12px; line-height: 1.45; }
.lesson-phrase-card > small {
  display: flex;
  align-items: center;
  gap: 5px;
  margin-top: 10px;
  color: var(--muted);
  font-size: 9px;
}
.lesson-phrase-card > small .material-symbols-rounded { font-size: 15px; }
.phrase-actions { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; margin-top: 13px; }
.phrase-actions button {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  min-height: 38px;
  border: 1px solid var(--line);
  border-radius: 11px;
  color: #a9cfff;
  background: var(--surface-2);
  font-size: 10px;
}
.phrase-actions .material-symbols-rounded { font-size: 17px; }
.dialog-card, .vocabulary-card, .quiz-card {
  border: 1px solid var(--line);
  border-radius: 17px;
  background: var(--surface);
}
.dialog-card { padding: 15px; }
.dialog-card > h4 { margin: 0 0 13px; font-size: 13px; }
.dialog-line {
  display: grid;
  grid-template-columns: 75px minmax(0, 1fr);
  gap: 10px;
  padding: 11px 0;
  border-top: 1px solid var(--line);
}
.dialog-line > span { color: #7fb2f8; font-size: 9px; font-weight: 700; }
.dialog-line strong { display: block; font-size: 12px; line-height: 1.45; }
.dialog-line p { margin-top: 4px; color: var(--muted); font-size: 10px; line-height: 1.4; }
.vocabulary-list { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.vocabulary-card { min-width: 0; padding: 13px; overflow-wrap: anywhere; }
.vocabulary-card strong, .vocabulary-card span { display: block; }
.vocabulary-card strong { color: #a9ceff; font-size: 13px; }
.vocabulary-card span { margin-top: 5px; font-size: 11px; }
.vocabulary-card p { margin-top: 9px; color: var(--muted); font-size: 9px; line-height: 1.4; }
.quiz-card { padding: 15px; }
.quiz-card > small { color: var(--blue); font-size: 9px; font-weight: 700; text-transform: uppercase; }
.quiz-card h4 { margin: 8px 0 13px; font-size: 13px; line-height: 1.45; }
.quiz-options { display: grid; gap: 8px; }
.quiz-options button {
  display: grid;
  grid-template-columns: 26px minmax(0, 1fr);
  align-items: center;
  gap: 8px;
  min-height: 44px;
  padding: 7px 10px;
  border: 1px solid var(--line);
  border-radius: 11px;
  text-align: left;
  color: #dce5f1;
  background: var(--surface-2);
  font-size: 10px;
  line-height: 1.35;
}
.quiz-options button > span {
  display: grid;
  place-items: center;
  width: 24px;
  height: 24px;
  border-radius: 8px;
  color: #9ec6ff;
  background: rgba(63, 140, 255, .12);
  font-weight: 700;
}
.quiz-options button.selected { border-color: #ff7586; }
.quiz-options button.correct-answer { border-color: #4ea5ff; background: rgba(63, 140, 255, .12); }
.quiz-feedback { margin-top: 12px; padding: 11px; border-radius: 11px; background: rgba(63, 140, 255, .08); }
.quiz-feedback strong { color: #8ec0ff; font-size: 11px; }
.quiz-card.incorrect .quiz-feedback strong { color: #ff91a0; }
.quiz-feedback p { margin-top: 4px; color: var(--muted); font-size: 9px; line-height: 1.4; }

.career-page, .career-detail-page { display: grid; gap: 18px; }
.career-search-panel {
  display: grid;
  gap: 13px;
  padding: 17px;
  border: 1px solid var(--line);
  border-radius: 19px;
  background: linear-gradient(145deg, rgba(16, 39, 63, .95), rgba(8, 25, 43, .96));
}
.career-search-panel h2 { margin-top: 3px; }
.career-search {
  display: flex;
  align-items: center;
  gap: 8px;
  min-height: 46px;
  padding: 0 12px;
  border: 1px solid var(--line);
  border-radius: 13px;
  background: var(--surface-2);
}
.career-search .material-symbols-rounded { color: var(--muted); }
.career-search input {
  min-width: 0;
  width: 100%;
  border: 0;
  outline: 0;
  color: var(--text);
  background: transparent;
}
.career-filters { overflow-x: auto; scrollbar-width: none; }
.career-filters::-webkit-scrollbar { display: none; }
.career-filters button { flex: 0 0 auto; }
.career-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 11px; }
.career-card {
  display: flex;
  flex-direction: column;
  min-height: 300px;
  padding: 15px;
  border: 1px solid var(--line);
  border-radius: 18px;
  background: var(--surface);
}
.career-card-head, .career-progress-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
}
.demand-badge {
  padding: 5px 7px;
  border-radius: 999px;
  color: #9dcbff;
  background: rgba(63, 140, 255, .1);
  font-size: 8px;
  font-weight: 700;
}
.demand-badge.very-high { color: #73ddbd; background: rgba(57, 188, 146, .1); }
.demand-badge.medium-high, .demand-badge.medium { color: #ffca85; background: rgba(255, 173, 69, .1); }
.career-card h3 { margin: 14px 0 0; font-size: 15px; line-height: 1.25; }
.career-card > p { margin: 7px 0 12px; color: var(--muted); font-size: 10px; line-height: 1.45; }
.career-facts { display: grid; gap: 7px; margin-top: auto; }
.career-facts > span {
  display: grid;
  gap: 3px;
  padding: 8px;
  border: 1px solid rgba(37, 56, 78, .75);
  border-radius: 10px;
  background: rgba(16, 36, 58, .55);
}
.career-facts small { color: var(--muted); font-size: 8px; }
.career-facts strong { font-size: 9px; line-height: 1.35; }
.career-progress-row { margin-top: 10px; color: var(--muted); font-size: 8px; }
.career-progress-row strong { color: #cfe0f5; }
.career-card .path-card-progress { margin-top: 6px; }
.career-card .path-open { margin-top: 8px; }
.career-empty { grid-column: 1 / -1; }
.career-general-blocks { display: grid; gap: 11px; margin-top: 4px; }
.career-general-blocks .section-heading { margin-top: 12px; }
.career-reference-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 9px; }
.career-reference-grid article {
  min-width: 0;
  padding: 13px;
  border: 1px solid var(--line);
  border-radius: 15px;
  background: var(--surface);
}
.career-reference-grid .material-symbols-rounded { color: var(--blue); font-size: 20px; }
.career-reference-grid strong { display: block; margin-top: 8px; font-size: 11px; overflow-wrap: anywhere; }
.career-reference-grid p { margin-top: 6px; color: var(--muted); font-size: 9px; line-height: 1.45; }
.career-warning-list, .career-sites { display: grid; gap: 8px; }
.career-warning-list > div {
  display: grid;
  grid-template-columns: 24px 1fr;
  gap: 8px;
  align-items: start;
  padding: 11px;
  border: 1px solid rgba(255, 117, 134, .2);
  border-radius: 12px;
  background: rgba(255, 91, 115, .05);
}
.career-warning-list .material-symbols-rounded { color: #ff8495; font-size: 19px; }
.career-warning-list p { font-size: 10px; line-height: 1.4; }
.career-sites button {
  display: grid;
  grid-template-columns: 32px minmax(0, 1fr) 20px;
  align-items: center;
  gap: 9px;
  min-height: 66px;
  padding: 10px 12px;
  border: 1px solid var(--line);
  border-radius: 14px;
  text-align: left;
  background: var(--surface);
}
.career-sites button > .material-symbols-rounded { color: var(--blue); }
.career-sites strong, .career-sites small { display: block; }
.career-sites strong { font-size: 11px; }
.career-sites small { margin-top: 4px; color: var(--muted); font-size: 9px; line-height: 1.35; }
.career-sites-entry,
.career-sites-summary {
  display: grid;
  grid-template-columns: 42px minmax(0, 1fr) 24px;
  align-items: center;
  gap: 11px;
  width: 100%;
  padding: 14px;
  border: 1px solid rgba(63, 140, 255, .32);
  border-radius: 16px;
  text-align: left;
  color: var(--text);
  background: linear-gradient(135deg, rgba(34, 77, 126, .65), rgba(12, 32, 54, .92));
}
.career-sites-entry { margin: 14px 0; }
.career-sites-entry-icon {
  display: grid;
  place-items: center;
  width: 42px;
  height: 42px;
  border-radius: 13px;
  color: #9bc5ff;
  background: rgba(63, 140, 255, .15);
}
.career-sites-entry small,
.career-sites-entry strong,
.career-sites-entry em,
.career-sites-summary strong,
.career-sites-summary small { display: block; }
.career-sites-entry small { color: #8cbcff; font-size: 8px; font-weight: 800; text-transform: uppercase; letter-spacing: .08em; }
.career-sites-entry strong { margin-top: 3px; font-size: 12px; line-height: 1.35; }
.career-sites-entry em { margin-top: 4px; color: var(--muted); font-size: 9px; font-style: normal; }
.career-sites-summary { background: var(--surface); border-color: var(--line); }
.career-sites-summary > .material-symbols-rounded { color: var(--blue); }
.career-sites-summary strong { font-size: 11px; }
.career-sites-summary small { margin-top: 4px; color: var(--muted); font-size: 9px; line-height: 1.4; }
.job-sites-page { display: grid; gap: 14px; padding-bottom: 12px; }
.job-sites-hero {
  display: grid;
  grid-template-columns: 44px minmax(0, 1fr);
  gap: 10px;
  padding: 17px;
  border: 1px solid rgba(63, 140, 255, .25);
  border-radius: 18px;
  background: linear-gradient(145deg, rgba(26, 62, 104, .76), rgba(8, 27, 47, .94));
}
.job-sites-hero .detail-icon { align-self: start; }
.job-sites-hero h2 { margin-top: 3px; font-size: 18px; line-height: 1.2; }
.job-sites-hero > p { grid-column: 1 / -1; color: var(--muted); font-size: 10px; line-height: 1.5; }
.job-sites-hero > strong {
  grid-column: 1 / -1;
  width: max-content;
  padding: 6px 9px;
  border-radius: 999px;
  color: #9fc9ff;
  background: rgba(63, 140, 255, .12);
  font-size: 9px;
}
.job-sites-tools {
  display: grid;
  gap: 10px;
  padding: 13px;
  border: 1px solid var(--line);
  border-radius: 16px;
  background: var(--surface);
}
.job-site-filters {
  display: flex;
  gap: 7px;
  margin: 0 -3px;
  padding: 0 3px 3px;
  overflow-x: auto;
  scrollbar-width: none;
}
.job-site-filters::-webkit-scrollbar { display: none; }
.job-site-filters button { flex: 0 0 auto; white-space: nowrap; }
.job-safety-warning {
  display: grid;
  grid-template-columns: 25px 1fr;
  gap: 9px;
  padding: 12px;
  border: 1px solid rgba(255, 181, 72, .28);
  border-radius: 14px;
  background: rgba(255, 169, 43, .07);
}
.job-safety-warning .material-symbols-rounded { color: #ffc36f; font-size: 21px; }
.job-safety-warning p { color: #e7c997; font-size: 9px; line-height: 1.5; }
.job-sites-results { display: grid; gap: 10px; }
.job-sites-grid { display: grid; gap: 11px; }
.job-site-card {
  display: grid;
  gap: 11px;
  min-width: 0;
  padding: 14px;
  border: 1px solid var(--line);
  border-radius: 17px;
  background: var(--surface);
}
.job-site-card-head {
  display: grid;
  grid-template-columns: 38px minmax(0, 1fr) 34px;
  align-items: center;
  gap: 9px;
}
.job-site-logo {
  display: grid;
  place-items: center;
  width: 38px;
  height: 38px;
  border-radius: 12px;
  color: #a8cdff;
  background: rgba(63, 140, 255, .13);
  font-size: 15px;
  font-weight: 800;
}
.job-site-card h3 { font-size: 13px; line-height: 1.25; overflow-wrap: anywhere; }
.job-site-card-head small { display: block; margin-top: 3px; color: var(--muted); font-size: 8px; }
.favorite-site-button {
  display: grid;
  place-items: center;
  width: 34px;
  height: 34px;
  padding: 0;
  border: 1px solid var(--line);
  border-radius: 11px;
  color: var(--muted);
  background: rgba(8, 25, 43, .45);
}
.favorite-site-button.active { color: #ffcb72; border-color: rgba(255, 193, 84, .28); background: rgba(255, 181, 72, .08); }
.favorite-site-button .material-symbols-rounded { font-size: 19px; }
.job-site-badges { display: flex; flex-wrap: wrap; gap: 5px; }
.job-site-badges span {
  padding: 4px 7px;
  border-radius: 999px;
  color: #a9cfff;
  background: rgba(63, 140, 255, .1);
  font-size: 7px;
  font-weight: 800;
}
.job-site-badges .official { color: #72ddbd; background: rgba(57, 188, 146, .1); }
.job-site-badges .ausbildung { color: #bd9dff; background: rgba(145, 99, 255, .1); }
.job-site-badges .pflege { color: #ff9bb0; background: rgba(255, 91, 115, .09); }
.job-site-badges .lkw { color: #8fc7ff; }
.job-site-badges .it { color: #77dfdf; background: rgba(63, 203, 203, .09); }
.job-site-badges .international { color: #ffcb7a; background: rgba(255, 181, 72, .09); }
.job-site-description { color: #d8e4f2; font-size: 10px; line-height: 1.5; }
.job-site-meta { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 7px; }
.job-site-meta > div {
  min-width: 0;
  padding: 8px;
  border: 1px solid rgba(37, 56, 78, .72);
  border-radius: 10px;
  background: rgba(8, 25, 43, .38);
}
.job-site-meta dt { color: var(--muted); font-size: 7px; }
.job-site-meta dd { margin-top: 3px; font-size: 8px; font-weight: 700; line-height: 1.35; overflow-wrap: anywhere; }
.job-site-note {
  display: grid;
  grid-template-columns: 20px 1fr;
  gap: 7px;
  padding: 9px;
  border-radius: 10px;
  color: #c6d9ee;
  background: rgba(63, 140, 255, .06);
}
.job-site-note .material-symbols-rounded { color: #84b8ff; font-size: 17px; }
.job-site-note p { font-size: 8px; line-height: 1.45; }
.job-site-actions { display: grid; grid-template-columns: 1fr 1fr; gap: 7px; }
.job-site-actions .primary-button,
.job-site-actions .secondary-button {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 5px;
  min-width: 0;
  min-height: 38px;
  padding: 8px;
  border-radius: 11px;
  text-align: center;
  font-size: 8px;
  text-decoration: none;
}
.job-site-actions .secondary-button {
  border: 1px solid var(--line);
  color: #b9d7ff;
  background: rgba(8, 25, 43, .4);
}
.job-site-actions .material-symbols-rounded { font-size: 16px; }
.job-sites-empty { min-height: 150px; }
.report-site-button {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 7px;
  width: 100%;
  padding: 11px;
  border: 1px solid rgba(255, 117, 134, .22);
  border-radius: 13px;
  color: #ff9aa8;
  background: rgba(255, 91, 115, .05);
  font-size: 9px;
  font-weight: 700;
}
.report-site-button .material-symbols-rounded { font-size: 18px; }
.life-page, .life-detail-page { display: grid; gap: 14px; padding-bottom: 12px; }
.life-search-panel {
  display: grid;
  gap: 12px;
  padding: 16px;
  border: 1px solid var(--line);
  border-radius: 18px;
  background: linear-gradient(145deg, rgba(24, 55, 91, .72), rgba(8, 26, 45, .92));
}
.life-search-panel h2 { margin-top: 3px; font-size: 19px; }
.life-search-panel > div:first-child > p:last-child { margin-top: 6px; color: var(--muted); font-size: 9px; line-height: 1.45; }
.life-filters {
  display: flex;
  gap: 7px;
  margin: 0 -3px;
  padding: 0 3px 3px;
  overflow-x: auto;
  scrollbar-width: none;
}
.life-filters::-webkit-scrollbar { display: none; }
.life-filters button { flex: 0 0 auto; white-space: nowrap; }
.life-topic-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 10px; }
.life-topic-card {
  display: flex;
  flex-direction: column;
  min-width: 0;
  padding: 13px;
  border: 1px solid var(--line);
  border-radius: 17px;
  background: var(--surface);
}
.life-topic-head { display: flex; align-items: flex-start; justify-content: space-between; gap: 7px; }
.life-importance {
  padding: 4px 6px;
  border-radius: 999px;
  color: #9dbad9;
  background: rgba(128, 158, 192, .08);
  font-size: 7px;
  font-weight: 800;
}
.life-importance.high { color: #ffcb7a; background: rgba(255, 181, 72, .09); }
.life-topic-card h3 { margin-top: 12px; font-size: 14px; line-height: 1.25; }
.life-topic-card > p { margin: 6px 0 11px; color: var(--muted); font-size: 9px; line-height: 1.45; }
.life-card-meta { display: grid; gap: 6px; margin-top: auto; }
.life-card-meta span {
  display: grid;
  gap: 2px;
  padding: 7px;
  border: 1px solid rgba(37, 56, 78, .72);
  border-radius: 9px;
  background: rgba(8, 25, 43, .35);
}
.life-card-meta small { color: var(--muted); font-size: 7px; }
.life-card-meta strong { font-size: 8px; }
.life-topic-card .path-open { margin-top: 8px; }
.life-empty { grid-column: 1 / -1; }
.life-overview-blocks { display: grid; gap: 10px; }
.life-overview-blocks .section-heading { margin-top: 9px; }
.life-first-days { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 7px; }
.life-first-days article {
  display: grid;
  gap: 7px;
  min-width: 0;
  padding: 10px;
  border: 1px solid var(--line);
  border-radius: 12px;
  background: var(--surface);
}
.life-first-days span {
  display: grid;
  place-items: center;
  width: 20px;
  height: 20px;
  border-radius: 7px;
  color: #9cc7ff;
  background: rgba(63, 140, 255, .12);
  font-size: 8px;
  font-weight: 800;
}
.life-first-days strong { font-size: 8px; line-height: 1.3; overflow-wrap: anywhere; }
.life-contacts { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 7px; }
.life-contacts div {
  display: grid;
  grid-template-columns: 22px 1fr;
  align-items: center;
  gap: 7px;
  min-width: 0;
  padding: 10px;
  border: 1px solid var(--line);
  border-radius: 12px;
  background: var(--surface);
}
.life-contacts .material-symbols-rounded { color: var(--blue); font-size: 18px; }
.life-contacts strong { font-size: 8px; line-height: 1.35; overflow-wrap: anywhere; }
.life-hero { margin-bottom: 0; }
.life-hero.barmer-hero {
  border-color: rgba(42, 187, 150, .28);
  background: linear-gradient(145deg, rgba(18, 74, 77, .66), rgba(8, 27, 47, .94));
}
.life-hero-facts { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 8px; margin-top: 14px; }
.life-hero-facts > div {
  display: grid;
  grid-template-columns: 22px 1fr;
  gap: 2px 7px;
  min-width: 0;
  padding: 10px;
  border: 1px solid rgba(37, 56, 78, .8);
  border-radius: 11px;
  background: rgba(8, 25, 43, .42);
}
.life-hero-facts .material-symbols-rounded { grid-row: 1 / 3; color: var(--blue); font-size: 19px; }
.life-hero-facts small { color: var(--muted); font-size: 7px; }
.life-hero-facts strong { font-size: 9px; }
.life-info-card {
  position: relative;
  display: grid;
  gap: 10px;
  padding: 15px;
  border: 1px solid var(--line);
  border-radius: 17px;
  background: var(--surface);
  overflow: hidden;
}
.life-info-card.partner-section {
  border-color: rgba(42, 187, 150, .32);
  background: linear-gradient(145deg, rgba(18, 67, 69, .52), var(--surface));
}
.life-section-number {
  position: absolute;
  top: 9px;
  right: 12px;
  color: rgba(126, 173, 230, .24);
  font-size: 25px;
  font-weight: 900;
}
.life-info-card h3 { padding-right: 38px; font-size: 14px; }
.life-info-card > p { color: #d5e0ed; font-size: 10px; line-height: 1.55; white-space: pre-line; }
.life-example, .life-tip {
  display: grid;
  grid-template-columns: 22px 1fr;
  gap: 8px;
  padding: 10px;
  border-radius: 11px;
}
.life-example { background: rgba(63, 140, 255, .07); }
.life-tip { background: rgba(255, 181, 72, .07); }
.life-example > .material-symbols-rounded { color: #86b9ff; font-size: 18px; }
.life-tip > .material-symbols-rounded { color: #ffc36f; font-size: 18px; }
.life-example small, .life-tip small { color: var(--muted); font-size: 7px; font-weight: 800; text-transform: uppercase; letter-spacing: .07em; }
.life-example p, .life-tip p { margin-top: 3px; font-size: 9px; line-height: 1.45; }
.barmer-button { min-height: 44px; margin-top: 2px; text-decoration: none; background: linear-gradient(135deg, #139e7d, #2e79d8); }
.life-checklist-section { gap: 10px; }
.life-checklist-section > .reset-path-button { width: 100%; }
.life-checklist { display: grid; gap: 8px; }
.life-checklist article {
  display: grid;
  grid-template-columns: 24px minmax(0, 1fr) auto;
  align-items: center;
  gap: 8px;
  padding: 10px;
  border: 1px solid var(--line);
  border-radius: 12px;
  background: var(--surface);
}
.life-checklist article > .material-symbols-rounded { color: #6e8baa; font-size: 20px; }
.life-checklist article > strong { font-size: 9px; line-height: 1.4; }
.life-checklist article > button {
  padding: 6px 7px;
  border: 1px solid rgba(63, 140, 255, .24);
  border-radius: 8px;
  color: #9fc6ff;
  background: rgba(63, 140, 255, .08);
  font-size: 7px;
}
.life-checklist article.done { border-color: rgba(57, 188, 146, .25); background: rgba(57, 188, 146, .05); }
.life-checklist article.done > .material-symbols-rounded { color: #56d5ad; }
.life-checklist article.done > strong { color: #8ba99f; text-decoration: line-through; }
.life-list-section { gap: 10px; }
.life-detail-list { display: grid; gap: 7px; }
.life-detail-list > div {
  display: grid;
  grid-template-columns: 22px 1fr;
  gap: 8px;
  align-items: start;
  padding: 9px 10px;
  border: 1px solid var(--line);
  border-radius: 11px;
  background: var(--surface);
}
.life-detail-list .material-symbols-rounded { color: var(--blue); font-size: 17px; }
.life-detail-list p { font-size: 9px; line-height: 1.45; }
.life-list-section.warning .life-detail-list > div { border-color: rgba(255, 117, 134, .18); }
.life-list-section.warning .material-symbols-rounded { color: #ff8d9d; }
.life-list-section.emergency .life-detail-list > div { border-color: rgba(255, 181, 72, .2); }
.life-list-section.emergency .material-symbols-rounded { color: #ffc36f; }
.life-connections { gap: 11px; }
.life-connection-group { display: grid; gap: 7px; }
.life-connection-group > strong { color: var(--muted); font-size: 8px; text-transform: uppercase; letter-spacing: .06em; }
.life-connection-group > div { display: flex; flex-wrap: wrap; gap: 6px; }
.life-connection-group button, .life-path-link {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  min-height: 34px;
  padding: 7px 9px;
  border: 1px solid var(--line);
  border-radius: 10px;
  color: #b9d7ff;
  background: var(--surface);
  font-size: 8px;
}
.life-connection-group .material-symbols-rounded, .life-path-link .material-symbols-rounded { font-size: 16px; }
.life-path-link { width: 100%; justify-content: center; }
.life-help-button { width: 100%; }
.templates-page, .template-category-page, .template-detail-page { display: grid; gap: 14px; padding-bottom: 12px; }
.templates-hero, .template-category-hero, .template-detail-hero {
  display: grid;
  grid-template-columns: 44px minmax(0, 1fr);
  gap: 10px;
  padding: 17px;
  border: 1px solid rgba(63, 140, 255, .25);
  border-radius: 18px;
  background: linear-gradient(145deg, rgba(29, 61, 101, .74), rgba(8, 27, 47, .94));
}
.templates-hero .detail-icon, .template-category-hero .detail-icon, .template-detail-hero .detail-icon { align-self: start; }
.templates-hero h2, .template-category-hero h2, .template-detail-hero h2 { margin-top: 3px; font-size: 18px; line-height: 1.2; }
.templates-hero > p, .template-category-hero > p, .template-detail-hero > p {
  grid-column: 1 / -1;
  color: var(--muted);
  font-size: 10px;
  line-height: 1.5;
}
.templates-hero > strong, .template-category-hero > strong {
  grid-column: 1 / -1;
  width: max-content;
  padding: 6px 9px;
  border-radius: 999px;
  color: #9fc9ff;
  background: rgba(63, 140, 255, .12);
  font-size: 9px;
}
.template-category-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 10px; }
.template-category-card {
  display: flex;
  flex-direction: column;
  min-width: 0;
  padding: 13px;
  border: 1px solid var(--line);
  border-radius: 17px;
  background: var(--surface);
}
.template-category-head { display: flex; justify-content: space-between; align-items: flex-start; gap: 7px; }
.template-category-card h3 { margin-top: 12px; font-size: 13px; line-height: 1.3; }
.template-category-card > p { margin: 6px 0 10px; color: var(--muted); font-size: 9px; line-height: 1.45; }
.template-category-card > small { margin-top: auto; color: #92bfff; font-size: 8px; font-weight: 700; }
.template-category-card .path-open { margin-top: 9px; }
.template-safety-warning {
  display: grid;
  grid-template-columns: 23px 1fr;
  gap: 8px;
  padding: 11px;
  border: 1px solid rgba(255, 181, 72, .24);
  border-radius: 13px;
  color: #e8c997;
  background: rgba(255, 169, 43, .06);
}
.template-safety-warning .material-symbols-rounded { color: #ffc36f; font-size: 19px; }
.template-safety-warning p { font-size: 9px; line-height: 1.45; }
.template-tools {
  display: grid;
  gap: 10px;
  padding: 13px;
  border: 1px solid var(--line);
  border-radius: 16px;
  background: var(--surface);
}
.template-filters {
  display: flex;
  gap: 7px;
  margin: 0 -3px;
  padding: 0 3px 3px;
  overflow-x: auto;
  scrollbar-width: none;
}
.template-filters::-webkit-scrollbar { display: none; }
.template-filters button { flex: 0 0 auto; white-space: nowrap; }
.template-list { display: grid; gap: 9px; }
.template-list-card {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 34px;
  gap: 9px;
  padding: 13px;
  border: 1px solid var(--line);
  border-radius: 15px;
  background: var(--surface);
}
.template-list-card h3 { margin-top: 7px; font-size: 12px; line-height: 1.3; }
.template-list-card p { margin-top: 5px; color: var(--muted); font-size: 9px; line-height: 1.4; }
.template-list-card .path-open { grid-column: 1 / -1; }
.template-difficulty {
  display: inline-block;
  padding: 4px 7px;
  border-radius: 999px;
  color: #74dbbd;
  background: rgba(57, 188, 146, .09);
  font-size: 7px;
  font-weight: 800;
}
.template-difficulty.medium { color: #ffca85; background: rgba(255, 173, 69, .09); }
.template-difficulty.hard { color: #ff9aab; background: rgba(255, 91, 115, .09); }
.template-partner-card {
  display: grid;
  grid-template-columns: 35px 1fr;
  gap: 10px;
  padding: 15px;
  border: 1px solid rgba(42, 187, 150, .3);
  border-radius: 17px;
  background: linear-gradient(145deg, rgba(18, 75, 72, .58), rgba(8, 27, 47, .95));
}
.template-partner-card > .material-symbols-rounded { color: #69dbb9; font-size: 28px; }
.template-partner-card h3 { font-size: 13px; }
.template-partner-card p { margin-top: 5px; color: #c5ddd8; font-size: 9px; line-height: 1.5; }
.template-partner-card > a, .template-partner-card > small { grid-column: 1 / -1; }
.template-partner-card > a { min-height: 43px; text-decoration: none; background: linear-gradient(135deg, #139e7d, #2e79d8); }
.template-partner-card > small {
  display: flex;
  gap: 6px;
  color: #e8c997;
  font-size: 8px;
  line-height: 1.4;
}
.template-partner-card > small .material-symbols-rounded { font-size: 16px; }
.template-detail-hero > .template-difficulty { grid-column: 1 / -1; width: max-content; }
.letter-panel {
  display: grid;
  gap: 11px;
  padding: 14px;
  border: 1px solid var(--line);
  border-radius: 16px;
  background: var(--surface);
}
.letter-panel.german { border-color: rgba(63, 140, 255, .25); }
.letter-panel.translation { background: rgba(14, 34, 56, .78); }
.letter-panel pre {
  margin: 0;
  padding: 12px;
  border-radius: 12px;
  color: #dce8f5;
  background: rgba(5, 18, 32, .62);
  font: 9px/1.65 Inter, sans-serif;
  white-space: pre-wrap;
  overflow-wrap: anywhere;
}
.letter-panel.translation pre { color: #b8cadc; }
.template-info-section { gap: 10px; }
.template-info-section > div:last-child { display: flex; flex-wrap: wrap; gap: 6px; }
.template-info-section > div:last-child > span {
  padding: 7px 9px;
  border: 1px solid var(--line);
  border-radius: 9px;
  color: #b7d3f6;
  background: var(--surface);
  font-size: 8px;
  line-height: 1.35;
}
.template-info-section.placeholder > div:last-child > span { color: #ffca85; border-color: rgba(255, 173, 69, .18); }
.template-detail-actions { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 8px; }
.template-detail-actions .secondary-button {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 5px;
  min-height: 41px;
  padding: 8px;
  border: 1px solid var(--line);
  border-radius: 11px;
  color: #b9d7ff;
  background: var(--surface);
  font-size: 8px;
}
.template-detail-actions .secondary-button.active { color: #ffcb72; border-color: rgba(255, 193, 84, .25); }
.template-detail-actions .material-symbols-rounded { font-size: 17px; }
.template-connections { gap: 11px; }
.template-connections > div:not(.path-section-heading) { display: grid; gap: 6px; }
.template-connections > div > strong { color: var(--muted); font-size: 8px; text-transform: uppercase; letter-spacing: .06em; }
.template-connections > div > span { display: flex; flex-wrap: wrap; gap: 6px; }
.template-connections button {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  min-height: 33px;
  padding: 7px 9px;
  border: 1px solid var(--line);
  border-radius: 9px;
  color: #b9d7ff;
  background: var(--surface);
  font-size: 8px;
}
.template-connections button .material-symbols-rounded { font-size: 15px; }
.career-hero { margin-bottom: 0; }
.career-hero-facts { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 8px; margin-top: 15px; }
.career-hero-facts > div {
  display: grid;
  grid-template-columns: 24px 1fr;
  gap: 2px 7px;
  min-width: 0;
  padding: 10px;
  border: 1px solid rgba(37, 56, 78, .8);
  border-radius: 12px;
  background: rgba(8, 25, 43, .5);
}
.career-hero-facts .material-symbols-rounded { grid-row: 1 / 3; color: var(--blue); font-size: 20px; }
.career-hero-facts small { color: var(--muted); font-size: 8px; }
.career-hero-facts strong { min-width: 0; font-size: 9px; line-height: 1.35; overflow-wrap: anywhere; }
.career-link-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 8px; }
.career-link-grid button {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 6px;
  min-height: 74px;
  padding: 8px;
  border: 1px solid var(--line);
  border-radius: 13px;
  text-align: center;
  color: #b9d7ff;
  background: var(--surface);
  font-size: 8px;
  line-height: 1.25;
}
.career-link-grid .material-symbols-rounded { font-size: 21px; }
.career-info-section, .career-checklist-section { gap: 10px; }
.career-info-list { display: grid; gap: 7px; }
.career-info-list > div {
  display: grid;
  grid-template-columns: 25px 1fr;
  align-items: start;
  gap: 8px;
  padding: 10px 11px;
  border: 1px solid var(--line);
  border-radius: 12px;
  background: var(--surface);
}
.career-info-list > div > span {
  display: grid;
  place-items: center;
  width: 23px;
  height: 23px;
  border-radius: 8px;
  color: #91bfff;
  background: rgba(63, 140, 255, .1);
  font-size: 10px;
  font-weight: 700;
}
.career-info-list .material-symbols-rounded { font-size: 16px; }
.career-info-list p { font-size: 10px; line-height: 1.45; }
.career-info-list.warning > div { border-color: rgba(255, 117, 134, .18); }
.career-info-list.warning > div > span { color: #ff8d9d; background: rgba(255, 91, 115, .08); }
.career-phrase-list { display: grid; gap: 8px; }
.career-phrase-list article {
  display: grid;
  grid-template-columns: 1fr 34px;
  align-items: center;
  gap: 8px;
  padding: 11px 12px;
  border: 1px solid var(--line);
  border-radius: 12px;
  background: var(--surface);
}
.career-phrase-list strong { font-size: 11px; line-height: 1.4; }
.career-phrase-list button { padding: 0; border: 0; color: var(--blue); background: transparent; }
.career-checklist-section > .reset-path-button { width: 100%; }
.career-checklist { display: grid; gap: 8px; }
.career-checklist article {
  display: grid;
  grid-template-columns: 25px minmax(0, 1fr) auto;
  align-items: center;
  gap: 8px;
  padding: 11px;
  border: 1px solid var(--line);
  border-radius: 13px;
  background: var(--surface);
}
.career-checklist article > .material-symbols-rounded { color: var(--blue); font-size: 21px; }
.career-checklist strong { font-size: 10px; line-height: 1.35; }
.career-checklist button {
  min-height: 32px;
  padding: 0 9px;
  border: 1px solid var(--line);
  border-radius: 9px;
  color: #9dc8ff;
  background: var(--surface-2);
  font-size: 8px;
}
.career-checklist article.done { opacity: .72; border-color: rgba(73, 162, 255, .4); }
.career-checklist article.done strong { text-decoration: line-through; }
.career-apply { margin-top: 0; }

@media (max-width: 380px) {
  .welcome-card { grid-template-columns: 1fr 88px; padding: 18px; }
  .progress-ring { width: 82px; height: 82px; }
  .quick-grid { grid-template-columns: repeat(2, 1fr); }
  .quick-card { min-height: 78px; }
  .menu-grid { grid-template-columns: repeat(2, 1fr); }
  .menu-card { min-height: 98px; }
  .journey-grid { grid-template-columns: 1fr; }
  .reminder-form-grid { grid-template-columns: 1fr; }
  .reminder-stats { grid-template-columns: repeat(2, 1fr); }
  .journey-card { min-height: 200px; }
  .path-progress-summary { grid-template-columns: 1fr; }
  .document-category-grid { grid-template-columns: 1fr; }
  .document-category-card { min-height: 210px; }
  .document-detail-card summary { grid-template-columns: 30px minmax(0, 1fr) 20px; }
  .document-detail-card summary .priority-badge { display: none; }
  .german-topic-grid, .vocabulary-list { grid-template-columns: 1fr; }
  .german-topic-card { min-height: 220px; }
  .career-grid, .career-reference-grid { grid-template-columns: 1fr; }
  .career-card { min-height: 270px; }
  .career-hero-facts { grid-template-columns: 1fr; }
  .profile-form-grid,
  .profile-check-grid,
  .profile-goals-grid,
  .readiness-grid,
  .help-situation-grid,
  .help-request-grid,
  .help-contact-grid,
  .service-card-grid,
  .service-card-grid.compact,
  .service-request-grid,
  .services-hero-actions,
  .letter-check-card > div:last-child { grid-template-columns: 1fr; }
}

@media (max-width: 430px) {
  .hero { gap: 8px; }
  .page-heading h1 { font-size: 21px; overflow-wrap: normal; }
  .language-control { padding: 0 8px; }
  .language-control select { max-width: 82px; }
}

.admin-shell { display: grid; gap: 16px; padding-bottom: 24px; }
.admin-login-shell { min-height: 68vh; place-items: center; }
.admin-login-card {
  display: grid; gap: 13px; width: min(100%, 430px); padding: 24px;
  border: 1px solid rgba(67, 140, 255, .24); border-radius: 22px;
  background: linear-gradient(155deg, rgba(17, 45, 76, .96), rgba(7, 23, 40, .98));
  box-shadow: 0 24px 60px rgba(0, 0, 0, .28);
}
.admin-brand-icon { display: grid; place-items: center; width: 52px; height: 52px; border-radius: 16px; color: #d7e9ff; background: rgba(63, 140, 255, .17); font-size: 29px; }
.admin-login-card h2, .admin-dashboard-header h2, .admin-page-header h2 { margin: 0; font-size: 22px; }
.admin-login-card > p, .admin-dashboard-header p, .admin-page-header p { margin: 0; color: var(--muted); font-size: 10px; line-height: 1.5; }
.admin-login-card form { display: grid; gap: 12px; }
.admin-login-card label, .admin-editor > label, .admin-form-grid > label {
  display: grid; gap: 7px; color: #c6d8ec; font-size: 9px; font-weight: 650;
}
.admin-login-card input, .admin-editor input, .admin-editor textarea, .admin-editor select,
.admin-toolbar input, .admin-toolbar select {
  width: 100%; min-height: 43px; padding: 10px 12px; border: 1px solid var(--line); border-radius: 11px;
  color: var(--text); background: rgba(5, 19, 34, .78); font: inherit; outline: none;
}
.admin-editor textarea { line-height: 1.55; resize: vertical; }
.admin-login-card input:focus, .admin-editor input:focus, .admin-editor textarea:focus, .admin-toolbar input:focus, .admin-toolbar select:focus { border-color: rgba(80, 157, 255, .65); }
.admin-production-note {
  padding: 12px 13px; border: 1px solid rgba(255, 179, 76, .2); border-radius: 12px;
  color: #ebca98; background: rgba(255, 169, 51, .07); font-size: 9px; line-height: 1.5;
}
.admin-dashboard-header, .admin-page-header {
  display: flex; align-items: center; justify-content: space-between; gap: 12px;
  padding: 17px; border: 1px solid var(--line); border-radius: 18px; background: var(--surface);
}
.admin-dashboard-header > div, .admin-page-header > div { min-width: 0; }
.admin-logout, .admin-back-button {
  display: inline-flex; align-items: center; justify-content: center; gap: 5px; min-height: 37px; padding: 8px 10px;
  border: 1px solid var(--line); border-radius: 10px; color: #b9d7ff; background: var(--surface-2); font-size: 8px;
}
.admin-logout .material-symbols-rounded, .admin-back-button .material-symbols-rounded { font-size: 16px; }
.admin-header-actions { display: flex; flex-wrap: wrap; align-items: center; justify-content: end; gap: 7px; }
.admin-api-status { display: inline-flex; align-items: center; gap: 6px; min-height: 31px; padding: 6px 9px; border: 1px solid var(--line); border-radius: 9px; color: #c7d7e8; background: var(--surface-2); font-size: 7px; white-space: nowrap; }
.admin-api-status i { width: 7px; height: 7px; border-radius: 50%; background: #e8a54d; box-shadow: 0 0 0 3px rgba(232, 165, 77, .1); }
.admin-api-status.connected i { background: #43d7a5; box-shadow: 0 0 0 3px rgba(67, 215, 165, .1); }
.admin-api-warning { padding: 11px 13px; border: 1px solid rgba(255, 173, 69, .2); border-radius: 12px; color: #f1cd97; background: rgba(255, 173, 69, .07); font-size: 9px; line-height: 1.5; }
.admin-page-header { align-items: start; }
.admin-page-header .admin-back-button { order: -1; }
.admin-stat-grid { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 8px; }
.admin-stat-grid article { display: grid; gap: 4px; padding: 13px; border: 1px solid var(--line); border-radius: 13px; background: var(--surface); }
.admin-stat-grid strong { color: #83b9ff; font-size: 19px; }
.admin-stat-grid span { color: var(--muted); font-size: 8px; line-height: 1.3; }
.admin-dashboard-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 10px; }
.admin-dashboard-card {
  display: grid; grid-template-columns: 38px 1fr; gap: 9px; padding: 14px;
  border: 1px solid var(--line); border-radius: 15px; background: var(--surface);
}
.admin-dashboard-card > .material-symbols-rounded { display: grid; place-items: center; width: 36px; height: 36px; border-radius: 11px; color: #83b9ff; background: rgba(63, 140, 255, .11); font-size: 21px; }
.admin-dashboard-card h3 { margin: 2px 0 3px; font-size: 11px; }
.admin-dashboard-card p { margin: 0; color: var(--muted); font-size: 8px; }
.admin-dashboard-card button { min-height: 34px; border: 0; border-radius: 9px; color: white; background: #347ee8; font-size: 8px; }
.admin-dashboard-card button.secondary { color: #b9d7ff; background: var(--surface-2); }
.admin-toolbar { display: flex; flex-wrap: wrap; align-items: center; gap: 8px; padding: 12px; border: 1px solid var(--line); border-radius: 14px; background: var(--surface); }
.admin-search { display: flex; align-items: center; flex: 1 1 210px; gap: 7px; padding-left: 10px; border: 1px solid var(--line); border-radius: 11px; background: rgba(5, 19, 34, .78); }
.admin-search input { min-width: 0; padding-left: 0; border: 0; background: transparent; }
.admin-search .material-symbols-rounded { color: var(--muted); font-size: 18px; }
.admin-toolbar select { width: auto; min-width: 140px; }
.admin-list { display: grid; gap: 9px; }
.admin-list-item {
  display: grid; grid-template-columns: minmax(0, 1fr) auto; gap: 12px; align-items: center; padding: 13px;
  border: 1px solid var(--line); border-radius: 14px; background: var(--surface);
}
.admin-list-item.inactive { opacity: .58; }
.admin-list-copy { min-width: 0; }
.admin-list-copy > span { color: #77b2ff; font-size: 7px; text-transform: uppercase; letter-spacing: .06em; }
.admin-list-copy h3 { margin: 5px 0; font-size: 11px; }
.admin-list-copy p, .admin-list-copy small { margin: 0; color: var(--muted); font-size: 8px; line-height: 1.45; overflow-wrap: anywhere; }
.admin-list-actions { display: flex; flex-wrap: wrap; justify-content: end; gap: 5px; }
.admin-list-actions button {
  display: inline-flex; align-items: center; justify-content: center; gap: 4px; min-height: 32px; padding: 7px 8px;
  border: 1px solid var(--line); border-radius: 8px; color: #b9d7ff; background: var(--surface-2); font-size: 7px;
}
.admin-list-actions button.danger { color: #ff9aaa; border-color: rgba(255, 91, 115, .2); }
.admin-list-actions .material-symbols-rounded { font-size: 15px; }
.admin-editor { display: grid; gap: 13px; padding: 16px; border: 1px solid var(--line); border-radius: 18px; background: var(--surface); }
.admin-form-heading {
  display: flex; align-items: start; justify-content: space-between; gap: 12px; padding: 14px;
  border: 1px solid rgba(63, 140, 255, .18); border-radius: 14px; background: rgba(63, 140, 255, .06);
}
.admin-form-heading h3 { margin: 3px 0; font-size: 14px; }
.admin-form-heading p { margin: 0; color: var(--muted); font-size: 9px; line-height: 1.45; }
.admin-form-heading > span { padding: 6px 8px; border-radius: 8px; color: #9dc8ff; background: rgba(63, 140, 255, .12); font-size: 8px; white-space: nowrap; }
.admin-form-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 11px; }
.admin-form-grid label:has(textarea), .admin-form-grid .admin-check, .admin-form-grid .admin-form-actions { grid-column: 1 / -1; }
.admin-check { display: flex !important; align-items: center; gap: 8px; min-height: 40px; padding: 10px 12px; border: 1px solid var(--line); border-radius: 11px; background: rgba(5, 19, 34, .55); }
.admin-check input { width: 17px; min-height: 17px; margin: 0; }
.admin-json-hint { margin: 0; color: #c8aa78; font-size: 9px; line-height: 1.5; }
.admin-json-editor { min-height: 420px; font-family: ui-monospace, SFMono-Regular, Menlo, monospace !important; font-size: 9px !important; tab-size: 2; }
.admin-form-actions { display: flex; flex-wrap: wrap; gap: 8px; padding-top: 4px; }
.admin-form-actions > * { flex: 1 1 130px; }
.admin-request-hero, .admin-request-message, .admin-barmer-preview { padding: 14px; border: 1px solid var(--line); border-radius: 14px; background: rgba(5, 19, 34, .56); }
.admin-request-hero > span { color: #77b2ff; font-size: 8px; text-transform: uppercase; }
.admin-request-hero h3 { margin: 5px 0; font-size: 16px; }
.admin-request-hero p, .admin-request-message p { margin: 0; color: var(--muted); font-size: 9px; line-height: 1.55; }
.admin-request-data { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 8px; margin: 0; }
.admin-request-data div { padding: 10px; border: 1px solid var(--line); border-radius: 10px; background: var(--surface-2); }
.admin-request-data dt { color: var(--muted); font-size: 7px; }
.admin-request-data dd { margin: 5px 0 0; font-size: 9px; overflow-wrap: anywhere; }
.notification-status-row { display: flex; flex-wrap: wrap; gap: 5px; margin-top: 8px; }
.notification-badge { padding: 4px 7px; border: 1px solid var(--line); border-radius: 999px; color: var(--muted); background: var(--surface-2); font-size: 7px; text-transform: uppercase; }
.notification-badge.sent { color: #75e0bb; border-color: rgba(67, 215, 165, .3); background: rgba(67, 215, 165, .08); }
.notification-badge.failed { color: #ff91a2; border-color: rgba(255, 91, 115, .3); background: rgba(255, 91, 115, .08); }
.notification-badge.disabled { color: #e9b96e; border-color: rgba(232, 165, 77, .25); background: rgba(232, 165, 77, .07); }
.admin-notification-result, .admin-notification-settings { display: grid; gap: 12px; padding: 14px; border: 1px solid var(--line); border-radius: 14px; background: rgba(5, 19, 34, .56); }
.admin-notification-result > strong { font-size: 10px; }
.admin-notification-result ul { margin: 0; padding-left: 18px; color: #ff9aaa; font-size: 8px; line-height: 1.5; }
.admin-notification-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 9px; }
.admin-notification-grid article { display: grid; grid-template-columns: 26px 1fr; gap: 2px 8px; padding: 11px; border: 1px solid var(--line); border-radius: 11px; background: var(--surface-2); }
.admin-notification-grid .material-symbols-rounded { grid-row: 1 / 3; color: #ff9aaa; font-size: 21px; }
.admin-notification-grid article.configured .material-symbols-rounded { color: #75e0bb; }
.admin-notification-grid strong { font-size: 9px; }
.admin-notification-grid small { color: var(--muted); font-size: 7px; }
.admin-notification-settings > p { margin: 0; color: var(--muted); font-size: 9px; }
.admin-contact-actions { display: flex; flex-wrap: wrap; gap: 7px; }
.admin-contact-actions a { padding: 9px 11px; border-radius: 9px; color: white; text-decoration: none; background: #347ee8; font-size: 8px; }
.admin-barmer-preview { display: grid; grid-template-columns: 38px 1fr; gap: 11px; border-color: rgba(36, 188, 142, .25); background: rgba(20, 136, 104, .08); }
.admin-barmer-preview > .material-symbols-rounded { color: #57d9b2; font-size: 29px; }
.admin-barmer-preview h3 { margin: 3px 0 6px; font-size: 14px; }
.admin-barmer-preview p, .admin-barmer-preview small { display: block; margin: 0 0 9px; color: #c5ddd8; font-size: 9px; line-height: 1.5; }
.admin-barmer-preview a { display: inline-flex; padding: 9px 11px; border-radius: 9px; color: white; text-decoration: none; background: #159b79; font-size: 8px; }
.admin-backup-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 10px; }
.admin-backup-grid article { display: grid; gap: 9px; padding: 16px; border: 1px solid var(--line); border-radius: 15px; background: var(--surface); }
.admin-backup-grid article > .material-symbols-rounded { color: #83b9ff; font-size: 27px; }
.admin-backup-grid h3, .admin-backup-grid p { margin: 0; }
.admin-backup-grid h3 { font-size: 12px; }
.admin-backup-grid p { color: var(--muted); font-size: 9px; line-height: 1.45; }
.admin-backup-grid button, .admin-file-button { display: grid; place-items: center; min-height: 40px; padding: 9px; border: 0; border-radius: 10px; color: white; background: #347ee8; font-size: 8px; cursor: pointer; }
.admin-file-button input { display: none; }
.admin-backup-grid article.danger { border-color: rgba(255, 91, 115, .22); }
.admin-backup-grid article.danger button { background: #a83449; }

@media (max-width: 620px) {
  .admin-stat-grid, .admin-dashboard-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .admin-page-header { display: grid; grid-template-columns: 1fr auto; }
  .admin-page-header > div { grid-column: 1 / -1; grid-row: 2; }
  .admin-page-header .admin-back-button { justify-self: start; }
  .admin-form-grid, .admin-request-data, .admin-backup-grid { grid-template-columns: 1fr; }
  .admin-form-grid label:has(textarea), .admin-form-grid .admin-check, .admin-form-grid .admin-form-actions { grid-column: auto; }
  .admin-list-item { grid-template-columns: 1fr; }
  .admin-list-actions { justify-content: start; }
}

@media (max-width: 380px) {
  .admin-stat-grid, .admin-dashboard-grid { grid-template-columns: 1fr; }
  .admin-toolbar { display: grid; }
  .admin-toolbar select { width: 100%; }
}
