:root {
  --accent-50: 237 246 240;
  --accent-100: 217 235 223;
  --accent-200: 183 215 193;
  --accent-500: 113 156 124;
  --accent-600: 88 132 101;
  --accent-700: 66 107 80;
  --editorial-ink: 36 31 26;
  --editorial-muted: 84 72 59;
  --editorial-page-bg: 252 250 246;
  --separator-wave-top-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1600 320' preserveAspectRatio='none'%3E%3Cpath fill='black' d='M0 0h1600v190c-39-16-86-46-149-46-92 0-142 67-233 67-88 0-143-73-235-73-95 0-146 91-244 91-100 0-150-76-245-76-93 0-145 63-236 63-97 0-147-70-258-70V0Z'/%3E%3C/svg%3E");
  --separator-wave-bottom-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1600 320' preserveAspectRatio='none'%3E%3Cpath fill='black' d='M0 124c44 19 90 52 161 52 91 0 147-70 236-70 86 0 135 61 220 61 91 0 145-79 244-79 102 0 161 66 253 66 87 0 136-42 210-42 112 0 174 53 276 53V320H0Z'/%3E%3C/svg%3E");
  --theme-white: 255 255 255;
  --theme-slate-50: 255 252 248;
  --theme-slate-100: 248 241 229;
  --theme-slate-200: 233 220 198;
  --theme-slate-300: 214 196 168;
  --theme-slate-400: 161 136 106;
  --theme-slate-500: 122 103 81;
  --theme-slate-600: 96 79 62;
  --theme-slate-700: 73 60 46;
  --theme-slate-800: 53 43 33;
  --theme-slate-900: 36 31 26;
  --theme-slate-950: 25 21 18;
  --theme-teal-50: 237 246 240;
  --theme-teal-100: 217 235 223;
  --theme-teal-200: 183 215 193;
  --theme-teal-400: 138 183 149;
  --theme-teal-500: 113 156 124;
  --theme-teal-600: 88 132 101;
  --theme-teal-700: 66 107 80;
  --theme-teal-800: 55 88 66;
  --theme-teal-900: 46 72 54;
  --theme-teal-950: 31 49 37;
  --theme-amber-50: 255 247 230;
  --theme-amber-100: 250 235 196;
  --theme-amber-200: 238 209 136;
  --theme-amber-400: 201 164 92;
  --theme-amber-500: 176 136 62;
  --theme-amber-600: 149 111 48;
  --theme-amber-700: 124 91 41;
  --theme-amber-800: 102 75 36;
  --theme-red-50: 254 242 242;
  --theme-red-100: 253 230 228;
  --theme-red-200: 244 199 191;
  --theme-red-300: 234 160 147;
  --theme-red-400: 217 119 105;
  --theme-red-600: 167 67 58;
  --theme-red-700: 142 53 46;
  --app-bg: rgb(var(--editorial-page-bg));
  --app-surface: rgba(255, 252, 248, 0.96);
  --app-surface-soft: rgba(247, 239, 227, 0.82);
  --app-border: rgba(97, 84, 69, 0.12);
  --app-border-strong: rgba(97, 84, 69, 0.18);
  --app-text: rgb(var(--editorial-ink));
  --app-text-muted: rgb(var(--editorial-muted));
  --app-text-subtle: rgba(84, 72, 59, 0.72);
  --app-label: rgba(58, 47, 37, 0.9);
  --app-accent: rgb(var(--accent-600));
  --app-accent-strong: rgb(var(--accent-700));
  --app-accent-soft: rgb(var(--accent-50) / 0.92);
  --app-accent-border: rgb(var(--accent-200) / 0.9);
  --app-focus-ring: rgb(var(--accent-100) / 0.68);
  --app-navbar-bg: rgba(255, 252, 248, 0.74);
  --app-sidebar-bg: linear-gradient(180deg, rgba(255, 252, 248, 0.96), rgba(247, 239, 227, 0.92));
  --app-sidebar-panel: rgba(255, 255, 255, 0.52);
  --app-sidebar-border: rgba(97, 84, 69, 0.12);
  --app-sidebar-divider: rgba(97, 84, 69, 0.12);
  --app-sidebar-text: rgb(var(--editorial-ink));
  --app-sidebar-muted: rgba(84, 72, 59, 0.72);
  --app-sidebar-accent: rgb(var(--accent-700));
  --app-sidebar-hover: rgb(var(--accent-50) / 0.78);
  --app-sidebar-active-bg: rgb(var(--accent-50) / 0.96);
  --app-sidebar-active-text: rgb(var(--accent-700));
  --app-hero-base: rgba(247, 239, 227, 0.82);
  --app-hero-overlay-top: linear-gradient(135deg, rgba(255, 252, 248, 0.92), rgba(237, 246, 240, 0.76), rgba(255, 247, 230, 0.58));
  --app-hero-overlay-bottom: linear-gradient(to top, rgba(255, 252, 248, 0.86), rgba(255, 252, 248, 0.44), rgba(255, 252, 248, 0.12));
  --app-panel-bg: rgba(255, 252, 248, 0.92);
  --app-panel-border: rgba(97, 84, 69, 0.12);
  --app-panel-shadow: 0 24px 64px rgba(79, 57, 34, 0.08);
  --app-card-bg: rgba(255, 248, 239, 0.86);
  --app-card-border: rgba(97, 84, 69, 0.12);
  --app-card-shadow: 0 18px 42px rgba(79, 57, 34, 0.06);
  --app-primary-button-bg: rgb(var(--accent-600));
  --app-primary-button-hover-bg: rgb(var(--accent-700));
  --app-primary-button-shadow: 0 18px 38px rgb(var(--accent-700) / 0.16);
  --app-primary-button-hover-shadow: 0 22px 44px rgb(var(--accent-700) / 0.22);
  --app-primary-button-disabled-bg: rgba(151, 163, 182, 0.92);
  --app-primary-button-disabled-text: rgba(255, 255, 255, 0.94);
  --app-secondary-button-border: rgba(97, 84, 69, 0.14);
  --app-secondary-button-bg: rgba(255, 250, 242, 0.88);
  --app-secondary-button-text: rgb(var(--editorial-ink));
  --app-secondary-button-hover-border: rgb(var(--accent-200) / 0.92);
  --app-secondary-button-hover-bg: rgb(var(--accent-50) / 0.7);
  --app-secondary-button-hover-text: rgb(var(--accent-700));
  --app-control-border: rgba(97, 84, 69, 0.14);
  --app-control-bg: rgba(255, 250, 242, 0.95);
  --app-control-text: rgb(var(--editorial-ink));
  --app-control-focus-border: rgb(var(--accent-500) / 0.72);
  --app-control-focus-bg: white;
  --app-control-focus-ring: 0 0 0 0.28rem rgb(var(--accent-100) / 0.6);
  --app-control-disabled-bg: rgba(247, 239, 227, 0.78);
  --app-control-disabled-text: rgb(var(--editorial-muted));
  --app-control-disabled-opacity: 0.85;
  --app-tabset-bg: rgba(255, 248, 239, 0.76);
  --app-tabset-shadow: var(--app-card-shadow);
  --app-tab-active-bg: rgba(255, 252, 248, 0.94);
  --app-tab-active-text: rgb(var(--accent-700));
  --app-tab-active-shadow: none;
  --app-success-banner-border: 1px solid rgb(var(--accent-200) / 0.9);
  --app-success-banner-bg: rgb(var(--accent-50) / 0.92);
  --app-success-banner-text: rgb(var(--accent-700));
  --editorial-frame-border: 1px solid rgba(97, 84, 69, 0.12);
  --editorial-frame-bg: rgba(255, 252, 248, 0.96);
  --editorial-frame-shadow: 0 24px 64px rgba(79, 57, 34, 0.08);
  --editorial-pill-border: 1px solid rgba(97, 84, 69, 0.14);
  --editorial-pill-bg: rgba(255, 248, 239, 0.9);
  --editorial-pill-text: rgb(var(--editorial-muted));
  --editorial-panel-border: 1px solid rgba(97, 84, 69, 0.12);
  --editorial-panel-bg: rgba(255, 248, 239, 0.92);
  --editorial-panel-shadow: 0 22px 60px rgba(79, 57, 34, 0.07);
  --editorial-card-border: 1px solid rgba(97, 84, 69, 0.12);
  --editorial-card-bg: rgba(255, 250, 242, 0.92);
  --editorial-card-shadow: 0 18px 42px rgba(79, 57, 34, 0.06);
  --editorial-card-arch-bg: rgba(246, 238, 225, 0.95);
  --editorial-card-arch-shadow: 0 22px 60px rgba(79, 57, 34, 0.08);
  --editorial-soft-card-border: 1px solid rgba(97, 84, 69, 0.1);
  --editorial-soft-card-bg: rgba(247, 239, 227, 0.8);
  --editorial-soft-card-inset-bg: rgba(255, 250, 242, 0.86);
  --editorial-soft-card-accent-bg: linear-gradient(180deg, rgb(var(--accent-50) / 0.78), rgba(247, 239, 227, 0.86));
  --app-auth-orb-top-bg: rgb(var(--accent-100) / 0.18);
  --app-auth-orb-bottom-bg: rgba(255, 248, 239, 0.68);
  --app-auth-card-border: 1px solid rgba(97, 84, 69, 0.12);
  --app-auth-card-bg: rgba(255, 252, 248, 0.92);
  --app-auth-card-shadow: 0 32px 80px rgba(79, 57, 34, 0.12);
  --app-auth-card-top-bar: linear-gradient(90deg, rgb(var(--accent-500)), rgb(var(--accent-700)));
  --app-auth-progress-border: 1px solid rgba(97, 84, 69, 0.12);
  --app-auth-progress-bg: rgba(247, 239, 227, 0.7);
  --app-auth-progress-text: rgb(var(--editorial-muted));
  --app-auth-progress-active-border: rgb(var(--accent-200) / 0.92);
  --app-auth-progress-active-bg: rgb(var(--accent-50) / 0.94);
  --app-auth-progress-active-text: rgb(var(--accent-700));
  --app-auth-progress-active-shadow: inset 0 1px 0 rgb(255 255 255 / 0.7);
  --app-auth-choice-border: 1px solid rgba(97, 84, 69, 0.12);
  --app-auth-choice-bg: rgba(247, 239, 227, 0.72);
  --app-auth-choice-hover-border: rgba(97, 84, 69, 0.18);
  --app-auth-choice-hover-bg: rgba(255, 252, 248, 0.96);
  --app-auth-choice-active-border: rgb(var(--accent-200) / 0.92);
  --app-auth-choice-active-bg: rgb(var(--accent-50) / 0.94);
  --app-auth-choice-active-shadow: 0 18px 44px rgb(var(--accent-700) / 0.08);
  --app-file-input-border: 1px solid rgba(97, 84, 69, 0.14);
  --app-file-input-bg: rgba(255, 250, 242, 0.95);
  --app-file-input-text: rgb(var(--editorial-muted));
  --app-file-input-hover-border: rgb(var(--accent-200) / 0.92);
  --app-file-input-hover-bg: rgba(255, 252, 248, 0.98);
  --app-file-input-button-bg: rgb(var(--accent-600));
  --app-file-input-button-hover-bg: rgb(var(--accent-700));
  --app-shell-gradient:
    radial-gradient(circle at 82% 18%, rgb(var(--accent-100) / 0.18), transparent 18%),
    radial-gradient(circle at 12% 0%, rgba(255, 248, 239, 0.84), transparent 28%),
    linear-gradient(180deg, rgb(var(--editorial-page-bg)) 0%, rgba(250, 246, 238, 0.98) 100%);
  --app-auth-gradient:
    radial-gradient(circle at top, rgb(var(--accent-100) / 0.3), transparent 32%),
    radial-gradient(circle at 82% 18%, rgba(255, 248, 239, 0.86), transparent 20%),
    linear-gradient(180deg, rgb(var(--editorial-page-bg)) 0%, rgba(246, 240, 228, 0.94) 100%);
  --app-sidebar-shadow: 0 30px 72px rgba(79, 57, 34, 0.08);
  --app-overlay: rgba(36, 31, 26, 0.22);
}

[data-experience='business'] {
  --app-shell-gradient:
    radial-gradient(circle at 86% 14%, rgb(var(--accent-100) / 0.2), transparent 20%),
    radial-gradient(circle at 12% 0%, rgba(255, 248, 239, 0.88), transparent 28%),
    linear-gradient(180deg, rgb(var(--editorial-page-bg)) 0%, rgba(248, 244, 237, 0.98) 100%);
}

[data-experience='consumer'] {
  --app-shell-gradient:
    radial-gradient(circle at 80% 16%, rgb(var(--accent-100) / 0.18), transparent 18%),
    radial-gradient(circle at 16% 0%, rgba(255, 248, 239, 0.9), transparent 30%),
    linear-gradient(180deg, rgb(var(--editorial-page-bg)) 0%, rgba(250, 246, 238, 0.98) 100%);
}

html {
  scroll-behavior: smooth;
  background: var(--app-bg);
  color: var(--app-text);
}

body {
  margin: 0;
  min-height: 100vh;
  background:
    radial-gradient(circle at top, rgba(255, 248, 239, 0.82), transparent 34%),
    linear-gradient(180deg, rgb(var(--editorial-page-bg)) 0%, rgba(250, 246, 238, 0.98) 100%);
  color: var(--app-text);
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  -webkit-font-smoothing: antialiased;
}

* {
  box-sizing: border-box;
}

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

::selection {
  background: rgb(var(--accent-600));
  color: white;
}

.editorial-page {
  color: rgb(var(--editorial-ink));
  font-family: "Space Grotesk", "Segoe UI", "Helvetica", "Arial", sans-serif;
}

.editorial-display {
  font-family: "Fraunces", Georgia, serif;
  letter-spacing: -0.04em;
}

.editorial-mono {
  font-family: "IBM Plex Mono", monospace;
}

.editorial-frame {
  border: var(--editorial-frame-border);
  background: var(--editorial-frame-bg);
  box-shadow: var(--editorial-frame-shadow);
  backdrop-filter: blur(18px);
}

.editorial-link {
  position: relative;
  padding-bottom: 0.35rem;
  color: rgb(var(--editorial-muted));
  font-size: 0.875rem;
  line-height: 1.25rem;
  transition: color 0.2s ease;
}

.editorial-link::after {
  position: absolute;
  right: 0;
  bottom: 0;
  left: 0;
  height: 2px;
  border-radius: 999px;
  background: rgb(var(--accent-600));
  content: "";
  transform: scaleX(0);
  transform-origin: center;
  transition: transform 0.2s ease;
}

.editorial-link:hover,
.editorial-link:focus-visible,
.editorial-link[aria-current="page"] {
  color: rgb(var(--accent-700));
}

.editorial-link:hover::after,
.editorial-link:focus-visible::after,
.editorial-link[aria-current="page"]::after {
  transform: scaleX(1);
}

.editorial-pill {
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  border: var(--editorial-pill-border);
  background: var(--editorial-pill-bg);
  padding: 0.5rem 1rem;
  color: var(--editorial-pill-text);
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.28em;
  text-transform: uppercase;
}

.editorial-primary-button,
.app-primary-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 0;
  border-radius: 999px;
  background: var(--app-primary-button-bg);
  padding: 0.85rem 1.35rem;
  color: white;
  font-size: 0.95rem;
  font-weight: 600;
  line-height: 1.2;
  text-decoration: none;
  transition: transform 0.2s ease, background-color 0.2s ease, box-shadow 0.2s ease, opacity 0.2s ease;
  box-shadow: var(--app-primary-button-shadow);
}

.editorial-primary-button:hover,
.app-primary-button:hover {
  transform: translateY(-1px);
  background: var(--app-primary-button-hover-bg);
  box-shadow: var(--app-primary-button-hover-shadow);
}

.app-primary-button:disabled {
  background: var(--app-primary-button-disabled-bg);
  color: var(--app-primary-button-disabled-text);
  box-shadow: none;
}

.editorial-secondary-button,
.app-secondary-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  border: 1px solid transparent;
  border-color: var(--app-secondary-button-border);
  background: var(--app-secondary-button-bg);
  padding: 0.85rem 1.3rem;
  color: var(--app-secondary-button-text);
  font-size: 0.95rem;
  font-weight: 600;
  line-height: 1.2;
  text-decoration: none;
  transition: transform 0.2s ease, border-color 0.2s ease, background-color 0.2s ease, color 0.2s ease, opacity 0.2s ease;
}

.editorial-secondary-button:hover,
.app-secondary-button:hover {
  transform: translateY(-1px);
  border-color: var(--app-secondary-button-hover-border);
  background: var(--app-secondary-button-hover-bg);
  color: var(--app-secondary-button-hover-text);
}

.editorial-accent-chip {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  border-radius: 999px;
  border: 1px solid rgb(var(--accent-200) / 0.92);
  background: rgb(var(--accent-50) / 0.92);
  padding: 0.5rem 1rem;
  color: rgb(var(--accent-700));
  font-size: 0.875rem;
  font-weight: 500;
  box-shadow: inset 0 1px 0 rgb(255 255 255 / 0.7);
}

.editorial-accent-chip::before {
  width: 0.5rem;
  height: 0.5rem;
  flex: none;
  border-radius: 999px;
  background: rgb(var(--accent-600));
  content: "";
}

.editorial-panel {
  border-radius: 2rem;
  border: var(--editorial-panel-border);
  background: var(--editorial-panel-bg);
  padding: 1.75rem;
  box-shadow: var(--editorial-panel-shadow);
}

.editorial-panel--accented {
  border-color: rgb(var(--accent-200) / 0.85);
  box-shadow:
    0 24px 64px rgb(var(--accent-700) / 0.09),
    inset 0 1px 0 rgb(255 255 255 / 0.72);
}

.editorial-card {
  border-radius: 1.6rem;
  border: var(--editorial-card-border);
  background: var(--editorial-card-bg);
  padding: 1.5rem;
  box-shadow: var(--editorial-card-shadow);
}

.editorial-card--arch-palette {
  background: var(--editorial-card-arch-bg);
  box-shadow: var(--editorial-card-arch-shadow);
}

.editorial-card--accented {
  border-color: rgb(var(--accent-200) / 0.72);
  border-top: 4px solid rgb(var(--accent-500) / 0.98);
}

.editorial-feature-icon {
  display: inline-flex;
  width: 2.4rem;
  height: 2.4rem;
  flex: 0 0 auto;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  background: rgb(var(--accent-50) / 0.92);
  color: rgb(var(--accent-600));
  box-shadow: 0 0 0 0.4rem rgb(var(--accent-50) / 0.56);
}

.editorial-feature-icon svg {
  width: 1.2rem;
  height: 1.2rem;
  stroke: currentColor;
}

.editorial-feature-head {
  display: flex;
  align-items: center;
  gap: 1rem;
}

.editorial-accent-kicker,
.app-eyebrow {
  color: rgb(var(--accent-700));
}

.editorial-soft-card {
  border-radius: 1.6rem;
  border: var(--editorial-soft-card-border);
  background: var(--editorial-soft-card-bg);
  padding: 1.25rem;
}

.editorial-soft-card--inset-paper {
  background: var(--editorial-soft-card-inset-bg);
}

.editorial-soft-card--accented {
  border-color: rgb(var(--accent-200) / 0.82);
  background: var(--editorial-soft-card-accent-bg);
}

.editorial-soft-card--sector {
  border-top: 3px solid rgb(var(--accent-200) / 0.95);
}

.editorial-input,
.app-input,
.app-select {
  width: 100%;
  border: 1px solid transparent;
  border-color: var(--app-control-border);
  border-radius: 1rem;
  background: var(--app-control-bg);
  padding: 0.95rem 1rem;
  color: var(--app-control-text);
  outline: none;
  transition: border-color 0.2s ease, transform 0.2s ease, background-color 0.2s ease, box-shadow 0.2s ease;
}

.editorial-input:focus,
.app-input:focus,
.app-select:focus {
  transform: translateY(-1px);
  border-color: var(--app-control-focus-border);
  background: var(--app-control-focus-bg);
  box-shadow: var(--app-control-focus-ring);
}

.app-input:disabled,
.app-select:disabled {
  cursor: not-allowed;
  background: var(--app-control-disabled-bg);
  color: var(--app-control-disabled-text);
  opacity: var(--app-control-disabled-opacity);
}

.app-shell {
  min-height: 100vh;
  background: var(--app-shell-gradient);
  color: var(--app-text);
}

.app-navbar {
  border-color: var(--app-border);
  background: var(--app-navbar-bg);
  box-shadow: 0 8px 24px rgba(79, 57, 34, 0.04);
}

.app-sidebar {
  border-color: var(--app-sidebar-border);
  background: var(--app-sidebar-bg);
  color: var(--app-sidebar-text);
  box-shadow: var(--app-sidebar-shadow);
  backdrop-filter: blur(18px);
}

.app-panel {
  border-radius: 2rem;
  border: 1px solid rgba(97, 84, 69, 0.12);
  border-color: var(--app-panel-border);
  background: var(--app-panel-bg);
  box-shadow: var(--app-panel-shadow);
}

.app-card-surface {
  border-radius: 1.6rem;
  border: 1px solid rgba(97, 84, 69, 0.12);
  border-color: var(--app-card-border);
  background: var(--app-card-bg);
  box-shadow: var(--app-card-shadow);
}

.app-danger-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  border: 1px solid rgb(var(--theme-red-200));
  background: rgb(var(--theme-red-50));
  padding: 0.85rem 1.3rem;
  color: rgb(var(--theme-red-700));
  font-weight: 600;
  transition: transform 0.2s ease, border-color 0.2s ease, background-color 0.2s ease, opacity 0.2s ease;
}

.app-danger-button:hover {
  transform: translateY(-1px);
  border-color: rgb(var(--theme-red-300));
  background: rgb(var(--theme-red-100));
}

.app-tabset {
  border-color: var(--app-card-border);
  background: var(--app-tabset-bg);
  box-shadow: var(--app-tabset-shadow);
}

.app-tab-active {
  background: var(--app-tab-active-bg);
  color: var(--app-tab-active-text);
  box-shadow: var(--app-tab-active-shadow);
}

.app-success-banner {
  border: var(--app-success-banner-border);
  background: var(--app-success-banner-bg);
  color: var(--app-success-banner-text);
}

.calendar-shell {
  --calendar-surface-bg: linear-gradient(180deg, rgba(255, 252, 248, 0.98) 0%, rgba(255, 248, 239, 0.92) 14rem), rgba(255, 252, 248, 0.98);
  --calendar-toolbar-border: rgba(97, 84, 69, 0.12);
  --calendar-toolbar-bg: linear-gradient(180deg, rgba(255, 250, 242, 0.96), rgba(247, 239, 227, 0.94));
  --calendar-toolbar-fg: rgb(var(--editorial-ink));
  --calendar-toolbar-button-border: rgba(97, 84, 69, 0.14);
  --calendar-toolbar-button-bg: rgba(255, 252, 248, 0.82);
  --calendar-toolbar-button-hover-bg: rgb(var(--accent-50) / 0.82);
  --calendar-toolbar-button-hover-border: rgb(var(--accent-200) / 0.92);
  --calendar-grid-border: rgba(97, 84, 69, 0.12);
  --calendar-header-bg: rgba(255, 250, 242, 0.92);
  --calendar-header-fg: rgba(84, 72, 59, 0.82);
  --calendar-day-bg: rgba(255, 252, 248, 0.88);
  --calendar-day-hover-bg: rgba(255, 248, 239, 0.94);
  --calendar-day-other-bg: rgba(250, 246, 238, 0.82);
  --calendar-day-other-fg: rgb(var(--theme-slate-400));
  --calendar-day-past-bg: rgba(252, 249, 244, 0.88);
  --calendar-day-today-bg: linear-gradient(180deg, rgb(var(--accent-50) / 0.96), rgba(255, 248, 239, 0.98));
  --calendar-day-number-fg: rgb(var(--editorial-ink));
  --calendar-day-today-number-fg: rgb(var(--accent-700));
  --calendar-day-today-dot: rgb(var(--accent-600));
  --calendar-event-border: rgb(var(--accent-200) / 0.9);
  --calendar-event-bg: rgb(var(--accent-50) / 0.88);
  --calendar-event-fg: rgb(var(--theme-teal-900));
  --calendar-more-link-fg: rgb(var(--accent-700));
  --calendar-multimonth-bg: rgba(255, 252, 248, 0.96);
  --calendar-multimonth-title-bg: rgba(255, 250, 242, 0.96);
  --calendar-multimonth-title-fg: rgb(var(--editorial-ink));
  --calendar-canceled-border: rgb(var(--theme-amber-200) / 0.95);
  --calendar-canceled-bg: rgb(var(--theme-amber-50) / 0.94);
  --calendar-canceled-fg: rgb(var(--theme-amber-800));
  display: flex;
  flex-direction: column;
  flex-grow: 1;
  overflow: hidden;
  border-radius: 1.5rem;
  background: var(--calendar-surface-bg);
  box-shadow: 0 18px 42px rgba(79, 57, 34, 0.06);
}

.calendar-shell[data-calendar-variant='business'] {
  --calendar-toolbar-bg: linear-gradient(135deg, rgba(247, 239, 227, 0.96), rgb(var(--accent-100) / 0.78));
  --calendar-day-today-bg: linear-gradient(180deg, rgb(var(--accent-50) / 0.98), rgb(var(--accent-100) / 0.64));
  --calendar-event-border: rgb(var(--accent-200) / 0.96);
  --calendar-event-bg: rgb(var(--accent-50) / 0.92);
  --calendar-event-fg: rgb(var(--theme-teal-900));
}

.calendar-shell[data-calendar-variant='public'] {
  --calendar-toolbar-bg: linear-gradient(180deg, rgba(255, 252, 248, 0.98), rgba(247, 239, 227, 0.94));
  --calendar-day-today-bg: linear-gradient(180deg, rgba(255, 247, 230, 0.98), rgba(250, 235, 196, 0.62));
  --calendar-day-today-number-fg: rgb(var(--theme-amber-700));
  --calendar-day-today-dot: rgb(var(--theme-amber-500));
  --calendar-event-border: rgba(97, 84, 69, 0.14);
  --calendar-event-bg: rgba(255, 248, 239, 0.92);
  --calendar-event-fg: rgb(var(--editorial-ink));
  --calendar-more-link-fg: rgb(var(--theme-amber-700));
}

.calendar-toolbar {
  display: flex;
  align-items: center;
  gap: 0.95rem;
  padding: 1rem 1.25rem;
  border-bottom: 1px solid var(--calendar-toolbar-border);
  background: var(--calendar-toolbar-bg);
  color: var(--calendar-toolbar-fg);
}

.calendar-toolbar__nav {
  display: flex;
  flex-shrink: 0;
  gap: 0.5rem;
  margin-right: 0.85rem;
}

.calendar-toolbar__button {
  border: 1px solid var(--calendar-toolbar-button-border);
  border-radius: 999px;
  background: var(--calendar-toolbar-button-bg);
  color: var(--calendar-toolbar-fg);
  padding: 0.55rem 0.95rem;
  font-size: 0.925rem;
  font-weight: 600;
  line-height: 1.2;
  transition:
    background-color 120ms ease,
    border-color 120ms ease,
    transform 120ms ease,
    color 120ms ease;
}

.calendar-toolbar__button:hover {
  border-color: var(--calendar-toolbar-button-hover-border);
  background: var(--calendar-toolbar-button-hover-bg);
  transform: translateY(-1px);
}

.calendar-toolbar__title {
  margin: 0;
  font-size: 1.15rem;
  font-weight: 600;
  letter-spacing: 0.01em;
}

.calendar-surface {
  flex: 1;
}

.calendar-shell .fc {
  min-height: 100%;
  color: var(--calendar-day-number-fg);
}

.calendar-shell .fc .fc-scrollgrid,
.calendar-shell .fc-theme-standard td,
.calendar-shell .fc-theme-standard th {
  border-color: var(--calendar-grid-border);
}

.calendar-shell .fc-theme-standard .fc-scrollgrid {
  border: 0;
}

.calendar-shell .fc .fc-col-header-cell {
  background: var(--calendar-header-bg);
}

.calendar-shell .fc .fc-col-header-cell-cushion {
  padding: 0.85rem 0.25rem;
  color: var(--calendar-header-fg);
  font-size: 0.76rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  text-decoration: none;
}

.calendar-shell .fc .fc-daygrid-day-frame {
  min-height: 6.75rem;
  background: var(--calendar-day-bg);
  transition: background-color 120ms ease;
}

.calendar-shell .fc .fc-daygrid-day:hover .fc-daygrid-day-frame {
  background: var(--calendar-day-hover-bg);
}

.calendar-shell .fc .fc-day-other .fc-daygrid-day-frame {
  background: var(--calendar-day-other-bg);
}

.calendar-shell .fc .fc-day-other .fc-daygrid-day-number {
  color: var(--calendar-day-other-fg);
}

.calendar-shell .fc .fc-day-past .fc-daygrid-day-frame {
  background: var(--calendar-day-past-bg);
}

.calendar-shell .fc .fc-day-today .fc-daygrid-day-frame {
  background: var(--calendar-day-today-bg);
}

.calendar-shell .fc .fc-daygrid-day-number {
  padding: 0.7rem 0.75rem;
  color: var(--calendar-day-number-fg);
  font-size: 0.9rem;
  font-weight: 600;
  text-decoration: none;
}

.calendar-shell .fc .fc-day-today .fc-daygrid-day-number {
  color: var(--calendar-day-today-number-fg);
}

.calendar-shell .fc .fc-day-today .fc-daygrid-day-number::after {
  display: inline-block;
  width: 0.45rem;
  height: 0.45rem;
  margin-left: 0.45rem;
  border-radius: 9999px;
  background: var(--calendar-day-today-dot);
  content: "";
  vertical-align: middle;
}

.calendar-shell .fc .fc-daygrid-event,
.calendar-shell .fc .fc-h-event {
  border: 1px solid var(--calendar-event-border);
  border-radius: 0.85rem;
  background: var(--calendar-event-bg);
  color: var(--calendar-event-fg);
  box-shadow: none;
  cursor: pointer;
}

.calendar-shell .fc .fc-event-main,
.calendar-shell .fc .fc-event-main-frame,
.calendar-shell .fc .fc-event-title,
.calendar-shell .fc .fc-event-time {
  color: var(--calendar-event-fg);
  font-size: 0.82rem;
  font-weight: 600;
}

.calendar-shell .fc .calendar-event--canceled {
  border-color: var(--calendar-canceled-border);
  background: var(--calendar-canceled-bg);
}

.calendar-shell .fc .calendar-event--canceled .fc-event-main,
.calendar-shell .fc .calendar-event--canceled .fc-event-main-frame,
.calendar-shell .fc .calendar-event--canceled .fc-event-title,
.calendar-shell .fc .calendar-event--canceled .fc-event-time {
  color: var(--calendar-canceled-fg);
}

.calendar-shell .fc .fc-daygrid-more-link {
  color: var(--calendar-more-link-fg);
  font-size: 0.78rem;
  font-weight: 600;
}

.calendar-instance.is-read-only .fc .fc-daygrid-day,
.calendar-instance.is-read-only .fc .fc-event {
  cursor: default;
}

.calendar-instance.is-read-only.allows-read-only-item-click .fc .fc-event {
  cursor: pointer;
}

.calendar-shell .fc .fc-multimonth {
  gap: 1rem;
  padding: 1rem;
}

.calendar-shell .fc .fc-multimonth-month {
  overflow: hidden;
  border: 1px solid var(--calendar-grid-border);
  border-radius: 1rem;
  background: var(--calendar-multimonth-bg);
}

.calendar-shell .fc .fc-multimonth-title {
  padding: 0.85rem 1rem;
  background: var(--calendar-multimonth-title-bg);
  color: var(--calendar-multimonth-title-fg);
  font-size: 0.95rem;
  font-weight: 700;
}

.app-auth-shell {
  position: relative;
  min-height: 100vh;
  background: var(--app-auth-gradient);
  overflow: hidden;
  overflow: clip;
  isolation: isolate;
}

.app-auth-shell::before,
.app-auth-shell::after {
  position: absolute;
  border-radius: 999px;
  content: "";
  pointer-events: none;
  z-index: 0;
}

.app-auth-shell::before {
  left: -7rem;
  top: 5rem;
  width: 20rem;
  height: 20rem;
  background: var(--app-auth-orb-top-bg);
}

.app-auth-shell::after {
  right: -8rem;
  bottom: -8rem;
  width: 22rem;
  height: 22rem;
  background: var(--app-auth-orb-bottom-bg);
}

.app-auth-card {
  position: relative;
  z-index: 1;
  overflow: hidden;
  border: var(--app-auth-card-border);
  border-radius: 2rem;
  background: var(--app-auth-card-bg);
  box-shadow: var(--app-auth-card-shadow);
  backdrop-filter: blur(18px);
}

.app-auth-card::before {
  position: absolute;
  inset: 0 auto auto 0;
  width: 100%;
  height: 0.3rem;
  background: var(--app-auth-card-top-bar);
  content: "";
}

.app-auth-progress-item {
  border: var(--app-auth-progress-border);
  border-radius: 1.25rem;
  background: var(--app-auth-progress-bg);
  color: var(--app-auth-progress-text);
  transition: border-color 0.2s ease, background-color 0.2s ease, color 0.2s ease;
}

.app-auth-progress-item.is-active {
  border-color: var(--app-auth-progress-active-border);
  background: var(--app-auth-progress-active-bg);
  color: var(--app-auth-progress-active-text);
  box-shadow: var(--app-auth-progress-active-shadow);
}

.app-auth-choice-card {
  border: var(--app-auth-choice-border);
  border-radius: 1.5rem;
  background: var(--app-auth-choice-bg);
  transition: transform 0.2s ease, border-color 0.2s ease, background-color 0.2s ease, box-shadow 0.2s ease;
}

.app-auth-choice-card:hover {
  transform: translateY(-1px);
  border-color: var(--app-auth-choice-hover-border);
  background: var(--app-auth-choice-hover-bg);
}

.app-auth-choice-card.is-active {
  border-color: var(--app-auth-choice-active-border);
  background: var(--app-auth-choice-active-bg);
  box-shadow: var(--app-auth-choice-active-shadow);
}

.app-auth-link {
  color: rgb(var(--accent-700));
  font-weight: 600;
  text-decoration: none;
  transition: color 0.2s ease;
}

.app-auth-link:hover {
  color: rgb(var(--accent-600));
}

.app-file-input {
  display: block;
  width: 100%;
  min-width: 0;
  border: var(--app-file-input-border);
  border-radius: 1rem;
  background: var(--app-file-input-bg);
  padding: 0.95rem 1rem;
  color: var(--app-file-input-text);
  font-size: 0.875rem;
  line-height: 1.5;
  transition: border-color 0.2s ease, box-shadow 0.2s ease, background-color 0.2s ease;
}

.app-file-input:focus-within,
.app-file-input:hover {
  border-color: var(--app-file-input-hover-border);
  background: var(--app-file-input-hover-bg);
}

.app-file-input::file-selector-button {
  margin-right: 1rem;
  border: 0;
  border-radius: 999px;
  background: var(--app-file-input-button-bg);
  padding: 0.7rem 1rem;
  color: white;
  font-weight: 600;
  cursor: pointer;
  transition: background-color 0.2s ease, transform 0.2s ease;
}

.app-file-input:hover::file-selector-button {
  background: var(--app-file-input-button-hover-bg);
  transform: translateY(-1px);
}

@media (max-width: 768px) {
  .app-auth-shell::after {
    right: -11rem;
    bottom: -11rem;
    width: 18rem;
    height: 18rem;
  }

  .calendar-toolbar {
    flex-direction: column;
    align-items: flex-start;
  }

  .calendar-toolbar__nav {
    margin-right: 0;
  }
}

@media (min-width: 640px) {
  .editorial-panel {
    padding: 2rem;
  }
}
