/* ===== BASE STYLES ===== */

/* ===== THEME VARIABLES ===== */
:root {
  /* Brand */
  --color-primary: #C8FE00;
  --color-primary-hover: #BFFF00;
  --color-primary-light: #D4FF33;
  --color-primary-dark: #A8E000;

  /* Text */
  --color-text: #FFFFFF;
  --color-text-secondary: #CCCCCC;
  --color-text-muted: #999999;
  --color-text-dim: #666666;
  --color-text-hint: rgba(255, 255, 255, 0.5);

  /* Backgrounds */
  --color-bg: #000000;
  --color-bg-elevated: #0D0D0D;
  --color-bg-surface: #0A0A0A;
  --color-bg-header: rgba(0, 0, 0, 0.95);

  /* Borders */
  --color-border: rgba(255, 255, 255, 0.1);
  --color-border-medium: rgba(255, 255, 255, 0.18);
  --color-border-accent: rgba(200, 254, 0, 0.5);
  --color-border-header: rgba(255, 255, 255, 0.05);

  /* Status */
  --color-success: #4CAF50;
  --color-warning: #FFC107;
  --color-error: #F44336;
  --color-info: #2196F3;
  --color-orange: #FF9800;
  --color-purple: #9C27B0;
  --color-pink: #E91E63;

  /* Telegram */
  --color-telegram: #0088cc;
  --color-telegram-light: #229ED9;

  /* Shadows */
  --shadow-card: 0 4px 20px rgba(0, 0, 0, 0.3);
  --shadow-primary: rgba(200, 254, 0, 0.3);
  --shadow-primary-light: rgba(200, 254, 0, 0.2);
  --shadow-primary-strong: rgba(200, 254, 0, 0.4);
  --shadow-telegram: 0 8px 32px rgba(34, 158, 217, 0.3);

  /* Card */
  --card-bg: linear-gradient(135deg, rgba(255, 255, 255, 0.08), rgba(255, 255, 255, 0.02));
  --card-border: rgba(255, 255, 255, 0.2);

  /* Gradients */
  --gradient-primary: linear-gradient(135deg, var(--color-primary), var(--color-primary-dark));

  /* Spacing */
  --spacing-xs: 4px;
  --spacing-sm: 8px;
  --spacing-md: 16px;
  --spacing-lg: 24px;
  --spacing-xl: 32px;
  --spacing-xxl: 40px;

  /* Border radius */
  --radius-xs: 8px;
  --radius-sm: 12px;
  --radius-md: 16px;
  --radius-lg: 24px;
  --radius-xl: 32px;

  /* Font sizes */
  --font-xs: 10px;
  --font-sm: 12px;
  --font-md: 14px;
  --font-lg: 16px;
  --font-xl: 18px;
  --font-xxl: 24px;
  --font-xxxl: 32px;

  /* Transitions */
  --transition: all 0.15s ease;
  --transition-fast: all 0.15s ease;
  --transition-normal: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  --transition-slow: all 0.4s ease-out;

  /* Extended spacing scale */
  --spacing-2xl: 24px;
  --spacing-3xl: 32px;
  --spacing-4xl: 40px;
  --spacing-5xl: 48px;

  /* Border-radius aliases (border-radius-* naming) */
  --border-radius-xs: 8px;
  --border-radius-sm: 12px;
  --border-radius-md: 12px;
  --border-radius-lg: 16px;
  --border-radius-xl: 20px;
  --border-radius-2xl: 24px;
  --border-radius-3xl: 32px;
  --border-radius: 24px;

  /* Telegram shadow variants */
  --shadow-telegram-light: rgba(34, 158, 217, 0.2);
  --shadow-telegram-strong: rgba(34, 158, 217, 0.4);

  /* Backward-compatible color aliases */
  --primary-green: var(--color-primary);
  --primary-green-hover: var(--color-primary-hover);
  --primary-green-light: var(--color-primary-light);
  --primary-green-dark: var(--color-primary-dark);
  --primary-color: var(--color-primary);
  --primary-dark: var(--color-primary-dark);
  --primary-light: var(--color-primary-light);
  --white: var(--color-text);
  --black: var(--color-bg);
  --gray-light: var(--color-text-secondary);
  --gray-medium: var(--color-text-muted);
  --gray-dark: var(--color-text-dim);
  --text-primary: var(--color-text);
  --text-secondary: var(--color-text-secondary);
  --text-muted: var(--color-text-muted);
  --text-white: var(--color-text);
  --text-gray: var(--color-text-secondary);
  --text-light-gray: var(--color-text-hint);
  --dark-bg: var(--color-bg-elevated);
  --darker-bg: var(--color-bg-surface);
  --bg-dark: var(--color-bg-elevated);
  --bg-darker: var(--color-bg-surface);
  --success: var(--color-success);
  --warning: var(--color-warning);
  --error: var(--color-error);
  --info: var(--color-info);
  --orange: var(--color-orange);
  --purple: var(--color-purple);
  --pink: var(--color-pink);
  --border-light: var(--color-border);
  --border-medium: var(--color-border-medium);
  --border-accent: var(--color-border-accent);
  --telegram-color: var(--color-telegram);
  --telegram-light: var(--color-telegram-light);
  --telegram-primary: var(--color-telegram);
  --telegram-secondary: var(--color-telegram-light);
  --success-color: var(--color-success);
  --error-color: var(--color-error);
  --info-color: var(--color-info);
  --warning-color: var(--color-orange);
  --success-subscription: var(--color-success);
}

/* [data-theme="light"] — будет добавлена позже */

body { 
  font-family: Inter, -apple-system, system-ui, Segoe UI, Roboto, Helvetica, Arial, sans-serif; 
  margin: 0; 
  padding: 0; 
  background: var(--color-bg);
  color: var(--color-text); 
  min-width: 320px;
  min-height: 100vh;
  overflow-x: auto;
  -webkit-text-size-adjust: 100%;
  -ms-text-size-adjust: 100%;
  text-size-adjust: 100%;
  -webkit-user-scalable: no;
  -moz-user-scalable: no;
  -ms-user-scalable: no;
  display: flex;
  flex-direction: column;
}

/* Минимальная ширина только для больших экранов */
@media (min-width: 1200px) {
  body { min-width: 1200px; }
}

/* Main container */
main.container {
  flex: 1;
}

.digital-bg { position: relative; min-height: 100vh; }
.minimal .bg-grid { 
  position: fixed; 
  inset: 0; 
  background-color: var(--color-bg);
  background-image: radial-gradient(rgba(255,255,255,0.03) 1px, transparent 0);
  background-size: 15px 15px;
  pointer-events: none;
  z-index: -10;
}

/* Отдельный слой для сетки */
.bg-grid::after {
  content: '';
  position: absolute;
  inset: 0;
  background-image: 
    /* глубокие фоны-блум */
    radial-gradient(900px 500px at 12% 12%, rgba(255,251,0,0.08), transparent 60%),
    radial-gradient(720px 420px at 82% 18%, rgba(232,255,27,0.12), transparent 60%),
    radial-gradient(600px 360px at 28% 70%, rgba(255,237,75,0.1), transparent 60%),
    /* яркие звезды первой величины */
    radial-gradient(3px 3px at 15% 25%, rgba(255,255,255,1) 0%, rgba(255,255,200,0.8) 30%, transparent 70%),
    radial-gradient(2.5px 2.5px at 85% 15%, rgba(255,255,255,1) 0%, rgba(255,255,180,0.9) 35%, transparent 65%),
    radial-gradient(2.8px 2.8px at 75% 85%, rgba(255,255,255,1) 0%, rgba(255,255,190,0.85) 32%, transparent 68%),
    radial-gradient(2.2px 2.2px at 45% 35%, rgba(255,255,255,1) 0%, rgba(255,255,200,0.9) 38%, transparent 62%),
    radial-gradient(2.6px 2.6px at 25% 75%, rgba(255,255,255,1) 0%, rgba(255,255,180,0.88) 34%, transparent 66%),
    /* звезды второй величины */
    radial-gradient(1.8px 1.8px at 8% 12%, rgba(255,255,240,0.95) 0%, rgba(255,255,180,0.7) 40%, transparent 70%),
    radial-gradient(1.6px 1.6px at 22% 8%, rgba(255,255,230,0.9) 0%, rgba(255,255,160,0.6) 45%, transparent 75%),
    radial-gradient(1.9px 1.9px at 38% 22%, rgba(255,255,250,0.92) 0%, rgba(255,255,190,0.75) 35%, transparent 65%),
    radial-gradient(1.7px 1.7px at 52% 18%, rgba(255,255,240,0.9) 0%, rgba(255,255,170,0.65) 42%, transparent 72%),
    radial-gradient(1.5px 1.5px at 68% 28%, rgba(255,255,220,0.88) 0%, rgba(255,255,150,0.6) 48%, transparent 78%),
    radial-gradient(1.8px 1.8px at 82% 22%, rgba(255,255,245,0.94) 0%, rgba(255,255,185,0.72) 37%, transparent 67%),
    radial-gradient(1.6px 1.6px at 95% 18%, rgba(255,255,230,0.9) 0%, rgba(255,255,165,0.68) 43%, transparent 73%),
    radial-gradient(1.9px 1.9px at 12% 45%, rgba(255,255,250,0.93) 0%, rgba(255,255,195,0.78) 36%, transparent 66%),
    radial-gradient(1.4px 1.4px at 28% 42%, rgba(255,255,220,0.85) 0%, rgba(255,255,140,0.55) 50%, transparent 80%),
    radial-gradient(1.7px 1.7px at 45% 48%, rgba(255,255,240,0.91) 0%, rgba(255,255,175,0.7) 39%, transparent 69%),
    radial-gradient(1.3px 1.3px at 62% 38%, rgba(255,255,210,0.82) 0%, rgba(255,255,130,0.5) 52%, transparent 82%),
    radial-gradient(1.8px 1.8px at 78% 45%, rgba(255,255,245,0.92) 0%, rgba(255,255,180,0.74) 38%, transparent 68%),
    radial-gradient(1.5px 1.5px at 92% 42%, rgba(255,255,225,0.87) 0%, rgba(255,255,155,0.62) 45%, transparent 75%),
    radial-gradient(1.6px 1.6px at 18% 65%, rgba(255,255,235,0.89) 0%, rgba(255,255,160,0.66) 44%, transparent 74%),
    radial-gradient(1.2px 1.2px at 35% 68%, rgba(255,255,200,0.8) 0%, rgba(255,255,120,0.45) 55%, transparent 85%),
    radial-gradient(1.7px 1.7px at 52% 72%, rgba(255,255,240,0.9) 0%, rgba(255,255,170,0.68) 41%, transparent 71%),
    radial-gradient(1.4px 1.4px at 68% 65%, rgba(255,255,215,0.84) 0%, rgba(255,255,145,0.58) 47%, transparent 77%),
    radial-gradient(1.8px 1.8px at 85% 68%, rgba(255,255,245,0.91) 0%, rgba(255,255,185,0.73) 37%, transparent 67%),
    radial-gradient(1.3px 1.3px at 95% 65%, rgba(255,255,205,0.81) 0%, rgba(255,255,135,0.52) 49%, transparent 79%),
    /* звезды третьей величины */
    radial-gradient(1.1px 1.1px at 5% 5%, rgba(255,255,200,0.8) 0%, rgba(255,255,120,0.4) 50%, transparent 80%),
    radial-gradient(0.9px 0.9px at 15% 35%, rgba(255,255,180,0.75) 0%, rgba(255,255,100,0.35) 55%, transparent 85%),
    radial-gradient(1.0px 1.0px at 25% 15%, rgba(255,255,190,0.78) 0%, rgba(255,255,110,0.38) 52%, transparent 82%),
    radial-gradient(0.8px 0.8px at 35% 55%, rgba(255,255,170,0.72) 0%, rgba(255,255,90,0.32) 58%, transparent 88%),
    radial-gradient(1.2px 1.2px at 48% 8%, rgba(255,255,210,0.82) 0%, rgba(255,255,130,0.42) 48%, transparent 78%),
    radial-gradient(0.7px 0.7px at 58% 35%, rgba(255,255,160,0.68) 0%, rgba(255,255,80,0.28) 60%, transparent 90%),
    radial-gradient(1.1px 1.1px at 72% 12%, rgba(255,255,200,0.79) 0%, rgba(255,255,120,0.39) 51%, transparent 81%),
    radial-gradient(0.9px 0.9px at 82% 35%, rgba(255,255,175,0.74) 0%, rgba(255,255,95,0.34) 56%, transparent 86%),
    radial-gradient(1.0px 1.0px at 92% 55%, rgba(255,255,185,0.76) 0%, rgba(255,255,105,0.36) 54%, transparent 84%),
    radial-gradient(0.8px 0.8px at 8% 75%, rgba(255,255,165,0.7) 0%, rgba(255,255,85,0.3) 58%, transparent 88%),
    radial-gradient(1.1px 1.1px at 18% 85%, rgba(255,255,195,0.77) 0%, rgba(255,255,115,0.37) 53%, transparent 83%),
    radial-gradient(0.9px 0.9px at 28% 95%, rgba(255,255,180,0.73) 0%, rgba(255,255,100,0.33) 57%, transparent 87%),
    radial-gradient(1.0px 1.0px at 38% 75%, rgba(255,255,190,0.75) 0%, rgba(255,255,110,0.35) 55%, transparent 85%),
    radial-gradient(0.7px 0.7px at 48% 85%, rgba(255,255,160,0.66) 0%, rgba(255,255,80,0.26) 62%, transparent 92%),
    radial-gradient(1.2px 1.2px at 58% 75%, rgba(255,255,205,0.8) 0%, rgba(255,255,125,0.4) 50%, transparent 80%),
    radial-gradient(0.8px 0.8px at 68% 85%, rgba(255,255,170,0.71) 0%, rgba(255,255,90,0.31) 59%, transparent 89%),
    radial-gradient(1.0px 1.0px at 78% 75%, rgba(255,255,185,0.74) 0%, rgba(255,255,105,0.34) 56%, transparent 86%),
    radial-gradient(0.9px 0.9px at 88% 85%, rgba(255,255,175,0.72) 0%, rgba(255,255,95,0.32) 58%, transparent 88%),
    radial-gradient(1.1px 1.1px at 95% 75%, rgba(255,255,195,0.76) 0%, rgba(255,255,115,0.36) 54%, transparent 84%),
    /* тусклые звезды четвертой величины */
    radial-gradient(0.6px 0.6px at 3% 18%, rgba(255,255,150,0.6) 0%, rgba(255,255,70,0.2) 60%, transparent 90%),
    radial-gradient(0.5px 0.5px at 7% 28%, rgba(255,255,140,0.55) 0%, rgba(255,255,60,0.15) 65%, transparent 95%),
    radial-gradient(0.7px 0.7px at 12% 38%, rgba(255,255,160,0.65) 0%, rgba(255,255,80,0.25) 55%, transparent 85%),
    radial-gradient(0.4px 0.4px at 17% 48%, rgba(255,255,130,0.5) 0%, rgba(255,255,50,0.1) 70%, transparent 100%),
    radial-gradient(0.6px 0.6px at 23% 58%, rgba(255,255,145,0.58) 0%, rgba(255,255,65,0.18) 62%, transparent 92%),
    radial-gradient(0.5px 0.5px at 28% 68%, rgba(255,255,135,0.52) 0%, rgba(255,255,55,0.12) 68%, transparent 98%),
    radial-gradient(0.7px 0.7px at 33% 78%, rgba(255,255,155,0.62) 0%, rgba(255,255,75,0.22) 58%, transparent 88%),
    radial-gradient(0.4px 0.4px at 38% 88%, rgba(255,255,125,0.48) 0%, rgba(255,255,45,0.08) 72%, transparent 100%),
    radial-gradient(0.6px 0.6px at 43% 98%, rgba(255,255,150,0.6) 0%, rgba(255,255,70,0.2) 60%, transparent 90%),
    radial-gradient(0.5px 0.5px at 48% 8%, rgba(255,255,140,0.55) 0%, rgba(255,255,60,0.15) 65%, transparent 95%),
    radial-gradient(0.7px 0.7px at 53% 18%, rgba(255,255,160,0.65) 0%, rgba(255,255,80,0.25) 55%, transparent 85%),
    radial-gradient(0.4px 0.4px at 58% 28%, rgba(255,255,130,0.5) 0%, rgba(255,255,50,0.1) 70%, transparent 100%),
    radial-gradient(0.6px 0.6px at 63% 38%, rgba(255,255,145,0.58) 0%, rgba(255,255,65,0.18) 62%, transparent 92%),
    radial-gradient(0.5px 0.5px at 68% 48%, rgba(255,255,135,0.52) 0%, rgba(255,255,55,0.12) 68%, transparent 98%),
    radial-gradient(0.7px 0.7px at 73% 58%, rgba(255,255,155,0.62) 0%, rgba(255,255,75,0.22) 58%, transparent 88%),
    radial-gradient(0.4px 0.4px at 78% 68%, rgba(255,255,125,0.48) 0%, rgba(255,255,45,0.08) 72%, transparent 100%),
    radial-gradient(0.6px 0.6px at 83% 78%, rgba(255,255,150,0.6) 0%, rgba(255,255,70,0.2) 60%, transparent 90%),
    radial-gradient(0.5px 0.5px at 88% 88%, rgba(255,255,140,0.55) 0%, rgba(255,255,60,0.15) 65%, transparent 95%),
    radial-gradient(0.7px 0.7px at 93% 98%, rgba(255,255,160,0.65) 0%, rgba(255,255,80,0.25) 55%, transparent 85%),
    /* очень тусклые звезды пятой величины */
    radial-gradient(0.3px 0.3px at 2% 8%, rgba(255,255,120,0.4) 0%, rgba(255,255,40,0.05) 80%, transparent 100%),
    radial-gradient(0.2px 0.2px at 6% 18%, rgba(255,255,110,0.35) 0%, rgba(255,255,30,0.02) 85%, transparent 100%),
    radial-gradient(0.3px 0.3px at 10% 28%, rgba(255,255,125,0.38) 0%, rgba(255,255,45,0.08) 75%, transparent 100%),
    radial-gradient(0.2px 0.2px at 14% 38%, rgba(255,255,115,0.33) 0%, rgba(255,255,35,0.03) 82%, transparent 100%),
    radial-gradient(0.3px 0.3px at 18% 48%, rgba(255,255,130,0.36) 0%, rgba(255,255,50,0.06) 78%, transparent 100%),
    radial-gradient(0.2px 0.2px at 22% 58%, rgba(255,255,120,0.31) 0%, rgba(255,255,40,0.01) 84%, transparent 100%),
    radial-gradient(0.3px 0.3px at 26% 68%, rgba(255,255,135,0.34) 0%, rgba(255,255,55,0.04) 76%, transparent 100%),
    radial-gradient(0.2px 0.2px at 30% 78%, rgba(255,255,125,0.29) 0%, rgba(255,255,45,0.02) 86%, transparent 100%),
    radial-gradient(0.3px 0.3px at 34% 88%, rgba(255,255,140,0.32) 0%, rgba(255,255,60,0.05) 74%, transparent 100%),
    radial-gradient(0.2px 0.2px at 38% 98%, rgba(255,255,130,0.27) 0%, rgba(255,255,50,0.01) 88%, transparent 100%),
    radial-gradient(0.3px 0.3px at 42% 8%, rgba(255,255,145,0.3) 0%, rgba(255,255,65,0.03) 80%, transparent 100%),
    radial-gradient(0.2px 0.2px at 46% 18%, rgba(255,255,135,0.25) 0%, rgba(255,255,55,0.01) 90%, transparent 100%),
    radial-gradient(0.3px 0.3px at 50% 28%, rgba(255,255,150,0.28) 0%, rgba(255,255,70,0.02) 82%, transparent 100%),
    radial-gradient(0.2px 0.2px at 54% 38%, rgba(255,255,140,0.23) 0%, rgba(255,255,60,0.01) 92%, transparent 100%),
    radial-gradient(0.3px 0.3px at 58% 48%, rgba(255,255,155,0.26) 0%, rgba(255,255,75,0.02) 84%, transparent 100%),
    radial-gradient(0.2px 0.2px at 62% 58%, rgba(255,255,145,0.21) 0%, rgba(255,255,65,0.01) 94%, transparent 100%),
    radial-gradient(0.3px 0.3px at 66% 68%, rgba(255,255,160,0.24) 0%, rgba(255,255,80,0.02) 86%, transparent 100%),
    radial-gradient(0.2px 0.2px at 70% 78%, rgba(255,255,150,0.19) 0%, rgba(255,255,70,0.01) 96%, transparent 100%),
    radial-gradient(0.3px 0.3px at 74% 88%, rgba(255,255,165,0.22) 0%, rgba(255,255,85,0.02) 88%, transparent 100%),
    radial-gradient(0.2px 0.2px at 78% 98%, rgba(255,255,155,0.17) 0%, rgba(255,255,75,0.01) 98%, transparent 100%),
    radial-gradient(0.3px 0.3px at 82% 8%, rgba(255,255,170,0.2) 0%, rgba(255,255,90,0.02) 90%, transparent 100%),
    radial-gradient(0.2px 0.2px at 86% 18%, rgba(255,255,160,0.15) 0%, rgba(255,255,80,0.01) 100%, transparent 100%),
    radial-gradient(0.3px 0.3px at 90% 28%, rgba(255,255,175,0.18) 0%, rgba(255,255,95,0.02) 92%, transparent 100%),
    radial-gradient(0.2px 0.2px at 94% 38%, rgba(255,255,165,0.13) 0%, rgba(255,255,85,0.01) 100%, transparent 100%),
    radial-gradient(0.3px 0.3px at 98% 48%, rgba(255,255,180,0.16) 0%, rgba(255,255,100,0.02) 94%, transparent 100%);
  pointer-events: none;
  z-index: -10;
}

.container { 
  width: 1200px; 
  margin: 0 auto; 
  padding: 32px 20px; 
  position: relative; 
  min-width: 1200px;
  flex: 1;
  z-index: 10;
}

/* Navigation */
.site-header { 
  position: sticky; 
  top: 0; 
  z-index: 19999; 
  background: var(--color-bg-header);
  backdrop-filter: blur(20px);
  border-bottom: 1px solid var(--color-border-header);
}

.nav { 
  display: flex; 
  align-items: center; 
  justify-content: space-between; 
  gap: 24px; 
  padding: 10px 24px; 
  min-height: 64px;
  width: 100%;
  min-width: 1200px;
  max-width: 1400px;
  margin: 0 auto;
}

.nav-links { 
  display: flex; 
  align-items: center; 
  gap: 12px; 
  flex-wrap: nowrap; 
}

/* Скрываем логотип на мобильных везде кроме app_landing */
@media screen and (max-width: 1199px) {
  .site-header .nav .brand {
    display: none;
    visibility: hidden;
    opacity: 0;
    overflow: hidden;
  }
}

.nav-center { 
  position: absolute; 
  left: 50%; 
  transform: translateX(-50%); 
  display: flex; 
  gap: 0; 
}

.nav-link {
  color: #fff;
  text-decoration: none;
  font-weight: 500;
  font-size: 15px;
  padding: 8px 0;
  margin-right: 10px;
  transition: all 0.3s cubic-bezier(0.4,0,0.2,1);
  position: relative;
}

.nav-link::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  width: 0;
  height: 2px;
  background: linear-gradient(90deg,#C8FE00,#BFFF00);
  transition: width 0.3s cubic-bezier(0.4,0,0.2,1);
}

.nav-link:hover {
  color: #C8FE00;
}

.nav-link:hover::after {
  width: 100%;
}

.nav-link-primary {
  color: #C8FE00;
  font-weight: 600;
}

.nav-link-primary:hover {
  color: #BFFF00;
}

.nav-form {
  display: inline;
  margin: 0;
}

.nav-button {
  background: none;
  border: none;
  color: #fff;
  font-weight: 500;
  font-size: 15px;
  padding: 8px 0;
  cursor: pointer;
  transition: all 0.3s cubic-bezier(0.4,0,0.2,1);
  position: relative;
}

.nav-button::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  width: 0;
  height: 2px;
  background: linear-gradient(90deg,#ff6b6b,#ff5252);
  transition: width 0.3s cubic-bezier(0.4,0,0.2,1);
}

.nav-button:hover {
  color: #ff6b6b;
}

.nav-button:hover::after {
  width: 100%;
}

/* Cabinet Menu - Modern Design */
.cabinet { 
  position: relative; 
  margin-right: 0; 
  z-index: 20000; /* Высший приоритет для навигации */
}

.cabinet-toggle { 
  background: none;
  border: none;
  color: #fff; 
  padding: 8px 0; 
  cursor: pointer; 
  white-space: nowrap; 
  text-overflow: ellipsis; 
  overflow: hidden; 
  text-align: right; 
  transition: all 0.3s cubic-bezier(0.4,0,0.2,1); 
  display: inline-flex; 
  align-items: center; 
  justify-content: flex-end; 
  gap: 8px; 
  font-weight: 500;
  font-size: 15px;
  position: relative;
}

.cabinet-toggle::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  width: 0;
  height: 2px;
  background: linear-gradient(90deg,#C8FE00,#BFFF00);
  transition: width 0.3s cubic-bezier(0.4,0,0.2,1);
}

.cabinet-toggle:hover {
  color: #C8FE00;
}

.cabinet-toggle:hover::after {
  width: 100%;
}

.cabinet-toggle .cabinet-label { 
  font-weight: 500; 
  color: #FFFFFF; 
  margin-right: 0; 
}

.cabinet-toggle .cabinet-arrow {
  color: #C8FE00;
  font-size: 12px;
  transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

.cabinet.open .cabinet-arrow {
  transform: rotate(180deg);
}

.cabinet.open .cabinet-toggle {
  color: #C8FE00;
}

.cabinet-menu { 
  position: absolute; 
  top: calc(100% + 12px); 
  left: 50%;
  transform: translateX(-50%);
  min-width: 360px; 
  max-height: 450px; 
  overflow: hidden; 
  background: linear-gradient(135deg,rgba(0,0,0,1),rgba(8,8,8,1));
  backdrop-filter: blur(25px);
  border: 1px solid rgba(200,254,0,0.15);
  border-radius: 16px;
  box-shadow: 0 25px 80px rgba(0,0,0,0.7),0 0 40px rgba(200,254,0,0.1),inset 0 1px 0 rgba(255,255,255,0.1);
  display: none; 
  padding: 20px; 
  z-index: 20001;
  animation: cabinetMenuSlide 0.4s cubic-bezier(0.4,0,0.2,1);
}

.cabinet.open .cabinet-menu { 
  display: block; 
}

@keyframes cabinetMenuSlide {
  from { opacity: 0; transform: translateX(-50%) translateY(-15px) scale(0.95); }
  to { opacity: 1; transform: translateX(-50%) translateY(0) scale(1); }
}

.cabinet-menu::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 1px;
  background: linear-gradient(90deg,transparent,rgba(200,254,0,0.5),transparent);
}

.cabinet-list { 
  max-height: 350px; 
  overflow-y: auto; 
  padding: 8px 0; 
  display: flex; 
  flex-direction: column; 
  gap: 4px; 
}

.cabinet-list::-webkit-scrollbar { 
  width: 8px; 
}

.cabinet-list::-webkit-scrollbar-thumb { 
  background: linear-gradient(135deg,rgba(200,254,0,0.4),rgba(200,254,0,0.2)); 
  border-radius: 4px; 
  border: 1px solid rgba(200,254,0,0.1);
}

.cabinet-list::-webkit-scrollbar-thumb:hover {
  background: linear-gradient(135deg,rgba(200,254,0,0.6),rgba(200,254,0,0.4));
}

.cabinet-list::-webkit-scrollbar-track {
  background: rgba(255, 255, 255, 0.05);
  border-radius: 4px;
}

.cabinet-list a { 
  color: #fff; 
  text-decoration: none; 
  padding: 14px 16px; 
  display: flex; 
  align-items: center; 
  gap: 12px; 
  transition: all 0.3s cubic-bezier(0.4,0,0.2,1);
  position: relative;
  border-radius: 8px;
  background: rgba(255,255,255,0.02);
  border: 1px solid rgba(255,255,255,0.05);
  font-weight: 500;
  font-size: 13px;
  margin: 0;
  overflow: hidden;
}

.cabinet-list a::before { 
  content: ""; 
  width: 6px; 
  height: 6px; 
  border-radius: 50%; 
  background: linear-gradient(135deg,#C8FE00,#BFFF00);
  box-shadow: 0 0 8px rgba(200,254,0,0.4);
  flex-shrink: 0;
  transition: all 0.3s ease;
}

.cabinet-list a::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg,rgba(200,254,0,0.08),rgba(200,254,0,0.03));
  opacity: 0;
  transition: opacity 0.3s ease;
  border-radius: 8px;
}

.cabinet-list a:hover { 
  background: rgba(200,254,0,0.08); 
  color: #C8FE00; 
  border-color: rgba(200,254,0,0.2);
  transform: none;
  box-shadow: 0 2px 8px rgba(200,254,0,0.1);
}

.cabinet-list a:hover::before {
  box-shadow: 0 0 12px rgba(200,254,0,0.6);
  transform: scale(1.05);
}

.cabinet-list a:hover::after {
  opacity: 1;
}

.cabinet-list a[aria-current="true"] { 
  background: linear-gradient(135deg,rgba(200,254,0,0.12),rgba(200,254,0,0.06)); 
  color: #C8FE00; 
  font-weight: 600;
  border-color: rgba(200,254,0,0.25);
  box-shadow: 0 2px 8px rgba(200,254,0,0.15);
}

.cabinet-list a[aria-current="true"]::before {
  box-shadow: 0 0 12px rgba(200,254,0,0.7);
  transform: scale(1.1);
}

.no-cabinets { 
  color: #CCCCCC; 
  padding: 20px; 
  text-align: center; 
  font-style: italic; 
  font-size: 14px;
  background: rgba(255, 255, 255, 0.02);
  border-radius: 12px;
  border: 1px solid rgba(255, 255, 255, 0.05);
}

.cabinet-add { 
  display: block; 
  margin-top: 16px; 
  padding: 16px 16px; 
  border-top: 1px solid rgba(200,254,0,0.15); 
  color: #C8FE00; 
  text-decoration: none; 
  text-align: center; 
  background: linear-gradient(135deg,rgba(200,254,0,0.06),rgba(200,254,0,0.02));
  transition: all 0.3s cubic-bezier(0.4,0,0.2,1);
  font-weight: 500;
  position: relative;
  border-radius: 8px;
  border: 1px solid rgba(200,254,0,0.08);
  font-size: 13px;
}

.cabinet-add::before {
  content: '+';
  margin-right: 6px;
  font-weight: 600;
  font-size: 14px;
}

.cabinet-add::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 0;
  height: 2px;
  background: linear-gradient(90deg, #C8FE00, #BFFF00);
  transition: width 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

.cabinet-add:hover { 
  background: linear-gradient(135deg, rgba(200, 254, 0, 0.1), rgba(200, 254, 0, 0.05)); 
  color: #BFFF00;
  border-color: rgba(200, 254, 0, 0.2);
  transform: none;
  box-shadow: 0 2px 8px rgba(200, 254, 0, 0.1);
}

.cabinet-add:hover::after {
  width: 70%;
}

/* User Menu - Ultra Modern Design */
.user-menu { 
  position: relative; 
  margin-left: 0; 
  z-index: 20000; /* Высший приоритет для навигации */
}

.user-menu-toggle { 
  background: none;
  border: none;
  color: #FFFFFF; 
  padding: 0; 
  cursor: pointer; 
  transition: all 0.2s cubic-bezier(0.25, 0.46, 0.45, 0.94);
  position: relative;
  border-radius: 12px;
  overflow: hidden;
}

.menu-toggle-content {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px 16px;
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 12px;
  transition: all 0.2s cubic-bezier(0.25, 0.46, 0.45, 0.94);
  backdrop-filter: blur(10px);
}

.user-menu-toggle:hover .menu-toggle-content {
  background: rgba(200, 254, 0, 0.08);
  border-color: rgba(200, 254, 0, 0.2);
  box-shadow: 0 8px 25px rgba(200, 254, 0, 0.15);
}

.menu-toggle-text {
  font-weight: 600;
  font-size: 15px;
  color: #FFFFFF;
  transition: color 0.3s ease;
}

.user-menu-toggle:hover .menu-toggle-text {
  color: #C8FE00;
}

.menu-toggle-icon {
  display: flex;
  flex-direction: column;
  gap: 4px;
  transition: all 0.2s cubic-bezier(0.25, 0.46, 0.45, 0.94);
  position: relative;
}

.hamburger-line {
  width: 20px;
  height: 2px;
  background: linear-gradient(90deg, #C8FE00, #BFFF00);
  border-radius: 2px;
  transition: all 0.2s cubic-bezier(0.25, 0.46, 0.45, 0.94);
  transform-origin: center;
  position: relative;
}

/* Анимация превращения в крестик */
.user-menu.open .hamburger-line:nth-child(1) {
  transform: rotate(45deg) translate(2px, 2px);
}

.user-menu.open .hamburger-line:nth-child(2) {
  opacity: 0;
  transform: scaleX(0);
}

.user-menu.open .hamburger-line:nth-child(3) {
  transform: rotate(-45deg) translate(2px, -2px);
}

/* Дополнительная настройка для точного пересечения */
.user-menu.open .menu-toggle-icon {
  gap: 0;
}

/* Эффект пульсации при наведении */
.user-menu-toggle:hover .hamburger-line {
  box-shadow: 0 0 8px rgba(200, 254, 0, 0.4);
}

.user-menu.open .hamburger-line {
  box-shadow: 0 0 12px rgba(200, 254, 0, 0.4);
}

.user-menu-dropdown { 
  position: absolute; 
  top: calc(100% + 16px); 
  right: 0;
  width: 360px;
  background: rgba(0, 0, 0, 1);
  backdrop-filter: blur(30px);
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: 20px;
  box-shadow: 
    0 32px 64px rgba(0, 0, 0, 0.4),
    0 0 0 1px rgba(255, 255, 255, 0.05),
    inset 0 1px 0 rgba(255, 255, 255, 0.1);
  display: none; 
  overflow: hidden;
  z-index: 20001;
  animation: menuSlideIn 0.15s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

.user-menu.open .user-menu-dropdown { 
  display: block; 
}

@keyframes menuSlideIn {
  from {
    opacity: 0;
    transform: translateY(-20px) scale(0.95);
  }
  to {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

.menu-header {
  padding: 24px 24px 16px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
  background: linear-gradient(135deg, rgba(200, 254, 0, 0.05), transparent);
}

.menu-title {
  font-size: 18px;
  font-weight: 700;
  color: #FFFFFF;
  margin: 0 0 4px 0;
  letter-spacing: -0.02em;
}

.menu-subtitle {
  font-size: 13px;
  color: rgba(255, 255, 255, 0.6);
  font-weight: 500;
}

.menu-items {
  padding: 16px 0;
}

.menu-item { 
  display: flex;
  align-items: center;
  gap: 16px;
  padding: 16px 24px;
  text-decoration: none;
  color: #FFFFFF;
  transition: all 0.3s cubic-bezier(0.25, 0.46, 0.45, 0.94);
  position: relative;
  border-radius: 0;
  margin: 0;
}

.menu-item::before {
  content: '';
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  width: 0;
  background: linear-gradient(135deg, rgba(200, 254, 0, 0.15), rgba(200, 254, 0, 0.05));
  transition: width 0.3s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

.menu-item:hover {
  background: rgba(200, 254, 0, 0.05);
  color: #C8FE00;
  transform: translateX(4px);
}

.menu-item:hover::before {
  width: 4px;
}

.menu-item-icon {
  width: 40px;
  height: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(200, 254, 0, 0.1);
  border-radius: 12px;
  color: #C8FE00;
  transition: all 0.3s cubic-bezier(0.25, 0.46, 0.45, 0.94);
  flex-shrink: 0;
}

.menu-item:hover .menu-item-icon {
  background: rgba(200, 254, 0, 0.2);
  transform: scale(1.05);
}

.menu-item-content {
  flex: 1;
}

.menu-item-title {
  font-size: 15px;
  font-weight: 600;
  color: inherit;
  margin: 0 0 2px 0;
  letter-spacing: -0.01em;
}

.menu-item-desc {
  font-size: 12px;
  color: rgba(255, 255, 255, 0.6);
  font-weight: 500;
  margin: 0;
}

.menu-footer {
  padding: 16px 24px 24px;
  border-top: 1px solid rgba(255, 255, 255, 0.08);
  background: rgba(0, 0, 0, 0.2);
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.logout-form {
  margin: 0;
  padding: 0;
  background: none;
  border: none;
}

.logout-button {
  display: flex;
  align-items: center;
  gap: 12px;
  width: 100%;
  padding: 14px 16px;
  background: rgba(255, 107, 107, 0.1);
  border: 1px solid rgba(255, 107, 107, 0.2);
  border-radius: 12px;
  color: #ff6b6b;
  font-weight: 600;
  font-size: 14px;
  cursor: pointer;
  transition: all 0.3s cubic-bezier(0.25, 0.46, 0.45, 0.94);
  position: relative;
  overflow: hidden;
}

.logout-button::before {
  content: '';
  position: absolute;
  top: 0;
  left: -100%;
  width: 100%;
  height: 100%;
  background: linear-gradient(90deg, transparent, rgba(255, 107, 107, 0.1), transparent);
  transition: left 0.5s ease;
}

.logout-button:hover {
  background: rgba(255, 107, 107, 0.15);
  border-color: rgba(255, 107, 107, 0.3);
  box-shadow: 0 8px 25px rgba(255, 107, 107, 0.2);
}

.logout-button:hover::before {
  left: 100%;
}

.logout-icon {
  width: 32px;
  height: 32px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(255, 107, 107, 0.2);
  border-radius: 8px;
  color: #ff6b6b;
  transition: all 0.3s ease;
  flex-shrink: 0;
}

.logout-button:hover .logout-icon {
  background: rgba(255, 107, 107, 0.3);
  transform: scale(1.05);
}

.logout-text {
  font-weight: 600;
  letter-spacing: -0.01em;
}

.add-cabinet-button {
  display: flex;
  align-items: center;
  gap: 12px;
  width: 100%;
  padding: 14px 16px;
  background: rgba(200, 254, 0, 0.1);
  border: 1px solid rgba(200, 254, 0, 0.2);
  border-radius: 12px;
  color: #C8FE00;
  font-weight: 600;
  font-size: 14px;
  text-decoration: none;
  cursor: pointer;
  transition: all 0.3s cubic-bezier(0.25, 0.46, 0.45, 0.94);
  position: relative;
  overflow: hidden;
}

.add-cabinet-button::before {
  content: '';
  position: absolute;
  top: 0;
  left: -100%;
  width: 100%;
  height: 100%;
  background: linear-gradient(90deg, transparent, rgba(200, 254, 0, 0.1), transparent);
  transition: left 0.5s ease;
}

.add-cabinet-button:hover {
  background: rgba(200, 254, 0, 0.15);
  border-color: rgba(200, 254, 0, 0.3);
  box-shadow: 0 8px 25px rgba(200, 254, 0, 0.2);
  color: #BFFF00;
}

.add-cabinet-button:hover::before {
  left: 100%;
}

.add-cabinet-icon {
  width: 32px;
  height: 32px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(200, 254, 0, 0.2);
  border-radius: 8px;
  color: #C8FE00;
  transition: all 0.3s ease;
  flex-shrink: 0;
}

.add-cabinet-button:hover .add-cabinet-icon {
  background: rgba(200, 254, 0, 0.3);
  transform: scale(1.05);
}

.add-cabinet-text {
  font-weight: 600;
  letter-spacing: -0.01em;
}

/* Brand and Logo */
.brand { 
  display: inline-flex; 
  align-items: center; 
  gap: 12px; 
}

.logo { 
  height: 32px; 
  width: auto;
  display: block; 
}

/* Common Components */
.card { background: #0D0D0D; border: 1px solid rgba(255,255,255,0.1); border-radius: 14px; padding: 22px; }
.panel { background: #0E0E0E; border: 1px solid rgba(255,255,255,0.1); border-radius: 12px; padding: 16px; }

/* Typography */
h1, h2, h3 { margin: 0 0 12px; }
p { margin: 0 0 12px; line-height: 1.7; }

/* Buttons */
.btn { 
  display: inline-block; 
  background: linear-gradient(135deg,#fff,#C8FE00); 
  color: #000; 
  padding: 12px 24px; 
  border-radius: 0; 
  text-decoration: none; 
  font-weight: 600; 
  margin-right: 0; 
  border: none; 
  cursor: pointer; 
  transition: all 0.3s cubic-bezier(0.4,0,0.2,1);
  position: relative;
  overflow: hidden;
}

.btn::before {
  content: '';
  position: absolute;
  top: 0;
  left: -100%;
  width: 100%;
  height: 100%;
  background: linear-gradient(90deg,transparent,rgba(255,255,255,0.2),transparent);
  transition: left 0.5s ease;
}

.btn:hover::before {
  left: 100%;
}

.btn:hover { 
  filter: brightness(1.1); 
  box-shadow: 0 8px 25px rgba(200,254,0,0.3);
}

.btn-outline { 
  background: none; 
  color: #fff; 
  border: none; 
  position: relative;
}

.btn-outline::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  width: 0;
  height: 2px;
  background: linear-gradient(90deg,#C8FE00,#BFFF00);
  transition: width 0.3s cubic-bezier(0.4,0,0.2,1);
}

.btn-outline:hover { color: #C8FE00; }
.btn-outline:hover::after { width: 100%; }




/* Responsive Design */
* {
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
}

html {
  -webkit-text-size-adjust: 100%;
  -ms-text-size-adjust: 100%;
  text-size-adjust: 100%;
}

/* Mobile-first responsive design */
@media screen and (max-width: 1199px) {
  body { min-width: 320px; overflow-x: auto; }
  .container { width: 100%; min-width: 320px; max-width: 100%; padding: 16px; }
  .nav { min-width: 320px; padding: 12px 16px; min-height: 60px; flex-wrap: wrap; }
  .nav-links { gap: 10px; flex-wrap: wrap; }
  .nav-center { position: static; transform: none; order: 3; width: 100%; justify-content: center; margin-top: 12px; }
  .cabinet-menu { min-width: 280px; left: 0; transform: none; }
  .user-menu-dropdown { width: 280px; right: 0; }
}

/* Tablet styles */
@media screen and (max-width: 1199px) {
  .container { padding: 12px; }
  .nav { padding: 8px 12px; min-height: 60px; flex-direction: row; gap: 12px; }
  .nav-links { gap: 10px; justify-content: center; flex-wrap: nowrap; margin: 0 auto; }
  .nav-center { order: 1; position: static; transform: none; margin: 0; }
  .user-menu { order: 2; }
  .nav-link { font-size: 14px; padding: 6px 8px; }
  .nav-link-primary { padding: 6px 12px; font-size: 14px; }
  .cabinet-toggle, .user-menu-toggle { font-size: 14px; }
  .cabinet-menu, .user-menu-dropdown { width: 100%; max-width: 300px; right: 0; left: auto; transform: none; position: fixed; z-index: 1000; }
  .user-menu-dropdown { max-width: calc(100vw - 20px); right: 10px; }
  .cabinet-menu { max-width: calc(100vw - 20px); right: 10px; }
  .cabinet-list a { padding: 12px 16px; font-size: 14px; }
  .menu-item { padding: 12px 16px; }
  .menu-item-title { font-size: 14px; }
  .menu-item-desc { font-size: 12px; }
}

/* Small mobile styles */
@media screen and (max-width: 480px) {
  .container { padding: 8px; }
  .nav { padding: 6px 8px; min-height: 60px; flex-direction: row; }
  .nav-links { gap: 10px; justify-content: center; flex-wrap: nowrap; margin: 0 auto; }
  .nav-center { order: 1; position: static; transform: none; }
  .user-menu { order: 2; }
  .nav-link { font-size: 13px; padding: 4px 6px; }
  .nav-link-primary { padding: 4px 8px; font-size: 13px; }
  .cabinet-toggle, .user-menu-toggle { font-size: 13px; }
  .menu-toggle-content { padding: 8px 12px; }
  .menu-toggle-text { font-size: 13px; }
  .hamburger-line { width: 16px; height: 2px; }
  .cabinet-menu, .user-menu-dropdown { width: calc(100vw - 16px); max-width: 280px; right: 8px; left: auto; transform: none; position: fixed; z-index: 1000; }
  .cabinet-list a { padding: 10px 12px; font-size: 13px; }
  .menu-item { padding: 10px 12px; }
  .menu-item-icon { width: 32px; height: 32px; }
  .menu-item-title { font-size: 13px; }
  .menu-item-desc { font-size: 11px; }
  .logout-button, .add-cabinet-button { padding: 10px 12px; font-size: 13px; }
  .logout-icon, .add-cabinet-icon { width: 24px; height: 24px; }
}

/* Touch-friendly improvements */
@media (hover: none) and (pointer: coarse) {
  .nav-link, .nav-button, .cabinet-toggle, .user-menu-toggle { min-height: 44px; min-width: 44px; display: flex; align-items: center; justify-content: center; }
  .cabinet-list a, .menu-item { min-height: 44px; }
  .btn, .btn-outline { min-height: 44px; padding: 12px 20px; }
}

/* КРИТИЧЕСКИ ВАЖНО: Скрываем логотип на мобильных везде кроме app_landing */
@media screen and (max-width: 1199px) {
  .brand { display: none !important; visibility: hidden !important; opacity: 0 !important; width: 0 !important; height: 0 !important; overflow: hidden !important; position: absolute !important; left: -9999px !important; }
  body.landing-page .brand { display: block !important; visibility: visible !important; opacity: 1 !important; width: auto !important; height: auto !important; overflow: visible !important; position: static !important; left: auto !important; }
}

/* ===== BALANCE WARNING STYLES ===== */
.balance-warning {
  position: sticky;
  top: 0;
  z-index: 10000; /* Выше контента, но ниже навигации */
  background: linear-gradient(135deg, #ffa726, #ff9800);
  border-bottom: 1px solid rgba(255, 255, 255, 0.1);
  box-shadow: 0 4px 20px rgba(255, 167, 38, 0.3);
  animation: slideDown 0.4s ease-out;
}

.balance-warning-content {
  display: flex;
  align-items: center;
  padding: 16px 20px;
  max-width: 1200px;
  margin: 0 auto;
  gap: 16px;
}

.balance-warning-icon {
  flex-shrink: 0;
  width: 32px;
  height: 32px;
  background: rgba(255, 255, 255, 0.2);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: white;
}

.balance-warning-text {
  flex: 1;
  min-width: 0;
}

.balance-warning-title {
  font-weight: 700;
  font-size: 16px;
  color: #2c2c2c;
  margin-bottom: 4px;
  text-shadow: 0 1px 2px rgba(255, 255, 255, 0.3);
}

.balance-warning-message {
  font-size: 14px;
  color: #2c2c2c;
  line-height: 1.4;
  text-shadow: 0 1px 2px rgba(255, 255, 255, 0.2);
}

.balance-warning-actions {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-shrink: 0;
}

.balance-warning-button {
  background: rgba(255, 255, 255, 0.25);
  color: #2c2c2c;
  padding: 10px 20px;
  border-radius: 8px;
  text-decoration: none;
  font-weight: 600;
  font-size: 14px;
  border: 1px solid rgba(255, 255, 255, 0.4);
  transition: all 0.2s ease;
  backdrop-filter: blur(10px);
  text-shadow: none;
}

.balance-warning-button:hover {
  background: rgba(255, 255, 255, 0.4);
  border-color: rgba(255, 255, 255, 0.6);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.2);
  color: #2c2c2c;
  text-decoration: none;
}

.balance-warning-close {
  background: none;
  border: none;
  color: rgba(44, 44, 44, 0.8);
  cursor: pointer;
  padding: 8px;
  border-radius: 50%;
  transition: all 0.2s ease;
  display: flex;
  align-items: center;
  justify-content: center;
}

.balance-warning-close:hover {
  background: rgba(255, 255, 255, 0.3);
  color: #2c2c2c;
  transform: scale(1.1);
}

/* Анимации */
@keyframes slideDown {
  from {
    transform: translateY(-100%);
    opacity: 0;
  }
  to {
    transform: translateY(0);
    opacity: 1;
  }
}

@keyframes fadeOutUp {
  from {
    transform: translateY(0);
    opacity: 1;
  }
  to {
    transform: translateY(-100%);
    opacity: 0;
  }
}

/* Адаптивность для мобильных устройств */
@media screen and (max-width: 768px) {
  .balance-warning-content {
    padding: 8px 12px;
    gap: 8px;
  }
  
  .balance-warning-icon {
    width: 24px;
    height: 24px;
  }
  
  .balance-warning-title {
    font-size: 14px;
    margin-bottom: 2px;
  }
  
  .balance-warning-message {
    font-size: 12px;
    line-height: 1.3;
  }
  
  .balance-warning-button {
    padding: 6px 12px;
    font-size: 12px;
  }
  
  .balance-warning-actions {
    gap: 6px;
  }
}

@media screen and (max-width: 480px) {
  .balance-warning-content {
    padding: 6px 10px;
    gap: 6px;
    flex-direction: row;
    align-items: center;
  }
  
  .balance-warning-icon {
    width: 20px;
    height: 20px;
    flex-shrink: 0;
  }
  
  .balance-warning-text {
    flex: 1;
    min-width: 0;
  }
  
  .balance-warning-title {
    font-size: 13px;
    margin-bottom: 1px;
  }
  
  .balance-warning-message {
    font-size: 11px;
    line-height: 1.2;
  }
  
  .balance-warning-actions {
    flex-shrink: 0;
    gap: 4px;
  }
  
  .balance-warning-button {
    padding: 4px 8px;
    font-size: 11px;
  }
  
  .balance-warning-close {
    padding: 4px;
  }
}

/* Предупреждение теперь использует sticky позиционирование и не требует отступов */


/* ===== SITE FOOTER STYLES ===== */
.site-footer {
  background: linear-gradient(135deg, var(--color-bg-elevated), var(--color-bg-surface));
  border-top: 1px solid var(--color-border);
  margin-top: 60px;
  padding: 20px 0;
  position: relative;
  z-index: 1;
}

.footer-content {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 20px;
}


.footer-copyright {
  text-align: center;
  color: rgba(255, 255, 255, 0.6);
  font-size: 12px;
  font-weight: 500;
}

/* Адаптивность футера */
@media screen and (max-width: 768px) {
  .site-footer {
    margin-top: 40px;
    padding: 16px 0;
  }
  
  .footer-content {
    padding: 0 16px;
  }
  
  .footer-copyright {
    font-size: 11px;
  }
}

@media screen and (max-width: 480px) {
  .site-footer {
    margin-top: 30px;
    padding: 12px 0;
  }
  
  .footer-content {
    padding: 0 12px;
  }
  
  .footer-copyright {
    font-size: 10px;
  }
}

/* ===== КАСТОМНЫЕ СКРОЛЛБАРЫ ===== */
/* Webkit браузеры (Chrome, Safari, Edge) */
::-webkit-scrollbar {
  width: 8px;
  height: 8px;
}

::-webkit-scrollbar-track {
  background: rgba(0, 0, 0, 0.3);
  border-radius: 4px;
}

::-webkit-scrollbar-thumb {
  background: linear-gradient(135deg, rgba(200, 254, 0, 0.6) 0%, rgba(200, 254, 0, 0.3) 100%);
  border-radius: 4px;
  border: 1px solid rgba(200, 254, 0, 0.2);
  transition: all 0.3s ease;
}

::-webkit-scrollbar-thumb:hover {
  background: linear-gradient(135deg, rgba(200, 254, 0, 0.8) 0%, rgba(200, 254, 0, 0.5) 100%);
  border-color: rgba(200, 254, 0, 0.4);
  box-shadow: 0 0 8px rgba(200, 254, 0, 0.3);
}

::-webkit-scrollbar-thumb:active {
  background: linear-gradient(135deg, rgba(200, 254, 0, 0.9) 0%, rgba(200, 254, 0, 0.6) 100%);
  box-shadow: 0 0 12px rgba(200, 254, 0, 0.5);
}

::-webkit-scrollbar-corner {
  background: rgba(0, 0, 0, 0.3);
}

/* Firefox */
* {
  scrollbar-width: thin;
  scrollbar-color: rgba(200, 254, 0, 0.6) rgba(0, 0, 0, 0.3);
}

/* Специальные стили для модальных окон */
.modal::-webkit-scrollbar,
.modal-backdrop::-webkit-scrollbar {
  width: 6px;
}

.modal::-webkit-scrollbar-thumb,
.modal-backdrop::-webkit-scrollbar-thumb {
  background: linear-gradient(135deg, rgba(200, 254, 0, 0.7) 0%, rgba(200, 254, 0, 0.4) 100%);
  border-radius: 3px;
}

.modal::-webkit-scrollbar-thumb:hover,
.modal-backdrop::-webkit-scrollbar-thumb:hover {
  background: linear-gradient(135deg, rgba(200, 254, 0, 0.9) 0%, rgba(200, 254, 0, 0.6) 100%);
}

/* Стили для таблиц */
.table::-webkit-scrollbar,
.table-wrap::-webkit-scrollbar {
  height: 6px;
}

.table::-webkit-scrollbar-thumb,
.table-wrap::-webkit-scrollbar-thumb {
  background: linear-gradient(90deg, rgba(200, 254, 0, 0.6) 0%, rgba(200, 254, 0, 0.3) 100%);
  border-radius: 3px;
}

/* Стили для списков таймслотов */
.timeslots-list::-webkit-scrollbar,
.slots-list::-webkit-scrollbar {
  width: 4px;
}

.timeslots-list::-webkit-scrollbar-thumb,
.slots-list::-webkit-scrollbar-thumb {
  background: linear-gradient(135deg, rgba(200, 254, 0, 0.5) 0%, rgba(200, 254, 0, 0.2) 100%);
  border-radius: 2px;
}

/* Анимация появления скроллбара */
::-webkit-scrollbar-thumb {
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

/* Скрытие скроллбара при отсутствии контента */
.no-scroll::-webkit-scrollbar {
  display: none;
}

.no-scroll {
  -ms-overflow-style: none;
  scrollbar-width: none;
}

/* Стили для мобильных устройств */
@media (max-width: 768px) {
  ::-webkit-scrollbar {
    width: 4px;
    height: 4px;
  }
  
  ::-webkit-scrollbar-thumb {
    background: linear-gradient(135deg, rgba(200, 254, 0, 0.7) 0%, rgba(200, 254, 0, 0.4) 100%);
    border-radius: 2px;
  }
}

