@import url('https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700;800&family=Playfair+Display:ital,wght@0,500;0,700;1,400&display=swap');

:root {
  --font-primary: 'Outfit', sans-serif;
  --font-serif: 'Playfair Display', serif;
  --radius-sm: 8px;
  --radius-md: 16px;
  --radius-lg: 24px;

  /* DEFAULT: Premium Light Theme Variables */
  --bg-darker: #f8fafc; /* Slate 50 (Clean off-white) */
  --bg-dark: #f1f5f9;   /* Slate 100 */
  --bg-card: rgba(255, 255, 255, 0.85); /* Semi-transparent white card */
  --bg-card-hover: rgba(255, 255, 255, 0.95);

  --color-gold-light: #34d399; /* Light Emerald */
  --color-gold: #059669;       /* Emerald 600 (Primary Green) */
  --color-gold-dark: #047857;  /* Emerald 700 */
  --color-gold-glow: rgba(16, 185, 129, 0.08);

  --color-orange: #f97316;     /* Orange 500 */
  --color-orange-dark: #ea580c; /* Orange 600 */
  --color-orange-glow: rgba(249, 115, 22, 0.06);

  --color-text-primary: #0f172a;   /* Slate 900 */
  --color-text-secondary: #475569; /* Slate 600 */
  --color-text-muted: #64748b;     /* Slate 500 */

  --border-gold: rgba(16, 185, 129, 0.16);
  --border-dark: rgba(0, 0, 0, 0.06);

  --shadow-gold: 0 10px 30px -10px rgba(16, 185, 129, 0.18);
  --shadow-dark: 0 10px 30px -10px rgba(0, 0, 0, 0.06);

  /* Theme-dependent base colors that we map to classes */
  --color-text-white: var(--color-text-primary); /* Slate 900 in light, Pure white in dark */
  --color-zinc-300: #334155;
  --color-zinc-400: #475569;
  --color-zinc-500: #64748b;
  --color-emerald-400: #047857;
  --color-red-200: #991b1b;
  --color-rose-400: #be123c;
  --color-amber-200: #92400e;
  --color-amber-400: #b45309;

  --color-bg-zinc-900: #f1f5f9;
  --color-bg-zinc-950: #e2e8f0;
  --color-bg-zinc-900-40: rgba(241, 245, 249, 0.4);
  --color-bg-zinc-950-20: rgba(226, 232, 240, 0.2);
  --color-bg-emerald-950-40: rgba(209, 250, 229, 0.8);
  --color-bg-red-950-40: rgba(254, 226, 226, 0.8);
  --color-bg-amber-950-20: rgba(254, 243, 199, 0.5);
  --color-bg-amber-950-40: rgba(254, 243, 199, 0.8);
  --color-bg-rose-950-40: rgba(254, 228, 226, 0.8);

  --color-border-zinc-900: #e2e8f0;
  --color-border-zinc-800: #cbd5e1;
  --color-border-emerald-500: #34d399;
  --color-border-emerald-800: #a7f3d0;
  --color-border-red-800: #fca5a5;
  --color-border-amber-800: #fde68a;
  --color-border-amber-800-30: rgba(251, 191, 36, 0.2);
  --color-border-rose-800: #fecaca;
  
  --color-modal-bg: #ffffff;
  --color-input-bg: #ffffff;
  --color-input-border: #cbd5e1;
  --color-input-focus-bg: #ffffff;

  /* Theme-adaptive gradients and backgrounds */
  --color-nav-bg: rgba(255, 255, 255, 0.85);
  --color-welcome-bg: linear-gradient(135deg, rgba(255, 255, 255, 0.95) 0%, rgba(241, 245, 249, 0.95) 100%);
  --color-hero-bg: linear-gradient(135deg, rgba(254, 243, 199, 0.5) 0%, var(--bg-card) 100%);
}

/* OVERRIDE: Premium Dark Theme Variables */

.dark-theme {
  --bg-darker: #05070c; /* Deep obsidian space black */
  --bg-dark: #0b0f19;   /* Obsidian night dark */
  --bg-card: rgba(13, 19, 33, 0.65); /* Semi-transparent glassmorphic obsidian card */
  --bg-card-hover: rgba(17, 26, 46, 0.85);

  --color-gold-light: #34d399;
  --color-gold: #10b981;
  --color-gold-dark: #059669;
  --color-gold-glow: rgba(16, 185, 129, 0.15);

  --color-orange: #f59e0b;     /* Gold / Amber 500 */
  --color-orange-dark: #d97706; /* Dark Gold / Amber 600 */
  --color-orange-glow: rgba(245, 158, 11, 0.12);

  --color-text-primary: #f8fafc;   /* Slate 50 */
  --color-text-secondary: #cbd5e1; /* Slate 300 */
  --color-text-muted: #94a3b8;     /* Slate 400 */

  --border-gold: rgba(16, 185, 129, 0.2);
  --border-dark: rgba(255, 255, 255, 0.08);

  --shadow-gold: 0 10px 30px -10px rgba(16, 185, 129, 0.35);
  --shadow-dark: 0 10px 30px -10px rgba(0, 0, 0, 0.5);

  --color-text-white: #ffffff;
  --color-zinc-300: #d1d5db;
  --color-zinc-400: #9ca3af;
  --color-zinc-500: #6b7280;
  --color-emerald-400: #34d399;
  --color-red-200: #fecaca;
  --color-rose-400: #fb7185;
  --color-amber-200: #fde68a;
  --color-amber-400: #fbbf24;

  --color-bg-zinc-900: #111827;
  --color-bg-zinc-950: #030712;
  --color-bg-zinc-900-40: rgba(17, 24, 39, 0.4);
  --color-bg-zinc-950-20: rgba(3, 7, 18, 0.2);
  --color-bg-emerald-950-40: rgba(6, 78, 59, 0.4);
  --color-bg-red-950-40: rgba(127, 29, 29, 0.4);
  --color-bg-amber-950-20: rgba(120, 53, 4, 0.2);
  --color-bg-amber-950-40: rgba(120, 53, 4, 0.4);
  --color-bg-rose-950-40: rgba(136, 19, 55, 0.4);

  --color-border-zinc-900: rgba(255, 255, 255, 0.08);
  --color-border-zinc-800: rgba(255, 255, 255, 0.12);
  --color-border-emerald-500: #10b981;
  --color-border-emerald-800: rgba(16, 185, 129, 0.3);
  --color-border-red-800: rgba(239, 68, 68, 0.3);
  --color-border-amber-800: rgba(245, 158, 11, 0.3);
  --color-border-amber-800-30: rgba(245, 158, 11, 0.15);
  --color-border-rose-800: rgba(244, 63, 94, 0.3);
  
  --color-modal-bg: var(--bg-dark);
  --color-input-bg: rgba(17, 24, 39, 0.8);
  --color-input-border: rgba(255, 255, 255, 0.12);
  --color-input-focus-bg: rgba(17, 24, 39, 0.95);

  /* Theme-adaptive gradients and backgrounds (Dark Theme) */
  --color-nav-bg: rgba(5, 7, 12, 0.8);
  --color-welcome-bg: linear-gradient(135deg, rgba(20, 30, 55, 0.85) 0%, rgba(10, 15, 30, 0.95) 100%);
  --color-hero-bg: linear-gradient(135deg, rgba(20, 15, 10, 0.5) 0%, var(--bg-card) 100%);
}

* {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
  -webkit-tap-highlight-color: transparent;
}

body {
  font-family: var(--font-primary);
  background-color: var(--bg-darker);
  color: var(--color-text-primary);
  line-height: 1.5;
  overflow-x: hidden;
  transition: background-color 0.3s ease, color 0.3s ease;
}

/* Background Animated Gradient Radial Glows */

.ambient-glow {
  position: fixed;
  width: 700px;
  height: 700px;
  border-radius: 50%;
  z-index: -1;
  pointer-events: none;
  filter: blur(100px);
  opacity: 0.7;
}

.glow-top-right {
  top: -250px;
  right: -250px;
  background: radial-gradient(circle, var(--color-gold-glow) 0%, rgba(248, 250, 252, 0) 70%);
}

.glow-bottom-left {
  bottom: -250px;
  left: -250px;
  background: radial-gradient(circle, var(--color-orange-glow) 0%, rgba(248, 250, 252, 0) 70%);
}

/* Scrollbar Style */

::-webkit-scrollbar {
  width: 8px;
}

::-webkit-scrollbar-track {
  background: var(--bg-darker);
}

::-webkit-scrollbar-thumb {
  background: var(--color-gold-light);
  border-radius: 4px;
}

::-webkit-scrollbar-thumb:hover {
  background: var(--color-gold);
}

/* Premium Card / Glassmorphism */

.glass-card {
  background: var(--bg-card);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border: 1px solid var(--border-gold);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-dark);
  transition: all 0.3s cubic-bezier(0.25, 0.8, 0.25, 1);
  overflow: hidden;
}

.glass-card:hover {
  border-color: var(--color-gold);
  box-shadow: var(--shadow-gold);
  background: var(--bg-card-hover);
}

/* Text Gradients (Vibrant Green to Orange Gradient) */

.text-gold-gradient {
  background: linear-gradient(135deg, var(--color-gold) 0%, var(--color-orange) 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}

/* Premium Buttons */

.btn-gold {
  background: linear-gradient(135deg, var(--color-gold) 0%, var(--color-gold-dark) 100%);
  color: #ffffff !important;
  border: none;
  font-family: var(--font-primary);
  font-weight: 600;
  font-size: 1rem;
  letter-spacing: 0.5px;
  padding: 14px 28px;
  border-radius: var(--radius-sm);
  cursor: pointer;
  box-shadow: 0 4px 15px rgba(5, 150, 105, 0.2);
  transition: all 0.3s ease;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  text-decoration: none;
}

.btn-gold:hover {
  transform: translateY(-2px);
  box-shadow: 0 6px 20px rgba(5, 150, 105, 0.35);
  background: linear-gradient(135deg, var(--color-gold-light) 0%, var(--color-gold) 100%);
}

.btn-gold:active {
  transform: translateY(0);
}

.btn-outline-gold {
  background: transparent;
  color: var(--color-gold);
  border: 1px solid var(--color-gold);
  font-family: var(--font-primary);
  font-weight: 600;
  font-size: 1rem;
  letter-spacing: 0.5px;
  padding: 13px 27px;
  border-radius: var(--radius-sm);
  cursor: pointer;
  transition: all 0.3s ease;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  text-decoration: none;
}

.btn-outline-gold:hover {
  background: rgba(5, 150, 105, 0.05);
  box-shadow: 0 0 15px rgba(5, 150, 105, 0.1);
  border-color: var(--color-gold-light);
  color: var(--color-gold-light);
}

/* Form inputs */

.form-group {
  margin-bottom: 20px;
  width: 100%;
}

.form-label {
  display: block;
  font-size: 0.875rem;
  font-weight: 500;
  margin-bottom: 8px;
  color: var(--color-text-secondary);
}

.form-input {
  width: 100%;
  padding: 14px 16px;
  background: var(--color-input-bg) !important;
  border: 1px solid var(--color-input-border) !important;
  border-radius: var(--radius-sm);
  color: var(--color-text-primary) !important;
  font-family: var(--font-primary);
  font-size: 1rem;
  transition: all 0.3s ease;
}

.form-input:focus {
  outline: none;
  border-color: var(--color-gold) !important;
  background: var(--color-input-focus-bg) !important;
  box-shadow: 0 0 8px rgba(16, 185, 129, 0.2);
}

/* ==========================================================================
   Admin Panel Form Components (prowith.kr style)
   ========================================================================== */

.admin-form-label {
  display: block;
  font-size: 13px;
  font-weight: 600;
  color: #374151;
  margin-bottom: 6px;
  letter-spacing: -0.01em;
}

.dark-theme .admin-form-label {
  color: #94a3b8;
}

.admin-form-input {
  width: 100%;
  padding: 11px 14px;
  background: #ffffff;
  border: 1px solid #d1d5db;
  border-radius: 8px;
  color: #111827;
  font-family: var(--font-primary);
  font-size: 14px;
  font-weight: 400;
  line-height: 1.5;
  transition: border-color 0.2s ease, box-shadow 0.2s ease;
  outline: none;
  box-sizing: border-box;
}

.admin-form-input::placeholder {
  color: #9ca3af;
  font-weight: 400;
}

.admin-form-input:focus {
  border-color: #10b981;
  box-shadow: 0 0 0 3px rgba(16, 185, 129, 0.12);
}

.dark-theme .admin-form-input {
  background: #1e293b;
  border-color: #334155;
  color: #f1f5f9;
}

.dark-theme .admin-form-input::placeholder {
  color: #64748b;
}

.dark-theme .admin-form-input:focus {
  border-color: #10b981;
  box-shadow: 0 0 0 3px rgba(16, 185, 129, 0.15);
}

.admin-form-btn-primary {
  width: 100%;
  padding: 12px 20px;
  background: #10b981;
  color: #ffffff;
  border: none;
  border-radius: 8px;
  font-family: var(--font-primary);
  font-size: 14px;
  font-weight: 700;
  cursor: pointer;
  transition: background 0.2s ease, box-shadow 0.2s ease;
  margin-top: 4px;
}

.admin-form-btn-primary:hover {
  background: #059669;
  box-shadow: 0 4px 12px rgba(16, 185, 129, 0.3);
}

.admin-form-btn-primary:disabled {
  background: #6ee7b7;
  cursor: not-allowed;
  box-shadow: none;
}

/* ==========================================================================
   Global Admin Input Override — applies prowith.kr style to ALL inputs,
   selects, textareas inside the admin <main> area, overriding the cramped
   inline classes (bg-zinc-955 px-3 py-2 text-xs, form-input py-1.5 text-xs)
   ========================================================================== */

/* Light theme */

body:not(.dark-theme) main input[type="text"],
body:not(.dark-theme) main input[type="number"],
body:not(.dark-theme) main input[type="email"],
body:not(.dark-theme) main input[type="password"],
body:not(.dark-theme) main input[type="date"],
body:not(.dark-theme) main input[type="search"],
body:not(.dark-theme) main select,
body:not(.dark-theme) main textarea {
  padding: 10px 14px !important;
  font-size: 14px !important;
  font-weight: 400 !important;
  line-height: 1.5 !important;
  border-radius: 8px !important;
  border: 1px solid #d1d5db !important;
  background: #ffffff !important;
  color: #111827 !important;
  font-family: var(--font-primary) !important;
  transition: border-color 0.2s ease, box-shadow 0.2s ease !important;
  outline: none !important;
  box-sizing: border-box !important;
}

body:not(.dark-theme) main input::placeholder,
body:not(.dark-theme) main textarea::placeholder {
  color: #9ca3af !important;
  font-weight: 400 !important;
}

body:not(.dark-theme) main input:focus,
body:not(.dark-theme) main select:focus,
body:not(.dark-theme) main textarea:focus {
  border-color: #10b981 !important;
  box-shadow: 0 0 0 3px rgba(16, 185, 129, 0.12) !important;
}

body:not(.dark-theme) main input:disabled,
body:not(.dark-theme) main select:disabled,
body:not(.dark-theme) main textarea:disabled {
  background: #f9fafb !important;
  color: #9ca3af !important;
  cursor: not-allowed !important;
}

/* Dark theme */

.dark-theme main input[type="text"],
.dark-theme main input[type="number"],
.dark-theme main input[type="email"],
.dark-theme main input[type="password"],
.dark-theme main input[type="date"],
.dark-theme main input[type="search"],
.dark-theme main select,
.dark-theme main textarea {
  padding: 10px 14px !important;
  font-size: 14px !important;
  font-weight: 400 !important;
  line-height: 1.5 !important;
  border-radius: 8px !important;
  border: 1px solid #334155 !important;
  background: #1e293b !important;
  color: #f1f5f9 !important;
  font-family: var(--font-primary) !important;
  transition: border-color 0.2s ease, box-shadow 0.2s ease !important;
  outline: none !important;
  box-sizing: border-box !important;
}

.dark-theme main input::placeholder,
.dark-theme main textarea::placeholder {
  color: #64748b !important;
  font-weight: 400 !important;
}

.dark-theme main input:focus,
.dark-theme main select:focus,
.dark-theme main textarea:focus {
  border-color: #10b981 !important;
  box-shadow: 0 0 0 3px rgba(16, 185, 129, 0.15) !important;
}

/* Override form-input py-1.5 override (search bars keep smaller height) */

body:not(.dark-theme) main input.form-input,
.dark-theme main input.form-input {
  padding: 10px 14px !important;
}

/* But search bars with pl-8 (icon inside) keep left padding */

body:not(.dark-theme) main input.form-input[style*="pl-8"],
body:not(.dark-theme) main input.pl-8 {
  padding-left: 32px !important;
}

/* Admin form labels: upgrade text-[10px] labels sitewide */

body:not(.dark-theme) main label {
  font-size: 13px !important;
  font-weight: 600 !important;
  color: #374151 !important;
}

.dark-theme main label {
  font-size: 13px !important;
  font-weight: 600 !important;
  color: #94a3b8 !important;
}

/* Don't override radio/checkbox inline labels */

body:not(.dark-theme) main label:has(input[type="radio"]),
body:not(.dark-theme) main label:has(input[type="checkbox"]),
.dark-theme main label:has(input[type="radio"]),
.dark-theme main label:has(input[type="checkbox"]) {
  font-size: 13px !important;
  font-weight: 500 !important;
  color: inherit !important;
}

/* Section headings inside glass-cards: h3 upgrade */

body:not(.dark-theme) main .glass-card h3 {
  font-size: 15px !important;
  font-weight: 700 !important;
  color: #0f172a !important;
  border-bottom-color: #e2e8f0 !important;
}

/* Modal styles */

.modal-overlay {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: rgba(15, 23, 42, 0.45); /* Soft overlay */
  backdrop-filter: blur(6px);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 1000;
  padding: 20px;
}

.modal-content {
  width: 100%;
  max-width: 500px;
  background: var(--color-modal-bg) !important;
  border: 1px solid var(--border-gold);
  box-shadow: var(--shadow-gold);
  animation: modalScaleIn 0.3s cubic-bezier(0.16, 1, 0.3, 1) forwards;
}

@keyframes modalScaleIn {
  from {
    opacity: 0;
    transform: scale(0.95) translateY(10px);
  }
  to {
    opacity: 1;
    transform: scale(1) translateY(0);
  }
}

/* ==========================================================================
   CSS Utility Classes (Bypassing Tailwind dependency)
   ========================================================================== */

/* Layout & Flexbox */

.flex { display: flex; }

.flex-col { flex-direction: column; }

.flex-row { flex-direction: row; }

.inline-flex { display: inline-flex; }

.items-center { align-items: center; }

.items-start { align-items: flex-start; }

.items-stretch { align-items: stretch; }

.justify-center { justify-content: center; }

.justify-between { justify-content: space-between; }

.flex-1 { flex: 1 1 0%; }

.shrink-0 { flex-shrink: 0; }

@media (min-width: 640px) {
  .sm\:flex-row { flex-direction: row; }
  .sm\:w-auto { width: auto; }
}

/* Grid Layout */

.grid { display: grid; }

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

.col-span-2 { grid-column: span 2 / span 2; }

@media (min-width: 768px) {
  .md\:grid-cols-2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .md\:grid-cols-3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
}

/* Gaps */

.gap-1 { gap: 0.25rem; }

.gap-1\.5 { gap: 0.375rem; }

.gap-2 { gap: 0.5rem; }

.gap-3 { gap: 0.75rem; }

.gap-4 { gap: 1rem; }

.gap-6 { gap: 1.5rem; }

.gap-8 { gap: 2rem; }

.gap-12 { gap: 3rem; }

/* Paddings */

.p-2 { padding: 0.5rem; }

.p-3 { padding: 0.75rem; }

.p-4 { padding: 1rem; }

.p-6 { padding: 1.5rem; }

.p-8 { padding: 2rem; }

.p-12 { padding: 3rem; }

.px-1\.5 { padding-left: 0.375rem; padding-right: 0.375rem; }

.px-2 { padding-left: 0.5rem; padding-right: 0.5rem; }

.px-3 { padding-left: 0.75rem; padding-right: 0.75rem; }

.px-4 { padding-left: 1rem; padding-right: 1rem; }

.px-6 { padding-left: 1.5rem; padding-right: 1.5rem; }

.py-0\.5 { padding-top: 0.125rem; padding-bottom: 0.125rem; }

.py-1\.5 { padding-top: 0.375rem; padding-bottom: 0.375rem; }

.py-4 { padding-top: 1rem; padding-bottom: 1rem; }

.py-6 { padding-top: 1.5rem; padding-bottom: 1.5rem; }

.pr-8 { padding-right: 2rem; }

@media (min-width: 768px) {
  .md\:p-12 { padding: 3rem; }
}

/* Margins */

.m-auto { margin: auto; }

.mx-auto { margin-left: auto; margin-right: auto; }

.my-8 { margin-top: 2rem; margin-bottom: 2rem; }

.my-12 { margin-top: 3rem; margin-bottom: 3rem; }

.mt-0\.5 { margin-top: 0.125rem; }

.mt-1 { margin-top: 0.25rem; }

.mt-1\.5 { margin-top: 0.375rem; }

.mt-2 { margin-top: 0.5rem; }

.mt-3 { margin-top: 0.75rem; }

.mt-4 { margin-top: 1rem; }

.mt-6 { margin-top: 1.5rem; }

.mt-8 { margin-top: 2rem; }

.mt-12 { margin-top: 3rem; }

.mt-20 { margin-top: 5rem; }

.mb-2 { margin-bottom: 0.5rem; }

.mb-4 { margin-bottom: 1rem; }

.mb-6 { margin-bottom: 1.5rem; }

.mb-8 { margin-bottom: 2rem; }

.mb-10 { margin-bottom: 2.5rem; }

/* Text & Typography */

.text-center { text-align: center; }

.text-left { text-align: left; }

.text-right { text-align: right; }

.text-xs { font-size: 0.75rem; }

.text-sm { font-size: 0.875rem; }

.text-lg { font-size: 1.125rem; }

.text-xl { font-size: 1.25rem; }

.text-2xl { font-size: 1.5rem; }

.text-3xl { font-size: 1.875rem; }

.text-4xl { font-size: 2.25rem; }

@media (min-width: 768px) {
  .md\:text-6xl { font-size: 3.75rem; }
}

/* Font Weights */

.font-light { font-weight: 300; }

.font-normal { font-weight: 400; }

.font-semibold { font-weight: 500; }

.font-bold { font-weight: 700; }

.font-extrabold { font-weight: 800; }

/* Spacing and Lettering */

.tracking-tight { letter-spacing: -0.025em; }

.tracking-wide { letter-spacing: 0.025em; }

.tracking-widest { letter-spacing: 0.1em; }

.leading-normal { line-height: 1.5; }

.leading-relaxed { line-height: 1.625; }

/* Sizing */

.w-full { width: 100%; }

.h-full { height: 100%; }

.w-12 { width: 3rem; }

.h-12 { height: 3rem; }

.w-16 { width: 4rem; }

.h-16 { height: 4rem; }

.w-48 { width: 12rem; }

.h-48 { height: 12rem; }

.aspect-square { aspect-ratio: 1 / 1; }

.max-w-xs { max-width: 20rem; }

.max-w-md { max-width: 28rem; }

.max-w-lg { max-width: 32rem; }

.max-w-2xl { max-width: 42rem; }

.max-w-4xl { max-width: 56rem; }

.max-w-5xl { max-width: 64rem; }

.max-w-7xl { max-width: 80rem; }

.min-h-screen { min-height: 100vh; }

/* Theme Mapped Utility Classes */

.text-white { color: var(--color-text-white) !important; }

/* Theme-dependent header color */

.text-zinc-300 { color: var(--color-zinc-300); }

.text-zinc-400 { color: var(--color-zinc-400); }

.text-zinc-500 { color: var(--color-zinc-500); }

.text-emerald-400 { color: var(--color-emerald-400); }

.text-red-200 { color: var(--color-red-200); }

.text-rose-400 { color: var(--color-rose-400); }

.text-amber-200 { color: var(--color-amber-200); }

.text-amber-400 { color: var(--color-amber-400); }

.bg-zinc-900 { background-color: var(--color-bg-zinc-900); }

.bg-zinc-950 { background-color: var(--color-bg-zinc-950); }

.bg-zinc-900\/40 { background-color: var(--color-bg-zinc-900-40); }

.bg-zinc-950\/20 { background-color: var(--color-bg-zinc-950-20); }

.bg-emerald-950\/40 { background-color: var(--color-bg-emerald-950-40); }

.bg-red-950\/40 { background-color: var(--color-bg-red-950-40); }

.bg-amber-950\/20 { background-color: var(--color-bg-amber-950-20); }

.bg-amber-950\/40 { background-color: var(--color-bg-amber-950-40); }

.bg-rose-950\/40 { background-color: var(--color-bg-rose-950-40); }

.border-zinc-900 { border-color: var(--color-border-zinc-900); }

.border-zinc-800 { border-color: var(--color-border-zinc-800); }

.border-emerald-500 { border-color: var(--color-border-emerald-500); }

.border-emerald-800 { border-color: var(--color-border-emerald-800); }

.border-red-800 { border-color: var(--color-border-red-800); }

.border-amber-800 { border-color: var(--color-border-amber-800); }

.border-amber-800\/30 { border-color: var(--color-border-amber-800-30); }

.border-rose-800 { border-color: var(--color-border-rose-800); }

/* Orange specific override highlights */

.text-orange-gradient {
  background: linear-gradient(135deg, var(--color-gold) 0%, var(--color-orange) 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}

.text-gold {
  color: var(--color-orange) !important;
}

/* Border Radius */

.rounded-full { border-radius: 9999px; }

.rounded-lg { border-radius: 8px; }

.rounded-xl { border-radius: 12px; }

.rounded-2xl { border-radius: 16px; }

/* Positioning & Layout Helpers */

.relative { position: relative; }

.absolute { position: absolute; }

.overflow-hidden { overflow: hidden; }

.truncate { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }

.block { display: block; }

.hidden { display: none; }

.top-4 { top: 1rem; }

.right-4 { right: 1rem; }

.top-1\/2 { top: 50%; }

.-translate-y-1\/2 { transform: translateY(-50%); }

.max-h-\[90vh\] { max-height: 90vh; }

.overflow-y-auto { overflow-y: auto; }

.cursor-pointer { cursor: pointer; }

.bg-transparent { background-color: transparent; }

.border-none { border: none; }

@media (min-width: 640px) {
  .sm\:inline { display: inline; }
}

@media (min-width: 768px) {
  .md\:inline { display: inline; }
  .md\:self-auto { align-self: auto; }
}

.self-start { align-self: flex-start; }

/* Scrollable chips navigation for mobile tabs */

.scroll-chips {
  display: flex;
  overflow-x: auto;
  gap: 8px;
  padding: 4px 0 12px 0;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
}

.scroll-chips::-webkit-scrollbar {
  display: none;
}

/* Timeline/Mobile Card Lists */

.timeline-card {
  background: var(--bg-card);
  border: 1px solid var(--border-dark);
  border-radius: var(--radius-sm);
  padding: 16px;
  transition: all 0.2s ease;
}

.timeline-card:hover {
  border-color: var(--color-gold);
  background: var(--bg-card-hover);
  box-shadow: var(--shadow-gold);
}

/* Additional Theme-Adaptive and Utility Classes */

.bg-emerald-500 { background-color: #10b981 !important; }

.bg-emerald-600 { background-color: var(--color-gold) !important; }

.bg-emerald-600:hover { background-color: var(--color-gold-dark) !important; }

.text-orange-400 { color: var(--color-orange) !important; }

.border-amber-800\/40 { border-color: var(--color-border-amber-800) !important; }

.border-zinc-900\/80 { border-color: var(--color-border-zinc-800) !important; }

.border-zinc-800\/80 { border-color: var(--color-border-zinc-800) !important; }

.bg-zinc-950\/60 { background-color: var(--color-bg-zinc-950-20) !important; }

/* React Flow MiniMap Styling & Responsiveness */

.react-flow__minimap {
  border: 1px solid var(--color-border-zinc-800) !important;
  border-radius: var(--radius-sm) !important;
  background-color: var(--bg-card) !important;
  box-shadow: var(--shadow-dark) !important;
}

.dark-theme .react-flow__minimap {
  background-color: rgba(11, 15, 25, 0.9) !important;
  border-color: rgba(255, 255, 255, 0.1) !important;
}

/* Hide on mobile screens */

@media (max-width: 767px) {
  .react-flow__minimap {
    display: none !important;
  }
}

/* Ensure the nodes inside the minimap are colored, filled, and visible */

.react-flow__minimap-node {
  fill-opacity: 0.95 !important;
  stroke-width: 1px !important;
  stroke: var(--color-border-zinc-800) !important;
}

.dark-theme .react-flow__minimap-node {
  stroke: rgba(255, 255, 255, 0.1) !important;
}

/* Style the viewport mask inside the minimap */

.react-flow__minimap-mask {
  fill: rgba(241, 245, 249, 0.65) !important;
}

.dark-theme .react-flow__minimap-mask {
  fill: rgba(3, 7, 18, 0.65) !important;
}

/* Custom Dashboard Tab Grid & Premium Flat Buttons for Mobile (Vanilla CSS) */

.tab-grid-container {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 8px;
  width: 100%;
}

.tab-span-2 {
  grid-column: span 2;
}

.flat-tab-btn {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 3px;
  padding: 12px 14px;
  border-radius: 10px;
  border: none;
  font-size: 12px;
  font-weight: 700;
  cursor: pointer;
  transition: all 0.2s ease;
  background: var(--bg-dark) !important;
  color: var(--color-text-secondary) !important;
}

.flat-tab-btn:hover {
  background: var(--bg-card-hover) !important;
  color: var(--color-text-primary) !important;
}

.flat-tab-btn.active {
  background: var(--color-gold-glow) !important;
  color: var(--color-gold) !important;
  box-shadow: 0 4px 12px -2px var(--color-gold-glow) !important;
}

/* Enhance active background color visibility slightly in dark mode */

.dark-theme .flat-tab-btn.active {
  background: rgba(16, 185, 129, 0.15) !important;
}

@media (min-width: 640px) {
  .tab-grid-container {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
  }
  .tab-span-2 {
    grid-column: auto;
  }
}

/* Premium Welcome Card Layout & Styles */

.welcome-card-container {
  display: flex;
  flex-direction: column;
  gap: 20px;
  width: 100%;
}

.welcome-profile-section {
  display: flex;
  align-items: center;
  gap: 16px;
}

.welcome-referral-section {
  display: flex;
  flex-direction: column;
  gap: 8px;
  width: 100%;
}

.referral-input-wrapper {
  position: relative;
  display: flex;
  align-items: center;
  width: 100%;
}

.referral-input-field {
  width: 100%;
  background: var(--bg-dark) !important;
  color: var(--color-text-primary) !important;
  font-family: monospace;
  font-size: 12px;
  padding: 12px 84px 12px 34px !important;
  border-radius: 8px;
  border: 1px solid var(--border-dark) !important;
  outline: none;
  box-sizing: border-box;
  transition: all 0.2s ease;
}

.referral-input-field:focus {
  border-color: var(--color-gold) !important;
  box-shadow: 0 0 0 2px var(--color-gold-glow) !important;
}

.referral-copy-btn {
  position: absolute;
  right: 6px;
  background: var(--color-gold) !important;
  color: #ffffff !important;
  font-weight: 800;
  font-size: 10px;
  letter-spacing: 0.5px;
  text-transform: uppercase;
  padding: 0 12px;
  border-radius: 6px;
  border: none;
  min-width: 68px;
  height: 32px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  box-shadow: 0 4px 10px rgba(5, 150, 105, 0.15);
  transition: all 0.2s ease;
}

.referral-copy-btn:hover {
  background: var(--color-gold-dark) !important;
  transform: translateY(-1px);
}

.referral-copy-btn.copied {
  background: #10b981 !important;
  box-shadow: 0 4px 10px rgba(16, 185, 129, 0.2);
}

@media (min-width: 768px) {
  .welcome-card-container {
    flex-direction: row;
    justify-content: space-between;
    align-items: center;
  }
  .welcome-referral-section {
    width: auto;
    min-width: 320px;
  }
}

/* ==========================================================================
   Antigravity Added: Missing Tailwind-like layout utility classes
   ========================================================================== */

.md\:flex {
  display: flex !important;
}

.md\:hidden {
  display: none !important;
}

.md\:flex-row {
  flex-direction: row !important;
}

.w-64 {
  width: 16rem !important;
}

.h-screen {
  height: 100vh !important;
}

.sticky {
  position: sticky !important;
}

.top-0 {
  top: 0 !important;
}

.z-10 {
  z-index: 10 !important;
}

.z-20 {
  z-index: 20 !important;
}

.z-30 {
  z-index: 30 !important;
}

.z-45 {
  z-index: 45 !important;
}

.z-50 {
  z-index: 50 !important;
}

.bg-\[\#141414\] {
  background-color: #141414 !important;
}

.bg-\[\#1a1a1a\] {
  background-color: #1a1a1a !important;
}

.bg-\[\#1f1f1f\] {
  background-color: #1f1f1f !important;
}

.bg-\[\#151515\] {
  background-color: #151515 !important;
}

.min-w-0 {
  min-width: 0 !important;
}

.h-14 {
  height: 3.5rem !important;
}

.md\:p-8 {
  padding: 2rem !important;
}

.antialiased {
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

/* Responsive Grid Columns */

@media (min-width: 768px) {
  .md\:grid-cols-4 {
    grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  }
}

@media (min-width: 1024px) {
  .lg\:grid-cols-4 {
    grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  }
  .lg\:col-span-1 {
    grid-column: span 1 / span 1 !important;
  }
  .lg\:col-span-3 {
    grid-column: span 3 / span 3 !important;
  }
}

/* Interactive Hover States & Scales */

.hover\:scale-102 {
  transition: transform 0.2s cubic-bezier(0.16, 1, 0.3, 1) !important;
}

.hover\:scale-102:hover {
  transform: scale(1.02) !important;
}

.hover\:bg-\[\#1f1f1f\]:hover {
  background-color: #1f1f1f !important;
}

.hover\:text-white:hover {
  color: #ffffff !important;
}

.hover\:bg-zinc-800:hover {
  background-color: rgba(255, 255, 255, 0.08) !important;
}

.hover\:bg-zinc-700:hover {
  background-color: rgba(255, 255, 255, 0.12) !important;
}

/* Adaptive text colors */

.text-slate-800 {
  color: var(--color-text-primary) !important;
}

.dark-theme .dark\:text-slate-100 {
  color: #f1f5f9 !important;
}

.text-zinc-505 {
  color: var(--color-zinc-400) !important;
}

.text-zinc-450 {
  color: var(--color-zinc-400) !important;
}

.text-zinc-555 {
  color: var(--color-zinc-500) !important;
}

.text-zinc-550 {
  color: var(--color-zinc-500) !important;
}

/* Sidebar Specific Contrast Overrides (Clean White Sidebar matching prowith.kr) */

aside {
  background-color: #ffffff !important;
  border-right: 1px solid #f1f5f9 !important;
  -ms-overflow-style: none !important;
  scrollbar-width: none !important;
}

aside::-webkit-scrollbar {
  display: none !important;
}

.sidebar-container {
  display: flex;
  flex-direction: column;
  height: 100%;
  background-color: #ffffff !important;
  font-family: var(--font-primary);
}

.sidebar-logo-section {
  padding: 14px 20px !important;
  border-bottom: 1px solid #f1f5f9 !important;
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.sidebar-logo-text {
  font-weight: 700 !important;
  font-size: 15px !important;
  letter-spacing: 0.5px !important;
  color: #0f172a !important;
}

.sidebar-nav {
  flex: 1;
  overflow-y: auto;
  padding: 12px 8px !important;
  -ms-overflow-style: none !important;
  scrollbar-width: none !important;
}

.sidebar-nav::-webkit-scrollbar {
  display: none !important;
}

.sidebar-group-title {
  font-size: 11px !important;
  font-weight: 600 !important;
  color: #94a3b8 !important;
  padding: 14px 16px 4px 16px !important;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.sidebar-item {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 9px 16px !important;
  margin-bottom: 2px !important;
  border-radius: 6px !important;
  font-size: 14px !important;
  font-weight: 500 !important;
  color: #475569 !important;
  background: transparent !important;
  border: none !important;
  cursor: pointer;
  transition: all 0.15s ease;
  text-align: left;
}

.sidebar-item:hover {
  background-color: #f8fafc !important;
  color: #0f172a !important;
}

.sidebar-item.active {
  background-color: #f8fafc !important;
  color: #0f172a !important;
  font-weight: 600 !important;
  border-left: 3px solid #10b981 !important;
  padding-left: 13px !important;
}

.sidebar-subitem-container {
  padding-left: 0 !important;
  margin-bottom: 4px !important;
  display: flex;
  flex-direction: column;
  gap: 1px;
}

.sidebar-subitem {
  width: 100%;
  padding: 7px 16px 7px 36px !important;
  font-size: 13px !important;
  font-weight: 400 !important;
  color: #64748b !important;
  background: transparent !important;
  border: none !important;
  border-radius: 6px !important;
  cursor: pointer;
  transition: all 0.15s ease;
  text-align: left;
  display: block;
}

.sidebar-subitem:hover {
  background-color: #f8fafc !important;
  color: #0f172a !important;
}

.sidebar-subitem.active {
  color: #10b981 !important;
  font-weight: 600 !important;
  background-color: transparent !important;
  border-left: 2px solid #10b981 !important;
  padding-left: 34px !important;
}

.sidebar-sub-subitem-container {
  padding-left: 16px !important;
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.sidebar-sub-subitem {
  width: 100%;
  padding: 6px 16px 6px 44px !important;
  font-size: 11px !important;
  font-weight: 500 !important;
  color: #64748b !important;
  background: transparent !important;
  border: none !important;
  border-radius: 6px !important;
  cursor: pointer;
  transition: all 0.2s ease;
  text-align: left;
  display: block;
}

.sidebar-sub-subitem:hover {
  background-color: #f8fafc !important;
  color: #0f172a !important;
}

.sidebar-sub-subitem.active {
  color: #10b981 !important;
  font-weight: 600 !important;
  background-color: transparent !important;
  border-left: 2px solid #10b981 !important;
  padding-left: 42px !important;
}

/* Global Font Override for Premium Typography */

.font-sans {
  font-family: var(--font-primary) !important;
}

/* ==========================================================================
   Prowith.kr Light-Theme Polish Overrides
   ========================================================================== */

body:not(.dark-theme) {
  background-color: #f8fafc !important;
}

body:not(.dark-theme) header {
  background-color: #ffffff !important;
  border-bottom: 1px solid #f1f5f9 !important;
}

body:not(.dark-theme) main {
  background-color: #f8fafc !important;
}

/* Card & Container Overrides */

body:not(.dark-theme) .glass-card,
body:not(.dark-theme) .bg-zinc-950\/50,
body:not(.dark-theme) .bg-zinc-955\/20,
body:not(.dark-theme) .bg-zinc-955\/40 {
  background-color: #ffffff !important;
  border-color: #e2e8f0 !important;
  box-shadow: 0 1px 3px 0 rgba(0, 0, 0, 0.05), 0 1px 2px 0 rgba(0, 0, 0, 0.03) !important;
  backdrop-filter: none !important;
}

/* Fix: Table container overflow so thead clips to card's border-radius */

.glass-card.overflow-x-auto,
.glass-card > .overflow-x-auto {
  overflow: hidden !important;
}

.glass-card:has(table) {
  overflow: hidden !important;
}

/* Border Overrides */

body:not(.dark-theme) .border-zinc-900,
body:not(.dark-theme) .border-zinc-850,
body:not(.dark-theme) .border-zinc-800,
body:not(.dark-theme) .border-zinc-700 {
  border-color: #e2e8f0 !important;
}

/* Table Specific Overrides */

body:not(.dark-theme) table {
  background-color: #ffffff !important;
}

body:not(.dark-theme) thead tr {
  background-color: #f8fafc !important;
}

body:not(.dark-theme) th {
  background-color: #f8fafc !important;
  color: #64748b !important;
  border-bottom: 2px solid #e2e8f0 !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  letter-spacing: 0.03em !important;
}

/* First/last th rounded corners to match card */

body:not(.dark-theme) thead tr th:first-child {
  border-top-left-radius: 0 !important;
}

body:not(.dark-theme) thead tr th:last-child {
  border-top-right-radius: 0 !important;
}

body:not(.dark-theme) td {
  border-bottom: 1px solid #f1f5f9 !important;
  color: #334155 !important;
}

body:not(.dark-theme) tbody tr:hover td {
  background-color: #f8fafc !important;
}

body:not(.dark-theme) tbody tr:last-child td {
  border-bottom: none !important;
}

/* Dark theme table thead fix */

.dark-theme thead tr {
  background-color: #141414 !important;
}

.dark-theme .glass-card:has(table) {
  overflow: hidden !important;
}

/* Input, Select, Textarea Overrides */

body:not(.dark-theme) input,
body:not(.dark-theme) select,
body:not(.dark-theme) textarea {
  background-color: #ffffff !important;
  border: 1px solid #cbd5e1 !important;
  color: #0f172a !important;
}

body:not(.dark-theme) input:focus,
body:not(.dark-theme) select:focus,
body:not(.dark-theme) textarea:focus {
  border-color: #10b981 !important;
  box-shadow: 0 0 0 2px rgba(16, 185, 129, 0.1) !important;
}

body:not(.dark-theme) ::placeholder {
  color: #94a3b8 !important;
}

/* Text Color Overrides for Main Content */

body:not(.dark-theme) main .text-white {
  color: #0f172a !important;
}

body:not(.dark-theme) main .text-zinc-100,
body:not(.dark-theme) main .text-zinc-200,
body:not(.dark-theme) main .text-zinc-250,
body:not(.dark-theme) main .text-zinc-300 {
  color: #1e293b !important;
}

body:not(.dark-theme) main .text-zinc-400,
body:not(.dark-theme) main .text-zinc-450,
body:not(.dark-theme) main .text-zinc-505,
body:not(.dark-theme) main .text-zinc-550,
body:not(.dark-theme) main .text-zinc-555 {
  color: #475569 !important;
}

body:not(.dark-theme) main .text-zinc-500 {
  color: #64748b !important;
}

body:not(.dark-theme) main .bg-zinc-900\/50 {
  background-color: #f1f5f9 !important;
}

/* Badges and Buttons */

body:not(.dark-theme) .bg-emerald-950\/40 {
  background-color: #ecfdf5 !important;
  color: #047857 !important;
  border-color: #a7f3d0 !important;
}

body:not(.dark-theme) .bg-amber-955\/20 {
  background-color: #fef3c7 !important;
  color: #d97706 !important;
  border-color: #fde68a !important;
}

/* Missing background & border utilities */

.bg-zinc-955 {
  background-color: var(--color-bg-zinc-950) !important;
}

.bg-zinc-850 {
  background-color: var(--color-border-zinc-900) !important;
}

.bg-zinc-955\/20 {
  background-color: var(--color-bg-zinc-950-20) !important;
}

.bg-zinc-955\/40 {
  background-color: var(--color-bg-zinc-950-20) !important;
}

.bg-zinc-900\/50 {
  background-color: var(--color-bg-zinc-900-40) !important;
}

.bg-zinc-900\/10 {
  background-color: rgba(0, 0, 0, 0.05) !important;
}

.dark-theme .bg-zinc-900\/10 {
  background-color: rgba(255, 255, 255, 0.03) !important;
}

.border-zinc-850 {
  border-color: var(--color-border-zinc-900) !important;
}

.border-zinc-800 {
  border-color: var(--color-border-zinc-800) !important;
}

.border-zinc-900 {
  border-color: var(--color-border-zinc-900) !important;
}

/* Missing Padding, Margin, and Gap Utilities */

.p-5 { padding: 1.25rem !important; }

.p-6 { padding: 1.5rem !important; }

.px-5 { padding-left: 1.25rem !important; padding-right: 1.25rem !important; }

.px-6 { padding-left: 1.5rem !important; padding-right: 1.5rem !important; }

.py-5 { padding-top: 1.25rem !important; padding-bottom: 1.25rem !important; }

.py-6 { padding-top: 1.5rem !important; padding-bottom: 1.5rem !important; }

.pb-5 { padding-bottom: 1.25rem !important; }

.pb-6 { padding-bottom: 1.5rem !important; }

.pt-5 { padding-top: 1.25rem !important; }

.pt-6 { padding-top: 1.5rem !important; }

.gap-5 { gap: 1.25rem !important; }

/* Vertical Spacing Utilities (space-y-X) */

.space-y-0\.5 > * + * { margin-top: 0.125rem !important; }

.space-y-1 > * + * { margin-top: 0.25rem !important; }

.space-y-2 > * + * { margin-top: 0.5rem !important; }

.space-y-3 > * + * { margin-top: 0.75rem !important; }

.space-y-4 > * + * { margin-top: 1rem !important; }

.space-y-5 > * + * { margin-top: 1.25rem !important; }

.space-y-6 > * + * { margin-top: 1.5rem !important; }

.space-y-8 > * + * { margin-top: 2rem !important; }

/* Horizontal Spacing Utilities (space-x-X) */

.space-x-1 > * + * { margin-left: 0.25rem !important; }

.space-x-2 > * + * { margin-left: 0.5rem !important; }

.space-x-3 > * + * { margin-left: 0.75rem !important; }

.space-x-4 > * + * { margin-left: 1rem !important; }

.space-x-6 > * + * { margin-left: 1.5rem !important; }

/* Text Alignment & Decoration Utilities */

.text-center { text-align: center !important; }

.text-right { text-align: right !important; }

.text-left { text-align: left !important; }

.no-underline { text-decoration: none !important; }

a.no-underline { text-decoration: none !important; }

a.no-underline:hover { text-decoration: none !important; }

/* Remove underline from all header links globally */

header a {
  text-decoration: none !important;
}





/* this gets exported as style.css and can be used for the default theming */
/* these are the necessary styles for React/Svelte Flow, they get used by base.css and style.css */
.react-flow {
  direction: ltr;

  --xy-edge-stroke-default: #b1b1b7;
  --xy-edge-stroke-width-default: 1;
  --xy-edge-stroke-selected-default: #555;

  --xy-connectionline-stroke-default: #b1b1b7;
  --xy-connectionline-stroke-width-default: 1;

  --xy-attribution-background-color-default: rgba(255, 255, 255, 0.5);

  --xy-minimap-background-color-default: #fff;
  --xy-minimap-mask-background-color-default: rgba(240, 240, 240, 0.6);
  --xy-minimap-mask-stroke-color-default: transparent;
  --xy-minimap-mask-stroke-width-default: 1;
  --xy-minimap-node-background-color-default: #e2e2e2;
  --xy-minimap-node-stroke-color-default: transparent;
  --xy-minimap-node-stroke-width-default: 2;

  --xy-background-color-default: transparent;
  --xy-background-pattern-dots-color-default: #91919a;
  --xy-background-pattern-lines-color-default: #eee;
  --xy-background-pattern-cross-color-default: #e2e2e2;
  background-color: var(--xy-background-color, var(--xy-background-color-default));
  --xy-node-color-default: inherit;
  --xy-node-border-default: 1px solid #1a192b;
  --xy-node-background-color-default: #fff;
  --xy-node-group-background-color-default: rgba(240, 240, 240, 0.25);
  --xy-node-boxshadow-hover-default: 0 1px 4px 1px rgba(0, 0, 0, 0.08);
  --xy-node-boxshadow-selected-default: 0 0 0 0.5px #1a192b;
  --xy-node-border-radius-default: 3px;

  --xy-handle-background-color-default: #1a192b;
  --xy-handle-border-color-default: #fff;

  --xy-selection-background-color-default: rgba(0, 89, 220, 0.08);
  --xy-selection-border-default: 1px dotted rgba(0, 89, 220, 0.8);

  --xy-controls-button-background-color-default: #fefefe;
  --xy-controls-button-background-color-hover-default: #f4f4f4;
  --xy-controls-button-color-default: inherit;
  --xy-controls-button-color-hover-default: inherit;
  --xy-controls-button-border-color-default: #eee;
  --xy-controls-box-shadow-default: 0 0 2px 1px rgba(0, 0, 0, 0.08);

  --xy-edge-label-background-color-default: #ffffff;
  --xy-edge-label-color-default: inherit;
  --xy-resize-background-color-default: #3367d9;
}
.react-flow.dark {
  --xy-edge-stroke-default: #3e3e3e;
  --xy-edge-stroke-width-default: 1;
  --xy-edge-stroke-selected-default: #727272;

  --xy-connectionline-stroke-default: #b1b1b7;
  --xy-connectionline-stroke-width-default: 1;

  --xy-attribution-background-color-default: rgba(150, 150, 150, 0.25);

  --xy-minimap-background-color-default: #141414;
  --xy-minimap-mask-background-color-default: rgba(60, 60, 60, 0.6);
  --xy-minimap-mask-stroke-color-default: transparent;
  --xy-minimap-mask-stroke-width-default: 1;
  --xy-minimap-node-background-color-default: #2b2b2b;
  --xy-minimap-node-stroke-color-default: transparent;
  --xy-minimap-node-stroke-width-default: 2;

  --xy-background-color-default: #141414;
  --xy-background-pattern-dots-color-default: #777;
  --xy-background-pattern-lines-color-default: #777;
  --xy-background-pattern-cross-color-default: #777;
  --xy-node-color-default: #f8f8f8;
  --xy-node-border-default: 1px solid #3c3c3c;
  --xy-node-background-color-default: #1e1e1e;
  --xy-node-group-background-color-default: rgba(240, 240, 240, 0.25);
  --xy-node-boxshadow-hover-default: 0 1px 4px 1px rgba(255, 255, 255, 0.08);
  --xy-node-boxshadow-selected-default: 0 0 0 0.5px #999;

  --xy-handle-background-color-default: #bebebe;
  --xy-handle-border-color-default: #1e1e1e;

  --xy-selection-background-color-default: rgba(200, 200, 220, 0.08);
  --xy-selection-border-default: 1px dotted rgba(200, 200, 220, 0.8);

  --xy-controls-button-background-color-default: #2b2b2b;
  --xy-controls-button-background-color-hover-default: #3e3e3e;
  --xy-controls-button-color-default: #f8f8f8;
  --xy-controls-button-color-hover-default: #fff;
  --xy-controls-button-border-color-default: #5b5b5b;
  --xy-controls-box-shadow-default: 0 0 2px 1px rgba(0, 0, 0, 0.08);

  --xy-edge-label-background-color-default: #141414;
  --xy-edge-label-color-default: #f8f8f8;
}
.react-flow__background {
  background-color: var(--xy-background-color-props, var(--xy-background-color, var(--xy-background-color-default)));
  pointer-events: none;
  z-index: -1;
}
.react-flow__container {
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
}
.react-flow__pane {
  z-index: 1;
  touch-action: none;
}
.react-flow__pane.draggable {
    cursor: grab;
  }
.react-flow__pane.dragging {
    cursor: grabbing;
  }
.react-flow__pane.selection {
    cursor: pointer;
  }
.react-flow__viewport {
  transform-origin: 0 0;
  z-index: 2;
  pointer-events: none;
}
.react-flow__renderer {
  z-index: 4;
}
.react-flow__selection {
  z-index: 6;
}
.react-flow__nodesselection-rect:focus,
.react-flow__nodesselection-rect:focus-visible {
  outline: none;
}
.react-flow__edge-path {
  stroke: var(--xy-edge-stroke, var(--xy-edge-stroke-default));
  stroke-width: var(--xy-edge-stroke-width, var(--xy-edge-stroke-width-default));
  fill: none;
}
.react-flow__connection-path {
  stroke: var(--xy-connectionline-stroke, var(--xy-connectionline-stroke-default));
  stroke-width: var(--xy-connectionline-stroke-width, var(--xy-connectionline-stroke-width-default));
  fill: none;
}
.react-flow .react-flow__edges {
  position: absolute;
}
.react-flow .react-flow__edges svg {
    overflow: visible;
    position: absolute;
    pointer-events: none;
  }
.react-flow__edge {
  pointer-events: visibleStroke;
}
.react-flow__edge.selectable {
    cursor: pointer;
  }
.react-flow__edge.animated path {
    stroke-dasharray: 5;
    animation: dashdraw 0.5s linear infinite;
  }
.react-flow__edge.animated path.react-flow__edge-interaction {
    stroke-dasharray: none;
    animation: none;
  }
.react-flow__edge.inactive {
    pointer-events: none;
  }
.react-flow__edge.selected,
  .react-flow__edge:focus,
  .react-flow__edge:focus-visible {
    outline: none;
  }
.react-flow__edge.selected .react-flow__edge-path,
  .react-flow__edge.selectable:focus .react-flow__edge-path,
  .react-flow__edge.selectable:focus-visible .react-flow__edge-path {
    stroke: var(--xy-edge-stroke-selected, var(--xy-edge-stroke-selected-default));
  }
.react-flow__edge-textwrapper {
    pointer-events: all;
  }
.react-flow__edge .react-flow__edge-text {
    pointer-events: none;
    -webkit-user-select: none;
       -moz-user-select: none;
            user-select: none;
  }
/* Arrowhead marker styles - use CSS custom properties as default */
.react-flow__arrowhead polyline {
  stroke: var(--xy-edge-stroke, var(--xy-edge-stroke-default));
}
.react-flow__arrowhead polyline.arrowclosed {
  fill: var(--xy-edge-stroke, var(--xy-edge-stroke-default));
}
.react-flow__connection {
  pointer-events: none;
}
.react-flow__connection .animated {
    stroke-dasharray: 5;
    animation: dashdraw 0.5s linear infinite;
  }
svg.react-flow__connectionline {
  z-index: 1001;
  overflow: visible;
  position: absolute;
}
.react-flow__nodes {
  pointer-events: none;
  transform-origin: 0 0;
}
.react-flow__node {
  position: absolute;
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
  pointer-events: all;
  transform-origin: 0 0;
  box-sizing: border-box;
  cursor: default;
}
.react-flow__node.selectable {
    cursor: pointer;
  }
.react-flow__node.draggable {
    cursor: grab;
    pointer-events: all;
  }
.react-flow__node.draggable.dragging {
      cursor: grabbing;
    }
.react-flow__nodesselection {
  z-index: 3;
  transform-origin: left top;
  pointer-events: none;
}
.react-flow__nodesselection-rect {
    position: absolute;
    pointer-events: all;
    cursor: grab;
  }
.react-flow__handle {
  position: absolute;
  pointer-events: none;
  min-width: 5px;
  min-height: 5px;
  width: 6px;
  height: 6px;
  background-color: var(--xy-handle-background-color, var(--xy-handle-background-color-default));
  border: 1px solid var(--xy-handle-border-color, var(--xy-handle-border-color-default));
  border-radius: 100%;
}
.react-flow__handle.connectingfrom {
    pointer-events: all;
  }
.react-flow__handle.connectionindicator {
    pointer-events: all;
    cursor: crosshair;
  }
.react-flow__handle-bottom {
    top: auto;
    left: 50%;
    bottom: 0;
    transform: translate(-50%, 50%);
  }
.react-flow__handle-top {
    top: 0;
    left: 50%;
    transform: translate(-50%, -50%);
  }
.react-flow__handle-left {
    top: 50%;
    left: 0;
    transform: translate(-50%, -50%);
  }
.react-flow__handle-right {
    top: 50%;
    right: 0;
    transform: translate(50%, -50%);
  }
.react-flow__edgeupdater {
  cursor: move;
  pointer-events: all;
}
.react-flow__pane.selection .react-flow__panel {
  pointer-events: none;
}
.react-flow__panel {
  position: absolute;
  z-index: 5;
  margin: 15px;
}
.react-flow__panel.top {
    top: 0;
  }
.react-flow__panel.bottom {
    bottom: 0;
  }
.react-flow__panel.top.center, .react-flow__panel.bottom.center {
      left: 50%;
      transform: translateX(-15px) translateX(-50%);
    }
.react-flow__panel.left {
    left: 0;
  }
.react-flow__panel.right {
    right: 0;
  }
.react-flow__panel.left.center, .react-flow__panel.right.center {
      top: 50%;
      transform: translateY(-15px) translateY(-50%);
    }
.react-flow__attribution {
  font-size: 10px;
  background: var(--xy-attribution-background-color, var(--xy-attribution-background-color-default));
  padding: 2px 3px;
  margin: 0;
}
.react-flow__attribution a {
    text-decoration: none;
    color: #999;
  }
@keyframes dashdraw {
  from {
    stroke-dashoffset: 10;
  }
}
.react-flow__edgelabel-renderer {
  position: absolute;
  width: 100%;
  height: 100%;
  pointer-events: none;
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
  left: 0;
  top: 0;
}
.react-flow__viewport-portal {
  position: absolute;
  width: 100%;
  height: 100%;
  left: 0;
  top: 0;
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
}
.react-flow__minimap {
  background: var(
    --xy-minimap-background-color-props,
    var(--xy-minimap-background-color, var(--xy-minimap-background-color-default))
  );
}
.react-flow__minimap-svg {
    display: block;
  }
.react-flow__minimap-mask {
    fill: var(
      --xy-minimap-mask-background-color-props,
      var(--xy-minimap-mask-background-color, var(--xy-minimap-mask-background-color-default))
    );
    stroke: var(
      --xy-minimap-mask-stroke-color-props,
      var(--xy-minimap-mask-stroke-color, var(--xy-minimap-mask-stroke-color-default))
    );
    stroke-width: var(
      --xy-minimap-mask-stroke-width-props,
      var(--xy-minimap-mask-stroke-width, var(--xy-minimap-mask-stroke-width-default))
    );
  }
.react-flow__minimap-node {
    fill: var(
      --xy-minimap-node-background-color-props,
      var(--xy-minimap-node-background-color, var(--xy-minimap-node-background-color-default))
    );
    stroke: var(
      --xy-minimap-node-stroke-color-props,
      var(--xy-minimap-node-stroke-color, var(--xy-minimap-node-stroke-color-default))
    );
    stroke-width: var(
      --xy-minimap-node-stroke-width-props,
      var(--xy-minimap-node-stroke-width, var(--xy-minimap-node-stroke-width-default))
    );
  }
.react-flow__background-pattern.dots {
    fill: var(
      --xy-background-pattern-color-props,
      var(--xy-background-pattern-color, var(--xy-background-pattern-dots-color-default))
    );
  }
.react-flow__background-pattern.lines {
    stroke: var(
      --xy-background-pattern-color-props,
      var(--xy-background-pattern-color, var(--xy-background-pattern-lines-color-default))
    );
  }
.react-flow__background-pattern.cross {
    stroke: var(
      --xy-background-pattern-color-props,
      var(--xy-background-pattern-color, var(--xy-background-pattern-cross-color-default))
    );
  }
.react-flow__controls {
  display: flex;
  flex-direction: column;
  box-shadow: var(--xy-controls-box-shadow, var(--xy-controls-box-shadow-default));
}
.react-flow__controls.horizontal {
    flex-direction: row;
  }
.react-flow__controls-button {
    display: flex;
    justify-content: center;
    align-items: center;
    height: 26px;
    width: 26px;
    padding: 4px;
    border: none;
    background: var(--xy-controls-button-background-color, var(--xy-controls-button-background-color-default));
    border-bottom: 1px solid
      var(
        --xy-controls-button-border-color-props,
        var(--xy-controls-button-border-color, var(--xy-controls-button-border-color-default))
      );
    color: var(
      --xy-controls-button-color-props,
      var(--xy-controls-button-color, var(--xy-controls-button-color-default))
    );
    cursor: pointer;
    -webkit-user-select: none;
       -moz-user-select: none;
            user-select: none;
  }
.react-flow__controls-button svg {
      width: 100%;
      max-width: 12px;
      max-height: 12px;
      fill: currentColor;
    }
.react-flow__edge.updating .react-flow__edge-path {
      stroke: #777;
    }
.react-flow__edge-text {
    font-size: 10px;
  }
.react-flow__node.selectable:focus,
  .react-flow__node.selectable:focus-visible {
    outline: none;
  }
.react-flow__node-input,
.react-flow__node-default,
.react-flow__node-output,
.react-flow__node-group {
  padding: 10px;
  border-radius: var(--xy-node-border-radius, var(--xy-node-border-radius-default));
  width: 150px;
  font-size: 12px;
  color: var(--xy-node-color, var(--xy-node-color-default));
  text-align: center;
  border: var(--xy-node-border, var(--xy-node-border-default));
  background-color: var(--xy-node-background-color, var(--xy-node-background-color-default));
}
.react-flow__node-input.selectable:hover, .react-flow__node-default.selectable:hover, .react-flow__node-output.selectable:hover, .react-flow__node-group.selectable:hover {
      box-shadow: var(--xy-node-boxshadow-hover, var(--xy-node-boxshadow-hover-default));
    }
.react-flow__node-input.selectable.selected,
    .react-flow__node-input.selectable:focus,
    .react-flow__node-input.selectable:focus-visible,
    .react-flow__node-default.selectable.selected,
    .react-flow__node-default.selectable:focus,
    .react-flow__node-default.selectable:focus-visible,
    .react-flow__node-output.selectable.selected,
    .react-flow__node-output.selectable:focus,
    .react-flow__node-output.selectable:focus-visible,
    .react-flow__node-group.selectable.selected,
    .react-flow__node-group.selectable:focus,
    .react-flow__node-group.selectable:focus-visible {
      box-shadow: var(--xy-node-boxshadow-selected, var(--xy-node-boxshadow-selected-default));
    }
.react-flow__node-group {
  background-color: var(--xy-node-group-background-color, var(--xy-node-group-background-color-default));
}
.react-flow__nodesselection-rect,
.react-flow__selection {
  background: var(--xy-selection-background-color, var(--xy-selection-background-color-default));
  border: var(--xy-selection-border, var(--xy-selection-border-default));
}
.react-flow__nodesselection-rect:focus,
  .react-flow__nodesselection-rect:focus-visible,
  .react-flow__selection:focus,
  .react-flow__selection:focus-visible {
    outline: none;
  }
.react-flow__controls-button:hover {
      background: var(
        --xy-controls-button-background-color-hover-props,
        var(--xy-controls-button-background-color-hover, var(--xy-controls-button-background-color-hover-default))
      );
      color: var(
        --xy-controls-button-color-hover-props,
        var(--xy-controls-button-color-hover, var(--xy-controls-button-color-hover-default))
      );
    }
.react-flow__controls-button:disabled {
      pointer-events: none;
    }
.react-flow__controls-button:disabled svg {
        fill-opacity: 0.4;
      }
.react-flow__controls-button:last-child {
    border-bottom: none;
  }
.react-flow__controls.horizontal .react-flow__controls-button {
    border-bottom: none;
    border-right: 1px solid
      var(
        --xy-controls-button-border-color-props,
        var(--xy-controls-button-border-color, var(--xy-controls-button-border-color-default))
      );
  }
.react-flow__controls.horizontal .react-flow__controls-button:last-child {
    border-right: none;
  }
.react-flow__resize-control {
  position: absolute;
}
.react-flow__resize-control.left,
.react-flow__resize-control.right {
  cursor: ew-resize;
}
.react-flow__resize-control.top,
.react-flow__resize-control.bottom {
  cursor: ns-resize;
}
.react-flow__resize-control.top.left,
.react-flow__resize-control.bottom.right {
  cursor: nwse-resize;
}
.react-flow__resize-control.bottom.left,
.react-flow__resize-control.top.right {
  cursor: nesw-resize;
}
/* handle styles */
.react-flow__resize-control.handle {
  width: 5px;
  height: 5px;
  border: 1px solid #fff;
  border-radius: 1px;
  background-color: var(--xy-resize-background-color, var(--xy-resize-background-color-default));
  translate: -50% -50%;
}
.react-flow__resize-control.handle.left {
  left: 0;
  top: 50%;
}
.react-flow__resize-control.handle.right {
  left: 100%;
  top: 50%;
}
.react-flow__resize-control.handle.top {
  left: 50%;
  top: 0;
}
.react-flow__resize-control.handle.bottom {
  left: 50%;
  top: 100%;
}
.react-flow__resize-control.handle.top.left {
  left: 0;
}
.react-flow__resize-control.handle.bottom.left {
  left: 0;
}
.react-flow__resize-control.handle.top.right {
  left: 100%;
}
.react-flow__resize-control.handle.bottom.right {
  left: 100%;
}
/* line styles */
.react-flow__resize-control.line {
  border-color: var(--xy-resize-background-color, var(--xy-resize-background-color-default));
  border-width: 0;
  border-style: solid;
}
.react-flow__resize-control.line.left,
.react-flow__resize-control.line.right {
  width: 1px;
  transform: translate(-50%, 0);
  top: 0;
  height: 100%;
}
.react-flow__resize-control.line.left {
  left: 0;
  border-left-width: 1px;
}
.react-flow__resize-control.line.right {
  left: 100%;
  border-right-width: 1px;
}
.react-flow__resize-control.line.top,
.react-flow__resize-control.line.bottom {
  height: 1px;
  transform: translate(0, -50%);
  left: 0;
  width: 100%;
}
.react-flow__resize-control.line.top {
  top: 0;
  border-top-width: 1px;
}
.react-flow__resize-control.line.bottom {
  border-bottom-width: 1px;
  top: 100%;
}
.react-flow__edge-textbg {
  fill: var(--xy-edge-label-background-color, var(--xy-edge-label-background-color-default));
}
.react-flow__edge-text {
  fill: var(--xy-edge-label-color, var(--xy-edge-label-color-default));
}
