/* Manifest Cleanup V6: generic dashboard card/grid rules removed. Dashboard cards now use only portal-dashboard-layout.css. */

:root {
  --teal:        #0ea5a0;
  --teal-deep:   #0b8b87;
  --teal-glow:   rgba(14,165,160,.18);
  --amber:       #f6b43c;
  --amber-soft:  rgba(246,180,60,.14);
  --red-soft:    rgba(239,68,68,.08);
  --red:         #ef4444;

  --bg:          #eef7f7;
  --bg2:         #e3f4f2;
  --surface:     rgba(255,255,255,.82);
  --surface2:    rgba(255,255,255,.94);
  --surface3:    rgba(255,255,255,.72);
  --border:      rgba(14,165,160,.16);
  --border-strong: rgba(14,165,160,.24);
  --border2:     rgba(255,255,255,.70);
  --ink:         #0c1116;
  --ink2:        #2b3c47;
  --muted:       #5a6e7a;
  --pill-bg:     rgba(255,255,255,.76);

  --shadow-sm:   0 2px 10px rgba(12,17,22,.07);
  --shadow-md:   0 8px 32px rgba(12,17,22,.10);
  --shadow-lg:   0 24px 72px rgba(12,17,22,.13);

  --r-sm: 14px;
  --r-md: 22px;
  --r-lg: 32px;
  --r-xl: 44px;

  --hero-grad: linear-gradient(145deg, #d4f0ee 0%, #e8f7f5 45%, #fdf6e3 100%);
  --soft-grad: linear-gradient(145deg, rgba(212,240,238,.92) 0%, rgba(232,247,245,.98) 45%, rgba(253,246,227,.88) 100%);
  --accent-grad: linear-gradient(145deg, #10a7a0 0%, #0b8b87 100%);
}

html[data-theme="dark"] {
  --bg:          #182329;
  --bg2:         #223038;
  --surface:     rgba(24,36,43,.90);
  --surface2:    rgba(30,44,52,.94);
  --surface3:    rgba(22,40,46,.78);
  --border:      rgba(132,188,190,.18);
  --border-strong: rgba(14,165,160,.36);
  --border2:     rgba(255,255,255,.10);
  --ink:         #edf6f4;
  --ink2:        #c6d8d4;
  --muted:       #8aa1a0;
  --pill-bg:     rgba(29,42,49,.88);
  --teal-glow:   rgba(76,176,168,.16);
  --amber-soft:  rgba(246,180,60,.08);

  --shadow-sm:   0 2px 10px rgba(0,0,0,.30);
  --shadow-md:   0 8px 32px rgba(0,0,0,.40);
  --shadow-lg:   0 24px 72px rgba(0,0,0,.50);

  --hero-grad: linear-gradient(145deg, #203036 0%, #243840 50%, #2f3631 100%);
  --soft-grad: linear-gradient(145deg, rgba(16,36,38,.94) 0%, rgba(16,42,47,.98) 45%, rgba(26,36,16,.90) 100%);
  --accent-grad: linear-gradient(145deg, #10a7a0 0%, #0b8b87 100%);
}

*,
*::before,
*::after { box-sizing: border-box; }

html { scroll-behavior: smooth; background: var(--bg) !important; }

html, body { min-height: 100%; }
body { min-height: 100vh; }

body {
  margin: 0;
  color: var(--ink) !important;
  font-family: "Plus Jakarta Sans", system-ui, -apple-system, sans-serif !important;
  font-size: 16px;
  line-height: 1.6;
  background: var(--bg) !important;
  overflow-x: hidden;
  transition: background .3s ease, color .3s ease;
}
body::before {
  content: "";
  position: fixed;
  inset: 0;
  background:
    radial-gradient(ellipse 900px 600px at 15% 10%, var(--teal-glow), transparent 60%),
    radial-gradient(ellipse 700px 500px at 85% 5%, var(--amber-soft), transparent 55%);
  pointer-events: none;
  z-index: 0;
}
html[data-theme="dark"] body::before {
  background:
    radial-gradient(ellipse 820px 520px at 14% 8%, rgba(76,176,168,.08), transparent 58%),
    radial-gradient(ellipse 620px 420px at 86% 4%, rgba(246,180,60,.04), transparent 52%);
}

/* Portal Darkmode Standard: Dashboard + Master_RIVAID */
html[data-theme="dark"] {
  color-scheme: dark;
  background:
    linear-gradient(180deg, rgba(10,34,50,.96) 0px, rgba(8,29,42,.94) 136px, rgba(13,27,30,.98) 248px, #0d1b1e 370px),
    #0d1b1e !important;
}
html[data-theme="dark"] body[class^="portal-"],
html[data-theme="dark"] body[class*=" portal-"] {
  background:
    linear-gradient(180deg, rgba(10,34,50,.96) 0px, rgba(8,29,42,.94) 136px, rgba(13,27,30,.98) 248px, #0d1b1e 370px),
    #0d1b1e !important;
  background-attachment: fixed !important;
  color: #e8f4f4 !important;
}
html[data-theme="dark"] body[class^="portal-"]::before,
html[data-theme="dark"] body[class*=" portal-"]::before {
  background:
    radial-gradient(ellipse 900px 600px at 15% 10%, rgba(14,165,160,.18), transparent 60%),
    radial-gradient(ellipse 700px 500px at 85% 5%, rgba(246,180,60,.14), transparent 55%) !important;
}
body > * { position: relative; z-index: 1; }

a { color: inherit; text-decoration: none; }

.wrap,
.m-wrap {
  max-width: 1100px !important;
  margin: 0 auto !important;
  padding-left: 24px !important;
  padding-right: 24px !important;
}
@media (max-width: 640px) {
  .wrap,
  .m-wrap { padding-left: 16px !important; padding-right: 16px !important; }
}

.auth-main {
  padding-top: 34px !important;
  padding-bottom: 56px !important;
}

body.auth-login .auth-main {
  padding-top: 54px !important;
}

.auth-shell {
  max-width: 1120px !important;
  margin: 0 auto !important;
  display: grid !important;
  grid-template-columns: minmax(0, 1.08fr) minmax(360px, .92fr) !important;
  background: var(--surface) !important;
  border: 1px solid var(--border) !important;
  border-radius: var(--r-lg) !important;
  box-shadow: var(--shadow-md) !important;
  overflow: hidden !important;
  backdrop-filter: blur(16px) !important;
  -webkit-backdrop-filter: blur(16px) !important;
}

.auth-story {
  display: flex !important;
  flex-direction: column !important;
  justify-content: space-between !important;
  gap: 24px !important;
  padding: 34px 36px 36px !important;
  background: var(--hero-grad) !important;
  border-right: 1px solid rgba(14,165,160,.10) !important;
}

.auth-story-copy {
  display: grid !important;
  gap: 14px !important;
}

.auth-story-eyebrow {
  display: inline-flex !important;
  align-items: center !important;
  gap: 8px !important;
  width: fit-content !important;
  padding: 7px 12px !important;
  border-radius: 999px !important;
  background: rgba(255,255,255,.72) !important;
  border: 1px solid rgba(14,165,160,.14) !important;
  color: var(--teal-deep) !important;
  font-size: 12px !important;
  font-weight: 800 !important;
  letter-spacing: .06em !important;
  text-transform: uppercase !important;
}

.auth-story h1 {
  margin: 0 !important;
  font-size: clamp(34px, 4.4vw, 60px) !important;
  max-width: 12ch !important;
}

.auth-story .sub {
  margin: 0 !important;
  max-width: 34rem !important;
  font-size: 16px !important;
  color: var(--ink2) !important;
}

.auth-story-visual {
  min-height: 220px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  border-radius: 26px !important;
  border: 1px solid rgba(14,165,160,.12) !important;
  background:
    radial-gradient(circle at 30% 30%, rgba(255,255,255,.78), transparent 44%),
    linear-gradient(135deg, rgba(14,165,160,.12), rgba(246,180,60,.10)) !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.54) !important;
}

.auth-story-emoji {
  font-size: clamp(56px, 9vw, 88px) !important;
  line-height: 1 !important;
  filter: drop-shadow(0 10px 24px rgba(12,17,22,.10)) !important;
}

.auth-story-points {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 12px !important;
}

.auth-story-point {
  display: grid !important;
  gap: 4px !important;
  padding: 14px 16px !important;
  border-radius: 20px !important;
  background: rgba(255,255,255,.60) !important;
  border: 1px solid rgba(14,165,160,.10) !important;
}

.auth-story-point strong {
  font-size: 15px !important;
  font-weight: 800 !important;
  color: var(--ink) !important;
}

.auth-story-point span {
  font-size: 13px !important;
  color: var(--muted) !important;
}

.auth-panel {
  display: flex !important;
  flex-direction: column !important;
  justify-content: center !important;
  gap: 18px !important;
  padding: 34px 34px 28px !important;
  background:
    linear-gradient(180deg, rgba(255,255,255,.70), rgba(255,255,255,.92)) !important;
}

.auth-panel-head {
  display: grid !important;
  gap: 8px !important;
}

.auth-panel-head h2 {
  margin: 0 !important;
  font-family: "Fraunces", Georgia, serif !important;
  font-size: clamp(28px, 3vw, 40px) !important;
  line-height: 1.06 !important;
  letter-spacing: -.02em !important;
  color: var(--ink) !important;
}

.auth-panel-head .sub {
  margin: 0 !important;
}

.auth-form {
  display: grid !important;
  gap: 0 !important;
}

.auth-form .msg,
.auth-form .flash {
  margin-top: 0 !important;
}

.auth-foot {
  margin-top: auto !important;
  color: var(--muted) !important;
  font-size: 12px !important;
}

.auth-foot a {
  color: var(--teal) !important;
  font-weight: 700 !important;
  border-bottom: 1px dashed rgba(14,165,160,.28) !important;
  padding-bottom: 1px !important;
}

.auth-card {
  max-width: 560px !important;
  margin: 0 auto !important;
}

.auth-card .btn,
.auth-card input[type="text"],
.auth-card input[type="email"],
.auth-card input[type="password"],
.auth-card input[type="search"],
.auth-card input[type="tel"],
.auth-card input[type="number"],
.auth-card input[type="date"],
.auth-card input[type="datetime-local"],
.auth-card textarea,
.auth-card select {
  border-radius: 14px !important;
}

.auth-actions {
  display: flex !important;
  align-items: center !important;
  justify-content: flex-end !important;
  gap: 12px !important;
  margin-top: 18px !important;
  flex-wrap: wrap !important;
}

.auth-actions-split {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 12px !important;
  margin-top: 18px !important;
  flex-wrap: wrap !important;
}

.auth-links {
  display: flex !important;
  align-items: center !important;
  gap: 12px !important;
  flex-wrap: wrap !important;
  margin-top: 14px !important;
}

.auth-links-stack {
  display: grid !important;
  grid-template-columns: 1fr !important;
  align-items: start !important;
  justify-items: start !important;
  gap: 10px !important;
}

.auth-links-stack a {
  width: fit-content !important;
}

.auth-links a {
  color: var(--ink2) !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  border-bottom: 1px dashed rgba(14,165,160,.28) !important;
  padding-bottom: 1px !important;
}

.auth-links a:hover {
  color: var(--teal) !important;
  border-bottom-color: var(--teal) !important;
}

@media (max-width: 640px) {
  .auth-main {
    padding-top: 24px !important;
    padding-bottom: 40px !important;
  }

  body.auth-login .auth-main {
    padding-top: 28px !important;
  }
}

@media (max-width: 940px) {
  .auth-shell {
    grid-template-columns: 1fr !important;
  }

  .auth-story {
    border-right: 0 !important;
    border-bottom: 1px solid rgba(14,165,160,.10) !important;
  }

  .auth-story h1 {
    max-width: 16ch !important;
  }
}

@media (max-width: 640px) {
  .auth-shell {
    border-radius: 24px !important;
  }

  .auth-story,
  .auth-panel {
    padding: 24px 20px !important;
  }

  .auth-story-visual {
    min-height: 160px !important;
  }

  .auth-story-points {
    grid-template-columns: 1fr !important;
  }

  .auth-actions,
  .auth-actions-split {
    align-items: stretch !important;
  }

  .auth-actions .btn,
  .auth-actions-split .btn {
    width: 100% !important;
  }
}

h1, h2, h3,
.pageHeadTitle,
.page-head h1,
.section-title {
  font-family: "Fraunces", Georgia, serif !important;
  line-height: 1.15 !important;
  font-weight: 700 !important;
  letter-spacing: -.02em !important;
  color: var(--ink) !important;
}
h1 { font-size: clamp(30px, 4.2vw, 48px) !important; margin: 0 0 12px !important; }
h2 { font-size: clamp(24px, 3vw, 36px) !important; margin: 0 0 10px !important; }
h3 { font-size: 19px !important; margin: 0 0 8px !important; }

p, li, dd, dt, label, input, textarea, select, button {
  font-family: "Plus Jakarta Sans", system-ui, -apple-system, sans-serif !important;
}

.sub, .muted, .hint, .tiny, .mini, .lead, .pageHeadSub, .page-head .sub {
  color: var(--muted) !important;
}

/* Buttons */
.btn,
button.btn,
a.btn,
input[type="submit"].btn {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 8px !important;
  min-height: 44px !important;
  padding: 12px 22px !important;
  border-radius: 999px !important;
  font-size: 14px !important;
  font-weight: 700 !important;
  line-height: 1 !important;
  cursor: pointer !important;
  border: 1px solid var(--border) !important;
  background: var(--surface2) !important;
  color: var(--ink) !important;
  box-shadow: var(--shadow-sm) !important;
  transition: transform .15s ease, box-shadow .15s ease, background .15s ease, border-color .15s ease !important;
  text-decoration: none !important;
}
.btn:hover { transform: translateY(-1px); box-shadow: var(--shadow-md) !important; }
.btn:active { transform: translateY(0); }

.btn.primary,
.btn-primary,
button.primary,
a.primary {
  background: var(--teal) !important;
  color: #fff !important;
  border-color: transparent !important;
  box-shadow: 0 4px 18px rgba(14,165,160,.35) !important;
}
.btn.primary:hover,
.btn-primary:hover,
button.primary:hover,
a.primary:hover {
  background: var(--teal-deep) !important;
  box-shadow: 0 8px 28px rgba(14,165,160,.42) !important;
}

.btn.secondary,
.btn-secondary,
button.secondary,
a.secondary {
  background: var(--surface2) !important;
  color: var(--ink) !important;
  border: 1px solid var(--border) !important;
  box-shadow: var(--shadow-sm) !important;
}
.btn.ghost,
.btn-ghost,
button.ghost,
a.ghost,
.btn.tertiary,
a.tertiary {
  background: transparent !important;
  color: var(--teal) !important;
  border: 1.5px solid var(--border) !important;
  box-shadow: none !important;
}
.btn.ghost:hover,
.btn-ghost:hover,
button.ghost:hover,
a.ghost:hover,
.btn.tertiary:hover,
a.tertiary:hover { background: var(--teal-glow) !important; border-color: var(--teal) !important; }

.btn.small,
.btn.tiny,
.btn.sm { min-height: 36px !important; padding: 9px 18px !important; font-size: 13px !important; }

.btn.danger,
a.danger,
button.danger {
  background: rgba(255,255,255,.94) !important;
  color: #b42323 !important;
  border-color: rgba(239,68,68,.22) !important;
}
html[data-theme="dark"] .btn.danger,
html[data-theme="dark"] a.danger,
html[data-theme="dark"] button.danger {
  background: rgba(60, 21, 24, .72) !important;
  color: #ffc7c7 !important;
  border-color: rgba(255,146,146,.22) !important;
}

/* Inputs */
label {
  display: block !important;
  margin: 12px 0 6px !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  color: var(--ink2) !important;
}
input[type="text"],
input[type="email"],
input[type="password"],
input[type="search"],
input[type="tel"],
input[type="number"],
input[type="date"],
input[type="datetime-local"],
textarea,
select,
.input {
  width: 100%;
  min-height: 46px;
  padding: 12px 16px;
  border-radius: 999px !important;
  border: 1.5px solid var(--border) !important;
  background: var(--surface2) !important;
  color: var(--ink) !important;
  font-size: 14px !important;
  outline: none !important;
  box-shadow: none !important;
}
textarea {
  min-height: 120px;
  border-radius: var(--r-sm) !important;
}
input::placeholder,
textarea::placeholder { color: var(--muted) !important; }
input:focus,
textarea:focus,
select:focus {
  border-color: var(--teal) !important;
  box-shadow: 0 0 0 3px rgba(14,165,160,.12) !important;
}
html[data-theme="dark"] input[type="text"],
html[data-theme="dark"] input[type="email"],
html[data-theme="dark"] input[type="password"],
html[data-theme="dark"] input[type="search"],
html[data-theme="dark"] input[type="tel"],
html[data-theme="dark"] input[type="number"],
html[data-theme="dark"] input[type="date"],
html[data-theme="dark"] input[type="datetime-local"],
html[data-theme="dark"] textarea,
html[data-theme="dark"] select,
html[data-theme="dark"] .input {
  background: rgba(8,25,37,.90) !important;
  border-color: rgba(174,210,224,.24) !important;
  color: #e7f4f9 !important;
}

select {
  appearance: auto !important;
  -webkit-appearance: menulist !important;
  background-image: none !important;
  cursor: pointer !important;
}

/* Cards and panels */
.card,
.panel,
.surface,
.box,
.section-card,
.mini-card,
.legal-box,
.kv,
.overviewItem,
.tableWrap,
.table-wrap,
.steps-card,
.story-card,
.faq-card,
.page-head,
.pageHead,
.callout,
.empty,
.detailItem,
.splitCol,
.hero-right,
.hero-main,
.head,
.cta-aside {
  background: var(--surface) !important;
  border: 1px solid var(--border) !important;
  border-radius: var(--r-md) !important;
  box-shadow: var(--shadow-sm) !important;
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
}
.cta-aside {
  background: linear-gradient(135deg, var(--teal) 0%, var(--teal-deep) 100%) !important;
  color: #fff !important;
  box-shadow: 0 12px 48px rgba(14,165,160,.32) !important;
}
.cta-aside h3,
.cta-aside p { color: #fff !important; }
.cta-aside .btn.primary,
.cta-aside .btn.btn-primary {
  background: #fff !important;
  color: var(--teal-deep) !important;
  border-color: transparent !important;
}
.cta-aside .btn.ghost,
.cta-aside .btn.btn-ghost,
.cta-aside .btn.secondary {
  color: #fff !important;
  border-color: rgba(255,255,255,.35) !important;
  background: transparent !important;
}

.head,
.pageHead,
.page-head {
  padding: 22px 24px !important;
  background:
    linear-gradient(135deg, rgba(14,165,160,.08), rgba(246,180,60,.05)),
    var(--surface) !important;
}
.body,
.content,
.inner,
.content-body { padding: 22px 24px !important; }
.foot { padding: 16px 24px 20px !important; color: var(--muted) !important; font-size: 12px !important; }

.msg,
.flash {
  border-radius: 14px !important;
  padding: 12px 14px !important;
  margin: 0 0 12px !important;
  border: 1px solid rgba(12,17,22,.10) !important;
  background: var(--surface2) !important;
  color: var(--ink2) !important;
}
.msg.err, .flash.err, .err, .warn {
  border-color: rgba(239,68,68,.22) !important;
  background: rgba(239,68,68,.06) !important;
  color: #8f1d1d !important;
}
html[data-theme="dark"] .msg,
html[data-theme="dark"] .flash {
  background: rgba(12,34,49,.88) !important;
  border-color: rgba(174,210,224,.22) !important;
  color: #d8e9f1 !important;
}
html[data-theme="dark"] .msg.err,
html[data-theme="dark"] .flash.err,
html[data-theme="dark"] .err,
html[data-theme="dark"] .warn {
  background: rgba(110,22,30,.34) !important;
  border-color: rgba(255,146,146,.34) !important;
  color: #ffd1d1 !important;
}

/* Links */
.links,
.row,
.row2,
.actions,
.section-actions,
.pageHeadActions,
.page-head .actions {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
}
.links a,
.link,
.link-arrow {
  color: var(--teal) !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  border-bottom: 1px solid rgba(14,165,160,.28);
  padding-bottom: 1px;
}
.links a:hover,
.link:hover,
.link-arrow:hover { border-color: var(--teal) !important; }

/* Pills / badges */
.pill,
.tag,
.badge,
.role-pill {
  display: inline-flex !important;
  align-items: center !important;
  gap: 6px !important;
  padding: 5px 10px !important;
  border-radius: 999px !important;
  background: rgba(14,165,160,.08) !important;
  border: 1px solid rgba(14,165,160,.14) !important;
  color: var(--teal-deep) !important;
  font-size: 11px !important;
  font-weight: 700 !important;
}
html[data-theme="dark"] .pill,
html[data-theme="dark"] .tag,
html[data-theme="dark"] .badge,
html[data-theme="dark"] .role-pill { color: var(--teal) !important; }
.pill.warn,
.tag.warn,
.badge.warn { background: var(--amber-soft) !important; border-color: rgba(246,180,60,.25) !important; color: #8c6115 !important; }
.pill.danger,
.tag.failed,
.badge.danger { background: rgba(239,68,68,.08) !important; border-color: rgba(239,68,68,.20) !important; color: #9f2222 !important; }

/* Topbar exacter am Manifest */
header.faq-topbar,
.rivaid-topbar {
  position: relative;
  z-index: 120;
  padding: 20px 24px 12px !important;
  max-width: 1100px !important;
  margin: 0 auto !important;
}
header.faq-topbar .nav-wrap,
.rivaid-topbar .nav-wrap {
  width: 100%;
}
header.faq-topbar .nav-pill,
.rivaid-topbar .nav-pill {
  display: flex !important;
  align-items: center !important;
  gap: 8px !important;
  padding: 7px 8px !important;
  border-radius: 999px !important;
  background: var(--pill-bg) !important;
  border: 1px solid var(--border2) !important;
  box-shadow: var(--shadow-md) !important;
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
}
header.faq-topbar .brand,
.rivaid-topbar .brand,
.nav-brand {
  display: flex !important;
  align-items: center !important;
  gap: 8px !important;
  padding: 4px 10px 4px 6px !important;
  border-radius: 999px !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  flex-shrink: 0;
}
.brand-logo {
  display: block !important;
  height: 28px !important;
  width: auto !important;
  max-width: 160px !important;
  object-fit: contain !important;
}
html[data-theme="dark"] .brand-logo { content: url("/assets/logo-btnlight-dark.png"); }

header.faq-topbar .nav-links,
.rivaid-topbar .nav-links,
.nav-links {
  display: flex !important;
  align-items: center !important;
  gap: 4px !important;
  flex: 1 !important;
  justify-content: center !important;
  min-width: 0;
}
header.faq-topbar .nav-links a,
.rivaid-topbar .nav-links a,
.nav-links a {
  padding: 8px 14px !important;
  border-radius: 999px !important;
  font-size: 13px !important;
  font-weight: 600 !important;
  color: var(--ink2) !important;
  border: 1px solid transparent !important;
  background: transparent !important;
  box-shadow: none !important;
}
header.faq-topbar .nav-links a:hover,
header.faq-topbar .nav-links a.active,
.rivaid-topbar .nav-links a:hover,
.rivaid-topbar .nav-links a.active,
.nav-links a:hover,
.nav-links a.active {
  background: rgba(14,165,160,.10) !important;
  border-color: rgba(14,165,160,.22) !important;
  color: var(--ink) !important;
}

.nav-meta,
.nav-spacer {
  flex: 1 1 auto;
  min-width: 0;
}
.nav-meta-text {
  display: flex;
  align-items: center;
  gap: 8px;
  color: var(--muted);
  font-size: 12px;
  justify-content: center;
}
.meta-sep { opacity: .55; }
.meta-text { white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }

.nav-cta {
  display: flex !important;
  align-items: center !important;
  gap: 8px !important;
  flex-shrink: 0 !important;
  margin-left: 0 !important;
}
.nav-cta a,
.btn-login,
.nav-support,
.support,
.userBtn,
.rivaid-theme-toggle,
.theme-toggle {
  min-height: 36px !important;
  height: 36px !important;
  padding: 8px 14px !important;
  border-radius: 999px !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  background: var(--surface2) !important;
  border: 1px solid var(--border) !important;
  color: var(--ink) !important;
  box-shadow: none !important;
}
.nav-cta a.support,
.support,
.nav-support { color: var(--ink2) !important; }
.nav-cta a.btn-login,
.btn-login,
.nav-login {
  border: 1px dashed rgba(14,165,160,.4) !important;
  color: var(--teal-deep) !important;
}
html[data-theme="dark"] .nav-cta a.btn-login,
html[data-theme="dark"] .btn-login,
html[data-theme="dark"] .nav-login { color: var(--teal) !important; }
.nav-cta a:hover,
.btn-login:hover,
.support:hover,
.userBtn:hover,
.rivaid-theme-toggle:hover,
.theme-toggle:hover {
  background: var(--teal-glow) !important;
  transform: translateY(-1px);
}
.rivaid-theme-toggle,
.theme-toggle {
  width: 36px !important;
  min-width: 36px !important;
  padding: 0 !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  cursor: pointer !important;
}
.userMenu { position: relative; }
.userMenu summary { list-style: none; }
.userMenu summary::-webkit-details-marker { display: none; }
.userDropdown {
  position: absolute !important;
  right: 0 !important;
  top: calc(100% + 8px) !important;
  min-width: 220px !important;
  padding: 8px !important;
  border-radius: var(--r-sm) !important;
  background: var(--surface2) !important;
  border: 1px solid var(--border) !important;
  box-shadow: var(--shadow-md) !important;
  display: none;
  z-index: 40;
}
.userMenu[open] .userDropdown { display: block !important; }
.userDropdown a {
  display: flex !important;
  align-items: center !important;
  min-height: 40px !important;
  padding: 10px 12px !important;
  border-radius: 12px !important;
  color: var(--ink2) !important;
}
.userDropdown a:hover { background: var(--teal-glow) !important; color: var(--ink) !important; }
.userDropdown a.danger { color: #a61f1f !important; }

@media (max-width: 900px) {
  header.faq-topbar,
  .rivaid-topbar { padding-left: 16px !important; padding-right: 16px !important; }
  header.faq-topbar .nav-links,
  .rivaid-topbar .nav-links { display: none !important; }
  .nav-meta { display: none !important; }
}

/* Tables and grids */
table {
  width: 100%;
  border-collapse: separate;
  border-spacing: 0;
  color: var(--ink);
}
th, td {
  padding: 12px 14px !important;
  border-bottom: 1px solid rgba(14,165,160,.12) !important;
  text-align: left;
  vertical-align: top;
}
th {
  font-size: 11px !important;
  font-weight: 700 !important;
  color: var(--muted) !important;
  text-transform: uppercase;
  letter-spacing: .04em;
}
tr:hover td { background: rgba(14,165,160,.03); }

.grid,
.filters,
.section-top,
.kvRow,
.healthRow,
.reviewRow {
  display: grid;
  gap: 14px;
}
.split,
.rowGrid { display: grid; gap: 18px; }
@media (min-width: 900px) {
  .split { grid-template-columns: 1.2fr .8fr; }
}
.pageHead,
.page-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap;
}
.pageHeadTitle,
.page-head h1 { margin-bottom: 0 !important; }
.pageHeadSub { font-size: 15px !important; }
.pageHeadActions,
.page-head .actions { margin-left: auto; }

.top,
.logo-wrap { display: flex; align-items: center; justify-content: center; margin: 8px 0 18px; }
.logo { height: 32px; width: auto; max-width: 220px; object-fit: contain; }

.steps { list-style: none; padding: 0; margin: 0; display: grid; gap: 12px; }
.steps li {
  display: grid;
  grid-template-columns: 40px 1fr;
  gap: 14px;
  align-items: start;
  padding: 14px 16px;
  border-radius: var(--r-sm);
  background: var(--surface2);
  border: 1px solid var(--border);
}
.steps .n,
.step-num {
  width: 40px;
  height: 40px;
  border-radius: 14px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: "Fraunces", serif !important;
  font-size: 18px;
  font-weight: 700;
  color: var(--teal);
  background: rgba(14,165,160,.12);
  border: 1.5px solid rgba(14,165,160,.25);
}

footer {
  margin-top: 72px;
  border-top: 1px solid var(--border);
  background: var(--surface);
  backdrop-filter: blur(12px);
}
footer a { color: var(--teal); }

html[data-theme="dark"] .card,
html[data-theme="dark"] .panel,
html[data-theme="dark"] .surface,
html[data-theme="dark"] .box,
html[data-theme="dark"] .section-card,
html[data-theme="dark"] .mini-card,
html[data-theme="dark"] .legal-box,
html[data-theme="dark"] .kv,
html[data-theme="dark"] .overviewItem,
html[data-theme="dark"] .tableWrap,
html[data-theme="dark"] .table-wrap,
html[data-theme="dark"] .steps-card,
html[data-theme="dark"] .story-card,
html[data-theme="dark"] .faq-card,
html[data-theme="dark"] .page-head,
html[data-theme="dark"] .pageHead,
html[data-theme="dark"] .callout,
html[data-theme="dark"] .empty,
html[data-theme="dark"] .detailItem,
html[data-theme="dark"] .splitCol,
html[data-theme="dark"] .hero-right,
html[data-theme="dark"] .hero-main,
html[data-theme="dark"] .head {
  background: var(--surface) !important;
  border-color: rgba(174,210,224,.18) !important;
}
html[data-theme="dark"] th,
html[data-theme="dark"] .sub,
html[data-theme="dark"] .muted,
html[data-theme="dark"] .hint,
html[data-theme="dark"] .tiny,
html[data-theme="dark"] .mini,
html[data-theme="dark"] .lead,
html[data-theme="dark"] .pageHeadSub,
html[data-theme="dark"] .page-head .sub,
html[data-theme="dark"] .foot { color: var(--muted) !important; }

html[data-theme="dark"] .auth-shell {
  background: rgba(24,36,43,.90) !important;
  border-color: rgba(132,188,190,.18) !important;
}

html[data-theme="dark"] .auth-story {
  border-right-color: rgba(132,188,190,.16) !important;
}

html[data-theme="dark"] .auth-story-eyebrow,
html[data-theme="dark"] .auth-story-point,
html[data-theme="dark"] .auth-panel {
  background: rgba(24,36,43,.72) !important;
  border-color: rgba(132,188,190,.16) !important;
}

html[data-theme="dark"] .auth-story-visual {
  border-color: rgba(132,188,190,.16) !important;
  background:
    radial-gradient(circle at 30% 30%, rgba(255,255,255,.06), transparent 44%),
    linear-gradient(135deg, rgba(76,176,168,.14), rgba(246,180,60,.08)) !important;
}

html[data-theme="dark"] .auth-story .sub,
html[data-theme="dark"] .auth-story-point span,
html[data-theme="dark"] .auth-foot {
  color: rgba(214,228,223,.78) !important;
}

html[data-theme="dark"] .auth-story-point strong,
html[data-theme="dark"] .auth-panel-head h2 {
  color: #edf6f4 !important;
}

/* === Etappe 1: globale UI-Basis === */
:root {
  --page-max: 1180px;
  --page-gutter: 24px;
  --page-gutter-sm: 16px;
  --dashboard-max: 1100px;
  --dashboard-gutter: 24px;
  --dashboard-gutter-sm: 18px;
  --dashboard-top-gap: 42px;
  --space-2xs: 8px;
  --space-xs: 12px;
  --space-sm: 16px;
  --space-md: 20px;
  --space-lg: 24px;
  --space-xl: 32px;
  --control-h: 48px;
  --control-radius: 18px;
  --card-radius: 26px;
  --card-pad-x: 26px;
  --card-pad-y: 24px;
}

.wrap,
.m-wrap,
header.faq-topbar,
.rivaid-topbar {
  max-width: var(--page-max) !important;
}

.wrap,
.m-wrap {
  padding-left: var(--page-gutter) !important;
  padding-right: var(--page-gutter) !important;
}

header.faq-topbar,
.rivaid-topbar {
  padding-top: 16px !important;
  padding-bottom: 10px !important;
}

.pageHead,
.page-head,
.head {
  display: grid !important;
  gap: var(--space-sm) !important;
  padding: 28px 30px !important;
  margin-bottom: var(--space-md) !important;
}

.pageHeadTitle,
.page-head .title,
.head .title {
  display: grid !important;
  gap: 8px !important;
}

.pageHeadActions,
.page-head .actions,
.section-actions,
.section-headActions {
  gap: var(--space-xs) !important;
  align-items: center !important;
}

.body,
.content,
.inner,
.content-body,
.panel .inner {
  padding: var(--card-pad-y) var(--card-pad-x) !important;
}

.card,
.panel,
.surface,
.box,
.section-card,
.mini-card,
.legal-box,
.kv,
.overviewItem,
.tableWrap,
.table-wrap,
.steps-card,
.story-card,
.faq-card,
.page-head,
.pageHead,
.callout,
.empty,
.detailItem,
.splitCol,
.hero-right,
.hero-main,
.head,
.cta-aside {
  border-radius: var(--card-radius) !important;
}

.grid {
  gap: 18px !important;
}

.btn,
button.btn,
a.btn,
input[type="submit"].btn {
  min-height: var(--control-h) !important;
  padding: 12px 20px !important;
  border-radius: 16px !important;
}

.btn.small,
.btn.tiny,
.btn.sm {
  min-height: 40px !important;
  padding: 9px 16px !important;
  border-radius: 14px !important;
}

label {
  margin: 10px 0 6px !important;
}

input[type="text"],
input[type="email"],
input[type="password"],
input[type="search"],
input[type="tel"],
input[type="number"],
input[type="date"],
input[type="datetime-local"],
textarea,
select,
.input {
  min-height: var(--control-h) !important;
  padding: 12px 16px !important;
  border-radius: var(--control-radius) !important;
}

textarea {
  min-height: 136px !important;
  border-radius: 20px !important;
}

.msg,
.flash,
.empty,
.callout {
  margin-bottom: var(--space-sm) !important;
}

.tableWrap,
.table-wrap {
  overflow-x: auto !important;
}

table {
  width: 100% !important;
}

thead th,
tbody td,
tbody th,
tr > td,
tr > th {
  vertical-align: top !important;
}

th,
td {
  padding: 14px 14px !important;
}

@media (max-width: 720px) {
  .wrap,
  .m-wrap {
    padding-left: var(--page-gutter-sm) !important;
    padding-right: var(--page-gutter-sm) !important;
  }

  .pageHead,
  .page-head,
  .head,
  .body,
  .content,
  .inner,
  .content-body,
  .panel .inner {
    padding-left: 18px !important;
    padding-right: 18px !important;
  }

  .pageHead,
  .page-head,
  .head {
    padding-top: 22px !important;
    padding-bottom: 22px !important;
  }

  .btn,
  button.btn,
  a.btn,
  input[type="submit"].btn {
    width: 100%;
  }
}


/* ============================================================
   Etappe 1 – Allgemeine Portal-Komponenten
   Dashboard-Shell, Portal-Cards, Card-Grid, Badges, Dropdown
============================================================ */

/* Dashboard-Shell: umschließende Karte */
.dashboard-shell {
  background: var(--surface) !important;
  border: 1px solid var(--border) !important;
  border-radius: var(--r-lg) !important;
  box-shadow: var(--shadow-md) !important;
  overflow: hidden !important;
}

.dashboard-shell > .section-head {
  padding: 22px 24px 20px !important;
  background: var(--hero-grad) !important;
  border-bottom: 1px solid var(--border) !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  backdrop-filter: none !important;
}

.dashboard-shell > .section-head h1 {
  font-size: clamp(28px, 3.6vw, 42px) !important;
  margin: 0 0 6px !important;
  line-height: 1.1 !important;
}

.dashboard-shell > .section-head p {
  margin: 0 !important;
  max-width: 680px !important;
  font-size: 15px !important;
  color: var(--muted) !important;
}

/* Card-Grid / Portal-Cards moved to portal-dashboard-layout.css */

/* btn-badge: Button mit eingebettetem Zähler-Badge */
.btn-has-badge {
  gap: 10px !important;
}

.btn-badge {
  display: inline-flex !important;
  align-items: center !important;
  padding: 3px 8px !important;
  border-radius: 999px !important;
  background: rgba(14,165,160,.14) !important;
  border: 1px solid rgba(14,165,160,.22) !important;
  color: var(--teal-deep) !important;
  font-size: 11px !important;
  font-weight: 800 !important;
  letter-spacing: .04em !important;
  white-space: nowrap !important;
}

html[data-theme="dark"] .btn-badge {
  background: rgba(14,165,160,.12) !important;
  border-color: rgba(14,165,160,.20) !important;
  color: var(--teal) !important;
}

/* User-Dropdown Dark Mode */
html[data-theme="dark"] .nav-pill .userDropdown {
  background: var(--surface2) !important;
  border-color: var(--border) !important;
  box-shadow: var(--shadow-lg) !important;
}

html[data-theme="dark"] .nav-pill .userDropdown a {
  color: var(--ink) !important;
}

html[data-theme="dark"] .nav-pill .userDropdown a:hover {
  background: rgba(14,165,160,.12) !important;
}

/* Theme-Toggle */
.theme-toggle:hover,
.rivaid-theme-toggle:hover {
  background: var(--teal-glow) !important;
  transform: rotate(20deg) !important;
}

/* Allgemeines main.wrap Padding */
main.wrap {
  padding-top: 22px;
  padding-bottom: 60px;
}

/* ============================================================
   Etappe 1j – Public-Parity Basis
   Ziel: Dashboard/Admin visuell näher an rivaid.de bringen,
   ohne Inhalte oder Logik zu verändern.
============================================================ */

:root {
  --public-btn-radius: 999px;
  --public-input-radius: 16px;
  --public-textarea-radius: 20px;
  --public-card-radius: 24px;
  --public-shell-radius: 32px;
  --public-shadow-card: 0 14px 38px rgba(12,17,22,.09);
  --public-shadow-card-hover: 0 18px 48px rgba(12,17,22,.12);
}

h1,
h2,
h3,
.pageHeadTitle h1,
.dashboard-hero-title,
.section-head h1 {
  font-family: "Fraunces", Georgia, serif !important;
  letter-spacing: -.02em !important;
}

.btn,
button.btn,
a.btn,
input[type="submit"].btn {
  min-height: 44px !important;
  padding: 13px 24px !important;
  border-radius: var(--public-btn-radius) !important;
  font-size: 14px !important;
  font-weight: 800 !important;
  line-height: 1 !important;
  border: 1px solid transparent !important;
  box-shadow: var(--shadow-sm) !important;
}

.btn:hover,
button.btn:hover,
a.btn:hover,
input[type="submit"].btn:hover,
.btn:focus-visible,
button.btn:focus-visible,
a.btn:focus-visible,
input[type="submit"].btn:focus-visible {
  transform: translateY(-1px) !important;
  outline: none !important;
}

.btn.primary,
.btn-primary,
button.primary,
a.primary {
  background: var(--teal) !important;
  color: #fff !important;
  border-color: transparent !important;
  box-shadow: 0 4px 18px rgba(14,165,160,.35) !important;
}

.btn.primary:hover,
.btn-primary:hover,
button.primary:hover,
a.primary:hover,
.btn.primary:focus-visible,
.btn-primary:focus-visible,
button.primary:focus-visible,
a.primary:focus-visible {
  background: var(--teal-deep) !important;
  box-shadow: 0 8px 28px rgba(14,165,160,.42) !important;
}

.btn.secondary,
.btn-secondary,
button.secondary,
a.secondary {
  background: var(--surface2) !important;
  color: var(--ink) !important;
  border-color: var(--border) !important;
  box-shadow: var(--shadow-sm) !important;
}

.btn.secondary:hover,
.btn-secondary:hover,
button.secondary:hover,
a.secondary:hover,
.btn.secondary:focus-visible,
.btn-secondary:focus-visible,
button.secondary:focus-visible,
a.secondary:focus-visible {
  box-shadow: var(--shadow-md) !important;
}

.btn.ghost,
.btn-ghost,
button.ghost,
a.ghost,
.btn.tertiary,
a.tertiary {
  background: transparent !important;
  color: var(--teal) !important;
  border-color: rgba(14,165,160,.24) !important;
}

.btn.ghost:hover,
.btn-ghost:hover,
button.ghost:hover,
a.ghost:hover,
.btn.tertiary:hover,
a.tertiary:hover,
.btn.ghost:focus-visible,
.btn-ghost:focus-visible,
button.ghost:focus-visible,
a.ghost:focus-visible,
.btn.tertiary:focus-visible,
a.tertiary:focus-visible {
  background: rgba(14,165,160,.10) !important;
  border-color: rgba(14,165,160,.28) !important;
}

.btn.small,
.btn.tiny,
.btn.sm {
  min-height: 38px !important;
  padding: 8px 16px !important;
  border-radius: var(--public-btn-radius) !important;
  font-size: 13px !important;
  font-weight: 700 !important;
}

input[type="text"],
input[type="email"],
input[type="password"],
input[type="search"],
input[type="tel"],
input[type="number"],
input[type="date"],
input[type="datetime-local"],
select,
.input {
  min-height: 46px !important;
  padding: 12px 16px !important;
  border-radius: var(--public-input-radius) !important;
  border-width: 1px !important;
  background: var(--surface2) !important;
}

textarea {
  min-height: 124px !important;
  padding: 14px 16px !important;
  border-radius: var(--public-textarea-radius) !important;
  border-width: 1px !important;
  background: var(--surface2) !important;
}

input:focus,
textarea:focus,
select:focus,
.input:focus {
  border-color: var(--teal) !important;
  box-shadow: 0 0 0 3px rgba(14,165,160,.12) !important;
  outline: none !important;
}

.card,
.panel,
.surface,
.box,
.section-card,
.mini-card,
.legal-box,
.kv,
.overviewItem,
.tableWrap,
.table-wrap,
.steps-card,
.story-card,
.faq-card,
.page-head,
.pageHead,
.callout,
.empty,
.detailItem,
.splitCol,
.hero-right,
.hero-main,
.head,
.cta-aside,
.dashboard-shell

.dashboard-shell,
.panel,
.tableWrap,
.table-wrap,
.card,
.section-card,
.mini-card {
  box-shadow: var(--public-shadow-card) !important;
}

.pageHead,
.page-head,
.head,
.section-head {
  background:
    radial-gradient(circle at 12% 14%, rgba(14,165,160,.08), transparent 30%),
    var(--hero-grad) !important;
  border-color: var(--border) !important;
}

.pill,
.role-pill,
.btn-badge {
  border-radius: 999px !important;
}

header.faq-topbar .nav-links a,
.rivaid-topbar .nav-links a,
.nav-links a,
.rbar-nav a {
  position: relative !important;
  background: transparent !important;
  border-color: transparent !important;
  color: var(--ink2) !important;
  box-shadow: none !important;
}

header.faq-topbar .nav-links a::after,
.rivaid-topbar .nav-links a::after,
.nav-links a::after,
.rbar-nav a::after {
  content: "" !important;
  position: absolute !important;
  left: 14px !important;
  right: 14px !important;
  bottom: 5px !important;
  height: 2px !important;
  border-radius: 999px !important;
  background: currentColor !important;
  opacity: 0 !important;
  transform: scaleX(.45) !important;
  transform-origin: center !important;
  transition: opacity .15s ease, transform .15s ease !important;
}

header.faq-topbar .nav-links a:hover,
header.faq-topbar .nav-links a.active,
header.faq-topbar .nav-links a:focus-visible,
.rivaid-topbar .nav-links a:hover,
.rivaid-topbar .nav-links a.active,
.rivaid-topbar .nav-links a:focus-visible,
.nav-links a:hover,
.nav-links a.active,
.nav-links a:focus-visible,
.rbar-nav a:hover,
.rbar-nav a.active,
.rbar-nav a:focus-visible {
  background: transparent !important;
  border-color: transparent !important;
  color: var(--ink) !important;
  outline: none !important;
}

header.faq-topbar .nav-links a:hover::after,
header.faq-topbar .nav-links a:focus-visible::after,
.rivaid-topbar .nav-links a:hover::after,
.rivaid-topbar .nav-links a:focus-visible::after,
.nav-links a:hover::after,
.nav-links a:focus-visible::after,
.rbar-nav a:hover::after,
.rbar-nav a:focus-visible::after {
  opacity: .42 !important;
  transform: scaleX(.82) !important;
}

header.faq-topbar .nav-links a.active::after,
header.faq-topbar .nav-links a[aria-current="page"]::after,
.rivaid-topbar .nav-links a.active::after,
.rivaid-topbar .nav-links a[aria-current="page"]::after,
.nav-links a.active::after,
.nav-links a[aria-current="page"]::after,
.rbar-nav a.active::after,
.rbar-nav a[aria-current="page"]::after {
  opacity: .95 !important;
  transform: scaleX(1) !important;
}

.nav-cta a,
.btn-login,
.nav-support,
.support,
.userBtn,
.rivaid-theme-toggle,
.theme-toggle {
  box-shadow: var(--shadow-sm) !important;
}

.nav-cta a:hover,
.btn-login:hover,
.support:hover,
.userBtn:hover,
.rivaid-theme-toggle:hover,
.theme-toggle:hover {
  box-shadow: var(--shadow-sm) !important;
}

/* ============================================================
   Etappe 1k – Canonical ownership bridge
   Ziel:
   - eine führende Token-Quelle für Portal + Legacy-Layer
   - Shells der Kernseiten ruhiger und konsistenter machen
   - alte Klassennamen kompatibel halten, ohne zweite UI-Landschaft
============================================================ */

:root {
  --rivaid-ink: var(--ink);
  --rivaid-muted: var(--muted);
  --rivaid-stroke: var(--border);
  --rivaid-panel: var(--surface);
  --rivaid-panel-strong: var(--surface2);
  --rivaid-glass: var(--surface3);
  --rivaid-shadow: var(--shadow-lg);
  --rivaid-shadow2: var(--shadow-md);
  --rivaid-teal: var(--teal);
  --rivaid-teal-deep: var(--teal-deep);
  --rivaid-teal-soft: var(--teal-glow);

  --btn-h: 44px;
  --btn-px: 18px;
  --btn-radius: var(--public-btn-radius);
  --btn-fs: 14px;
  --btn-fw: 700;
  --btn-lh: 1;
  --btn-border-w: 1px;
  --btn-border-style: solid;

  --btn-text: #ffffff;
  --btn-bg: var(--accent-grad);
  --btn-bg-size: 100% 100%;
  --btn-bg-pos: 0% 0;
  --btn-border: transparent;
  --btn-shadow: 0 4px 18px rgba(14,165,160,.28);
  --btn-hover-border: transparent;
  --btn-hover-shadow: 0 8px 28px rgba(14,165,160,.34);
  --btn-focus-shadow: 0 0 0 4px rgba(14,165,160,.18), 0 8px 28px rgba(14,165,160,.20);
  --btn-primary-shadow: 0 4px 18px rgba(14,165,160,.28);
  --btn-primary-hover-shadow: 0 8px 28px rgba(14,165,160,.34);
  --btn-primary-active-bg: linear-gradient(145deg, #0b8b87 0%, #087a76 100%);
  --btn-primary-active-shadow: 0 6px 16px rgba(14,165,160,.24);
  --btn-secondary-text: var(--ink);
  --btn-secondary-bg: var(--surface2);
  --btn-secondary-border: var(--border);
  --btn-secondary-hover-bg: rgba(255,255,255,.98);
  --btn-secondary-hover-text: var(--ink);
  --btn-secondary-hover-border: var(--border-strong);
  --btn-secondary-hover-shadow: var(--shadow-md);
  --btn-secondary-active-shadow: var(--shadow-sm);
  --btn-ghost-text: var(--teal);
  --btn-danger-text: #b42323;
  --btn-danger-bg: rgba(255,255,255,.95);
  --btn-danger-border: rgba(220,38,38,.28);
  --btn-danger-hover-bg: rgba(255,248,248,.98);
  --btn-danger-hover-border: rgba(220,38,38,.38);
  --btn-danger-hover-text: #a61f1f;
  --btn-link-text: color-mix(in srgb, var(--ink) 78%, transparent);
}

html[data-theme="dark"] {
  --bg: #0d1b1e;
  --bg2: #102126;
  --surface: rgba(22,40,46,.90);
  --surface2: rgba(28,50,58,.95);
  --surface3: rgba(22,40,46,.78);
  --border: rgba(14,165,160,.22);
  --border-strong: rgba(14,165,160,.36);
  --border2: rgba(255,255,255,.08);
  --ink: #e8f4f4;
  --ink2: #c6dddd;
  --muted: #8ca8b0;
  --pill-bg: rgba(22,40,46,.88);
  --teal-glow: rgba(14,165,160,.28);
  --amber-soft: rgba(246,180,60,.12);
  --hero-grad: linear-gradient(145deg, #0d2426 0%, #102a2f 45%, #1a2410 100%);
  --soft-grad: linear-gradient(145deg, rgba(16,36,38,.94) 0%, rgba(16,42,47,.98) 45%, rgba(26,36,16,.90) 100%);

  --btn-secondary-bg: rgba(28,50,58,.95);
  --btn-secondary-border: rgba(14,165,160,.22);
  --btn-secondary-hover-bg: rgba(34,58,66,.98);
  --btn-secondary-hover-text: var(--ink);
  --btn-secondary-hover-border: rgba(14,165,160,.32);
  --btn-danger-bg: rgba(72,24,28,.72);
  --btn-danger-border: rgba(255,146,146,.24);
  --btn-danger-hover-bg: rgba(92,28,34,.82);
  --btn-danger-hover-border: rgba(255,146,146,.34);
  --btn-danger-hover-text: #ffd1d1;
}

.pageShell,
.support-shell,
body.portal-profile .card.wide,
body.portal-admin main.panel {
  background: var(--surface) !important;
  border: 1px solid var(--border) !important;
  border-radius: var(--public-shell-radius) !important;
  box-shadow: var(--public-shadow-card) !important;
  overflow: hidden !important;
}

.pageShellBody,
.support-shell > .content,
body.portal-admin main.panel > .inner {
  padding: 22px 24px !important;
}

body.portal-dashboard .dashboard-content,
body.portal-support .support-content,
body.portal-support .workspaceFoldBody,
body.portal-ids .pageShellBody,
body.portal-admin main.panel > .inner {
  gap: 18px !important;
}

.btn.btnGhost,
.btnGhost {
  background: var(--btn-secondary-bg) !important;
  color: var(--btn-secondary-text) !important;
  border: 1px solid var(--btn-secondary-border) !important;
  box-shadow: var(--shadow-sm) !important;
}

.btn.btnGhost:hover,
.btnGhost:hover,
.btn.btnGhost:focus-visible,
.btnGhost:focus-visible {
  background: var(--btn-secondary-hover-bg) !important;
  color: var(--btn-secondary-hover-text) !important;
  border-color: var(--btn-secondary-hover-border) !important;
  box-shadow: var(--shadow-md) !important;
}



/* Gemeinsame Legal-Zeile für meine.rivaid.de */
footer.rivaLegalFooter {
  width: min(100% - 32px, 1180px);
  margin: 28px auto 0;
  padding: 0;
  border: 0;
  background: transparent;
  backdrop-filter: none;
}

footer.rivaLegalFooter .rivaLegalFooterInner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap;
  padding: 18px 2px 6px;
  border-top: 1px solid var(--border);
  font-size: 13px;
  line-height: 1.5;
  color: var(--muted);
  font-weight: 600;
}

footer.rivaLegalFooter .rivaLegalFooterBrand {
  letter-spacing: .01em;
  color: var(--ink2);
}

footer.rivaLegalFooter .rivaLegalFooterNav {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}

footer.rivaLegalFooter .rivaLegalFooterSep {
  opacity: .48;
}

footer.rivaLegalFooter a {
  color: var(--teal);
  text-decoration: none;
  transition: color .12s ease, text-decoration-color .12s ease;
}

footer.rivaLegalFooter a:hover {
  color: var(--teal-600);
  text-decoration: underline;
}

html[data-theme="dark"] footer.rivaLegalFooter .rivaLegalFooterInner {
  border-top-color: rgba(132,188,190,.16);
  color: var(--muted);
}

html[data-theme="dark"] footer.rivaLegalFooter .rivaLegalFooterBrand {
  color: #e7f4f9;
}

@media (max-width: 760px) {
  footer.rivaLegalFooter {
    width: min(100% - 24px, 1180px);
    margin-top: 24px;
  }

  footer.rivaLegalFooter .rivaLegalFooterInner {
    justify-content: center;
    text-align: center;
    padding-top: 16px;
    padding-bottom: 4px;
  }

  footer.rivaLegalFooter .rivaLegalFooterNav {
    justify-content: center;
  }
}

@media (max-width: 560px) {
  footer.rivaLegalFooter .rivaLegalFooterInner,
  footer.rivaLegalFooter .rivaLegalFooterNav {
    flex-direction: column;
    align-items: center;
  }

  footer.rivaLegalFooter .rivaLegalFooterSep {
    display: none;
  }
}

