@import url('https://fonts.googleapis.com/css2?family=Work+Sans:wght@400;500;600;700&display=swap');

:root {
  --font-family-base: 'Work Sans', system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --space-1: 4px;
  --space-2: 8px;
  --space-3: 12px;
  --space-4: 16px;
  --space-5: 20px;
  --space-6: 24px;
  --space-8: 32px;
  --space-10: 40px;
  --space-12: 48px;
  --space-16: 64px;
  --radius-sm: 12px;
  --radius-md: 15px;
  --radius-lg: 20px;
  --shadow-soft: 0 24px 60px rgba(0, 0, 0, 0.24);
  --shadow-card: 0 18px 48px rgba(0, 0, 0, 0.18);
  --shadow-admin: 0 16px 40px rgba(17, 24, 39, 0.08);
  --border-soft: 1px solid rgba(255, 255, 255, 0.08);
  --border-admin: 1px solid #e5e5e5;
  --color-primary: #ec0194;
  --color-primary-hover: #d10083;
  --color-primary-active: #97015f;
  --color-admin-text: #111827;
}

* {
  box-sizing: border-box;
}

html {
  font-size: 16px;
}

body {
  margin: 0;
  min-height: 100vh;
  font-family: var(--font-family-base);
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: clip;
}

body.theme-frontend {
  color-scheme: dark;
  background:
    radial-gradient(circle at top, rgba(219, 11, 247, 0.2), transparent 32%),
    linear-gradient(180deg, #000000 0%, #1f102e 42%, #512f6f 100%);
  color: #ffffff;
}

body.theme-frontend.page-portal {
  background:
    radial-gradient(circle at top, rgba(248, 217, 143, 0.2), transparent 30%),
    linear-gradient(180deg, #512f6f 0%, #1f102e 46%, #050206 100%);
}

body.theme-admin {
  color-scheme: light;
  background: #f7f7f7;
  color: #000000;
  overflow-x: hidden;
}

.theme-admin h1 {
  margin-bottom: var(--space-2);
  color: var(--color-admin-text);
  font-size: clamp(1.8rem, 3vw, 2.35rem);
  line-height: 1.12;
  font-weight: 700;
}

.theme-admin h2 {
  color: var(--color-admin-text);
  font-size: 1.2rem;
  line-height: 1.25;
  font-weight: 700;
}

.theme-admin h3 {
  color: var(--color-admin-text);
  font-size: 1rem;
  line-height: 1.3;
  font-weight: 700;
}

a {
  color: inherit;
}

img {
  max-width: 100%;
  height: auto;
}

input,
select,
textarea,
button,
a {
  font: inherit;
}

button {
  cursor: pointer;
}

.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

.system-banner,
.site-header,
.site-footer {
  width: min(100%, 1200px);
  margin: 0 auto;
  padding-left: var(--space-4);
  padding-right: var(--space-4);
}

.system-banner {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: var(--space-3);
  padding-top: var(--space-3);
  padding-bottom: var(--space-3);
  background: #fde5cc;
  color: #664d03;
}

.site-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--space-4);
  padding-top: var(--space-4);
  padding-bottom: var(--space-2);
  position: relative;
  z-index: 20;
}

.site-header__brand {
  color: inherit;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-decoration: none;
  text-transform: uppercase;
}

.site-header__actions {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
}

.site-header details {
  position: relative;
}

.site-header summary {
  list-style: none;
}

.site-header summary::-webkit-details-marker {
  display: none;
}

.language-menu > summary,
.site-menu > summary,
.site-icon-link {
  min-width: 48px;
  min-height: 48px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  border: 1px solid rgba(255, 255, 255, 0.12);
  background: rgba(255, 255, 255, 0.06);
  box-shadow: 0 12px 32px rgba(0, 0, 0, 0.18);
  cursor: pointer;
}

.theme-admin .language-menu > summary,
.theme-admin .site-menu > summary,
.theme-admin .site-icon-link {
  border-color: #d1d5db;
  background: #ffffff;
  box-shadow: var(--shadow-admin);
}

.site-icon-form {
  display: inline-flex;
  margin: 0;
}

.site-icon-form .site-icon-link {
  cursor: pointer;
  font: inherit;
  padding: 0;
}

.site-icon-link {
  position: relative;
  color: inherit;
  text-decoration: none;
}

.site-icon-link__symbol {
  font-size: 1.2rem;
  font-weight: 700;
  line-height: 1;
}

.site-icon-link__badge {
  position: absolute;
  top: 2px;
  right: 2px;
  min-width: 20px;
  height: 20px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0 5px;
  border-radius: 999px;
  background: #f8d98f;
  color: #170816;
  font-size: 0.72rem;
  font-weight: 700;
  line-height: 1;
}

.site-icon-link--onboarding {
  color: #f8d98f;
}

.site-icon-menu {
  position: relative;
}

.site-icon-menu > summary {
  list-style: none;
}

.site-icon-menu > summary::-webkit-details-marker {
  display: none;
}

.site-icon-menu__panel {
  position: absolute;
  top: calc(100% + var(--space-2));
  right: 0;
  width: min(320px, calc(100vw - 32px));
  display: grid;
  gap: var(--space-3);
  padding: var(--space-4);
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: var(--radius-md);
  background: rgba(15, 5, 23, 0.96);
  box-shadow: var(--shadow-soft);
  z-index: 50;
}

.theme-admin .site-icon-menu__panel {
  border: var(--border-admin);
  background: #ffffff;
  box-shadow: var(--shadow-admin);
}

.site-icon-menu__item {
  display: grid;
  gap: var(--space-1);
}

.site-icon-menu__item span,
.site-icon-menu__item p,
.site-icon-menu__empty {
  margin: 0;
  color: rgba(255, 255, 255, 0.72);
  font-size: 0.88rem;
}

.theme-admin .site-icon-menu__item span,
.theme-admin .site-icon-menu__item p,
.theme-admin .site-icon-menu__empty {
  color: #4b5563;
}

.site-icon-menu__footer {
  color: #f8d98f;
  font-weight: 700;
  text-decoration: none;
}

.language-menu__flag,
.language-menu__option {
  font-size: 1.35rem;
  line-height: 1;
}

.site-menu > summary {
  flex-direction: column;
  gap: 5px;
}

.site-menu > summary span {
  width: 20px;
  height: 2px;
  border-radius: 999px;
  background: currentColor;
}

.language-menu__panel,
.site-menu__panel {
  position: absolute;
  top: calc(100% + var(--space-2));
  right: 0;
  border-radius: var(--radius-lg);
  border: var(--border-soft);
  background: rgba(18, 10, 25, 0.96);
  box-shadow: var(--shadow-soft);
  backdrop-filter: blur(18px);
}

.theme-admin .language-menu__panel,
.theme-admin .site-menu__panel {
  border: var(--border-admin);
  background: #ffffff;
  box-shadow: var(--shadow-admin);
}

.language-menu__panel {
  display: grid;
  gap: var(--space-2);
  padding: var(--space-2);
}

.language-menu__option {
  min-width: 44px;
  min-height: 44px;
  padding: 0;
  border-radius: 999px;
  background: transparent;
}

.language-menu__option:hover {
  background: rgba(255, 255, 255, 0.08);
  transform: none;
}

.site-menu__panel {
  width: min(88vw, 320px);
  padding: var(--space-4);
}

.site-menu__group {
  display: grid;
  gap: var(--space-2);
  padding: var(--space-3) 0;
}

.site-menu__group + .site-menu__group {
  border-top: 1px solid rgba(255, 255, 255, 0.08);
}

.theme-admin .site-menu__group + .site-menu__group {
  border-top-color: #e5e7eb;
}

.site-menu__group strong {
  color: rgba(255, 255, 255, 0.56);
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.theme-admin .site-menu__group strong {
  color: #6b7280;
}

.site-menu__group a {
  padding: 0.55rem 0;
  color: inherit;
  font-weight: 600;
  text-decoration: none;
}

.site-menu__group a:hover {
  color: #ff5ec7;
}

.site-menu__group a.site-menu__link--cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 44px;
  margin: 0.15rem 0;
  padding: 0.7rem 1rem;
  border-radius: 999px;
  background: linear-gradient(135deg, #ec0194, #ff5ec7);
  box-shadow: 0 14px 30px rgba(236, 1, 148, 0.26);
  color: #ffffff;
}

.site-menu__group a.site-menu__link--cta:hover {
  color: #ffffff;
  transform: translateY(-1px);
}

.site-menu__group--accordion {
  gap: 0;
}

.site-menu__group--accordion > summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
  min-height: 44px;
  padding: 0.55rem 0;
  cursor: pointer;
}

.site-menu__accordion-icon {
  position: relative;
  width: 16px;
  height: 16px;
  flex: 0 0 auto;
}

.site-menu__accordion-icon::before,
.site-menu__accordion-icon::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 11px;
  height: 2px;
  border-radius: 999px;
  background: currentColor;
  transform: translate(-50%, -50%);
  transition: transform 160ms ease;
}

.site-menu__accordion-icon::after {
  transform: translate(-50%, -50%) rotate(90deg);
}

.site-menu__group--accordion[open] .site-menu__accordion-icon::after {
  transform: translate(-50%, -50%) rotate(0deg);
}

.site-menu__submenu {
  display: grid;
  gap: var(--space-2);
  padding-bottom: var(--space-2);
}

.site-footer {
  padding-top: var(--space-8);
  padding-bottom: var(--space-8);
  text-align: center;
  font-size: 0.875rem;
}

.site-footer,
.site-footer a,
.site-header,
.site-header a {
  color: inherit;
}

.site-footer__links {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: var(--space-2);
}

.layout {
  width: min(100%, min(1200px, 90vw));
  max-width: 100vw;
  min-height: calc(100vh - 140px);
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  place-items: start center;
  justify-items: center;
  padding: var(--space-6) var(--space-4) var(--space-12);
  overflow-x: hidden;
}

.theme-admin .layout {
  overflow-x: hidden;
}

.panel {
  width: 100%;
  max-width: 680px;
  justify-self: center;
  margin-inline: auto;
  border-radius: var(--radius-lg);
  padding: var(--space-6);
  position: relative;
  overflow: hidden;
}

.theme-frontend .panel {
  background: rgba(255, 255, 255, 0.05);
  border: var(--border-soft);
  box-shadow: var(--shadow-soft);
  backdrop-filter: blur(18px);
}

.theme-admin .panel {
  background: #ffffff;
  border: var(--border-admin);
  box-shadow: 0 8px 24px rgba(17, 24, 39, 0.04);
}

.theme-admin .layout {
  align-content: start;
}

.panel--portal,
.panel--profiles,
.panel--profile_detail,
.panel--messages,
.panel--message_thread,
.panel--profile_settings,
.panel--orders,
.panel--checkout,
.panel--blog_index,
.panel--blog_detail,
.panel--alerts,
.panel--email_settings,
.panel--admin_orders,
.panel--admin_blog,
.panel--admin_email,
.panel--admin_newsletter_campaigns {
  max-width: 1200px;
}

.panel--login,
.panel--register,
.panel--register_pending,
.panel--password_reset_request,
.panel--password_reset_confirm,
.panel--checkout_thanks {
  max-width: 540px;
}

.page-shell.panel {
  width: min(100%, min(1200px, 90vw));
  margin: var(--space-6) auto var(--space-12);
}

.page-shell--wide.panel {
  width: min(100%, min(1200px, 90vw));
}

.panel__back-link {
  margin-top: var(--space-6);
}

.panel__section + .panel__back-link,
.panel__list + .panel__back-link,
.blog-detail__tags + .panel__back-link {
  margin-top: var(--space-8);
}

/* Blog detail: remove nested card styling for intro and content */
.blog-detail-content {
  padding: 0;
  border-radius: 0;
  background: transparent;
  border: none;
  margin-top: 0;
}

.blog-detail-content p,
.blog-detail-content h1,
.blog-detail-content h2,
.blog-detail-content h3,
.blog-detail-content h4,
.blog-detail-content h5,
.blog-detail-content h6 {
  max-width: min(100%, 720px);
  margin-left: auto;
  margin-right: auto;
}

/* Mobile blog detail: use parent width, no nested card */
@media (max-width: 767px) {
  .panel--blog_detail .blog-detail-content {
    padding: 0;
    border-radius: 0;
    background: transparent;
    border: none;
    margin-top: 0;
  }

  .blog-detail-content p,
  .blog-detail-content h1,
  .blog-detail-content h2,
  .blog-detail-content h3,
  .blog-detail-content h4,
  .blog-detail-content h5,
  .blog-detail-content h6 {
    width: 100%;
    max-width: 100%;
    margin-left: auto;
    margin-right: auto;
  }
}

.page-shell--xwide.panel {
  width: min(100%, min(1200px, 90vw));
}

.home-wysiwyg {
  width: min(100%, 960px);
  margin: var(--space-8) auto;
  padding: var(--space-6);
  border: var(--border-soft);
  border-radius: var(--radius-lg);
  background: rgba(255, 255, 255, 0.08);
  box-shadow: var(--shadow-card);
}

.home-wysiwyg__content {
  display: grid;
  gap: var(--space-3);
}

.home-wysiwyg__content > :first-child {
  margin-top: 0;
}

.home-wysiwyg__content > :last-child {
  margin-bottom: 0;
}

.page-shell--admin.panel {
  background: #ffffff;
  border: var(--border-admin);
  box-shadow: 0 8px 24px rgba(17, 24, 39, 0.04);
}

.theme-admin .page-shell--admin.panel {
  padding: var(--space-6);
  border-radius: var(--radius-md);
}

.panel__eyebrow {
  margin: 0 0 var(--space-2);
  text-transform: uppercase;
  letter-spacing: 0.16em;
  font-size: 0.75rem;
  font-weight: 600;
  color: rgba(255, 255, 255, 0.56);
}

.theme-admin .panel__eyebrow {
  color: #6b7280;
  letter-spacing: 0.14em;
  font-size: 0.72rem;
  font-weight: 700;
}

h1,
h2,
h3,
p,
ul,
ol {
  margin-top: 0;
}

h1 {
  margin-bottom: var(--space-3);
  font-size: clamp(2rem, 5vw, 2.5rem);
  line-height: 1.05;
  font-weight: 600;
}

h2 {
  margin-bottom: var(--space-3);
  font-size: clamp(1.35rem, 3vw, 1.5rem);
  font-weight: 600;
}

h3 {
  margin-bottom: var(--space-2);
  font-size: 1.25rem;
  font-weight: 600;
}

.panel__meta,
.panel__error,
.panel__success {
  margin-bottom: var(--space-4);
}

.panel__meta {
  color: rgba(255, 255, 255, 0.72);
}

.theme-admin .panel__meta {
  color: #4b5563;
}

.panel__error,
.panel__error-list {
  color: #ffd1d9;
}

.theme-admin .panel__error,
.theme-admin .panel__error-list {
  color: #b42318;
}

.panel__success {
  color: #d0ffd8;
}

.theme-admin .panel__success {
  color: #0f7b3f;
}

.panel__flash {
  display: grid;
  gap: var(--space-2);
  padding: 0;
  margin: 0 0 var(--space-4);
  list-style: none;
}

.panel__flash-button {
  display: flex;
  width: 100%;
  min-width: 0;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
  padding: 0.75rem 0.95rem;
  border: 1px solid rgba(255, 255, 255, 0.18);
  border-radius: 0.75rem;
  background: rgba(255, 255, 255, 0.08);
  color: rgba(255, 255, 255, 0.86);
  text-align: left;
  cursor: pointer;
  overflow-wrap: anywhere;
}

.panel__flash--success .panel__flash-button {
  border-color: rgba(52, 211, 153, 0.42);
  background: rgba(52, 211, 153, 0.1);
  color: #d0ffd8;
}

.panel__flash--error .panel__flash-button {
  border-color: rgba(255, 99, 132, 0.42);
  background: rgba(255, 99, 132, 0.1);
  color: #ffd1d9;
}

.panel__flash-button:hover,
.panel__flash-button:focus-visible {
  border-color: rgba(255, 255, 255, 0.36);
  background: rgba(255, 255, 255, 0.12);
}

.panel__flash-button i {
  flex: 0 0 auto;
  font-size: 0.9rem;
  opacity: 0.72;
}

.theme-admin .panel__flash--success .panel__flash-button {
  border-color: rgba(15, 123, 63, 0.28);
  background: rgba(15, 123, 63, 0.08);
  color: #0f7b3f;
}

.theme-admin .panel__flash--error .panel__flash-button {
  border-color: rgba(180, 35, 24, 0.28);
  background: rgba(180, 35, 24, 0.08);
  color: #b42318;
}

.panel__list,
.profile-cards,
.admin-list,
.faq-list {
  list-style: none;
  padding: 0;
  margin: 0;
}

.panel__list {
  display: grid;
  gap: var(--space-3);
}

.theme-admin .panel__list > li {
  padding: var(--space-4);
  border: var(--border-admin);
  border-radius: var(--radius-md);
  background: #ffffff;
}

.theme-admin .panel__list > li > strong:first-child {
  display: inline-block;
  margin-bottom: var(--space-1);
  color: var(--color-admin-text);
}

.panel__section {
  margin-top: var(--space-6);
  padding: var(--space-5);
  border-radius: var(--radius-md);
}

.theme-frontend .panel__section {
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid rgba(255, 255, 255, 0.06);
}

.theme-admin .panel__section {
  background: #f7f7f7;
  border: var(--border-admin);
}

.panel__sections {
  display: grid;
  gap: var(--space-4);
  margin-bottom: var(--space-6);
}

.portal-tabs {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(190px, 1fr));
  gap: var(--space-3);
  margin-top: var(--space-5);
}

.portal-tab {
  appearance: none;
  min-height: 76px;
  display: flex;
  align-items: flex-start;
  gap: var(--space-3);
  padding: var(--space-4);
  border: 0;
  border-radius: var(--radius-md);
  color: inherit;
  font: inherit;
  text-align: left;
  text-decoration: none;
  cursor: pointer;
  transition: transform 160ms ease, background-color 160ms ease, outline-color 160ms ease;
}

.theme-frontend .portal-tab {
  border: 1px solid rgba(255, 255, 255, 0.08);
  background: rgba(255, 255, 255, 0.055);
}

.theme-admin .portal-tab {
  border: var(--border-admin);
  background: #ffffff;
}

.portal-tab:hover {
  transform: translateY(-1px);
}

.portal-tab:focus-visible {
  outline: 2px solid rgba(248, 217, 143, 0.7);
  outline-offset: 2px;
}

.portal-tab.is-active {
  outline: 2px solid rgba(248, 217, 143, 0.56);
  background: rgba(248, 217, 143, 0.12);
}

.portal-tab__icon {
  width: 36px;
  height: 36px;
  display: inline-flex;
  flex: 0 0 auto;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  background: rgba(248, 217, 143, 0.16);
  color: #f8d98f;
  font-weight: 700;
}

.portal-tab__icon i {
  font-size: 0.95rem;
  line-height: 1;
}

.profile-tabs-row {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--space-3);
  margin-top: var(--space-5);
}

.profile-tabs {
  display: inline-flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  padding: 0.25rem;
  border-radius: var(--radius-md);
}

.theme-frontend .profile-tabs {
  background: rgba(255, 255, 255, 0.06);
}

.profile-tab {
  min-height: 42px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.6rem 1rem;
  border-radius: var(--radius-sm);
  color: inherit;
  text-decoration: none;
  font-weight: 700;
}

.profile-tab.is-active {
  background: rgba(248, 217, 143, 0.18);
  color: #f8d98f;
}

.profile-filter {
  position: relative;
  display: grid;
  justify-items: end;
}

.profile-filter__toggle,
.profile-card__icon-button {
  appearance: none;
  min-width: 42px;
  min-height: 42px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.4rem;
  border-radius: 999px;
  border: 1px solid rgba(248, 217, 143, 0.35);
  background: rgba(255, 255, 255, 0.06);
  color: #f8d98f;
  font: inherit;
  font-weight: 700;
  cursor: pointer;
}

.profile-filter__toggle.is-active,
.profile-card__icon-button.is-active {
  background: rgba(248, 217, 143, 0.2);
}

.profile-filter__form {
  width: min(720px, calc(100vw - 2rem));
  margin-top: var(--space-3);
}

.profile-filter__range {
  display: grid;
  gap: var(--space-2);
}

.profile-filter__range strong {
  color: #f8d98f;
}

.profile-filter__range-inputs {
  display: grid;
  gap: 0.35rem;
}

.portal-tab__content {
  display: grid;
  gap: var(--space-1);
}

.portal-tab__content strong {
  font-size: 1rem;
}

.portal-logout {
  margin-top: var(--space-5);
}

.portal-tab-content {
  margin-top: var(--space-5);
}

.portal-home,
.portal-upgrade {
  display: grid;
  gap: var(--space-4);
}

.portal-infographic {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(120px, 1fr));
  gap: var(--space-3);
  margin: 0;
}

.portal-stat {
  display: grid;
  gap: var(--space-1);
  padding: var(--space-4);
  border-radius: var(--radius-md);
  background: rgba(255, 255, 255, 0.06);
}

.portal-stat dt {
  color: rgba(255, 255, 255, 0.68);
  font-size: 0.82rem;
}

.portal-stat dd {
  margin: 0;
  color: #f8d98f;
  font-size: 1.8rem;
  font-weight: 800;
}

.portal-stat--link dt a {
  color: inherit;
  text-decoration: none;
}

.portal-stat--link dt a::after {
  content: "";
  position: absolute;
  inset: 0;
}

.portal-stat--link {
  position: relative;
  transition: transform 160ms ease, border-color 160ms ease, background 160ms ease;
}

.portal-stat--link:hover {
  transform: translateY(-1px);
}

.theme-admin .portal-stat {
  background: #ffffff;
}

.theme-admin .portal-stat dt {
  color: #4b5563;
}

.portal-cta__button {
  width: fit-content;
}

.panel__form {
  display: grid;
  gap: var(--space-4);
}

.panel__form--compact {
  gap: var(--space-3);
}

.panel__form--inline,
.inline-form {
  display: flex;
  flex-wrap: wrap;
  align-items: end;
  gap: var(--space-3);
}

.panel__field {
  display: grid;
  gap: var(--space-2);
}

.panel__field--checkbox {
  grid-template-columns: auto 1fr;
  align-items: center;
}

.panel__field span,
.panel__field label,
label {
  font-size: 0.875rem;
  font-weight: 500;
}

input,
select,
textarea {
  width: 100%;
  border-radius: var(--radius-md);
  padding: 0.9rem 1rem;
  transition: border-color 160ms ease, box-shadow 160ms ease, background 160ms ease;
}

textarea {
  min-height: 120px;
  resize: vertical;
}

.theme-frontend input,
.theme-frontend select,
.theme-frontend textarea {
  color: #ffffff;
  border: 1px solid rgba(255, 255, 255, 0.1);
  background: rgba(255, 255, 255, 0.06);
}

.theme-frontend input::placeholder,
.theme-frontend textarea::placeholder {
  color: rgba(255, 255, 255, 0.46);
}

.theme-admin input,
.theme-admin select,
.theme-admin textarea {
  color: #111827;
  border: 1px solid #d1d5db;
  background: #ffffff;
}

input:focus,
select:focus,
textarea:focus {
  outline: none;
  border-color: #ec0194;
  box-shadow: 0 0 0 3px rgba(236, 1, 148, 0.18);
}

button,
.button,
.button-link,
.profile-card__cta,
.panel__actions a,
.panel__cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 52px;
  padding: 0.85rem 1.2rem;
  border-radius: var(--radius-md);
  border: 1px solid transparent;
  font-weight: 700;
  text-decoration: none;
  text-align: center;
  overflow-wrap: anywhere;
  transition: transform 160ms ease, background 160ms ease, border-color 160ms ease, color 160ms ease;
}

button,
.button,
.panel__cta,
.profile-card__cta,
.panel__actions a {
  background: var(--color-primary);
  color: #ffffff;
}

.button--primary {
  background: var(--color-primary);
  color: #ffffff;
}

.profile-card__cta--secondary {
  border-color: rgba(255, 255, 255, 0.18);
  background: rgba(255, 255, 255, 0.08);
}

button:hover,
.button:hover,
.button-link:hover,
.profile-card__cta:hover,
.panel__actions a:hover,
.panel__cta:hover {
  transform: translateY(-1px);
  background: var(--color-primary-hover);
}

.profile-card__cta--secondary:hover {
  background: rgba(255, 255, 255, 0.14);
}

button:active,
.button:active,
.button-link:active,
.profile-card__cta:active,
.panel__actions a:active,
.panel__cta:active {
  background: var(--color-primary-active);
}

button:disabled,
.button-link[aria-disabled="true"],
.profile-card__cta[aria-disabled="true"],
.panel__cta[aria-disabled="true"] {
  cursor: not-allowed;
  opacity: 0.58;
  transform: none;
}

.onboarding__link,
.text-link,
.secondary-link,
.panel a:not(.profile-card__cta):not(.panel__cta):not(.button-link):not(.panel__actions a):not(.frontend-pagination__control):not(.blog-pagination__control) {
  color: #ffffff;
  text-decoration: underline;
  text-decoration-color: rgba(255, 255, 255, 0.24);
  text-underline-offset: 0.2em;
}

.theme-admin .onboarding__link,
.theme-admin .text-link,
.theme-admin .secondary-link,
.theme-admin .panel a:not(.profile-card__cta):not(.panel__cta):not(.button-link):not(.admin-icon-button):not(.panel__actions a):not(.frontend-pagination__control):not(.blog-pagination__control) {
  color: #111827;
  text-decoration-color: rgba(17, 24, 39, 0.28);
}

.theme-admin button:not(.button--primary):not(.button--danger):not(.button--ghost):not(.admin-icon-button):not(.panel__flash-button),
.theme-admin .button:not(.button--primary):not(.button--danger):not(.button--ghost),
.theme-admin .panel__actions a:not(.button--primary):not(.button--danger):not(.button--ghost) {
  min-height: 44px;
  padding: 0.65rem 0.95rem;
  border-color: #d1d5db;
  background: #ffffff;
  color: var(--color-admin-text);
  font-weight: 700;
}

.theme-admin button:not(.button--primary):not(.button--danger):not(.button--ghost):not(.admin-icon-button):not(.panel__flash-button):hover,
.theme-admin .button:not(.button--primary):not(.button--danger):not(.button--ghost):hover,
.theme-admin .panel__actions a:not(.button--primary):not(.button--danger):not(.button--ghost):hover {
  border-color: #bfc5cf;
  background: #f9fafb;
  color: var(--color-admin-text);
}

.panel__actions {
  display: flex;
  gap: var(--space-3);
  flex-wrap: wrap;
  align-items: center;
}

.panel__actions form {
  margin: 0;
}

.panel__actions--top {
  margin-bottom: var(--space-4);
}

.split-layout {
  display: grid;
  gap: var(--space-6);
}

.admin-list {
  display: grid;
  gap: var(--space-3);
}

.admin-dashboard {
  display: grid;
  gap: var(--space-6);
}

.admin-dashboard__hero {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-5);
  padding: var(--space-6);
  border-radius: var(--radius-md);
  background: #ffffff;
  border: var(--border-admin);
}

.admin-dashboard__hero h1,
.admin-dashboard__hero .panel__meta,
.admin-section-heading h2,
.admin-section-heading .panel__meta,
.admin-card__header h2,
.admin-card__header .panel__meta {
  margin-bottom: 0;
}

.admin-tabs {
  margin-top: 0;
}

.admin-kpi-grid,
.admin-module-grid,
.admin-dashboard__content-grid,
.admin-mini-metrics {
  display: grid;
  gap: var(--space-3);
}

.admin-kpi-grid {
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
}

.admin-kpi-card,
.admin-module-card {
  border-radius: var(--radius-md);
  border: var(--border-admin);
  background: #ffffff;
  box-shadow: none;
}

.admin-kpi-card {
  display: grid;
  gap: var(--space-1);
  min-height: 128px;
  padding: var(--space-5);
  color: #111827;
  text-decoration: none;
  transition: transform 160ms ease, border-color 160ms ease, box-shadow 160ms ease;
}

.admin-kpi-card:hover {
  transform: translateY(-1px);
  border-color: #cfd4dc;
  box-shadow: 0 8px 20px rgba(17, 24, 39, 0.05);
}

.admin-kpi-card--attention {
  border-color: #f4b8d9;
  background: #fff7fb;
}

.admin-kpi-card__label,
.admin-kpi-card__hint,
.admin-module-card small,
.admin-activity-list span,
.admin-mini-metrics dt {
  color: #6b7280;
}

.admin-kpi-card__label,
.admin-mini-metrics dt {
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.admin-kpi-card strong {
  color: #111827;
  font-size: 2.4rem;
  line-height: 1;
}

.admin-dashboard__section {
  display: grid;
  gap: var(--space-4);
}

.admin-section-heading,
.admin-card__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-4);
}

.admin-module-grid {
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
}

.admin-module-card {
  min-height: 108px;
  display: flex;
  align-items: flex-start;
  gap: var(--space-3);
  padding: var(--space-4);
  color: #111827;
  text-decoration: none;
  transition: transform 160ms ease, border-color 160ms ease, box-shadow 160ms ease;
}

.admin-module-card:hover {
  transform: translateY(-1px);
  border-color: #cfd4dc;
  box-shadow: 0 8px 20px rgba(17, 24, 39, 0.05);
}

.admin-module-card__icon {
  width: 38px;
  height: 38px;
  display: inline-flex;
  flex: 0 0 auto;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  background: #f3f4f6;
  color: #374151;
  font-weight: 800;
}

.admin-module-card span:last-child {
  display: grid;
  gap: var(--space-1);
  min-width: 0;
}

.admin-module-card strong,
.admin-module-card small {
  overflow-wrap: anywhere;
}

.admin-dashboard__content-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.admin-card--dashboard {
  display: grid;
  gap: var(--space-4);
}

.admin-email-summary,
.admin-email-section {
  display: grid;
  gap: var(--space-4);
  padding: var(--space-4);
  border: var(--border-admin);
  border-radius: var(--radius-md);
  background: #f9fafb;
}

.admin-email-summary h2,
.admin-email-section h2 {
  margin: 0;
  font-size: 1rem;
  color: #111827;
}

.admin-email-form {
  margin-top: var(--space-5);
}

.admin-email-stats {
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
}

.admin-email-stats li {
  padding: var(--space-3);
  border: var(--border-admin);
  border-radius: var(--radius-sm);
  background: #ffffff;
}

.admin-email-stats .panel__meta {
  display: block;
  font-size: 0.875rem;
  color: #4b5563;
  margin-bottom: 0.25rem;
}

.admin-email-backlog-button {
  margin-bottom: var(--space-2);
}

.admin-email-test {
  margin-top: var(--space-5);
}

.admin-email-test .button--secondary {
  justify-self: start;
}

.admin-email-notice {
  margin: 0;
  padding: 0.75rem 0.9rem;
  border-radius: var(--radius-sm);
  border: 1px solid transparent;
  font-weight: 700;
}

.admin-email-notice--success {
  border-color: rgba(52, 211, 153, 0.45);
  background: rgba(52, 211, 153, 0.12);
  color: #d0ffd8;
}

.admin-email-notice--error {
  border-color: rgba(255, 99, 132, 0.45);
  background: rgba(255, 99, 132, 0.12);
  color: #ffd1d9;
}

.theme-admin .admin-email-notice--success {
  border-color: rgba(15, 123, 63, 0.28);
  background: rgba(15, 123, 63, 0.08);
  color: #0f7b3f;
}

.theme-admin .admin-email-notice--error {
  border-color: rgba(180, 35, 24, 0.28);
  background: rgba(180, 35, 24, 0.08);
  color: #b42318;
}

.admin-email-field--checkbox {
  width: fit-content;
  min-height: 44px;
}

.admin-email-field--checkbox input[type="checkbox"] {
  width: 1.1rem;
  height: 1.1rem;
  padding: 0;
}

.admin-email-field--range input[type="range"] {
  padding-inline: 0;
}

.admin-email-range__meta {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  align-items: center;
  color: #4b5563;
}

.admin-email-range__meta strong {
  min-width: 4rem;
  color: #111827;
}

.button-link--secondary {
  min-height: 44px;
  padding: 0.65rem 0.95rem;
  background: #ffffff;
  color: #111827;
  border-color: #d1d5db;
}

.button-link--secondary:hover {
  background: #f9fafb;
}

.button--secondary {
  min-height: 44px;
  padding: 0.65rem 0.95rem;
  background: rgba(236, 1, 148, 0.06);
  color: #b80073;
  border-color: rgba(236, 1, 148, 0.42);
}

.button--secondary:hover,
.button--secondary:active {
  background: rgba(236, 1, 148, 0.1);
  color: #97015f;
  border-color: rgba(236, 1, 148, 0.62);
}

.theme-admin .button--secondary,
.theme-admin .button-link--secondary {
  background: #ffffff;
  color: var(--color-admin-text);
  border-color: #d1d5db;
}

.theme-admin .button--secondary:hover,
.theme-admin .button--secondary:active,
.theme-admin .button-link--secondary:hover,
.theme-admin .button-link--secondary:active {
  background: #f9fafb;
  color: var(--color-admin-text);
  border-color: #bfc5cf;
}

.button--ghost {
  min-height: 44px;
  padding: 0.65rem 0.95rem;
  background: transparent;
  color: inherit;
  border-color: rgba(255, 255, 255, 0.18);
}

.theme-admin .button--ghost {
  border-color: #d1d5db;
  color: var(--color-admin-text);
  background: transparent;
}

.theme-admin .button--ghost:hover,
.theme-admin .button--ghost:active {
  background: #f9fafb;
  color: var(--color-admin-text);
}

.button--danger {
  min-height: 44px;
  padding: 0.65rem 0.95rem;
  background: rgba(180, 35, 24, 0.08);
  color: #b42318;
  border-color: rgba(180, 35, 24, 0.32);
}

.button--danger:hover,
.button--danger:active {
  background: rgba(180, 35, 24, 0.14);
  color: #8a1f17;
  border-color: rgba(180, 35, 24, 0.5);
}

.admin-activity-list {
  display: grid;
  gap: var(--space-3);
  padding: 0;
  margin: 0;
  list-style: none;
}

.admin-activity-list li {
  display: grid;
  gap: var(--space-1);
  padding: var(--space-3);
  border-radius: var(--radius-sm);
  background: #f9fafb;
}

.admin-activity-list a {
  color: #111827;
  font-weight: 700;
  text-decoration: none;
}

.ticket-attachments {
  display: grid;
  gap: var(--space-3);
  margin-top: var(--space-3);
  padding-left: 0;
  list-style: none;
}

.ticket-attachment {
  display: grid;
  gap: var(--space-2);
  align-items: start;
  max-width: 360px;
}

.ticket-attachment__preview {
  display: block;
  overflow: hidden;
  border-radius: var(--radius-md);
  border: var(--border-admin);
  background: #f9fafb;
}

.ticket-attachment__preview img {
  display: block;
  width: 100%;
  max-height: 220px;
  object-fit: cover;
}

.admin-mini-metrics {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  margin: 0;
}

.admin-mini-metrics div {
  padding: var(--space-3);
  border-radius: var(--radius-sm);
  background: #f9fafb;
}

.admin-mini-metrics dd {
  margin: var(--space-1) 0 0;
  color: #111827;
  font-size: 1.6rem;
  font-weight: 800;
}

.admin-list__item,
.admin-card,
.faq-list__item {
  padding: var(--space-4);
  border-radius: var(--radius-md);
  border: var(--border-admin);
  background: #ffffff;
}

.theme-frontend .admin-list__item,
.theme-frontend .admin-card,
.theme-frontend .faq-list__item {
  background: rgba(255, 255, 255, 0.05);
  border: var(--border-soft);
}

.admin-list__item.is-active {
  border-color: #bfc5cf;
  box-shadow: inset 0 0 0 1px #e5e5e5;
}

.admin-breadcrumb {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  max-width: min(100% - 2rem, 1200px);
  margin: var(--space-4) auto 0;
  color: #6b7280;
  font-size: 0.92rem;
}

.admin-breadcrumb a {
  color: #374151;
  font-weight: 700;
  text-decoration: none;
}

.admin-breadcrumb span::before {
  content: "/";
  margin-right: var(--space-2);
  color: #9ca3af;
}

.admin-surface,
.admin-page-heading {
  display: grid;
  gap: var(--space-5);
}

.admin-page-heading {
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: end;
}

.admin-summary-grid {
  display: grid;
  gap: var(--space-3);
}

.admin-summary-grid--2 {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.admin-toolbar {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: flex-end;
  gap: var(--space-2);
}

.admin-popover {
  position: relative;
}

.admin-popover > summary {
  list-style: none;
  cursor: pointer;
}

.admin-popover > summary::-webkit-details-marker {
  display: none;
}

.admin-popover__panel {
  position: absolute;
  top: calc(100% + var(--space-2));
  right: 0;
  z-index: 20;
  width: min(92vw, 520px);
  padding: var(--space-4);
  border: var(--border-admin);
  border-radius: var(--radius-md);
  background: #ffffff;
  box-shadow: var(--shadow-soft);
}

.admin-table {
  width: 100%;
  max-width: 100%;
  border-collapse: collapse;
  font-size: 0.95rem;
}

.admin-table-wrap {
  width: 100%;
  overflow-x: auto;
}

.admin-table--interactive tbody tr {
  transition: background 150ms ease;
}

.admin-table--interactive tbody tr:hover {
  background: #f9fafb;
}

.admin-clickable-row {
  cursor: pointer;
}

.admin-table th,
.admin-table td {
  padding: var(--space-3) var(--space-2);
  border-bottom: var(--border-admin);
  vertical-align: middle;
  text-align: left;
}

.admin-table th {
  font-size: 0.8rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: #6b7280;
}

.admin-row-link {
  color: #111827;
  font-weight: 700;
  text-decoration: none;
}

.admin-row-link:hover,
.admin-row-link:focus-visible {
  color: #111827;
  text-decoration: underline;
}

.admin-table__actions,
.admin-action-row {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
}

.admin-action-row {
  flex-wrap: wrap;
  margin: var(--space-4) 0;
}

.admin-action-row form,
.admin-table__actions form {
  margin: 0;
}

/* Vertically center all action column content */
.admin-table td:last-child {
  display: flex;
  align-items: center;
  justify-content: flex-end;
}

/* Handle warning messages in action columns */
.admin-table td:last-child p.panel__flash {
  margin: 0 0.5rem 0 0;
  white-space: nowrap;
}

.admin-icon-button {
  width: 2.75rem;
  min-width: 2.75rem;
  height: 2.75rem;
  min-height: 2.75rem;
  flex: 0 0 2.75rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  border: var(--border-admin);
  border-radius: var(--radius-sm);
  appearance: none;
  background: #ffffff;
  color: #374151;
  font: inherit;
  font-weight: 700;
  line-height: 1;
  text-decoration: none;
  cursor: pointer;
}

.admin-icon-button:hover,
.admin-icon-button:focus-visible {
  color: var(--color-admin-text);
  border-color: #bfc5cf;
  background: #f9fafb;
}

.admin-icon-button--danger {
  color: #374151;
}

.admin-icon-button--danger:hover,
.admin-icon-button--danger:focus-visible {
  color: var(--color-admin-text);
  border-color: #bfc5cf;
  background: #f9fafb;
}

.admin-icon-button--active-danger {
  color: #b91c1c;
  border-color: rgba(185, 28, 28, 0.38);
  background: #fef2f2;
}

.admin-icon-button--active-danger:hover,
.admin-icon-button--active-danger:focus-visible {
  color: #991b1b;
  border-color: rgba(185, 28, 28, 0.5);
  background: #fee2e2;
}

.admin-pagination {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: var(--space-3);
  margin-top: var(--space-4);
}

.admin-detail-list {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--space-3);
}

.admin-detail-list div {
  padding: var(--space-3);
  border: var(--border-admin);
  border-radius: var(--radius-sm);
  background: #f9fafb;
}

.admin-detail-list dt {
  color: #6b7280;
  font-size: 0.78rem;
  font-weight: 700;
  text-transform: uppercase;
}

.admin-detail-list dd {
  margin: var(--space-1) 0 0;
  color: #111827;
  overflow-wrap: anywhere;
}

.admin-code-block {
  max-height: 340px;
  overflow: auto;
  padding: var(--space-3);
  border: var(--border-admin);
  border-radius: var(--radius-sm);
  background: #111827;
  color: #f9fafb;
  font-size: 0.82rem;
  white-space: pre-wrap;
  overflow-wrap: anywhere;
}

.admin-status-pill {
  display: inline-flex;
  align-items: center;
  min-height: 1.9rem;
  padding: 0 var(--space-2);
  border-radius: 999px;
  background: #eef2ff;
  color: #3730a3;
  font-size: 0.82rem;
  font-weight: 700;
}

.admin-status-pill--attention {
  background: #fff7fb;
  color: #9d174d;
}

.admin-modal {
  position: fixed;
  inset: 0;
  z-index: 1200;
  display: none;
  place-items: center;
  align-content: center;
  min-height: 100%;
  width: 100%;
  padding: var(--space-4);
  overflow-y: auto;
  overflow-x: hidden;
  box-sizing: border-box;
}

.admin-modal:target,
.admin-modal.is-open {
  display: grid;
}

.admin-modal--sub:target {
  z-index: 1300;
}

.admin-modal__backdrop {
  position: fixed;
  inset: 0;
  background: rgba(17, 24, 39, 0.58);
}

.admin-modal__card {
  position: relative;
  z-index: 1;
  width: min(100%, min(760px, 90vw));
  max-width: min(1200px, 90vw);
  max-height: min(84vh, 760px);
  overflow: auto;
  display: grid;
  gap: var(--space-4);
  padding: var(--space-5);
  border: var(--border-admin);
  border-radius: var(--radius-lg);
  background: #ffffff;
  box-shadow: 0 24px 70px rgba(17, 24, 39, 0.24);
  margin: auto;
  box-sizing: border-box;
}

.admin-modal__card--narrow {
  width: min(100%, min(420px, 90vw));
}

.admin-table--logs td:nth-child(4) {
  max-width: 520px;
}

.admin-table--logs small,
.admin-log-detail pre {
  overflow-wrap: anywhere;
  word-break: break-word;
}

.admin-log-detail {
  display: grid;
  gap: var(--space-3);
}

.admin-log-detail h3 {
  margin: 0;
  color: #374151;
  font-size: 0.9rem;
}

.admin-log-detail p,
.admin-log-detail pre {
  margin: 0;
  padding: var(--space-3);
  border: var(--border-admin);
  border-radius: var(--radius-sm);
  background: #f9fafb;
  color: #111827;
}

.admin-log-detail pre {
  white-space: pre-wrap;
  font-size: 0.85rem;
}

.profile-cards {
  display: grid;
  gap: var(--space-4);
  margin-top: var(--space-4);
}

.profile-card {
  display: grid;
  min-width: 0;
  gap: var(--space-4);
  padding: var(--space-5);
  border-radius: var(--radius-lg);
  overflow-wrap: anywhere;
}

.profile-card--discovery {
  grid-template-columns: minmax(96px, 128px) minmax(0, 1fr);
  align-items: stretch;
}

.profile-card--upgrade {
  border-color: rgba(248, 217, 143, 0.34);
  background:
    linear-gradient(135deg, rgba(248, 217, 143, 0.14), rgba(236, 1, 148, 0.1)),
    rgba(255, 255, 255, 0.06);
}

.theme-frontend .profile-card {
  background: rgba(255, 255, 255, 0.05);
  border: 1px solid rgba(255, 255, 255, 0.07);
}

.theme-frontend .profile-card--upgrade {
  border-color: rgba(248, 217, 143, 0.34);
  background:
    linear-gradient(135deg, rgba(248, 217, 143, 0.14), rgba(236, 1, 148, 0.1)),
    rgba(255, 255, 255, 0.06);
}

.theme-admin .profile-card {
  background: #f7f7f7;
  border: var(--border-admin);
}

.profile-card__content {
  display: grid;
  gap: var(--space-2);
}

.profile-card__photo,
.profile-card__photo-placeholder {
  width: 100%;
  aspect-ratio: 1;
  border-radius: var(--radius-md);
}

.profile-card__photo {
  object-fit: cover;
}

.profile-card__photo-placeholder {
  display: grid;
  place-items: center;
  padding: var(--space-3);
  text-align: center;
  font-size: 0.78rem;
  font-weight: 800;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.76);
  background:
    linear-gradient(135deg, rgba(248, 217, 143, 0.16), rgba(6, 154, 233, 0.16)),
    rgba(255, 255, 255, 0.06);
  border: 1px dashed rgba(255, 255, 255, 0.22);
}

.profile-card__footer {
  grid-column: 2;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  align-items: center;
  gap: var(--space-3);
}

.profile-card__actions {
  display: contents;
}

.profile-card__actions--detail {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--space-3);
}

.profile-card__flirt-form {
  grid-column: 1 / -1;
}

.profile-card__action-button,
.profile-card__actions form {
  width: 100%;
}

.profile-card__action-button {
  min-height: 46px;
  border-radius: var(--radius-sm);
  padding: 0.55rem 0.75rem;
}

.profile-card__actions form {
  margin: 0;
}

.profile-card__icon-actions {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  flex-wrap: wrap;
}

.profile-card__icon-actions form {
  margin: 0;
}

.profile-card__header {
  display: flex;
  justify-content: space-between;
  gap: var(--space-3);
  align-items: center;
  flex-wrap: wrap;
}

.profile-card__name {
  font-size: 1.125rem;
  font-weight: 600;
}

.profile-card__badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 32px;
  padding: 0.35rem 0.75rem;
  border-radius: 999px;
  background: rgba(6, 154, 233, 0.16);
  color: #8fd8ff;
  font-size: 0.8rem;
  font-weight: 600;
}

.profile-card--catch {
  border-style: dashed;
  background: rgba(255, 255, 255, 0.03);
}

.theme-admin .profile-card__badge {
  background: #e0f2fe;
  color: #0369a1;
}

.profile-card__meta,
.profile-card__about {
  margin: 0;
}

.profile-card__meta {
  color: rgba(255, 255, 255, 0.66);
}

.theme-admin .profile-card__meta {
  color: #4b5563;
}

.profile-card__about {
  color: rgba(255, 255, 255, 0.92);
}

.theme-admin .profile-card__about {
  color: #111827;
}

.modal-backdrop {
  position: fixed;
  inset: 0;
  z-index: 1000;
  display: grid;
  place-items: center;
  min-height: 100vh;
  min-width: 100%;
  align-content: center;
  overflow-y: auto;
  overflow-x: hidden;
  box-sizing: border-box;
  padding: var(--space-4);
  background: rgba(0, 0, 0, 0.56);
}

.modal-card {
  width: min(460px, 100%);
  display: grid;
  gap: var(--space-4);
  padding: var(--space-5);
  border-radius: var(--radius-md);
  background: #221923;
  border: 1px solid rgba(255, 255, 255, 0.12);
  box-shadow: 0 20px 80px rgba(0, 0, 0, 0.35);
  color: rgba(255, 255, 255, 0.92);
  margin: auto;
  box-sizing: border-box;
  max-width: min(460px, calc(100vw - (var(--space-4) * 2)));
}

.modal-card__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
}

.modal-card__header h2 {
  margin: 0;
  font-size: 1.2rem;
  color: #ffffff;
}

.modal-card .panel__meta,
.modal-card .admin-table th {
  color: rgba(255, 255, 255, 0.68);
}

.modal-card .admin-table td,
.modal-card .admin-table th {
  border-color: rgba(255, 255, 255, 0.14);
}

.modal-card .admin-table,
.modal-card p {
  color: rgba(255, 255, 255, 0.9);
}

.theme-admin .modal-card {
  border: var(--border-admin);
  border-radius: var(--radius-lg);
  background: #ffffff;
  color: var(--color-admin-text);
  box-shadow: 0 24px 70px rgba(17, 24, 39, 0.24);
}

.theme-admin .modal-card__header h2,
.theme-admin .modal-card p,
.theme-admin .modal-card .admin-table {
  color: var(--color-admin-text);
}

.theme-admin .modal-card .panel__meta,
.theme-admin .modal-card .admin-table th {
  color: #6b7280;
}

.theme-admin .modal-card .admin-table td,
.theme-admin .modal-card .admin-table th {
  border-color: #e5e5e5;
}

.profile-detail__photo-wrap,
.media-frame {
  margin-bottom: var(--space-5);
}

.profile-detail__photo,
.profile-detail__photo-placeholder,
.media-frame__image {
  display: block;
  max-width: 100%;
  border-radius: var(--radius-lg);
}

.profile-detail__photo,
.media-frame__image {
  width: auto;
  height: auto;
  max-height: min(70vh, 720px);
  margin-left: auto;
  margin-right: auto;
  object-fit: contain;
  object-position: center center;
}

.profile-detail__photo-placeholder {
  width: 100%;
  min-height: 240px;
  display: grid;
  place-items: center;
  text-align: center;
  padding: var(--space-5);
}

.theme-frontend .profile-detail__photo,
.theme-frontend .profile-detail__photo-placeholder,
.theme-frontend .media-frame__image {
  border: 1px solid rgba(255, 255, 255, 0.07);
  background: rgba(255, 255, 255, 0.05);
}

.theme-admin .profile-detail__photo,
.theme-admin .profile-detail__photo-placeholder,
.theme-admin .media-frame__image {
  border: var(--border-admin);
  background: #ffffff;
}

.profile-detail__photo--blurred {
  filter: blur(10px);
}

.message-image,
.blog-cover,
.blog-cover--detail,
.blog-cover--admin {
  display: block;
  width: 100%;
  border-radius: var(--radius-md);
}

.message-image {
  max-width: 320px;
  max-height: 320px;
  object-fit: cover;
  margin-top: var(--space-2);
}

.blog-cover {
  max-width: 240px;
  margin-bottom: var(--space-3);
}

.blog-cover--detail {
  margin-bottom: var(--space-4);
}

.blog-cover--admin {
  max-width: 240px;
}

.blog-cards {
  display: grid;
  gap: var(--space-4);
  margin-top: var(--space-4);
}

.blog-card {
  display: grid;
  min-width: 0;
  overflow: hidden;
  border-radius: var(--radius-lg);
}

.theme-frontend .blog-card {
  background: rgba(255, 255, 255, 0.05);
  border: 1px solid rgba(255, 255, 255, 0.07);
}

.theme-admin .blog-card {
  background: #f7f7f7;
  border: var(--border-admin);
}

.blog-card__image,
.blog-card__placeholder {
  display: block;
  width: 100%;
  aspect-ratio: 16 / 10;
}

.blog-card__image {
  height: auto;
  object-fit: cover;
  object-position: center;
}

.panel__section img,
.blog-cover,
.blog-cover--detail,
.public-page__image {
  height: auto;
  object-fit: contain;
  object-position: center;
}

.blog-card__placeholder {
  position: relative;
  overflow: hidden;
  background:
    radial-gradient(circle at 50% 22%, rgba(248, 217, 143, 0.28), transparent 18%),
    linear-gradient(145deg, rgba(31, 16, 46, 0.95), rgba(131, 64, 99, 0.72) 52%, rgba(248, 217, 143, 0.28));
}

.blog-card__placeholder::before {
  content: "";
  position: absolute;
  inset: auto 18% 0;
  height: 58%;
  border-radius: 46% 46% 0 0;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.16), transparent 34%),
    rgba(18, 10, 24, 0.58);
  filter: blur(0.2px);
}

.blog-card__placeholder::after {
  content: "";
  position: absolute;
  left: 50%;
  bottom: 47%;
  width: 18%;
  aspect-ratio: 1;
  transform: translateX(-50%);
  border-radius: 50% 50% 45% 45%;
  background: rgba(245, 209, 176, 0.84);
  box-shadow: 0 18px 40px rgba(0, 0, 0, 0.24);
}

.blog-card__placeholder span {
  position: absolute;
  left: 28%;
  right: 28%;
  bottom: 27%;
  height: 19%;
  border-radius: 999px 999px 20px 20px;
  background: rgba(255, 255, 255, 0.42);
  transform: rotate(-4deg);
}

.public-page__image {
  display: block;
  width: 100%;
  margin: var(--space-5) 0 var(--space-5);
  border-radius: var(--radius-lg);
  border: var(--border-soft);
  box-shadow: var(--shadow-soft);
}

.cookie-settings {
  display: grid;
  gap: var(--space-4);
}

.cookie-settings__actions,
.cookie-banner__actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
}

.cookie-settings button,
.cookie-banner button {
  min-height: 44px;
  padding: 0.7rem 1rem;
  border-radius: 999px;
  border: 1px solid rgba(236, 1, 148, 0.42);
  background: rgba(236, 1, 148, 0.06);
  color: #f6c2df;
}

.cookie-settings button:hover,
.cookie-banner button:hover {
  background: rgba(236, 1, 148, 0.12);
  border-color: rgba(236, 1, 148, 0.62);
}

.cookie-settings button.is-selected {
  border-color: rgba(52, 211, 153, 0.82);
  box-shadow: 0 0 0 1px rgba(52, 211, 153, 0.24);
}

.cookie-banner {
  position: fixed;
  left: var(--space-4);
  right: var(--space-4);
  bottom: var(--space-4);
  z-index: 30;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: var(--space-4);
  max-width: 1120px;
  margin: 0 auto;
  padding: var(--space-4);
  border-radius: var(--radius-lg);
  border: var(--border-soft);
  background: rgba(18, 10, 24, 0.96);
  box-shadow: var(--shadow-card);
  backdrop-filter: blur(16px);
}

.cookie-banner[hidden] {
  display: none;
}

.cookie-banner__content {
  display: grid;
  gap: var(--space-2);
}

.cookie-banner__content p {
  margin: 0;
  color: rgba(255, 255, 255, 0.76);
}

.cookie-banner__content a {
  color: #f8d98f;
}

.blog-detail__tags {
  margin-top: var(--space-7);
  padding-top: var(--space-4);
  border-top: 1px solid rgba(255, 255, 255, 0.12);
}

.blog-card__content {
  display: grid;
  align-content: start;
  gap: var(--space-3);
  padding: var(--space-5) var(--space-5) var(--space-4);
}

.blog-card__header {
  display: grid;
  gap: var(--space-2);
}

.blog-card__title {
  font-size: 1.35rem;
  line-height: 1.12;
  font-weight: 700;
}

.theme-frontend .blog-card__title {
  display: -webkit-box;
  min-height: calc(2 * 1.12em);
  overflow: hidden;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
}

.blog-card__meta {
  color: rgba(255, 255, 255, 0.66);
  font-size: 0.92rem;
}

.theme-admin .blog-card__meta {
  color: #4b5563;
}

.blog-card__excerpt {
  min-height: 9.6em;
  margin: 0;
  color: rgba(255, 255, 255, 0.86);
}

.theme-admin .blog-card__excerpt {
  color: #111827;
}

.blog-card__cta {
  display: flex;
  min-height: 52px;
  margin: 0 var(--space-5) var(--space-5);
  border-color: rgba(236, 1, 148, 0.76);
  background: rgba(236, 1, 148, 0.08);
  color: #ffffff;
}

.blog-card__cta:hover {
  border-color: #ff5dbd;
  background: rgba(236, 1, 148, 0.16);
}

.blog-card__cta:active {
  background: rgba(236, 1, 148, 0.24);
}

.frontend-pagination,
.blog-pagination {
  display: grid;
  grid-template-columns: 44px auto 44px;
  align-items: center;
  justify-content: center;
  gap: var(--space-3);
  margin-top: var(--space-6);
}

.frontend-pagination a,
.frontend-pagination__spacer,
.frontend-pagination__status,
.blog-pagination a,
.blog-pagination__spacer,
.blog-pagination__status {
  min-height: 44px;
  display: inline-flex;
  align-items: center;
}

.frontend-pagination a,
.frontend-pagination__control,
.blog-pagination a,
.blog-pagination__control {
  justify-content: center;
  width: 44px;
  padding: 0;
  border: 1px solid rgba(236, 1, 148, 0.76);
  border-radius: 999px;
  background: rgba(236, 1, 148, 0.08);
  color: #ffffff;
  font-size: 1.35rem;
  font-weight: 700;
  line-height: 1;
  text-decoration: none;
}

.frontend-pagination a:hover,
.frontend-pagination__control:hover,
.blog-pagination a:hover,
.blog-pagination__control:hover {
  background: rgba(236, 1, 148, 0.16);
  text-decoration: none;
}

.frontend-pagination__control span,
.blog-pagination__control span {
  text-decoration: none;
}

.frontend-pagination__spacer,
.blog-pagination__spacer {
  width: 44px;
}

.frontend-pagination > span,
.blog-pagination > span {
  justify-content: center;
  color: rgba(255, 255, 255, 0.72);
  font-weight: 700;
}

.profile-settings__layout {
  position: relative;
  align-items: start;
}

.profile-settings__layout .panel__section {
  margin-top: 0;
  min-width: 0;
}

.profile-settings__side {
  position: relative;
  z-index: 1;
  display: grid;
  gap: var(--space-4);
  min-width: 0;
}

.profile-settings__main {
  position: relative;
  z-index: 2;
  display: grid;
  gap: var(--space-4);
  min-width: 0;
}

.profile-settings__media {
  position: relative;
  z-index: 3;
  min-width: 0;
  overflow: visible;
}

.profile-settings__media-header {
  display: flex;
  align-items: start;
  justify-content: space-between;
  gap: var(--space-4);
}

.profile-settings__upload-cta {
  flex: 0 0 auto;
  justify-self: end;
}

.profile-settings__current-photo {
  display: grid;
  grid-template-columns: minmax(96px, 148px) minmax(0, 1fr);
  gap: var(--space-4);
  align-items: start;
  margin-bottom: var(--space-4);
  padding: var(--space-3);
  border: 1px solid rgba(52, 211, 153, 0.42);
  border-radius: var(--radius-md);
  background: rgba(52, 211, 153, 0.08);
}

.profile-settings__current-photo img {
  width: 100%;
  aspect-ratio: 1;
  object-fit: cover;
  border-radius: var(--radius-md);
}

.profile-settings__current-photo-body {
  display: grid;
  gap: var(--space-2);
  min-width: 0;
}

.profile-gallery {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(118px, 1fr));
  gap: var(--space-3);
}

.profile-gallery__item {
  position: relative;
  display: grid;
  gap: var(--space-2);
  overflow: hidden;
  border-radius: var(--radius-md);
}

.profile-gallery__item img {
  width: 100%;
  aspect-ratio: 1;
  object-fit: cover;
  border-radius: var(--radius-md);
}

.profile-gallery__preview-button {
  position: relative;
  display: block;
  width: 100%;
  padding: 0;
  border: 0;
  border-radius: var(--radius-md);
  background: transparent;
  color: inherit;
  cursor: pointer;
  overflow: hidden;
}

.profile-gallery__preview-button:focus-visible {
  outline: 3px solid rgba(52, 211, 153, 0.7);
  outline-offset: 2px;
}

.profile-gallery__preview-button:disabled {
  cursor: default;
}

.profile-gallery__item--teaser {
  background: rgba(255, 255, 255, 0.05);
}

.profile-detail__photo--teaser {
  filter: blur(12px) saturate(0.82);
  transform: scale(1.04);
}

.profile-gallery__teaser-label {
  position: absolute;
  inset-inline: var(--space-2);
  bottom: var(--space-2);
  z-index: 1;
  display: inline-flex;
  justify-content: center;
  padding: 0.42rem 0.55rem;
  border-radius: var(--radius-sm);
  background: rgba(0, 0, 0, 0.58);
  color: rgba(255, 255, 255, 0.92);
  font-size: 0.76rem;
  line-height: 1.2;
  text-align: center;
}

.profile-gallery-preview {
  position: fixed;
  inset: 0;
  z-index: 1100;
  display: grid;
  place-items: center;
  align-content: center;
  min-height: 100%;
  min-width: 100%;
  overflow-y: auto;
  overflow-x: hidden;
  box-sizing: border-box;
  padding: var(--space-4);
  background: rgba(0, 0, 0, 0.82);
}

.profile-gallery-preview__frame {
  width: min(980px, 100%);
  max-height: calc(100vh - 2 * var(--space-4));
  display: grid;
  gap: var(--space-3);
}

.profile-gallery-preview__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
  color: rgba(255, 255, 255, 0.86);
  font-size: 0.9rem;
}

.profile-gallery-preview__header button,
.profile-gallery-preview__nav {
  border: 1px solid rgba(255, 255, 255, 0.22);
  background: rgba(255, 255, 255, 0.1);
  color: rgba(255, 255, 255, 0.92);
}

.profile-gallery-preview__stage {
  position: relative;
  min-height: min(72vh, 680px);
  display: grid;
  place-items: center;
  overflow: hidden;
  border-radius: var(--radius-md);
  background: rgba(255, 255, 255, 0.05);
}

.profile-gallery-preview__image {
  display: block;
  max-width: 100%;
  max-height: min(72vh, 680px);
  width: auto;
  height: auto;
  object-fit: contain;
}

.profile-gallery-preview__nav {
  position: absolute;
  top: 50%;
  z-index: 2;
  transform: translateY(-50%);
  min-width: 5.5rem;
}

.profile-gallery-preview__nav--previous {
  left: var(--space-3);
}

.profile-gallery-preview__nav--next {
  right: var(--space-3);
}

.profile-gallery-preview__teaser-label {
  position: absolute;
  left: 50%;
  bottom: var(--space-4);
  z-index: 2;
  transform: translateX(-50%);
  padding: 0.5rem 0.75rem;
  border-radius: var(--radius-sm);
  background: rgba(0, 0, 0, 0.62);
  color: rgba(255, 255, 255, 0.92);
  font-size: 0.86rem;
}

.profile-settings__section-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
}

.profile-settings__icon-button {
  width: 2.5rem;
  height: 2.5rem;
  display: inline-grid;
  place-items: center;
  flex: 0 0 auto;
  padding: 0;
  border-radius: 999px;
  border: 1px solid rgba(255, 255, 255, 0.18);
  background: rgba(255, 255, 255, 0.08);
  color: #fff;
  cursor: pointer;
}

.profile-settings__icon-button:hover,
.profile-settings__icon-button:focus-visible {
  background: rgba(236, 1, 148, 0.18);
  border-color: rgba(236, 1, 148, 0.46);
}

.theme-admin .profile-settings__icon-button {
  border: var(--border-admin);
  background: #ffffff;
  color: #374151;
}

.theme-admin .profile-settings__icon-button:hover,
.theme-admin .profile-settings__icon-button:focus-visible {
  border-color: #bfc5cf;
  background: #f9fafb;
  color: var(--color-admin-text);
}

.profile-settings__list {
  display: grid;
  gap: var(--space-3);
  margin: 0;
}

.profile-settings__row {
  display: grid;
  grid-template-columns: minmax(8rem, 0.36fr) 1fr;
  gap: var(--space-3);
  align-items: start;
}

.profile-settings__row dt {
  color: rgba(255, 255, 255, 0.62);
  font-weight: 700;
}

.profile-settings__row dd {
  margin: 0;
  min-width: 0;
  overflow-wrap: anywhere;
  word-break: break-word;
}

.profile-settings__low-actions {
  justify-content: flex-start;
}

.profile-settings__email-actions {
  margin-top: var(--space-5);
}

.profile-settings__embedded {
  display: grid;
  gap: var(--space-3);
}

.profile-settings__embedded .panel__form {
  margin-top: 0;
}

.profile-settings__embedded .panel__section {
  padding: 0;
  border: 0;
  background: transparent;
}

.profile-settings__form-grid {
  display: grid;
  grid-template-columns: minmax(8rem, 0.42fr) 1fr;
  gap: var(--space-3);
}

.profile-settings__dropzone input[type="file"] {
  position: absolute;
  width: 1px;
  height: 1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
}

.profile-settings__hint {
  color: rgba(255, 255, 255, 0.62);
  font-size: 0.92rem;
}

.profile-settings__gallery-item {
  overflow: visible;
  padding: var(--space-3);
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: var(--radius-md);
  background: rgba(255, 255, 255, 0.04);
}

.profile-settings__gallery-item.is-menu-open {
  z-index: 20;
}

.profile-settings__gallery-item.is-profile-photo {
  border-color: rgba(52, 211, 153, 0.68);
  box-shadow: 0 0 0 1px rgba(52, 211, 153, 0.22);
}

.profile-settings__photo-labels {
  min-height: 1.7rem;
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-1);
  align-items: center;
}

.profile-settings__badge {
  display: inline-flex;
  align-items: center;
  gap: var(--space-1);
  padding: 0.24rem 0.48rem;
  border-radius: 999px;
  background: rgba(52, 211, 153, 0.18);
  border: 1px solid rgba(52, 211, 153, 0.46);
  color: #fff;
  font-size: 0.76rem;
  font-weight: 800;
}

.profile-settings__status-label {
  padding: 0.24rem 0.48rem;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.08);
  color: rgba(255, 255, 255, 0.76);
  font-size: 0.76rem;
  font-weight: 700;
}

.profile-settings__photo-menu {
  position: absolute;
  top: var(--space-2);
  right: var(--space-2);
  z-index: 30;
}

.profile-settings__menu-button {
  width: 2.25rem;
  height: 2.25rem;
  background: rgba(0, 0, 0, 0.56);
  border-color: rgba(255, 255, 255, 0.22);
  backdrop-filter: blur(8px);
}

.profile-settings__menu {
  position: absolute;
  top: calc(100% + var(--space-2));
  right: 0;
  z-index: 31;
  width: min(220px, calc(100vw - 48px));
  display: grid;
  gap: var(--space-1);
  padding: var(--space-2);
  border-radius: var(--radius-md);
  background: #221923;
  border: 1px solid rgba(255, 255, 255, 0.14);
  box-shadow: 0 18px 45px rgba(0, 0, 0, 0.34);
}

.profile-settings__menu--floating {
  position: fixed;
  right: auto;
  bottom: auto;
  z-index: 1300;
  max-width: calc(100vw - 24px);
}

.profile-settings__menu form {
  margin: 0;
}

.profile-settings__menu button {
  width: 100%;
  min-height: 42px;
  justify-content: flex-start;
  padding: 0.62rem 0.72rem;
  border-radius: var(--radius-sm);
  background: transparent;
  color: rgba(255, 255, 255, 0.92);
  text-align: left;
}

.profile-settings__menu button:hover,
.profile-settings__menu button:focus-visible {
  transform: none;
  background: rgba(255, 255, 255, 0.08);
}

.profile-settings__menu button:disabled {
  cursor: not-allowed;
  opacity: 0.46;
}

.profile-settings__low-action {
  margin-top: var(--space-2);
}

.profile-edit-modal {
  width: min(620px, 100%);
  max-height: calc(100vh - (var(--space-4) * 2));
  overflow: auto;
}

.onboarding-modal {
  position: fixed;
  inset: 0;
  z-index: 50;
  display: grid;
  place-items: center;
  align-content: center;
  min-height: 100%;
  min-width: 100%;
  overflow-y: auto;
  overflow-x: hidden;
  padding: var(--space-4);
  background: rgba(0, 0, 0, 0.68);
  backdrop-filter: blur(12px);
}

.onboarding {
  width: min(100%, 720px);
  max-height: calc(100vh - (var(--space-4) * 2));
  overflow: auto;
  padding: var(--space-6);
  border-radius: var(--radius-lg);
  background: linear-gradient(180deg, rgba(21, 10, 26, 0.98) 0%, rgba(54, 24, 70, 0.98) 100%);
  border: var(--border-soft);
  box-shadow: var(--shadow-soft);
}

.onboarding__header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--space-3);
}

.onboarding__close {
  min-width: 36px;
  min-height: 36px;
  padding: 0;
  border-radius: 999px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  background: rgba(255, 255, 255, 0.04);
  color: rgba(255, 255, 255, 0.56);
  font-size: 1.35rem;
  line-height: 1;
}

.onboarding__close:hover {
  background: rgba(255, 255, 255, 0.08);
  color: #ffffff;
}

.onboarding__accordion {
  display: grid;
  gap: var(--space-2);
  margin-top: var(--space-5);
}

.onboarding__step {
  border-radius: var(--radius-md);
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid rgba(255, 255, 255, 0.05);
  overflow: hidden;
}

.onboarding__step.is-active {
  border-color: rgba(236, 1, 148, 0.5);
}

.onboarding__step.is-complete {
  border-color: rgba(175, 236, 174, 0.55);
}

.onboarding__step-header {
  width: 100%;
  min-height: 56px;
  justify-content: space-between;
  padding: var(--space-3) var(--space-4);
  border-radius: 0;
  background: transparent;
  color: #ffffff;
  text-align: left;
}

.onboarding__step-header:hover {
  background: rgba(255, 255, 255, 0.06);
}

.onboarding__step-header strong {
  color: #b9f6b7;
  font-size: 0.82rem;
}

.onboarding__step-body {
  padding: 0 var(--space-4) var(--space-4);
}

.onboarding__actions {
  display: flex;
  justify-content: flex-end;
  align-items: center;
  gap: var(--space-3);
}

.onboarding__legal-link {
  margin: var(--space-4) 0 0;
  text-align: center;
  font-size: 0.88rem;
}

.onboarding-photo,
.onboarding-about {
  display: grid;
  gap: var(--space-4);
}

.onboarding-photo__dropzone {
  position: relative;
  display: grid;
  gap: var(--space-2);
  min-height: 168px;
  place-items: center;
  padding: var(--space-5);
  border: 1px dashed rgba(255, 255, 255, 0.22);
  border-radius: var(--radius-md);
  background: rgba(255, 255, 255, 0.06);
  text-align: center;
  transition: background 160ms ease, border-color 160ms ease, transform 160ms ease;
}

.onboarding-photo__dropzone.is-dragging,
.onboarding-photo__dropzone:hover {
  border-color: rgba(236, 1, 148, 0.7);
  background: rgba(236, 1, 148, 0.09);
  transform: translateY(-1px);
}

.onboarding-photo__dropzone input {
  position: absolute;
  inset: 0;
  opacity: 0;
  cursor: pointer;
}

.onboarding-photo__dropzone-title {
  font-weight: 800;
}

.onboarding-photo__dropzone-copy,
.onboarding-photo__dropzone-meta {
  color: rgba(255, 255, 255, 0.68);
  font-size: 0.92rem;
}

.onboarding-photo__preview {
  display: grid;
  gap: var(--space-2);
  padding: var(--space-3);
  border-radius: var(--radius-md);
  background: rgba(0, 0, 0, 0.2);
}

.onboarding-photo__preview img {
  display: block;
  width: auto;
  max-width: 100%;
  height: auto;
  max-height: min(62vh, 620px);
  margin-left: auto;
  margin-right: auto;
  object-fit: contain;
  object-position: center center;
  border-radius: var(--radius-md);
  border: var(--border-soft);
  background: rgba(0, 0, 0, 0.18);
}

.onboarding-photo__replace {
  position: relative;
  overflow: hidden;
  background: rgba(255, 255, 255, 0.08);
  border-color: rgba(255, 255, 255, 0.16);
}

.onboarding-photo__replace input {
  position: absolute;
  inset: 0;
  opacity: 0;
  cursor: pointer;
}

.onboarding-role-choice {
  display: grid;
  gap: var(--space-2);
}

.onboarding-role-choice__options {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
}

.onboarding-role-choice__option {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  min-height: 38px;
  padding: 0.45rem 0.75rem;
  border: 1px solid rgba(255, 255, 255, 0.14);
  border-radius: var(--radius-sm);
  background: rgba(255, 255, 255, 0.06);
  color: rgba(255, 255, 255, 0.88);
  cursor: pointer;
}

.onboarding-role-choice__option.is-selected {
  border-color: rgba(236, 1, 148, 0.62);
  background: rgba(236, 1, 148, 0.18);
  color: #ffffff;
}

.onboarding-role-choice__option input {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}

.onboarding-role-choice__check {
  display: inline-grid;
  place-items: center;
  width: 1.05rem;
  height: 1.05rem;
  flex: 0 0 1.05rem;
  border: 1px solid rgba(255, 255, 255, 0.38);
  border-radius: 0.28rem;
  background: rgba(0, 0, 0, 0.22);
  box-shadow: inset 0 0 0 2px rgba(25, 10, 30, 0.85);
}

.onboarding-role-choice__option.is-selected .onboarding-role-choice__check {
  border-color: rgba(255, 255, 255, 0.72);
  background: var(--color-primary);
}

.onboarding-role-choice__option.is-selected .onboarding-role-choice__check::after {
  content: "";
  width: 0.34rem;
  height: 0.58rem;
  border: solid #ffffff;
  border-width: 0 2px 2px 0;
  transform: translateY(-0.05rem) rotate(45deg);
}

.onboarding-role-choice__option:focus-within {
  outline: 2px solid rgba(255, 255, 255, 0.72);
  outline-offset: 2px;
}

.onboarding-toolbar {
  display: flex;
  flex-wrap: wrap;
  align-items: stretch;
  gap: 0;
  overflow: hidden;
  border: 1px solid rgba(210, 214, 220, 0.34);
  border-radius: var(--radius-sm);
  background: rgba(13, 7, 20, 0.72);
  box-shadow: inset 0 -1px 0 rgba(255, 255, 255, 0.06);
}

.onboarding-toolbar__group {
  display: flex;
  align-items: stretch;
  border-right: 1px solid rgba(255, 255, 255, 0.12);
}

.onboarding-toolbar__group:last-child {
  border-right: 0;
}

.onboarding-toolbar__select,
.onboarding-toolbar button {
  min-height: 38px;
  border: 0;
  border-radius: 0;
  background: transparent;
  color: rgba(255, 255, 255, 0.88);
  box-shadow: none;
  transform: none;
}

.onboarding-toolbar__select {
  width: 150px;
  padding: 0 2.1rem 0 0.75rem;
  cursor: pointer;
}

.onboarding-toolbar__select option {
  color: #1f102e;
  background: #ffffff;
}

.onboarding-toolbar button {
  justify-content: center;
  min-width: 40px;
  padding: 0;
  font-weight: 700;
}

.onboarding-toolbar__select:hover,
.onboarding-toolbar button:hover,
.onboarding-toolbar__select:focus,
.onboarding-toolbar button:focus {
  background: rgba(255, 255, 255, 0.1);
  box-shadow: none;
  outline: none;
  transform: none;
}

.onboarding-toolbar__select:focus-visible,
.onboarding-toolbar button:focus-visible {
  outline: 2px solid rgba(236, 1, 148, 0.75);
  outline-offset: -2px;
}

.onboarding-toolbar__underline {
  text-decoration: underline;
}

.onboarding-toolbar__color {
  min-width: 40px;
  position: relative;
}

.onboarding-toolbar__color::after {
  content: "";
  width: 18px;
  height: 18px;
  border-radius: 50%;
  border: 1px solid rgba(255, 255, 255, 0.52);
  box-shadow: 0 0 0 1px rgba(0, 0, 0, 0.18);
}

.onboarding-toolbar__color--black::after { background: #000000; }
.onboarding-toolbar__color--red::after { background: #d72222; }
.onboarding-toolbar__color--green::after { background: #12823b; }
.onboarding-toolbar__color--blue::after { background: #2147dc; }
.onboarding-toolbar__color--pink::after { background: #f7aabe; }
.onboarding-toolbar__color--gray::after { background: #8a8f98; }

.onboarding-editor-shell {
  position: relative;
}

.onboarding-editor {
  min-height: 240px;
  padding: var(--space-4) var(--space-4) 3rem;
  border-radius: 0 0 var(--radius-sm) var(--radius-sm);
  border: 1px solid rgba(210, 214, 220, 0.36);
  border-top: 0;
  background: rgba(255, 255, 255, 0.09);
  direction: ltr;
  text-align: left;
  unicode-bidi: plaintext;
  outline: none;
}

.onboarding-toolbar + .onboarding-editor-shell {
  margin-top: calc(var(--space-4) * -1);
}

.onboarding-editor:focus {
  border-color: rgba(236, 1, 148, 0.58);
  box-shadow: inset 0 0 0 1px rgba(236, 1, 148, 0.28);
}

.onboarding-editor.is-empty::before {
  content: attr(data-placeholder);
  color: rgba(255, 255, 255, 0.42);
}

.onboarding-editor__counter {
  position: absolute;
  right: var(--space-3);
  bottom: var(--space-2);
  padding: 0.2rem 0.45rem;
  border-radius: var(--radius-sm);
  background: rgba(13, 7, 20, 0.74);
  color: rgba(255, 255, 255, 0.68);
  font-size: 0.82rem;
  font-weight: 700;
  line-height: 1;
  pointer-events: none;
}

.onboarding-editor__counter.is-over-limit {
  color: #ffd7e9;
  background: rgba(236, 1, 148, 0.48);
}

@media (min-width: 768px) {
  .layout {
    padding-left: var(--space-6);
    padding-right: var(--space-6);
  }

  .panel {
    padding: var(--space-8);
  }

  .split-layout,
  .panel__sections {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    align-items: start;
  }

  .profile-settings__layout {
    grid-template-columns: minmax(0, 0.38fr) minmax(0, 0.62fr);
  }

  .panel__sections > .panel__section:last-child,
  .panel__sections > .panel__form:last-child {
    grid-column: 1 / -1;
  }

  .panel__sections.profile-settings__layout > .profile-settings__main,
  .panel__sections.profile-settings__layout > .profile-settings__media {
    grid-column: auto;
  }

  .profile-cards {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .blog-cards {
    grid-template-columns: 1fr;
  }

  .blog-card__title {
    font-size: 1.45rem;
  }
}

@media (max-width: 767px) {
  .profile-tabs-row,
  .profile-card__footer {
    display: grid;
    justify-items: stretch;
  }

  .profile-filter,
  .profile-filter__toggle,
  .profile-card__cta {
    width: 100%;
  }

  .profile-card--discovery {
    grid-template-columns: 1fr;
  }

  .profile-card__footer {
    grid-column: 1;
  }

  .profile-card__photo,
  .profile-card__photo-placeholder {
    max-width: 180px;
  }

  .profile-settings__row,
  .profile-settings__form-grid {
    grid-template-columns: 1fr;
  }

  .profile-settings__media-header {
    display: grid;
  }

  .profile-settings__current-photo {
    grid-template-columns: 1fr;
  }

  .profile-settings__current-photo img {
    max-width: 220px;
  }

  .profile-settings__media-header > .profile-settings__upload-cta {
    justify-self: start;
  }

  .profile-settings__low-actions {
    display: grid;
  }

  .panel__actions {
    align-items: stretch;
  }

  .panel__actions > a,
  .panel__actions > button,
  .panel__actions > form,
  .panel__actions > form > button {
    width: 100%;
  }

  .profile-settings__low-actions button,
  .profile-settings__gallery-item .panel__actions button {
    width: 100%;
  }

  .cookie-banner {
    grid-template-columns: 1fr;
    align-items: start;
  }

  .cookie-banner__actions {
    width: 100%;
  }

  .cookie-banner button,
  .cookie-settings button {
    width: 100%;
  }

  .admin-dashboard__hero,
  .admin-section-heading,
  .admin-card__header,
  .admin-page-heading {
    display: grid;
    align-items: start;
  }

  .admin-dashboard__hero {
    padding: var(--space-5);
  }

  /* Mobile blog overview: reduce padding by about half */
  .panel--blog_index,
  .panel--blog_detail {
    padding: var(--space-3);
  }

  .panel--blog_index .blog-cards {
    width: 100%;
    gap: var(--space-3);
  }

  .theme-frontend .panel--blog_index .blog-card {
    width: 100%;
    max-width: 100%;
    margin-inline: auto;
    overflow: visible;
    border: 0;
    border-radius: 0;
    background: transparent;
  }

  .blog-card__content {
    padding: var(--space-3) 0;
  }

  /* Stack image above content on narrow screens */
  .blog-card {
    grid-template-columns: 1fr;
  }

  .blog-card__image,
  .blog-card__placeholder {
    width: 100%;
    max-height: none;
    border-radius: var(--radius-md);
  }

  .admin-card__header .button-link {
    width: 100%;
  }

  .admin-dashboard__content-grid,
  .admin-mini-metrics,
  .admin-detail-list {
    grid-template-columns: 1fr;
  }

  .admin-pagination {
    justify-content: flex-start;
    flex-wrap: wrap;
  }
}

@media (min-width: 1024px) {
  .layout {
    padding-left: var(--space-8);
    padding-right: var(--space-8);
  }

  .theme-admin .page-shell--admin.panel {
    min-width: 1200px;
  }

  .split-layout--sidebar {
    grid-template-columns: 280px minmax(0, 1fr);
  }

  .split-layout--sidebar-large {
    grid-template-columns: 340px minmax(0, 1fr);
  }

  .split-layout--equal {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .profile-settings__layout {
    grid-template-columns: minmax(0, 0.36fr) minmax(0, 0.64fr);
  }

  .profile-cards {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .blog-cards {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .panel--message_thread .panel__list,
  .panel--admin_blog .panel__list,
  .panel--admin_newsletter_campaigns .panel__list {
    gap: var(--space-4);
  }
}

/* home landing */
.layout--home{width:min(100%,1240px);margin:0 auto;place-items:stretch;padding-top:var(--space-4)}
.home-landing{width:100%;display:grid;gap:var(--space-10)}
.home-hero{min-height:clamp(520px,70vh,680px);display:grid;align-items:center;gap:var(--space-8);position:relative;overflow:hidden;border-radius:var(--radius-lg);padding:clamp(var(--space-6),7vw,var(--space-16));border:var(--border-soft);background:#110817;box-shadow:var(--shadow-soft)}
.home-hero:before{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(90deg,rgba(5,3,5,.8) 0%,rgba(12,6,12,.64) 34%,rgba(12,6,12,.26) 63%,rgba(5,3,5,.14) 100%),linear-gradient(0deg,rgba(5,3,5,.5),rgba(5,3,5,.06) 46%,rgba(5,3,5,.28));pointer-events:none}
.home-hero__image{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center center;filter:saturate(.9) contrast(1.04)}
.home-hero__copy{max-width:760px;position:relative;z-index:1}.home-hero h1{max-width:820px;margin-bottom:var(--space-5);font-size:clamp(2.6rem,7vw,5.8rem);line-height:.96;letter-spacing:0}.home-hero__subtitle{max-width:620px;margin-bottom:var(--space-6);color:rgba(255,255,255,.78);font-size:clamp(1.05rem,2vw,1.35rem)}
.home-hero__actions{display:flex;flex-wrap:wrap;align-items:center;gap:var(--space-4)}.home-hero__cta,.home-online__cta-panel .panel__cta{min-width:min(100%,220px)}.home-hero__privacy{max-width:320px;margin:0;color:rgba(255,255,255,.62);font-size:.9rem}
.home-proof{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:var(--space-4);margin:var(--space-5) 0 0}.home-proof__item{padding-top:var(--space-4);border-top:1px solid rgba(255,255,255,.16)}.home-proof dt{margin-bottom:var(--space-2);color:#f8d98f;font-size:1.2rem;font-weight:700}.home-proof dd{margin:0;color:rgba(255,255,255,.7);font-size:.92rem}
.home-online{display:grid;gap:var(--space-6)}.home-online__intro,.home-online__cta-panel{display:flex;align-items:end;justify-content:space-between;gap:var(--space-5)}.home-online__intro h2,.home-online__cta-panel h3{margin-bottom:0}.home-online__grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:var(--space-3);padding:0;margin:0;list-style:none}
.home-online-card{min-height:238px;display:grid;align-content:end;position:relative;overflow:hidden;border-radius:var(--radius-md);border:var(--border-soft);background:linear-gradient(180deg,transparent 12%,rgba(0,0,0,.76) 100%),rgba(255,255,255,.06);box-shadow:var(--shadow-card)}.home-online-card__link{position:absolute;inset:0;display:grid;align-content:end;color:inherit;text-decoration:none}.home-online-card__link:focus-visible{outline:3px solid rgba(236,1,148,.55);outline-offset:-3px}.home-online-card__portrait,.home-online-card__portrait:before{position:absolute;inset:0}.home-online-card__portrait{filter:saturate(.92) contrast(1.02);opacity:.96;background:radial-gradient(circle at 50% 28%,rgba(255,255,255,.2),transparent 18%),linear-gradient(150deg,#301931,#9a4c78 46%,#d5a466);background-position:center;background-size:cover}.home-online-card--blurred .home-online-card__portrait{filter:saturate(.88) contrast(1.02) blur(10px);transform:scale(1.05)}.home-online-card__portrait:before{content:"";background:linear-gradient(180deg,rgba(0,0,0,.04) 0%,rgba(0,0,0,.22) 44%,rgba(0,0,0,.78) 100%)}.home-online-card__portrait.has-photo:before{background:linear-gradient(180deg,rgba(0,0,0,.1) 0%,rgba(0,0,0,.32) 42%,rgba(0,0,0,.82) 100%)}.home-online-card__portrait span{position:absolute;top:var(--space-5);left:50%;width:96px;height:96px;transform:translateX(-50%);border-radius:50%;overflow:hidden;border:2px solid rgba(255,255,255,.72);box-shadow:0 18px 40px rgba(0,0,0,.34);background:radial-gradient(circle at 50% 34%,rgba(238,204,178,.96) 0 16%,transparent 17%),radial-gradient(ellipse at 50% 70%,rgba(40,28,42,.96) 0 34%,transparent 35%),linear-gradient(145deg,rgba(255,255,255,.36),rgba(255,255,255,.04));filter:blur(1.4px)}
.home-online-card__portrait span:before{content:"";position:absolute;inset:13% 24% 48%;border-radius:999px 999px 48% 48%;background:rgba(33,20,31,.82)}.home-online-card__portrait span:after{content:"";position:absolute;inset:51% 18% 0;border-radius:44% 44% 0 0;background:rgba(24,19,29,.86)}
.home-online-card--2 .home-online-card__portrait{background:radial-gradient(circle at 52% 28%,rgba(255,255,255,.18),transparent 18%),linear-gradient(150deg,#172025,#415c5f 46%,#d4b06f)}.home-online-card--2 .home-online-card__portrait span{background:radial-gradient(circle at 50% 34%,rgba(230,194,165,.96) 0 16%,transparent 17%),radial-gradient(ellipse at 50% 70%,rgba(28,42,45,.96) 0 34%,transparent 35%),linear-gradient(145deg,rgba(255,255,255,.34),rgba(255,255,255,.04))}.home-online-card--3 .home-online-card__portrait{background:radial-gradient(circle at 48% 28%,rgba(255,255,255,.18),transparent 18%),linear-gradient(150deg,#1f102e,#8d245f 48%,#bd985f)}.home-online-card--3 .home-online-card__portrait span{background:radial-gradient(circle at 50% 34%,rgba(238,202,171,.96) 0 16%,transparent 17%),radial-gradient(ellipse at 50% 70%,rgba(68,22,48,.96) 0 34%,transparent 35%),linear-gradient(145deg,rgba(255,255,255,.34),rgba(255,255,255,.04))}.home-online-card--4 .home-online-card__portrait{background:radial-gradient(circle at 51% 28%,rgba(255,255,255,.18),transparent 18%),linear-gradient(150deg,#111827,#5e4a70 46%,#d9bf8d)}.home-online-card--4 .home-online-card__portrait span{background:radial-gradient(circle at 50% 34%,rgba(224,184,151,.96) 0 16%,transparent 17%),radial-gradient(ellipse at 50% 70%,rgba(31,25,42,.96) 0 34%,transparent 35%),linear-gradient(145deg,rgba(255,255,255,.34),rgba(255,255,255,.04))}.home-online-card--5 .home-online-card__portrait{background:radial-gradient(circle at 53% 28%,rgba(255,255,255,.18),transparent 18%),linear-gradient(150deg,#210f1d,#75466f 48%,#efc875)}.home-online-card--5 .home-online-card__portrait span{background:radial-gradient(circle at 50% 34%,rgba(251,225,198,.96) 0 16%,transparent 17%),radial-gradient(ellipse at 50% 70%,rgba(51,17,40,.96) 0 34%,transparent 35%),linear-gradient(145deg,rgba(255,255,255,.34),rgba(255,255,255,.04))}.home-online-card--6 .home-online-card__portrait{background:radial-gradient(circle at 49% 28%,rgba(255,255,255,.18),transparent 18%),linear-gradient(150deg,#10191d,#576c66 48%,#c69f6b)}.home-online-card--6 .home-online-card__portrait span{background:radial-gradient(circle at 50% 34%,rgba(236,204,176,.96) 0 16%,transparent 17%),radial-gradient(ellipse at 50% 70%,rgba(22,34,40,.96) 0 34%,transparent 35%),linear-gradient(145deg,rgba(255,255,255,.34),rgba(255,255,255,.04))}
.home-online-card__content{position:relative;z-index:1;display:grid;gap:var(--space-1);padding:var(--space-4)}.home-online-card__content strong{font-size:1rem}.home-online-card__content span{color:rgba(255,255,255,.68);font-size:.85rem}.home-online__cta-panel{align-items:center;padding:var(--space-6);border-radius:var(--radius-lg);border:var(--border-soft);background:rgba(255,255,255,.06);box-shadow:var(--shadow-card);backdrop-filter:blur(16px)}.home-online__cta-panel p{max-width:660px;margin:var(--space-2) 0 0;color:rgba(255,255,255,.72)}.home-online__cta-copy{width:100%;max-width:none}.home-online__cta-link{justify-self:start;margin-top:var(--space-5)}.home-proof__item ul{display:grid;gap:var(--space-2);margin:var(--space-3) 0 0;padding-left:1.1rem;color:rgba(255,255,255,.72);font-size:.9rem}.home-proof__item li{padding-left:.1rem}
.home-news{display:grid;gap:var(--space-5);padding-top:var(--space-4)}.home-news__intro h2{margin-bottom:0}.home-news-card{display:grid;grid-template-columns:minmax(220px,.42fr) minmax(0,1fr);overflow:hidden;border-radius:var(--radius-lg);border:var(--border-soft);background:rgba(255,255,255,.055);box-shadow:var(--shadow-card);color:inherit;text-decoration:none}.home-news-card__image{width:100%;height:100%;min-height:260px;object-fit:cover;background:linear-gradient(135deg,rgba(248,217,143,.34),rgba(131,64,99,.28)),#151016}.home-news-card__content{display:grid;align-content:center;gap:var(--space-3);padding:var(--space-6)}.home-news-card__content strong{font-size:clamp(1.45rem,3vw,2.35rem);line-height:1.08}.home-news-card__content span:not(.home-news-card__meta){max-width:680px;color:rgba(255,255,255,.72);line-height:1.6}.home-news-card__meta,.home-news-card__content em{color:#f8d98f;font-size:.9rem;font-style:normal}.home-news__empty{color:rgba(255,255,255,.72)}
@media (max-width: 767px){.layout--home{padding-top:var(--space-2)}.home-hero{min-height:0;padding:var(--space-6);border-radius:var(--radius-md)}.home-hero:before{background:linear-gradient(90deg,rgba(5,3,5,.84),rgba(5,3,5,.62)),linear-gradient(0deg,rgba(5,3,5,.52),rgba(5,3,5,.14))}.home-hero h1{font-size:clamp(2.35rem,14vw,4rem)}.home-proof{grid-template-columns:1fr;gap:var(--space-3)}.home-online__intro,.home-online__cta-panel{display:grid;align-items:start}.home-online__desktop-cta{display:none}.home-online-card{min-height:196px}.home-online-card__content{padding:var(--space-3)}.home-news-card{grid-template-columns:1fr}.home-news-card__image{min-height:190px}.home-news-card__content{padding:var(--space-5)}}
@media (min-width: 768px){.home-online__grid{grid-template-columns:repeat(5,minmax(0,1fr))}.home-online-card--6{display:none}.home-online-card{min-height:300px}}
@media (min-width: 1024px){.home-online-card{min-height:340px}}
@media (min-width: 768px){.home-proof{width:100%;gap:0}.home-proof__item{min-width:0;padding:var(--space-4) var(--space-4) 0}.home-proof__item:not(:first-child){border-left:1px solid rgba(255,255,255,.16)}}

.customer-feedback-tab{position:fixed;right:0;top:50%;z-index:80;transform:translateY(-50%);font-size:.95rem}.customer-feedback-tab summary{display:grid;place-items:center;min-width:44px;min-height:136px;padding:var(--space-3) var(--space-2);border:1px solid rgba(248,217,143,.4);border-left:0;border-radius:0 var(--radius-md) var(--radius-md) 0;background:rgba(22,12,23,.94);box-shadow:var(--shadow-card);color:#f8d98f;font-weight:700;letter-spacing:0;writing-mode:vertical-rl;transform:rotate(180deg);cursor:pointer;list-style:none}.customer-feedback-tab summary::-webkit-details-marker{display:none}.customer-feedback-tab[open] summary{background:#f8d98f;color:#170b17}.customer-feedback-tab__panel{position:absolute;right:44px;top:50%;width:min(86vw,340px);display:grid;gap:var(--space-3);padding:var(--space-4);border:var(--border-soft);border-radius:var(--radius-md) 0 var(--radius-md) var(--radius-md);background:rgba(16,8,18,.98);box-shadow:var(--shadow-soft);transform:translateY(-50%)}.customer-feedback-tab__notice{display:grid;gap:var(--space-2);margin:0;padding:var(--space-3);border:1px solid rgba(68,210,180,.42);border-radius:var(--radius-sm);background:rgba(68,210,180,.12);color:#e9fff9;font-weight:700;list-style:none}.customer-feedback-tab__panel label{display:grid;gap:var(--space-2);color:rgba(255,255,255,.78);font-weight:700}.customer-feedback-tab__panel textarea{width:100%;resize:vertical;border:1px solid rgba(255,255,255,.16);border-radius:var(--radius-sm);background:rgba(255,255,255,.08);color:#fff;padding:var(--space-3);font:inherit}.customer-feedback-tab__panel button{justify-self:start;border:0;border-radius:var(--radius-sm);background:#ec0194;color:#fff;padding:var(--space-2) var(--space-4);font-weight:700;cursor:pointer}@media (max-width: 767px){.customer-feedback-tab{top:auto;right:var(--space-3);bottom:var(--space-3);transform:none}.customer-feedback-tab summary{min-width:104px;min-height:58px;font-size:.63rem;padding:0.25rem 0.7rem;border:1px solid rgba(248,217,143,.4);border-radius:999px;background:rgba(248,217,143,.24);box-shadow:none;color:#f8d98f;font-weight:600;letter-spacing:.05em;text-transform:uppercase;writing-mode:horizontal-tb;transform:none}.customer-feedback-tab[open] summary{background:#f8d98f;color:#170b17}.customer-feedback-tab__panel{right:0;top:auto;bottom:calc(100% + var(--space-2));left:var(--space-3);width:min(92vw,480px);max-width:calc(100vw - 2 * var(--space-3));transform:none;border-radius:var(--radius-md)}}

body.theme-frontend.page-cubes,
body.theme-frontend.page-cubes-thanks {
  color-scheme: light;
  background: #f1eee8;
  color: #17130f;
}

.page-cubes .site-header,
.page-cubes .site-footer,
.page-cubes-thanks .site-header,
.page-cubes-thanks .site-footer {
  color: #17130f;
}

.page-cubes .language-menu > summary,
.page-cubes .site-menu > summary,
.page-cubes .site-icon-link,
.page-cubes-thanks .language-menu > summary,
.page-cubes-thanks .site-menu > summary,
.page-cubes-thanks .site-icon-link {
  border-color: rgba(23, 19, 15, .18);
  background: rgba(255, 255, 255, .74);
  box-shadow: 0 12px 30px rgba(41, 35, 28, .12);
}

.cubes-page {
  display: grid;
  gap: 0;
}

.cubes-hero {
  position: relative;
  min-height: 680px;
  display: grid;
  align-items: end;
  overflow: hidden;
  margin-top: -70px;
  padding: 150px var(--space-5) 88px;
  isolation: isolate;
}

.cubes-hero__image,
.cubes-hero__overlay {
  position: absolute;
  inset: 0;
}

.cubes-hero__image {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center 28%;
  filter: saturate(.8) contrast(1.04);
  z-index: -2;
}

.cubes-hero__overlay {
  z-index: -1;
  background:
    linear-gradient(90deg, rgba(14, 12, 10, .82) 0%, rgba(14, 12, 10, .58) 38%, rgba(14, 12, 10, .18) 70%),
    linear-gradient(180deg, rgba(241, 238, 232, .35) 0%, rgba(20, 15, 10, .06) 34%, rgba(20, 15, 10, .48) 100%);
}

.cubes-hero__content {
  width: min(100%, 1180px);
  margin: 0 auto;
  color: #fffaf2;
}

.cubes-hero__content > [data-cubes-locale] {
  max-width: 720px;
}

.cubes-eyebrow,
.cubes-step-panel__kicker {
  margin: 0 0 var(--space-3);
  color: #9c3f23;
  font-size: .78rem;
  font-weight: 800;
  letter-spacing: .12em;
  text-transform: uppercase;
}

.cubes-hero .cubes-eyebrow {
  color: #f0c46f;
}

.cubes-hero h1 {
  max-width: 780px;
  margin: 0 0 var(--space-4);
  font-family: Georgia, 'Times New Roman', serif;
  font-size: 4.4rem;
  line-height: .95;
  letter-spacing: 0;
}

.cubes-hero__intro {
  max-width: 620px;
  margin: 0 0 var(--space-6);
  color: rgba(255, 250, 242, .86);
  font-size: 1.12rem;
}

.cubes-locale-toggle {
  display: inline-flex;
  gap: 0;
  margin-bottom: var(--space-8);
  padding: 3px;
  border: 1px solid rgba(255, 250, 242, .34);
  border-radius: 999px;
  background: rgba(23, 19, 15, .42);
  backdrop-filter: blur(14px);
}

.cubes-locale-toggle button {
  min-width: 54px;
  min-height: 36px;
  border: 0;
  border-radius: 999px;
  background: transparent;
  color: rgba(255, 250, 242, .76);
  font-size: .76rem;
  font-weight: 800;
  letter-spacing: .08em;
}

.cubes-locale-toggle button[aria-pressed="true"] {
  background: #fffaf2;
  color: #17130f;
}

.cubes-scan-status {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  min-height: 40px;
  padding: 0 var(--space-4);
  border: 1px solid rgba(240, 196, 111, .42);
  border-radius: 999px;
  background: rgba(23, 19, 15, .48);
  color: #fffaf2;
  font-size: .9rem;
  font-weight: 800;
}

.cubes-wizard {
  display: grid;
  gap: var(--space-8);
  width: min(100%, 1180px);
  margin: 0 auto;
  padding: var(--space-10) var(--space-5) var(--space-16);
}

.cubes-wizard__heading h2 {
  margin: 0 0 var(--space-2);
  font-family: Georgia, 'Times New Roman', serif;
  font-size: 2.2rem;
  line-height: 1.05;
  letter-spacing: 0;
}

.cubes-wizard__heading p {
  max-width: 620px;
  margin: 0;
  color: #62584b;
}

.cubes-flashes {
  display: grid;
  gap: var(--space-2);
}

.cubes-flash {
  margin: 0;
  padding: var(--space-3) var(--space-4);
  border: 1px solid rgba(27, 92, 70, .28);
  border-radius: 8px;
  background: #e5f3ed;
  color: #174b3b;
  font-weight: 700;
}

.cubes-flash--error {
  border-color: rgba(156, 63, 35, .28);
  background: #f7e3d8;
  color: #702b18;
}

.cubes-wizard__layout {
  display: grid;
  grid-template-columns: 280px minmax(0, 1fr);
  gap: var(--space-6);
  align-items: start;
}

.cubes-step-nav {
  display: grid;
  gap: var(--space-2);
  position: sticky;
  top: var(--space-5);
}

.cubes-step-nav button {
  width: 100%;
  display: grid;
  grid-template-columns: 46px minmax(0, 1fr);
  gap: var(--space-3);
  align-items: center;
  min-height: 62px;
  padding: var(--space-2) var(--space-3);
  border: 1px solid rgba(23, 19, 15, .14);
  border-radius: 8px;
  background: rgba(255, 255, 255, .62);
  color: #17130f;
  text-align: left;
}

.cubes-step-nav button span:first-child {
  display: grid;
  place-items: center;
  width: 38px;
  height: 38px;
  border-radius: 50%;
  background: #26231f;
  color: #fffaf2;
  font-size: .78rem;
  font-weight: 800;
}

.cubes-step-nav button strong {
  min-width: 0;
  overflow-wrap: anywhere;
  font-size: .94rem;
}

.cubes-step-nav button.is-active {
  border-color: rgba(156, 63, 35, .45);
  background: #fffaf2;
  box-shadow: 0 18px 42px rgba(41, 35, 28, .12);
}

.cubes-step-nav button.is-active span:first-child {
  background: #9c3f23;
}

.cubes-step-panels {
  min-width: 0;
}

.cubes-step-panel {
  display: grid;
  grid-template-columns: minmax(280px, .44fr) minmax(0, 1fr);
  overflow: hidden;
  border: 1px solid rgba(23, 19, 15, .14);
  border-radius: 8px;
  background: #fffaf2;
  box-shadow: 0 24px 70px rgba(41, 35, 28, .13);
}

.cubes-step-panel__media {
  min-height: 520px;
  background: #d9d2c5;
  overflow: hidden;
}

.cubes-step-panel__image {
  width: 100%;
  height: 100%;
  min-height: 520px;
  object-fit: cover;
}

.cubes-step-panel__image--register { object-position: 76% 22%; }
.cubes-step-panel__image--donate { object-position: 22% 48%; }
.cubes-step-panel__image--payment { object-position: 18% 45%; }
.cubes-step-panel__image--choose { object-position: 78% 50%; }
.cubes-step-panel__image--write { object-position: 24% 82%; }
.cubes-step-panel__image--finish { object-position: 78% 82%; }

.cubes-step-panel__body {
  display: grid;
  align-content: center;
  gap: var(--space-5);
  min-width: 0;
  padding: var(--space-8);
}

.cubes-step-panel__body h3 {
  margin: 0 0 var(--space-3);
  font-family: Georgia, 'Times New Roman', serif;
  font-size: 2rem;
  line-height: 1.05;
  letter-spacing: 0;
}

.cubes-step-panel__body p {
  max-width: 620px;
  margin: 0;
  color: #51483d;
}

.cubes-step-panel__note {
  color: #9c3f23 !important;
  font-weight: 800;
}

.cubes-inline-actions,
.cubes-step-panel__controls {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
  align-items: center;
}

.cubes-button {
  min-height: 44px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  padding: 0 var(--space-4);
  border-radius: 8px;
  border: 1px solid transparent;
  text-decoration: none;
  font-weight: 800;
  line-height: 1.1;
}

.cubes-button--primary {
  background: #9c3f23;
  color: #fffaf2;
}

.cubes-button--ghost {
  border-color: rgba(23, 19, 15, .18);
  background: #fffaf2;
  color: #17130f;
}

.cubes-button:disabled {
  cursor: not-allowed;
  opacity: .45;
}

.cubes-donation-form,
.cubes-signin-callout {
  display: grid;
  gap: var(--space-4);
  padding: var(--space-5);
  border: 1px solid rgba(27, 92, 70, .2);
  border-radius: 8px;
  background: #eef4ef;
}

.cubes-donation-form h4,
.cubes-signin-callout h4 {
  margin: 0 0 var(--space-2);
  color: #174b3b;
  font-size: 1.05rem;
}

.cubes-donation-form__disclaimer,
.cubes-donation-form__methods {
  font-size: .9rem;
}

.cubes-amount-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: var(--space-2);
}

.cubes-amount-option {
  min-height: 54px;
  display: grid;
  place-items: center;
  position: relative;
  padding: var(--space-2);
  border: 1px solid rgba(23, 19, 15, .16);
  border-radius: 8px;
  background: #fffaf2;
  color: #17130f;
  font-weight: 800;
}

.cubes-amount-option input[type="radio"] {
  position: absolute;
  inset: 0;
  opacity: 0;
}

.cubes-amount-option:has(input[type="radio"]:checked) {
  border-color: #174b3b;
  box-shadow: inset 0 0 0 2px #174b3b;
}

.cubes-amount-option--custom {
  grid-column: span 2;
  grid-template-columns: auto minmax(90px, 1fr);
  gap: var(--space-2);
  place-items: center stretch;
}

.cubes-amount-option--custom input[type="text"] {
  width: 100%;
  min-height: 38px;
  border: 1px solid rgba(23, 19, 15, .18);
  border-radius: 6px;
  background: #fff;
  color: #17130f;
  padding: 0 var(--space-3);
}

.cubes-amount-grid--preview .cubes-amount-option {
  pointer-events: none;
}

.cubes-amount-grid--preview .cubes-amount-option--custom {
  grid-column: auto;
}

.cubes-thanks {
  min-height: 72vh;
  display: grid;
  place-items: center;
  padding: var(--space-8) var(--space-4);
}

.cubes-thanks__panel {
  width: min(100%, 680px);
  display: grid;
  gap: var(--space-4);
  padding: var(--space-8);
  border: 1px solid rgba(23, 19, 15, .14);
  border-radius: 8px;
  background: #fffaf2;
  box-shadow: 0 24px 70px rgba(41, 35, 28, .13);
}

.cubes-thanks__panel h1 {
  margin: 0;
  font-family: Georgia, 'Times New Roman', serif;
  font-size: 2.4rem;
}

.admin-cubes-editor {
  display: grid;
  gap: var(--space-5);
}

.admin-cubes-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--space-3);
}

.admin-cubes-locale,
.admin-cubes-step {
  display: grid;
  gap: var(--space-3);
  min-width: 0;
  padding: var(--space-4);
  border: 1px solid #d1d5db;
  border-radius: 8px;
  background: #fff;
}

.admin-cubes-locale legend {
  padding: 0 var(--space-2);
  font-weight: 800;
}

.admin-cubes-steps {
  display: grid;
  gap: var(--space-3);
}

.admin-cubes-step h4 {
  margin: 0;
  color: #111827;
}

@media (max-width: 900px) {
  .cubes-hero {
    min-height: 620px;
    margin-top: -62px;
    padding: 132px var(--space-4) 64px;
  }

  .cubes-hero__overlay {
    background:
      linear-gradient(90deg, rgba(14, 12, 10, .88), rgba(14, 12, 10, .54)),
      linear-gradient(180deg, rgba(241, 238, 232, .26), rgba(20, 15, 10, .48));
  }

  .cubes-hero h1 {
    font-size: 3rem;
  }

  .cubes-wizard__layout,
  .cubes-step-panel {
    grid-template-columns: 1fr;
  }

  .cubes-step-nav {
    position: static;
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .cubes-step-nav button {
    grid-template-columns: 1fr;
    justify-items: center;
    text-align: center;
    min-height: 88px;
  }

  .cubes-step-panel__media,
  .cubes-step-panel__image {
    min-height: 320px;
  }

  .admin-cubes-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 620px) {
  .cubes-hero {
    min-height: 580px;
  }

  .cubes-hero h1 {
    font-size: 2.35rem;
  }

  .cubes-hero__intro {
    font-size: 1rem;
  }

  .cubes-wizard {
    padding-left: var(--space-3);
    padding-right: var(--space-3);
  }

  .cubes-step-nav {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .cubes-step-panel__body,
  .cubes-thanks__panel {
    padding: var(--space-5);
  }

  .cubes-step-panel__body h3 {
    font-size: 1.55rem;
  }

  .cubes-amount-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .cubes-amount-option--custom {
    grid-column: 1 / -1;
  }

  .cubes-button {
    width: 100%;
  }
}
