/* ===================== DESIGN SYSTEM ===================== */

:root {
  --font: 'Inter', -apple-system, BlinkMacSystemFont, 'SF Pro Display', sans-serif;

  /* Colors */
  --bg: #000000;
  --bg-secondary: #1c1c1e;
  --bg-tertiary: #2c2c2e;
  --bg-elevated: #3a3a3c;

  --text: #ffffff;
  --text-secondary: rgba(255, 255, 255, 0.6);
  --text-tertiary: rgba(255, 255, 255, 0.4);

  --border: rgba(255, 255, 255, 0.1);
  --border-strong: rgba(255, 255, 255, 0.2);

  /* Accent */
  --accent: #0a84ff;
  --accent-secondary: #5e5ce6;
  --accent-glow: rgba(10, 132, 255, 0.3);

  /* Status */
  --green: #30d158;
  --red: #ff453a;
  --orange: #ff9f0a;

  /* Spacing */
  --radius-sm: 8px;
  --radius-md: 12px;
  --radius-lg: 16px;
  --radius-xl: 20px;
  --radius-2xl: 24px;
}

/* ===================== THEMES ===================== */

[data-theme="light"] {
  --bg: #f5f5f7;
  --bg-secondary: #ffffff;
  --bg-tertiary: #e5e5ea;
  --bg-elevated: #ffffff;
  --text: #1d1d1f;
  --text-secondary: rgba(0, 0, 0, 0.6);
  --text-tertiary: rgba(0, 0, 0, 0.4);
  --border: rgba(0, 0, 0, 0.08);
  --border-strong: rgba(0, 0, 0, 0.15);
}

[data-theme="serika_dark"] {
  --bg: #323437;
  --bg-secondary: #2c2e31;
  --bg-tertiary: #3a3c3f;
  --accent: #e2b714;
  --accent-secondary: #d4a912;
  --accent-glow: rgba(226, 183, 20, 0.3);
}

[data-theme="serika_light"] {
  --bg: #e1e1e3;
  --bg-secondary: #d5d5d7;
  --bg-tertiary: #c9c9cb;
  --bg-elevated: #ebebed;
  --text: #323437;
  --text-secondary: rgba(50, 52, 55, 0.7);
  --text-tertiary: rgba(50, 52, 55, 0.5);
  --border: rgba(0, 0, 0, 0.1);
  --accent: #e2b714;
  --accent-secondary: #d4a912;
}

[data-theme="botanical"] {
  --bg: #7b9c98;
  --bg-secondary: #6d8e8a;
  --bg-tertiary: #8aaba7;
  --text: #eaf1f3;
  --accent: #495755;
  --accent-secondary: #3d4a48;
}

[data-theme="carbon"] {
  --bg: #313131;
  --bg-secondary: #292929;
  --bg-tertiary: #3a3a3a;
  --text: #f5e6c8;
  --accent: #f66e0d;
  --accent-secondary: #e06000;
  --accent-glow: rgba(246, 110, 13, 0.3);
}

[data-theme="dracula"] {
  --bg: #282a36;
  --bg-secondary: #21222c;
  --bg-tertiary: #343746;
  --text: #f8f8f2;
  --accent: #bd93f9;
  --accent-secondary: #ff79c6;
  --accent-glow: rgba(189, 147, 249, 0.3);
  --green: #50fa7b;
  --red: #ff5555;
}

[data-theme="nord"] {
  --bg: #2e3440;
  --bg-secondary: #272c36;
  --bg-tertiary: #3b4252;
  --text: #eceff4;
  --accent: #88c0d0;
  --accent-secondary: #81a1c1;
  --accent-glow: rgba(136, 192, 208, 0.3);
  --green: #a3be8c;
  --red: #bf616a;
}

[data-theme="monokai"] {
  --bg: #272822;
  --bg-secondary: #1e1f1a;
  --bg-tertiary: #32332c;
  --text: #f8f8f2;
  --accent: #66d9ef;
  --accent-secondary: #ae81ff;
  --accent-glow: rgba(102, 217, 239, 0.3);
  --green: #a6e22e;
  --red: #f92672;
}

[data-theme="gruvbox_dark"] {
  --bg: #282828;
  --bg-secondary: #1d2021;
  --bg-tertiary: #3c3836;
  --text: #ebdbb2;
  --accent: #fabd2f;
  --accent-secondary: #fe8019;
  --accent-glow: rgba(250, 189, 47, 0.3);
  --green: #b8bb26;
  --red: #fb4934;
}

[data-theme="tokyo_night"] {
  --bg: #1a1b26;
  --bg-secondary: #13141c;
  --bg-tertiary: #24283b;
  --text: #c0caf5;
  --accent: #7aa2f7;
  --accent-secondary: #bb9af7;
  --accent-glow: rgba(122, 162, 247, 0.3);
  --green: #9ece6a;
  --red: #f7768e;
}

[data-theme="catppuccin"] {
  --bg: #1e1e2e;
  --bg-secondary: #181825;
  --bg-tertiary: #313244;
  --text: #cdd6f4;
  --accent: #89b4fa;
  --accent-secondary: #cba6f7;
  --accent-glow: rgba(137, 180, 250, 0.3);
  --green: #a6e3a1;
  --red: #f38ba8;
}

[data-theme="matrix"] {
  --bg: #0d0208;
  --bg-secondary: #000000;
  --bg-tertiary: #1a0a10;
  --text: #00ff41;
  --text-secondary: rgba(0, 255, 65, 0.7);
  --accent: #00ff41;
  --accent-secondary: #00cc33;
  --accent-glow: rgba(0, 255, 65, 0.3);
  --border: rgba(0, 255, 65, 0.2);
}

[data-theme="laser"] {
  --bg: #221b44;
  --bg-secondary: #1a1535;
  --bg-tertiary: #2d2555;
  --text: #f7f7f7;
  --accent: #ff007f;
  --accent-secondary: #00ffff;
  --accent-glow: rgba(255, 0, 127, 0.4);
}

[data-theme="vaporwave"] {
  --bg: #1f1139;
  --bg-secondary: #170d2d;
  --bg-tertiary: #2a1749;
  --text: #fcf4ff;
  --accent: #ff6ac1;
  --accent-secondary: #00f9ff;
  --accent-glow: rgba(255, 106, 193, 0.4);
}

[data-theme="8008"] {
  --bg: #333a45;
  --bg-secondary: #2b313b;
  --bg-tertiary: #3d4551;
  --text: #f44c7f;
  --text-secondary: rgba(244, 76, 127, 0.7);
  --accent: #f44c7f;
  --accent-secondary: #faa5b9;
}

[data-theme="olivia"] {
  --bg: #1c1b1d;
  --bg-secondary: #151415;
  --bg-tertiary: #262527;
  --text: #deaf9d;
  --accent: #deaf9d;
  --accent-secondary: #f3e4dc;
}

[data-theme="cafe"] {
  --bg: #2b211f;
  --bg-secondary: #221a18;
  --bg-tertiary: #362b28;
  --text: #dec0a1;
  --accent: #c7a383;
  --accent-secondary: #a17e5c;
}

[data-theme="solarized_dark"] {
  --bg: #002b36;
  --bg-secondary: #00212b;
  --bg-tertiary: #073642;
  --text: #839496;
  --accent: #268bd2;
  --accent-secondary: #2aa198;
  --green: #859900;
  --red: #dc322f;
}

[data-theme="honey"] {
  --bg: #f2aa00;
  --bg-secondary: #e09d00;
  --bg-tertiary: #ffb81c;
  --bg-elevated: #ffc233;
  --text: #1a1400;
  --text-secondary: rgba(26, 20, 0, 0.7);
  --text-tertiary: rgba(26, 20, 0, 0.5);
  --border: rgba(0, 0, 0, 0.15);
  --accent: #1a1400;
  --accent-secondary: #3d3000;
}

[data-theme="rose_pine"] {
  --bg: #191724;
  --bg-secondary: #13111d;
  --bg-tertiary: #26233a;
  --text: #e0def4;
  --accent: #c4a7e7;
  --accent-secondary: #9ccfd8;
  --accent-glow: rgba(196, 167, 231, 0.3);
  --green: #9ccfd8;
  --red: #eb6f92;
}

[data-theme="mizu"] {
  --bg: #253746;
  --bg-secondary: #1e2e3b;
  --bg-tertiary: #2e4254;
  --text: #fcfaf2;
  --accent: #9cd3e6;
  --accent-secondary: #c8e6ed;
}

[data-theme="midnight"] {
  --bg: #0b0e13;
  --bg-secondary: #050709;
  --bg-tertiary: #14181f;
  --text: #c5c8c6;
  --accent: #81a2be;
  --accent-secondary: #b294bb;
}

[data-theme="sunset"] {
  --bg: #1f1d2b;
  --bg-secondary: #181621;
  --bg-tertiary: #292637;
  --text: #f8d2c9;
  --accent: #f9cb8e;
  --accent-secondary: #f9896b;
}

[data-theme="aurora"] {
  --bg: #011926;
  --bg-secondary: #00101a;
  --bg-tertiary: #042433;
  --text: #fffeec;
  --accent: #00e980;
  --accent-secondary: #00fff7;
  --accent-glow: rgba(0, 233, 128, 0.3);
}

[data-theme="ocean"] {
  --bg: #1b2838;
  --bg-secondary: #141f2c;
  --bg-tertiary: #243447;
  --text: #c7d5e0;
  --accent: #66c0f4;
  --accent-secondary: #2a475e;
}

[data-theme="burgundy"] {
  --bg: #1a1014;
  --bg-secondary: #130b0e;
  --bg-tertiary: #24171c;
  --text: #eee5db;
  --accent: #9e2835;
  --accent-secondary: #c75c6b;
  --red: #9e2835;
}

[data-theme="jungle"] {
  --bg: #131e14;
  --bg-secondary: #0d150e;
  --bg-tertiary: #1c2a1d;
  --text: #d6e5c7;
  --accent: #7eb356;
  --accent-secondary: #a4d989;
  --green: #7eb356;
}

[data-theme="mint"] {
  --bg: #0b1a16;
  --bg-secondary: #071210;
  --bg-tertiary: #11241f;
  --text: #e2f3e9;
  --accent: #4fd1a5;
  --accent-secondary: #8df7d6;
  --green: #4fd1a5;
}

[data-theme="lavender"] {
  --bg: #1a1625;
  --bg-secondary: #13101b;
  --bg-tertiary: #241f31;
  --text: #e6e2f1;
  --accent: #b4a7d6;
  --accent-secondary: #d4ccec;
}

[data-theme="crimson"] {
  --bg: #1a1a1a;
  --bg-secondary: #121212;
  --bg-tertiary: #242424;
  --text: #f3f3f3;
  --accent: #dc143c;
  --accent-secondary: #ff4d6d;
  --red: #dc143c;
}

[data-theme="peach"] {
  --bg: #2d2424;
  --bg-secondary: #241d1d;
  --bg-tertiary: #382e2e;
  --text: #ffeedd;
  --accent: #ffb8a3;
  --accent-secondary: #ffd4c4;
}

[data-theme="cyber"] {
  --bg: #0a0a12;
  --bg-secondary: #050508;
  --bg-tertiary: #12121c;
  --text: #f0f0f0;
  --accent: #f7e018;
  --accent-secondary: #ffe44d;
  --accent-glow: rgba(247, 224, 24, 0.3);
}

/* Light themes */
[data-theme="dino"] {
  --bg: #ffffff;
  --bg-secondary: #f0f0f0;
  --bg-tertiary: #e5e5e5;
  --text: #1d221f;
  --text-secondary: rgba(29, 34, 31, 0.7);
  --text-tertiary: rgba(29, 34, 31, 0.5);
  --border: rgba(0, 0, 0, 0.1);
  --accent: #40d672;
  --accent-secondary: #2bc45e;
}

[data-theme="magic_girl"] {
  --bg: #ffffff;
  --bg-secondary: #f5f0f2;
  --bg-tertiary: #ebe5e8;
  --text: #00ac8c;
  --text-secondary: rgba(0, 172, 140, 0.7);
  --text-tertiary: rgba(0, 172, 140, 0.5);
  --border: rgba(0, 0, 0, 0.1);
  --accent: #f5b1cc;
  --accent-secondary: #93e8d3;
}

[data-theme="milkshake"] {
  --bg: #ffffff;
  --bg-secondary: #f0f5f7;
  --bg-tertiary: #e5eef2;
  --text: #212b43;
  --text-secondary: rgba(33, 43, 67, 0.7);
  --text-tertiary: rgba(33, 43, 67, 0.5);
  --border: rgba(0, 0, 0, 0.1);
  --accent: #62cfe6;
  --accent-secondary: #212b43;
}

[data-theme="modern_ink"] {
  --bg: #ffffff;
  --bg-secondary: #f5f5f5;
  --bg-tertiary: #eaeaea;
  --text: #000000;
  --text-secondary: rgba(0, 0, 0, 0.6);
  --text-tertiary: rgba(0, 0, 0, 0.4);
  --border: rgba(0, 0, 0, 0.1);
  --accent: #ff360d;
  --accent-secondary: #b7b7b7;
}

[data-theme="ms_cupcakes"] {
  --bg: #ffffff;
  --bg-secondary: #f5f0f3;
  --bg-tertiary: #ebe5e8;
  --text: #0a282f;
  --text-secondary: rgba(10, 40, 47, 0.7);
  --text-tertiary: rgba(10, 40, 47, 0.5);
  --border: rgba(0, 0, 0, 0.1);
  --accent: #d64090;
  --accent-secondary: #5ed5f3;
}

[data-theme="sewing_tin_light"] {
  --bg: #ffffff;
  --bg-secondary: #f0f0f5;
  --bg-tertiary: #e5e5f0;
  --text: #2d2076;
  --text-secondary: rgba(45, 32, 118, 0.7);
  --text-tertiary: rgba(45, 32, 118, 0.5);
  --border: rgba(0, 0, 0, 0.1);
  --accent: #385eca;
  --accent-secondary: #2d2076;
}

[data-theme="vesper_light"] {
  --bg: #ffffff;
  --bg-secondary: #f5f5f5;
  --bg-tertiary: #eaeaea;
  --text: #000000;
  --text-secondary: rgba(0, 0, 0, 0.6);
  --text-tertiary: rgba(0, 0, 0, 0.4);
  --border: rgba(0, 0, 0, 0.1);
  --accent: #fb7100;
  --accent-secondary: #067a6e;
}

[data-theme="lilac_mist"] {
  --bg: #fffbfe;
  --bg-secondary: #f5f0f5;
  --bg-tertiary: #ebe5eb;
  --text: #5c2954;
  --text-secondary: rgba(92, 41, 84, 0.7);
  --text-tertiary: rgba(92, 41, 84, 0.5);
  --border: rgba(0, 0, 0, 0.1);
  --accent: #b94189;
  --accent-secondary: #e094c2;
}

[data-theme="rose_pine_dawn"] {
  --bg: #fffaf3;
  --bg-secondary: #f5f0e8;
  --bg-tertiary: #ebe5dd;
  --text: #286983;
  --text-secondary: rgba(40, 105, 131, 0.7);
  --text-tertiary: rgba(40, 105, 131, 0.5);
  --border: rgba(0, 0, 0, 0.1);
  --accent: #56949f;
  --accent-secondary: #c4a7e7;
}

[data-theme="soaring_skies"] {
  --bg: #fff9f2;
  --bg-secondary: #f5efe7;
  --bg-tertiary: #ebe5dc;
  --text: #1d1e1e;
  --text-secondary: rgba(29, 30, 30, 0.7);
  --text-tertiary: rgba(29, 30, 30, 0.5);
  --border: rgba(0, 0, 0, 0.1);
  --accent: #55c6f0;
  --accent-secondary: #1e107a;
}

[data-theme="rainbow_trail"] {
  --bg: #f5f5f5;
  --bg-secondary: #eaeaea;
  --bg-tertiary: #dfdfdf;
  --text: #1f1f1f;
  --text-secondary: rgba(31, 31, 31, 0.7);
  --text-tertiary: rgba(31, 31, 31, 0.5);
  --border: rgba(0, 0, 0, 0.1);
  --accent: #363636;
  --accent-secondary: #4f4f4f;
}

[data-theme="nord_light"] {
  --bg: #eceff4;
  --bg-secondary: #e2e5ea;
  --bg-tertiary: #d8dbe0;
  --text: #8fbcbb;
  --text-secondary: rgba(143, 188, 187, 0.8);
  --text-tertiary: rgba(143, 188, 187, 0.6);
  --border: rgba(0, 0, 0, 0.1);
  --accent: #8fbcbb;
  --accent-secondary: #6a7791;
}

[data-theme="solarized_light"] {
  --bg: #fdf6e3;
  --bg-secondary: #f3ecd8;
  --bg-tertiary: #e9e2cd;
  --text: #181819;
  --text-secondary: rgba(24, 24, 25, 0.7);
  --text-tertiary: rgba(24, 24, 25, 0.5);
  --border: rgba(0, 0, 0, 0.1);
  --accent: #859900;
  --accent-secondary: #2aa198;
}

[data-theme="tangerine"] {
  --bg: #ffede0;
  --bg-secondary: #f5e3d5;
  --bg-tertiary: #ebd9ca;
  --text: #3d1705;
  --text-secondary: rgba(61, 23, 5, 0.7);
  --text-tertiary: rgba(61, 23, 5, 0.5);
  --border: rgba(0, 0, 0, 0.1);
  --accent: #fe5503;
  --accent-secondary: #ff9562;
}

[data-theme="camping"] {
  --bg: #faf1e4;
  --bg-secondary: #f0e7d9;
  --bg-tertiary: #e6ddce;
  --text: #3c403b;
  --text-secondary: rgba(60, 64, 59, 0.7);
  --text-tertiary: rgba(60, 64, 59, 0.5);
  --border: rgba(0, 0, 0, 0.1);
  --accent: #618c56;
  --accent-secondary: #c2b8aa;
}

[data-theme="slambook"] {
  --bg: #FFFDDE;
  --bg-secondary: #f5f3d3;
  --bg-tertiary: #ebe9c8;
  --text: #125d98;
  --text-secondary: rgba(18, 93, 152, 0.7);
  --text-tertiary: rgba(18, 93, 152, 0.5);
  --border: rgba(0, 0, 0, 0.1);
  --accent: #13005A;
  --accent-secondary: #1c82ad;
}

[data-theme="paper"] {
  --bg: #eeeeee;
  --bg-secondary: #e4e4e4;
  --bg-tertiary: #dadada;
  --text: #444444;
  --text-secondary: rgba(68, 68, 68, 0.7);
  --text-tertiary: rgba(68, 68, 68, 0.5);
  --border: rgba(0, 0, 0, 0.1);
  --accent: #444444;
  --accent-secondary: #b2b2b2;
}

[data-theme="desert_oasis"] {
  --bg: #fff2d5;
  --bg-secondary: #f5e8ca;
  --bg-tertiary: #ebdebf;
  --text: #332800;
  --text-secondary: rgba(51, 40, 0, 0.7);
  --text-tertiary: rgba(51, 40, 0, 0.5);
  --border: rgba(0, 0, 0, 0.1);
  --accent: #d19d01;
  --accent-secondary: #0061fe;
}

[data-theme="iceberg_light"] {
  --bg: #e8e9ec;
  --bg-secondary: #dedfe2;
  --bg-tertiary: #d4d5d8;
  --text: #33374c;
  --text-secondary: rgba(51, 55, 76, 0.7);
  --text-tertiary: rgba(51, 55, 76, 0.5);
  --border: rgba(0, 0, 0, 0.1);
  --accent: #2d539e;
  --accent-secondary: #adb1c4;
}

[data-theme="cheesecake"] {
  --bg: #fdf0d5;
  --bg-secondary: #f3e6ca;
  --bg-tertiary: #e9dcbf;
  --text: #3a3335;
  --text-secondary: rgba(58, 51, 53, 0.7);
  --text-tertiary: rgba(58, 51, 53, 0.5);
  --border: rgba(0, 0, 0, 0.1);
  --accent: #8e2949;
  --accent-secondary: #d91c81;
}

[data-theme="9009"] {
  --bg: #eeebe2;
  --bg-secondary: #e4e1d7;
  --bg-tertiary: #dad7cc;
  --text: #080909;
  --text-secondary: rgba(8, 9, 9, 0.7);
  --text-tertiary: rgba(8, 9, 9, 0.5);
  --border: rgba(0, 0, 0, 0.1);
  --accent: #080909;
  --accent-secondary: #99947f;
}

[data-theme="lil_dragon"] {
  --bg: #ebe1ef;
  --bg-secondary: #e1d7e5;
  --bg-tertiary: #d7cddb;
  --text: #212b43;
  --text-secondary: rgba(33, 43, 67, 0.7);
  --text-tertiary: rgba(33, 43, 67, 0.5);
  --border: rgba(0, 0, 0, 0.1);
  --accent: #8a5bd6;
  --accent-secondary: #a28db8;
}

[data-theme="blueberry_light"] {
  --bg: #dae0f5;
  --bg-secondary: #d0d6eb;
  --bg-tertiary: #c6cce1;
  --text: #678198;
  --text-secondary: rgba(103, 129, 152, 0.8);
  --text-tertiary: rgba(103, 129, 152, 0.6);
  --border: rgba(0, 0, 0, 0.1);
  --accent: #506477;
  --accent-secondary: #92a4be;
}

[data-theme="witch_girl"] {
  --bg: #f3dbda;
  --bg-secondary: #e9d1d0;
  --bg-tertiary: #dfc7c6;
  --text: #56786a;
  --text-secondary: rgba(86, 120, 106, 0.8);
  --text-tertiary: rgba(86, 120, 106, 0.6);
  --border: rgba(0, 0, 0, 0.1);
  --accent: #56786a;
  --accent-secondary: #ddb4a7;
}

[data-theme="terrazzo"] {
  --bg: #f1e5da;
  --bg-secondary: #e7dbd0;
  --bg-tertiary: #ddd1c6;
  --text: #023e3b;
  --text-secondary: rgba(2, 62, 59, 0.7);
  --text-tertiary: rgba(2, 62, 59, 0.5);
  --border: rgba(0, 0, 0, 0.1);
  --accent: #e0794e;
  --accent-secondary: #688e8f;
}

[data-theme="darling"] {
  --bg: #fec8cd;
  --bg-secondary: #f4bec3;
  --bg-tertiary: #eab4b9;
  --text: #ffffff;
  --text-secondary: rgba(255, 255, 255, 0.8);
  --text-tertiary: rgba(255, 255, 255, 0.6);
  --border: rgba(0, 0, 0, 0.1);
  --accent: #a30000;
  --accent-secondary: #ffffff;
}

[data-theme="serika"] {
  --bg: #e1e1e3;
  --bg-secondary: #d7d7d9;
  --bg-tertiary: #cdcdcf;
  --text: #323437;
  --text-secondary: rgba(50, 52, 55, 0.7);
  --text-tertiary: rgba(50, 52, 55, 0.5);
  --border: rgba(0, 0, 0, 0.1);
  --accent: #e2b714;
  --accent-secondary: #aaaeb3;
}

[data-theme="gruvbox_light"] {
  --bg: #fbf1c7;
  --bg-secondary: #f1e7bc;
  --bg-tertiary: #e7ddb1;
  --text: #3c3836;
  --text-secondary: rgba(60, 56, 54, 0.7);
  --text-tertiary: rgba(60, 56, 54, 0.5);
  --border: rgba(0, 0, 0, 0.1);
  --accent: #689d6a;
  --accent-secondary: #a89984;
}

[data-theme="repose_light"] {
  --bg: #efead0;
  --bg-secondary: #e5e0c5;
  --bg-tertiary: #dbd6ba;
  --text: #333538;
  --text-secondary: rgba(51, 53, 56, 0.7);
  --text-tertiary: rgba(51, 53, 56, 0.5);
  --border: rgba(0, 0, 0, 0.1);
  --accent: #5f605e;
  --accent-secondary: #8f8e84;
}

[data-theme="godspeed"] {
  --bg: #eae4cf;
  --bg-secondary: #e0dac4;
  --bg-tertiary: #d6d0b9;
  --text: #646669;
  --text-secondary: rgba(100, 102, 105, 0.8);
  --text-tertiary: rgba(100, 102, 105, 0.6);
  --border: rgba(0, 0, 0, 0.1);
  --accent: #9abbcd;
  --accent-secondary: #ada998;
}

[data-theme="dollar"] {
  --bg: #e4e4d4;
  --bg-secondary: #dadac9;
  --bg-tertiary: #d0d0be;
  --text: #555a56;
  --text-secondary: rgba(85, 90, 86, 0.8);
  --text-tertiary: rgba(85, 90, 86, 0.6);
  --border: rgba(0, 0, 0, 0.1);
  --accent: #6b886b;
  --accent-secondary: #8a9b69;
}

[data-theme="dmg"] {
  --bg: #dadbdc;
  --bg-secondary: #d0d1d2;
  --bg-tertiary: #c6c7c8;
  --text: #414141;
  --text-secondary: rgba(65, 65, 65, 0.7);
  --text-tertiary: rgba(65, 65, 65, 0.5);
  --border: rgba(0, 0, 0, 0.1);
  --accent: #ae185e;
  --accent-secondary: #3846b1;
}

[data-theme="modern_dolch_light"] {
  --bg: #dbdbdb;
  --bg-secondary: #d1d1d1;
  --bg-tertiary: #c7c7c7;
  --text: #454545;
  --text-secondary: rgba(69, 69, 69, 0.7);
  --text-tertiary: rgba(69, 69, 69, 0.5);
  --border: rgba(0, 0, 0, 0.1);
  --accent: #8fd1c3;
  --accent-secondary: #acacac;
}

[data-theme="olive"] {
  --bg: #e9e5cc;
  --bg-secondary: #dfdbc1;
  --bg-tertiary: #d5d1b6;
  --text: #373731;
  --text-secondary: rgba(55, 55, 49, 0.7);
  --text-tertiary: rgba(55, 55, 49, 0.5);
  --border: rgba(0, 0, 0, 0.1);
  --accent: #92946f;
  --accent-secondary: #b7b39e;
}

[data-theme="taro"] {
  --bg: #b3baff;
  --bg-secondary: #a9b0f5;
  --bg-tertiary: #9fa6eb;
  --text: #130f1a;
  --text-secondary: rgba(19, 15, 26, 0.7);
  --text-tertiary: rgba(19, 15, 26, 0.5);
  --border: rgba(0, 0, 0, 0.1);
  --accent: #130f1a;
  --accent-secondary: #6f6c91;
}

[data-theme="shoko"] {
  --bg: #ced7e0;
  --bg-secondary: #c4cdd6;
  --bg-tertiary: #bac3cc;
  --text: #3b4c58;
  --text-secondary: rgba(59, 76, 88, 0.7);
  --text-tertiary: rgba(59, 76, 88, 0.5);
  --border: rgba(0, 0, 0, 0.1);
  --accent: #81c4dd;
  --accent-secondary: #7599b1;
}

[data-theme="beach"] {
  --bg: #ffeead;
  --bg-secondary: #f5e4a2;
  --bg-tertiary: #ebda97;
  --text: #5b7869;
  --text-secondary: rgba(91, 120, 105, 0.8);
  --text-tertiary: rgba(91, 120, 105, 0.6);
  --border: rgba(0, 0, 0, 0.1);
  --accent: #96ceb4;
  --accent-secondary: #ffcc5c;
}

[data-theme="breeze"] {
  --bg: #e8d5c4;
  --bg-secondary: #decbb9;
  --bg-tertiary: #d4c1ae;
  --text: #1b4c5e;
  --text-secondary: rgba(27, 76, 94, 0.7);
  --text-tertiary: rgba(27, 76, 94, 0.5);
  --border: rgba(0, 0, 0, 0.1);
  --accent: #7d67a9;
  --accent-secondary: #3a98b9;
}

[data-theme="froyo"] {
  --bg: #e1dacb;
  --bg-secondary: #d7d0c0;
  --bg-tertiary: #cdc6b5;
  --text: #7b7d7d;
  --text-secondary: rgba(123, 125, 125, 0.8);
  --text-tertiary: rgba(123, 125, 125, 0.6);
  --border: rgba(0, 0, 0, 0.1);
  --accent: #b29c5e;
  --accent-secondary: #7b7d7d;
}

[data-theme="mr_sleeves"] {
  --bg: #d1d7da;
  --bg-secondary: #c7cdd0;
  --bg-tertiary: #bdc3c6;
  --text: #1d1d1d;
  --text-secondary: rgba(29, 29, 29, 0.7);
  --text-tertiary: rgba(29, 29, 29, 0.5);
  --border: rgba(0, 0, 0, 0.1);
  --accent: #daa99b;
  --accent-secondary: #9a9fa1;
}

[data-theme="fruit_chew"] {
  --bg: #d6d3d6;
  --bg-secondary: #ccc9cc;
  --bg-tertiary: #c2bfc2;
  --text: #282528;
  --text-secondary: rgba(40, 37, 40, 0.7);
  --text-tertiary: rgba(40, 37, 40, 0.5);
  --border: rgba(0, 0, 0, 0.1);
  --accent: #5c1e5f;
  --accent-secondary: #b49cb5;
}

[data-theme="peaches"] {
  --bg: #e0d7c1;
  --bg-secondary: #d6cdb6;
  --bg-tertiary: #ccc3ab;
  --text: #5f4c41;
  --text-secondary: rgba(95, 76, 65, 0.7);
  --text-tertiary: rgba(95, 76, 65, 0.5);
  --border: rgba(0, 0, 0, 0.1);
  --accent: #dd7a5f;
  --accent-secondary: #e7b28e;
}

[data-theme="hanok"] {
  --bg: #d8d2c3;
  --bg-secondary: #cec8b8;
  --bg-tertiary: #c4bead;
  --text: #393b3b;
  --text-secondary: rgba(57, 59, 59, 0.7);
  --text-tertiary: rgba(57, 59, 59, 0.5);
  --border: rgba(0, 0, 0, 0.1);
  --accent: #513a2a;
  --accent-secondary: #8b6f5c;
}

[data-theme="retro"] {
  --bg: #dad3c1;
  --bg-secondary: #d0c9b6;
  --bg-tertiary: #c6bfab;
  --text: #1d1b17;
  --text-secondary: rgba(29, 27, 23, 0.7);
  --text-tertiary: rgba(29, 27, 23, 0.5);
  --border: rgba(0, 0, 0, 0.1);
  --accent: #1d1b17;
  --accent-secondary: #918b7d;
}

[data-theme="pastel"] {
  --bg: #e0b2bd;
  --bg-secondary: #d6a8b3;
  --bg-tertiary: #cc9ea9;
  --text: #6d5c6f;
  --text-secondary: rgba(109, 92, 111, 0.8);
  --text-tertiary: rgba(109, 92, 111, 0.6);
  --border: rgba(0, 0, 0, 0.1);
  --accent: #fbf4b6;
  --accent-secondary: #b4e9ff;
}

[data-theme="frozen_llama"] {
  --bg: #9bf2ea;
  --bg-secondary: #91e8e0;
  --bg-tertiary: #87ded6;
  --text: #ffffff;
  --text-secondary: rgba(255, 255, 255, 0.8);
  --text-tertiary: rgba(255, 255, 255, 0.6);
  --border: rgba(0, 0, 0, 0.1);
  --accent: #6d44a6;
  --accent-secondary: #b690fd;
}

[data-theme="mizu_light"] {
  --bg: #afcbdd;
  --bg-secondary: #a5c1d3;
  --bg-tertiary: #9bb7c9;
  --text: #1a2633;
  --text-secondary: rgba(26, 38, 51, 0.7);
  --text-tertiary: rgba(26, 38, 51, 0.5);
  --border: rgba(0, 0, 0, 0.1);
  --accent: #fcfbf6;
  --accent-secondary: #85a5bb;
}

[data-theme="pink_lemonade"] {
  --bg: #f6d992;
  --bg-secondary: #eccf87;
  --bg-tertiary: #e2c57c;
  --text: #fcfcf8;
  --text-secondary: rgba(252, 252, 248, 0.8);
  --text-tertiary: rgba(252, 252, 248, 0.6);
  --border: rgba(0, 0, 0, 0.1);
  --accent: #f6a192;
  --accent-secondary: #f6b092;
}

[data-theme="tiramisu"] {
  --bg: #cfc6b9;
  --bg-secondary: #c5bcae;
  --bg-tertiary: #bbb2a3;
  --text: #7d5448;
  --text-secondary: rgba(125, 84, 72, 0.8);
  --text-tertiary: rgba(125, 84, 72, 0.6);
  --border: rgba(0, 0, 0, 0.1);
  --accent: #c0976f;
  --accent-secondary: #c0976f;
}

[data-theme="macroblank"] {
  --bg: #b2d2c8;
  --bg-secondary: #a8c8be;
  --bg-tertiary: #9ebeb4;
  --text: #490909;
  --text-secondary: rgba(73, 9, 9, 0.7);
  --text-tertiary: rgba(73, 9, 9, 0.5);
  --border: rgba(0, 0, 0, 0.1);
  --accent: #c13117;
  --accent-secondary: #717977;
}

[data-theme="snes"] {
  --bg: #bfbec2;
  --bg-secondary: #b5b4b8;
  --bg-tertiary: #abaabe;
  --text: #2e2e2e;
  --text-secondary: rgba(46, 46, 46, 0.7);
  --text-tertiary: rgba(46, 46, 46, 0.5);
  --border: rgba(0, 0, 0, 0.1);
  --accent: #553d94;
  --accent-secondary: #9f8ad4;
}

[data-theme="strawberry"] {
  --bg: #f37f83;
  --bg-secondary: #e97579;
  --bg-tertiary: #df6b6f;
  --text: #fcfcf8;
  --text-secondary: rgba(252, 252, 248, 0.8);
  --text-tertiary: rgba(252, 252, 248, 0.6);
  --border: rgba(0, 0, 0, 0.1);
  --accent: #e53c58;
  --accent-secondary: #fcfcf8;
}

[data-theme="creamsicle"] {
  --bg: #ff9869;
  --bg-secondary: #f58e5f;
  --bg-tertiary: #eb8455;
  --text: #fcfcf8;
  --text-secondary: rgba(252, 252, 248, 0.8);
  --text-tertiary: rgba(252, 252, 248, 0.6);
  --border: rgba(0, 0, 0, 0.1);
  --accent: #ff661f;
  --accent-secondary: #fcfcf8;
}

[data-theme="lavender_light"] {
  --bg: #ada6c2;
  --bg-secondary: #a39cb8;
  --bg-tertiary: #9992ae;
  --text: #2f2a41;
  --text-secondary: rgba(47, 42, 65, 0.7);
  --text-tertiary: rgba(47, 42, 65, 0.5);
  --border: rgba(0, 0, 0, 0.1);
  --accent: #e4e3e9;
  --accent-secondary: #e4e3e9;
}

[data-theme="bingsu"] {
  --bg: #b8a7aa;
  --bg-secondary: #ae9da0;
  --bg-tertiary: #a49396;
  --text: #ebe6ea;
  --text-secondary: rgba(235, 230, 234, 0.8);
  --text-tertiary: rgba(235, 230, 234, 0.6);
  --border: rgba(0, 0, 0, 0.1);
  --accent: #83616e;
  --accent-secondary: #48373d;
}

[data-theme="cafe_light"] {
  --bg: #ceb18d;
  --bg-secondary: #c4a782;
  --bg-tertiary: #ba9d77;
  --text: #14120f;
  --text-secondary: rgba(20, 18, 15, 0.7);
  --text-tertiary: rgba(20, 18, 15, 0.5);
  --border: rgba(0, 0, 0, 0.1);
  --accent: #14120f;
  --accent-secondary: #d4d2d1;
}

[data-theme="fleuriste"] {
  --bg: #c6b294;
  --bg-secondary: #bca889;
  --bg-tertiary: #b29e7e;
  --text: #091914;
  --text-secondary: rgba(9, 25, 20, 0.7);
  --text-tertiary: rgba(9, 25, 20, 0.5);
  --border: rgba(0, 0, 0, 0.1);
  --accent: #405a52;
  --accent-secondary: #64374d;
}

[data-theme="miami"] {
  --bg: #f35588;
  --bg-secondary: #e94b7e;
  --bg-tertiary: #df4174;
  --text: #f0e9ec;
  --text-secondary: rgba(240, 233, 236, 0.8);
  --text-tertiary: rgba(240, 233, 236, 0.6);
  --border: rgba(0, 0, 0, 0.1);
  --accent: #05dfd7;
  --accent-secondary: #94294c;
}

[data-theme="iv_clover"] {
  --bg: #a0a0a0;
  --bg-secondary: #969696;
  --bg-tertiary: #8c8c8c;
  --text: #3b2d3b;
  --text-secondary: rgba(59, 45, 59, 0.7);
  --text-tertiary: rgba(59, 45, 59, 0.5);
  --border: rgba(0, 0, 0, 0.1);
  --accent: #573e40;
  --accent-secondary: #353535;
}

[data-theme="mexican"] {
  --bg: #f8ad34;
  --bg-secondary: #eea329;
  --bg-tertiary: #e4991e;
  --text: #eee;
  --text-secondary: rgba(238, 238, 238, 0.8);
  --text-tertiary: rgba(238, 238, 238, 0.6);
  --border: rgba(0, 0, 0, 0.1);
  --accent: #b12189;
  --accent-secondary: #333;
}

[data-theme="lime"] {
  --bg: #7c878e;
  --bg-secondary: #727d84;
  --bg-tertiary: #68737a;
  --text: #bfcfdc;
  --text-secondary: rgba(191, 207, 220, 0.8);
  --text-tertiary: rgba(191, 207, 220, 0.6);
  --border: rgba(0, 0, 0, 0.15);
  --accent: #93c247;
  --accent-secondary: #4b5257;
}

[data-theme="leather"] {
  --bg: #a86948;
  --bg-secondary: #9e5f3d;
  --bg-tertiary: #945532;
  --text: #ffe4bc;
  --text-secondary: rgba(255, 228, 188, 0.8);
  --text-tertiary: rgba(255, 228, 188, 0.6);
  --border: rgba(0, 0, 0, 0.15);
  --accent: #ffe4bc;
  --accent-secondary: #81482b;
}

[data-theme="diner"] {
  --bg: #537997;
  --bg-secondary: #496f8d;
  --bg-tertiary: #3f6583;
  --text: #dfdbc8;
  --text-secondary: rgba(223, 219, 200, 0.8);
  --text-tertiary: rgba(223, 219, 200, 0.6);
  --border: rgba(0, 0, 0, 0.15);
  --accent: #c3af5b;
  --accent-secondary: #445c7f;
}

[data-theme="alpine"] {
  --bg: #6c687f;
  --bg-secondary: #625e75;
  --bg-tertiary: #58546b;
  --text: #ffffff;
  --text-secondary: rgba(255, 255, 255, 0.8);
  --text-tertiary: rgba(255, 255, 255, 0.6);
  --border: rgba(255, 255, 255, 0.15);
  --accent: #ffffff;
  --accent-secondary: #9994b8;
}

[data-theme="dualshot"] {
  --bg: #737373;
  --bg-secondary: #696969;
  --bg-tertiary: #5f5f5f;
  --text: #212222;
  --text-secondary: rgba(33, 34, 34, 0.8);
  --text-tertiary: rgba(33, 34, 34, 0.6);
  --border: rgba(0, 0, 0, 0.15);
  --accent: #212222;
  --accent-secondary: #aaaaaa;
}

[data-theme="fundamentals"] {
  --bg: #727474;
  --bg-secondary: #686a6a;
  --bg-tertiary: #5e6060;
  --text: #131313;
  --text-secondary: rgba(19, 19, 19, 0.8);
  --text-tertiary: rgba(19, 19, 19, 0.6);
  --border: rgba(0, 0, 0, 0.15);
  --accent: #7fa482;
  --accent-secondary: #cac4be;
}

[data-theme="our_theme"] {
  --bg: #ce1226;
  --bg-secondary: #c4081c;
  --bg-tertiary: #ba0012;
  --text: #ffffff;
  --text-secondary: rgba(255, 255, 255, 0.8);
  --text-tertiary: rgba(255, 255, 255, 0.6);
  --border: rgba(0, 0, 0, 0.15);
  --accent: #fcd116;
  --accent-secondary: #6d0f19;
}

[data-theme="ez_mode"] {
  --bg: #0068c6;
  --bg-secondary: #005ebc;
  --bg-tertiary: #0054b2;
  --text: #ffffff;
  --text-secondary: rgba(255, 255, 255, 0.8);
  --text-tertiary: rgba(255, 255, 255, 0.6);
  --border: rgba(255, 255, 255, 0.15);
  --accent: #fa62d5;
  --accent-secondary: #138bf7;
}

[data-theme="evil_eye"] {
  --bg: #0084c2;
  --bg-secondary: #007ab8;
  --bg-tertiary: #0070ae;
  --text: #171718;
  --text-secondary: rgba(23, 23, 24, 0.8);
  --text-tertiary: rgba(23, 23, 24, 0.6);
  --border: rgba(0, 0, 0, 0.15);
  --accent: #f7f2ea;
  --accent-secondary: #01589f;
}

[data-theme="menthol"] {
  --bg: #00c18c;
  --bg-secondary: #00b782;
  --bg-tertiary: #00ad78;
  --text: #ffffff;
  --text-secondary: rgba(255, 255, 255, 0.8);
  --text-tertiary: rgba(255, 255, 255, 0.6);
  --border: rgba(0, 0, 0, 0.15);
  --accent: #ffffff;
  --accent-secondary: #186544;
}

[data-theme="comfy"] {
  --bg: #4a5b6e;
  --bg-secondary: #405164;
  --bg-tertiary: #36475a;
  --text: #f5efee;
  --text-secondary: rgba(245, 239, 238, 0.8);
  --text-tertiary: rgba(245, 239, 238, 0.6);
  --border: rgba(255, 255, 255, 0.15);
  --accent: #f8cdc6;
  --accent-secondary: #9ec1cc;
}

[data-theme="trackday"] {
  --bg: #464d66;
  --bg-secondary: #3c435c;
  --bg-tertiary: #323952;
  --text: #cfcfcf;
  --text-secondary: rgba(207, 207, 207, 0.8);
  --text-tertiary: rgba(207, 207, 207, 0.6);
  --border: rgba(255, 255, 255, 0.15);
  --accent: #e0513e;
  --accent-secondary: #5c7eb9;
}

[data-theme="muted"] {
  --bg: #525252;
  --bg-secondary: #484848;
  --bg-tertiary: #3e3e3e;
  --text: #b1e4e3;
  --text-secondary: rgba(177, 228, 227, 0.8);
  --text-tertiary: rgba(177, 228, 227, 0.6);
  --border: rgba(255, 255, 255, 0.15);
  --accent: #c5b4e3;
  --accent-secondary: #939eae;
}

[data-theme="red_samurai"] {
  --bg: #84202c;
  --bg-secondary: #7a1622;
  --bg-tertiary: #700c18;
  --text: #e2dad0;
  --text-secondary: rgba(226, 218, 208, 0.8);
  --text-tertiary: rgba(226, 218, 208, 0.6);
  --border: rgba(0, 0, 0, 0.2);
  --accent: #c79e6e;
  --accent-secondary: #55131b;
}

[data-theme="sweden"] {
  --bg: #0058a3;
  --bg-secondary: #004e99;
  --bg-tertiary: #00448f;
  --text: #ffffff;
  --text-secondary: rgba(255, 255, 255, 0.8);
  --text-tertiary: rgba(255, 255, 255, 0.6);
  --border: rgba(255, 255, 255, 0.15);
  --accent: #ffcc02;
  --accent-secondary: #57abdb;
}

[data-theme="passion_fruit"] {
  --bg: #7c2142;
  --bg-secondary: #721738;
  --bg-tertiary: #680d2e;
  --text: #ffffff;
  --text-secondary: rgba(255, 255, 255, 0.8);
  --text-tertiary: rgba(255, 255, 255, 0.6);
  --border: rgba(255, 255, 255, 0.15);
  --accent: #f4a3b4;
  --accent-secondary: #9994b8;
}

[data-theme="suisei"] {
  --bg: #3b4a62;
  --bg-secondary: #314058;
  --bg-tertiary: #27364e;
  --text: #dbdeeb;
  --text-secondary: rgba(219, 222, 235, 0.8);
  --text-tertiary: rgba(219, 222, 235, 0.6);
  --border: rgba(255, 255, 255, 0.15);
  --accent: #bef0ff;
  --accent-secondary: #fe9841;
}

[data-theme="striker"] {
  --bg: #124883;
  --bg-secondary: #083e79;
  --bg-tertiary: #00346f;
  --text: #d6dbd9;
  --text-secondary: rgba(214, 219, 217, 0.8);
  --text-tertiary: rgba(214, 219, 217, 0.6);
  --border: rgba(255, 255, 255, 0.15);
  --accent: #d7dcda;
  --accent-secondary: #0f2d4e;
}

[data-theme="cy_red"] {
  --bg: #6e2626;
  --bg-secondary: #641c1c;
  --bg-tertiary: #5a1212;
  --text: #ffaaaa;
  --text-secondary: rgba(255, 170, 170, 0.8);
  --text-tertiary: rgba(255, 170, 170, 0.6);
  --border: rgba(255, 255, 255, 0.15);
  --accent: #e55050;
  --accent-secondary: #ff6060;
}

[data-theme="grand_prix"] {
  --bg: #36475c;
  --bg-secondary: #2c3d52;
  --bg-tertiary: #223348;
  --text: #c1c7d7;
  --text-secondary: rgba(193, 199, 215, 0.8);
  --text-tertiary: rgba(193, 199, 215, 0.6);
  --border: rgba(255, 255, 255, 0.15);
  --accent: #c0d036;
  --accent-secondary: #5c6c80;
}

[data-theme="deku"] {
  --bg: #058b8c;
  --bg-secondary: #008182;
  --bg-tertiary: #007778;
  --text: #f7f2ea;
  --text-secondary: rgba(247, 242, 234, 0.8);
  --text-tertiary: rgba(247, 242, 234, 0.6);
  --border: rgba(0, 0, 0, 0.15);
  --accent: #b63530;
  --accent-secondary: #255458;
}

[data-theme="hedge"] {
  --bg: #415e31;
  --bg-secondary: #375427;
  --bg-tertiary: #2d4a1d;
  --text: #f7f1d6;
  --text-secondary: rgba(247, 241, 214, 0.8);
  --text-tertiary: rgba(247, 241, 214, 0.6);
  --border: rgba(255, 255, 255, 0.15);
  --accent: #6a994e;
  --accent-secondary: #ede5b4;
}

[data-theme="pale_nimbus"] {
  --bg: #433e4c;
  --bg-secondary: #393442;
  --bg-tertiary: #2f2a38;
  --text: #feffdb;
  --text-secondary: rgba(254, 255, 219, 0.8);
  --text-tertiary: rgba(254, 255, 219, 0.6);
  --border: rgba(255, 255, 255, 0.15);
  --accent: #94ffc2;
  --accent-secondary: #ffaca3;
}

[data-theme="retrocast"] {
  --bg: #07737a;
  --bg-secondary: #006970;
  --bg-tertiary: #005f66;
  --text: #ffffff;
  --text-secondary: rgba(255, 255, 255, 0.8);
  --text-tertiary: rgba(255, 255, 255, 0.6);
  --border: rgba(255, 255, 255, 0.15);
  --accent: #88dbdf;
  --accent-secondary: #f3e03b;
}

[data-theme="sewing_tin"] {
  --bg: #241963;
  --bg-secondary: #1a0f59;
  --bg-tertiary: #10054f;
  --text: #ffffff;
  --text-secondary: rgba(255, 255, 255, 0.8);
  --text-tertiary: rgba(255, 255, 255, 0.6);
  --border: rgba(255, 255, 255, 0.15);
  --accent: #f2ce83;
  --accent-secondary: #446ad5;
}

[data-theme="bento"] {
  --bg: #2d394d;
  --bg-secondary: #232f43;
  --bg-tertiary: #192539;
  --text: #fffaf8;
  --text-secondary: rgba(255, 250, 248, 0.8);
  --text-tertiary: rgba(255, 250, 248, 0.6);
  --border: rgba(255, 255, 255, 0.15);
  --accent: #ff7a90;
  --accent-secondary: #4a768d;
}

[data-theme="matcha_moccha"] {
  --bg: #523525;
  --bg-secondary: #482b1b;
  --bg-tertiary: #3e2111;
  --text: #ecddcc;
  --text-secondary: rgba(236, 221, 204, 0.8);
  --text-tertiary: rgba(236, 221, 204, 0.6);
  --border: rgba(255, 255, 255, 0.15);
  --accent: #7ec160;
  --accent-secondary: #9e6749;
}

[data-theme="fledgling"] {
  --bg: #3b363f;
  --bg-secondary: #312c35;
  --bg-tertiary: #27222b;
  --text: #e6d5d3;
  --text-secondary: rgba(230, 213, 211, 0.8);
  --text-tertiary: rgba(230, 213, 211, 0.6);
  --border: rgba(255, 255, 255, 0.15);
  --accent: #fc6e83;
  --accent-secondary: #8e5568;
}

[data-theme="onedark"] {
  --bg: #2f343f;
  --bg-secondary: #252a35;
  --bg-tertiary: #1b202b;
  --text: #98c379;
  --text-secondary: rgba(152, 195, 121, 0.8);
  --text-tertiary: rgba(152, 195, 121, 0.6);
  --border: rgba(255, 255, 255, 0.15);
  --accent: #61afef;
  --accent-secondary: #eceff4;
}

[data-theme="copper"] {
  --bg: #442f29;
  --bg-secondary: #3a251f;
  --bg-tertiary: #301b15;
  --text: #e7e0de;
  --text-secondary: rgba(231, 224, 222, 0.8);
  --text-tertiary: rgba(231, 224, 222, 0.6);
  --border: rgba(255, 255, 255, 0.15);
  --accent: #b46a55;
  --accent-secondary: #7ebab5;
}

[data-theme="graen"] {
  --bg: #303c36;
  --bg-secondary: #26322c;
  --bg-tertiary: #1c2822;
  --text: #a59682;
  --text-secondary: rgba(165, 150, 130, 0.8);
  --text-tertiary: rgba(165, 150, 130, 0.6);
  --border: rgba(255, 255, 255, 0.15);
  --accent: #a59682;
  --accent-secondary: #181d1a;
}

[data-theme="cherry_blossom"] {
  --bg: #323437;
  --bg-secondary: #282a2d;
  --bg-tertiary: #1e2023;
  --text: #d1d0c5;
  --text-secondary: rgba(209, 208, 197, 0.8);
  --text-tertiary: rgba(209, 208, 197, 0.6);
  --border: rgba(255, 255, 255, 0.1);
  --accent: #d65ccc;
  --accent-secondary: #787d82;
}

[data-theme="discord"] {
  --bg: #313338;
  --bg-secondary: #27292e;
  --bg-tertiary: #1d1f24;
  --text: #dcdee3;
  --text-secondary: rgba(220, 222, 227, 0.8);
  --text-tertiary: rgba(220, 222, 227, 0.6);
  --border: rgba(255, 255, 255, 0.1);
  --accent: #5a65ea;
  --accent-secondary: #565861;
}

[data-theme="repose_dark"] {
  --bg: #2f3338;
  --bg-secondary: #25292e;
  --bg-tertiary: #1b1f24;
  --text: #d6d2bc;
  --text-secondary: rgba(214, 210, 188, 0.8);
  --text-tertiary: rgba(214, 210, 188, 0.6);
  --border: rgba(255, 255, 255, 0.1);
  --accent: #d6d2bc;
  --accent-secondary: #8f8e84;
}

[data-theme="rose_pine_moon"] {
  --bg: #2a273f;
  --bg-secondary: #201d35;
  --bg-tertiary: #16132b;
  --text: #e0def4;
  --text-secondary: rgba(224, 222, 244, 0.8);
  --text-tertiary: rgba(224, 222, 244, 0.6);
  --border: rgba(255, 255, 255, 0.1);
  --accent: #9ccfd8;
  --accent-secondary: #c4a7e7;
}

[data-theme="blueberry_dark"] {
  --bg: #212b42;
  --bg-secondary: #172138;
  --bg-tertiary: #0d172e;
  --text: #91b4d5;
  --text-secondary: rgba(145, 180, 213, 0.8);
  --text-tertiary: rgba(145, 180, 213, 0.6);
  --border: rgba(255, 255, 255, 0.1);
  --accent: #add7ff;
  --accent-secondary: #5c7da5;
}

[data-theme="oblivion"] {
  --bg: #313231;
  --bg-secondary: #272827;
  --bg-tertiary: #1d1e1d;
  --text: #f7f5f1;
  --text-secondary: rgba(247, 245, 241, 0.8);
  --text-tertiary: rgba(247, 245, 241, 0.6);
  --border: rgba(255, 255, 255, 0.1);
  --accent: #a5a096;
  --accent-secondary: #5d6263;
}

[data-theme="watermelon"] {
  --bg: #1f4437;
  --bg-secondary: #153a2d;
  --bg-tertiary: #0b3023;
  --text: #cdc6bc;
  --text-secondary: rgba(205, 198, 188, 0.8);
  --text-tertiary: rgba(205, 198, 188, 0.6);
  --border: rgba(255, 255, 255, 0.1);
  --accent: #d6686f;
  --accent-secondary: #3e7a65;
}

[data-theme="future_funk"] {
  --bg: #2e1a47;
  --bg-secondary: #24103d;
  --bg-tertiary: #1a0633;
  --text: #f7f2ea;
  --text-secondary: rgba(247, 242, 234, 0.8);
  --text-tertiary: rgba(247, 242, 234, 0.6);
  --border: rgba(255, 255, 255, 0.1);
  --accent: #f7f2ea;
  --accent-secondary: #c18fff;
}

[data-theme="mint_dark"] {
  --bg: #05385b;
  --bg-secondary: #002e51;
  --bg-tertiary: #002447;
  --text: #edf5e1;
  --text-secondary: rgba(237, 245, 225, 0.8);
  --text-tertiary: rgba(237, 245, 225, 0.6);
  --border: rgba(255, 255, 255, 0.1);
  --accent: #5cdb95;
  --accent-secondary: #20688a;
}

[data-theme="sonokai"] {
  --bg: #2c2e34;
  --bg-secondary: #22242a;
  --bg-tertiary: #181a20;
  --text: #e2e2e3;
  --text-secondary: rgba(226, 226, 227, 0.8);
  --text-tertiary: rgba(226, 226, 227, 0.6);
  --border: rgba(255, 255, 255, 0.1);
  --accent: #9ed072;
  --accent-secondary: #e7c664;
}

[data-theme="viridescent"] {
  --bg: #2c3333;
  --bg-secondary: #222929;
  --bg-tertiary: #181f1f;
  --text: #e9f5db;
  --text-secondary: rgba(233, 245, 219, 0.8);
  --text-tertiary: rgba(233, 245, 219, 0.6);
  --border: rgba(255, 255, 255, 0.1);
  --accent: #95d5b2;
  --accent-secondary: #84a98c;
}

[data-theme="material"] {
  --bg: #263238;
  --bg-secondary: #1c282e;
  --bg-tertiary: #121e24;
  --text: #e6edf3;
  --text-secondary: rgba(230, 237, 243, 0.8);
  --text-tertiary: rgba(230, 237, 243, 0.6);
  --border: rgba(255, 255, 255, 0.1);
  --accent: #80cbc4;
  --accent-secondary: #4c6772;
}

[data-theme="modern_dolch"] {
  --bg: #2d2e30;
  --bg-secondary: #232426;
  --bg-tertiary: #191a1c;
  --text: #e3e6eb;
  --text-secondary: rgba(227, 230, 235, 0.8);
  --text-tertiary: rgba(227, 230, 235, 0.6);
  --border: rgba(255, 255, 255, 0.1);
  --accent: #7eddd3;
  --accent-secondary: #54585c;
}

[data-theme="superuser"] {
  --bg: #262a33;
  --bg-secondary: #1c2029;
  --bg-tertiary: #12161f;
  --text: #e5f7ef;
  --text-secondary: rgba(229, 247, 239, 0.8);
  --text-tertiary: rgba(229, 247, 239, 0.6);
  --border: rgba(255, 255, 255, 0.1);
  --accent: #43ffaf;
  --accent-secondary: #526777;
}

[data-theme="rudy"] {
  --bg: #1a2b3e;
  --bg-secondary: #102134;
  --bg-tertiary: #06172a;
  --text: #c9c8bf;
  --text-secondary: rgba(201, 200, 191, 0.8);
  --text-tertiary: rgba(201, 200, 191, 0.6);
  --border: rgba(255, 255, 255, 0.1);
  --accent: #af8f5c;
  --accent-secondary: #3a506c;
}

[data-theme="bushido"] {
  --bg: #242933;
  --bg-secondary: #1a1f29;
  --bg-tertiary: #10151f;
  --text: #f6f0e9;
  --text-secondary: rgba(246, 240, 233, 0.8);
  --text-tertiary: rgba(246, 240, 233, 0.6);
  --border: rgba(255, 255, 255, 0.1);
  --accent: #ec4c56;
  --accent-secondary: #596172;
}

[data-theme="mashu"] {
  --bg: #2b2b2c;
  --bg-secondary: #212122;
  --bg-tertiary: #171718;
  --text: #f1e2e4;
  --text-secondary: rgba(241, 226, 228, 0.8);
  --text-tertiary: rgba(241, 226, 228, 0.6);
  --border: rgba(255, 255, 255, 0.1);
  --accent: #76689a;
  --accent-secondary: #d8a0a6;
}

[data-theme="bouquet"] {
  --bg: #173f35;
  --bg-secondary: #0d352b;
  --bg-tertiary: #032b21;
  --text: #e9e0d2;
  --text-secondary: rgba(233, 224, 210, 0.8);
  --text-tertiary: rgba(233, 224, 210, 0.6);
  --border: rgba(255, 255, 255, 0.1);
  --accent: #eaa09c;
  --accent-secondary: #408e7b;
}

[data-theme="nebula"] {
  --bg: #212135;
  --bg-secondary: #17172b;
  --bg-tertiary: #0d0d21;
  --text: #838686;
  --text-secondary: rgba(131, 134, 134, 0.8);
  --text-tertiary: rgba(131, 134, 134, 0.6);
  --border: rgba(255, 255, 255, 0.1);
  --accent: #be3c88;
  --accent-secondary: #19b3b8;
}

[data-theme="peach_blossom"] {
  --bg: #292929;
  --bg-secondary: #1f1f1f;
  --bg-tertiary: #151515;
  --text: #fecea8;
  --text-secondary: rgba(254, 206, 168, 0.8);
  --text-tertiary: rgba(254, 206, 168, 0.6);
  --border: rgba(255, 255, 255, 0.1);
  --accent: #99b898;
  --accent-secondary: #616161;
}

[data-theme="80s_after_dark"] {
  --bg: #1b1d36;
  --bg-secondary: #11132c;
  --bg-tertiary: #070922;
  --text: #e1e7ec;
  --text-secondary: rgba(225, 231, 236, 0.8);
  --text-tertiary: rgba(225, 231, 236, 0.6);
  --border: rgba(255, 255, 255, 0.1);
  --accent: #fca6d1;
  --accent-secondary: #99d6ea;
}

[data-theme="github"] {
  --bg: #212830;
  --bg-secondary: #171e26;
  --bg-tertiary: #0d141c;
  --text: #ccdae6;
  --text-secondary: rgba(204, 218, 230, 0.8);
  --text-tertiary: rgba(204, 218, 230, 0.6);
  --border: rgba(255, 255, 255, 0.1);
  --accent: #41ce5c;
  --accent-secondary: #788386;
}

[data-theme="luna"] {
  --bg: #221c35;
  --bg-secondary: #18122b;
  --bg-tertiary: #0e0821;
  --text: #ffe3eb;
  --text-secondary: rgba(255, 227, 235, 0.8);
  --text-tertiary: rgba(255, 227, 235, 0.6);
  --border: rgba(255, 255, 255, 0.1);
  --accent: #f67599;
  --accent-secondary: #5a3a7e;
}

[data-theme="blue_dolphin"] {
  --bg: #003950;
  --bg-secondary: #002f46;
  --bg-tertiary: #00253c;
  --text: #82eaff;
  --text-secondary: rgba(130, 234, 255, 0.8);
  --text-tertiary: rgba(130, 234, 255, 0.6);
  --border: rgba(255, 255, 255, 0.1);
  --accent: #ffcefb;
  --accent-secondary: #00e4ff;
}

[data-theme="purpleish"] {
  --bg: #1e1e32;
  --bg-secondary: #141428;
  --bg-tertiary: #0a0a1e;
  --text: #7a52cc;
  --text-secondary: rgba(122, 82, 204, 0.8);
  --text-tertiary: rgba(122, 82, 204, 0.6);
  --border: rgba(255, 255, 255, 0.1);
  --accent: #7a52cc;
  --accent-secondary: #3d3d66;
}

[data-theme="bliss"] {
  --bg: #262727;
  --bg-secondary: #1c1d1d;
  --bg-tertiary: #121313;
  --text: #fff;
  --text-secondary: rgba(255, 255, 255, 0.8);
  --text-tertiary: rgba(255, 255, 255, 0.6);
  --border: rgba(255, 255, 255, 0.1);
  --accent: #f0d3c9;
  --accent-secondary: #665957;
}

[data-theme="wavez"] {
  --bg: #1c292f;
  --bg-secondary: #121f25;
  --bg-tertiary: #08151b;
  --text: #e9efe6;
  --text-secondary: rgba(233, 239, 230, 0.8);
  --text-tertiary: rgba(233, 239, 230, 0.6);
  --border: rgba(255, 255, 255, 0.1);
  --accent: #6bde3b;
  --accent-secondary: #1f5e6b;
}

[data-theme="earthsong"] {
  --bg: #292521;
  --bg-secondary: #1f1b17;
  --bg-tertiary: #15110d;
  --text: #e6c7a8;
  --text-secondary: rgba(230, 199, 168, 0.8);
  --text-tertiary: rgba(230, 199, 168, 0.6);
  --border: rgba(255, 255, 255, 0.1);
  --accent: #509452;
  --accent-secondary: #f5ae2d;
}

[data-theme="nautilus"] {
  --bg: #132237;
  --bg-secondary: #09182d;
  --bg-tertiary: #000e23;
  --text: #1cbaac;
  --text-secondary: rgba(28, 186, 172, 0.8);
  --text-tertiary: rgba(28, 186, 172, 0.6);
  --border: rgba(255, 255, 255, 0.1);
  --accent: #ebb723;
  --accent-secondary: #0b4c6c;
}

[data-theme="norse"] {
  --bg: #242425;
  --bg-secondary: #1a1a1b;
  --bg-tertiary: #101011;
  --text: #ccc2b1;
  --text-secondary: rgba(204, 194, 177, 0.8);
  --text-tertiary: rgba(204, 194, 177, 0.6);
  --border: rgba(255, 255, 255, 0.1);
  --accent: #2b5f6d;
  --accent-secondary: #505b5e;
}

[data-theme="metaverse"] {
  --bg: #232323;
  --bg-secondary: #191919;
  --bg-tertiary: #0f0f0f;
  --text: #e8e8e8;
  --text-secondary: rgba(232, 232, 232, 0.8);
  --text-tertiary: rgba(232, 232, 232, 0.6);
  --border: rgba(255, 255, 255, 0.1);
  --accent: #d82934;
  --accent-secondary: #5e5e5e;
}

[data-theme="dev"] {
  --bg: #1b2028;
  --bg-secondary: #11161e;
  --bg-tertiary: #070c14;
  --text: #ccccb5;
  --text-secondary: rgba(204, 204, 181, 0.8);
  --text-tertiary: rgba(204, 204, 181, 0.6);
  --border: rgba(255, 255, 255, 0.1);
  --accent: #23a9d5;
  --accent-secondary: #4b5975;
}

[data-theme="horizon"] {
  --bg: #1c1e26;
  --bg-secondary: #12141c;
  --bg-tertiary: #080a12;
  --text: #bbbbbb;
  --text-secondary: rgba(187, 187, 187, 0.8);
  --text-tertiary: rgba(187, 187, 187, 0.6);
  --border: rgba(255, 255, 255, 0.1);
  --accent: #c4a88a;
  --accent-secondary: #db886f;
}

[data-theme="night_runner"] {
  --bg: #212121;
  --bg-secondary: #171717;
  --bg-tertiary: #0d0d0d;
  --text: #e8e8e8;
  --text-secondary: rgba(232, 232, 232, 0.8);
  --text-tertiary: rgba(232, 232, 232, 0.6);
  --border: rgba(255, 255, 255, 0.1);
  --accent: #feff04;
  --accent-secondary: #5c4a9c;
}

[data-theme="sunset_dark"] {
  --bg: #211e24;
  --bg-secondary: #17141a;
  --bg-tertiary: #0d0a10;
  --text: #f4e0c9;
  --text-secondary: rgba(244, 224, 201, 0.8);
  --text-tertiary: rgba(244, 224, 201, 0.6);
  --border: rgba(255, 255, 255, 0.1);
  --accent: #f79777;
  --accent-secondary: #5b578e;
}

[data-theme="moonlight"] {
  --bg: #191f28;
  --bg-secondary: #0f151e;
  --bg-tertiary: #050b14;
  --text: #ccccb5;
  --text-secondary: rgba(204, 204, 181, 0.8);
  --text-tertiary: rgba(204, 204, 181, 0.6);
  --border: rgba(255, 255, 255, 0.1);
  --accent: #c69f68;
  --accent-secondary: #4b5975;
}

[data-theme="ishtar"] {
  --bg: #202020;
  --bg-secondary: #161616;
  --bg-tertiary: #0c0c0c;
  --text: #fae1c3;
  --text-secondary: rgba(250, 225, 195, 0.8);
  --text-tertiary: rgba(250, 225, 195, 0.6);
  --border: rgba(255, 255, 255, 0.1);
  --accent: #91170c;
  --accent-secondary: #847869;
}

[data-theme="phantom"] {
  --bg: #1a1b26;
  --bg-secondary: #10111c;
  --bg-tertiary: #060712;
  --text: #c0caf5;
  --text-secondary: rgba(192, 202, 245, 0.8);
  --text-tertiary: rgba(192, 202, 245, 0.6);
  --border: rgba(255, 255, 255, 0.1);
  --accent: #7aa2f7;
  --accent-secondary: #414868;
}

[data-theme="dark_note"] {
  --bg: #1f1f1f;
  --bg-secondary: #151515;
  --bg-tertiary: #0b0b0b;
  --text: #d2dff4;
  --text-secondary: rgba(210, 223, 244, 0.8);
  --text-tertiary: rgba(210, 223, 244, 0.6);
  --border: rgba(255, 255, 255, 0.1);
  --accent: #f2c17b;
  --accent-secondary: #768f95;
}

[data-theme="drowning"] {
  --bg: #191826;
  --bg-secondary: #0f0e1c;
  --bg-tertiary: #050412;
  --text: #9393a7;
  --text-secondary: rgba(147, 147, 167, 0.8);
  --text-tertiary: rgba(147, 147, 167, 0.6);
  --border: rgba(255, 255, 255, 0.1);
  --accent: #4a6fb5;
  --accent-secondary: #50688c;
}

[data-theme="grape"] {
  --bg: #2c003e;
  --bg-secondary: #220034;
  --bg-tertiary: #18002a;
  --text: #fff;
  --text-secondary: rgba(255, 255, 255, 0.8);
  --text-tertiary: rgba(255, 255, 255, 0.6);
  --border: rgba(255, 255, 255, 0.1);
  --accent: #ff8f00;
  --accent-secondary: #651e56;
}

[data-theme="vscode"] {
  --bg: #1e1e1e;
  --bg-secondary: #141414;
  --bg-tertiary: #0a0a0a;
  --text: #d4d4d4;
  --text-secondary: rgba(212, 212, 212, 0.8);
  --text-tertiary: rgba(212, 212, 212, 0.6);
  --border: rgba(255, 255, 255, 0.1);
  --accent: #007acc;
  --accent-secondary: #4d4d4d;
}

[data-theme="metropolis"] {
  --bg: #0f1f2c;
  --bg-secondary: #051522;
  --bg-tertiary: #000b18;
  --text: #e4edf1;
  --text-secondary: rgba(228, 237, 241, 0.8);
  --text-tertiary: rgba(228, 237, 241, 0.6);
  --border: rgba(255, 255, 255, 0.1);
  --accent: #56c3b7;
  --accent-secondary: #326984;
}

[data-theme="alduin"] {
  --bg: #1c1c1c;
  --bg-secondary: #121212;
  --bg-tertiary: #080808;
  --text: #f5f3ed;
  --text-secondary: rgba(245, 243, 237, 0.8);
  --text-tertiary: rgba(245, 243, 237, 0.6);
  --border: rgba(255, 255, 255, 0.1);
  --accent: #dfd7af;
  --accent-secondary: #444444;
}

[data-theme="iceberg_dark"] {
  --bg: #161821;
  --bg-secondary: #0c0e17;
  --bg-tertiary: #02040d;
  --text: #c6c8d1;
  --text-secondary: rgba(198, 200, 209, 0.8);
  --text-tertiary: rgba(198, 200, 209, 0.6);
  --border: rgba(255, 255, 255, 0.1);
  --accent: #84a0c6;
  --accent-secondary: #595e76;
}

[data-theme="dark_magic_girl"] {
  --bg: #091f2c;
  --bg-secondary: #001522;
  --bg-tertiary: #000b18;
  --text: #a288d9;
  --text-secondary: rgba(162, 136, 217, 0.8);
  --text-tertiary: rgba(162, 136, 217, 0.6);
  --border: rgba(255, 255, 255, 0.1);
  --accent: #f5b1cc;
  --accent-secondary: #93e8d3;
}

[data-theme="cyberspace"] {
  --bg: #181c18;
  --bg-secondary: #0e120e;
  --bg-tertiary: #040804;
  --text: #c2fbe1;
  --text-secondary: rgba(194, 251, 225, 0.8);
  --text-tertiary: rgba(194, 251, 225, 0.6);
  --border: rgba(255, 255, 255, 0.1);
  --accent: #00ce7c;
  --accent-secondary: #9578d3;
}

[data-theme="terminal"] {
  --bg: #191a1b;
  --bg-secondary: #0f1011;
  --bg-tertiary: #050607;
  --text: #e7eae0;
  --text-secondary: rgba(231, 234, 224, 0.8);
  --text-tertiary: rgba(231, 234, 224, 0.6);
  --border: rgba(255, 255, 255, 0.1);
  --accent: #79a617;
  --accent-secondary: #48494b;
}

[data-theme="chaos_theory"] {
  --bg: #141221;
  --bg-secondary: #0a0817;
  --bg-tertiary: #00000d;
  --text: #dde5ed;
  --text-secondary: rgba(221, 229, 237, 0.8);
  --text-tertiary: rgba(221, 229, 237, 0.6);
  --border: rgba(255, 255, 255, 0.1);
  --accent: #fd77d7;
  --accent-secondary: #676e8a;
}

[data-theme="joker"] {
  --bg: #1a0e25;
  --bg-secondary: #10041b;
  --bg-tertiary: #060011;
  --text: #e9e2f5;
  --text-secondary: rgba(233, 226, 245, 0.8);
  --text-tertiary: rgba(233, 226, 245, 0.6);
  --border: rgba(255, 255, 255, 0.1);
  --accent: #99de1e;
  --accent-secondary: #7554a3;
}

[data-theme="dots"] {
  --bg: #121520;
  --bg-secondary: #080b16;
  --bg-tertiary: #00010c;
  --text: #fff;
  --text-secondary: rgba(255, 255, 255, 0.8);
  --text-tertiary: rgba(255, 255, 255, 0.6);
  --border: rgba(255, 255, 255, 0.1);
  --accent: #fff;
  --accent-secondary: #676e8a;
}

[data-theme="everblush"] {
  --bg: #141b1e;
  --bg-secondary: #0a1114;
  --bg-tertiary: #00070a;
  --text: #dadada;
  --text-secondary: rgba(218, 218, 218, 0.8);
  --text-tertiary: rgba(218, 218, 218, 0.6);
  --border: rgba(255, 255, 255, 0.1);
  --accent: #8ccf7e;
  --accent-secondary: #838887;
}

[data-theme="miami_nights"] {
  --bg: #18181a;
  --bg-secondary: #0e0e10;
  --bg-tertiary: #040406;
  --text: #fff;
  --text-secondary: rgba(255, 255, 255, 0.8);
  --text-tertiary: rgba(255, 255, 255, 0.6);
  --border: rgba(255, 255, 255, 0.1);
  --accent: #e4609b;
  --accent-secondary: #47bac0;
}

[data-theme="aether"] {
  --bg: #101820;
  --bg-secondary: #060e16;
  --bg-tertiary: #00040c;
  --text: #eedaea;
  --text-secondary: rgba(238, 218, 234, 0.8);
  --text-tertiary: rgba(238, 218, 234, 0.6);
  --border: rgba(255, 255, 255, 0.1);
  --accent: #eedaea;
  --accent-secondary: #cf6bdd;
}

[data-theme="pulse"] {
  --bg: #181818;
  --bg-secondary: #0e0e0e;
  --bg-tertiary: #040404;
  --text: #e5f4f4;
  --text-secondary: rgba(229, 244, 244, 0.8);
  --text-tertiary: rgba(229, 244, 244, 0.6);
  --border: rgba(255, 255, 255, 0.1);
  --accent: #17b8bd;
  --accent-secondary: #53565a;
}

[data-theme="anti_hero"] {
  --bg: #00002e;
  --bg-secondary: #000024;
  --bg-tertiary: #00001a;
  --text: #f1deef;
  --text-secondary: rgba(241, 222, 239, 0.8);
  --text-tertiary: rgba(241, 222, 239, 0.6);
  --border: rgba(255, 255, 255, 0.1);
  --accent: #ffadad;
  --accent-secondary: #ff3d8b;
}

[data-theme="ryujinscales"] {
  --bg: #081426;
  --bg-secondary: #000a1c;
  --bg-tertiary: #000012;
  --text: #ffe4bc;
  --text-secondary: rgba(255, 228, 188, 0.8);
  --text-tertiary: rgba(255, 228, 188, 0.6);
  --border: rgba(255, 255, 255, 0.1);
  --accent: #f17754;
  --accent-secondary: #ffbc90;
}

[data-theme="floret"] {
  --bg: #00272c;
  --bg-secondary: #001d22;
  --bg-tertiary: #001318;
  --text: #E5E5E5;
  --text-secondary: rgba(229, 229, 229, 0.8);
  --text-tertiary: rgba(229, 229, 229, 0.6);
  --border: rgba(255, 255, 255, 0.1);
  --accent: #ffdd6d;
  --accent-secondary: #779097;
}

[data-theme="terror_below"] {
  --bg: #0b1e1a;
  --bg-secondary: #011410;
  --bg-tertiary: #000a06;
  --text: #dceae5;
  --text-secondary: rgba(220, 234, 229, 0.8);
  --text-tertiary: rgba(220, 234, 229, 0.6);
  --border: rgba(255, 255, 255, 0.1);
  --accent: #66ac92;
  --accent-secondary: #015c53;
}

[data-theme="tron_orange"] {
  --bg: #0d1c1c;
  --bg-secondary: #031212;
  --bg-tertiary: #000808;
  --text: #ffffff;
  --text-secondary: rgba(255, 255, 255, 0.8);
  --text-tertiary: rgba(255, 255, 255, 0.6);
  --border: rgba(255, 255, 255, 0.1);
  --accent: #f0e800;
  --accent-secondary: #ff6600;
}

[data-theme="spiderman"] {
  --bg: #0d1219;
  --bg-secondary: #03080f;
  --bg-tertiary: #000005;
  --text: #f0f0f0;
  --text-secondary: rgba(240, 240, 240, 0.8);
  --text-tertiary: rgba(240, 240, 240, 0.6);
  --border: rgba(255, 255, 255, 0.1);
  --accent: #e23636;
  --accent-secondary: #0476f2;
}

[data-theme="red_dragon"] {
  --bg: #1a0b0c;
  --bg-secondary: #100102;
  --bg-tertiary: #060000;
  --text: #4a4d4e;
  --text-secondary: rgba(74, 77, 78, 0.8);
  --text-tertiary: rgba(74, 77, 78, 0.6);
  --border: rgba(255, 255, 255, 0.1);
  --accent: #ff3a32;
  --accent-secondary: #e2a528;
}

[data-theme="dark"] {
  --bg: #111;
  --bg-secondary: #070707;
  --bg-tertiary: #000;
  --text: #eee;
  --text-secondary: rgba(238, 238, 238, 0.8);
  --text-tertiary: rgba(238, 238, 238, 0.6);
  --border: rgba(255, 255, 255, 0.1);
  --accent: #eee;
  --accent-secondary: #444;
}

[data-theme="rgb"] {
  --bg: #111;
  --bg-secondary: #070707;
  --bg-tertiary: #000;
  --text: #eee;
  --text-secondary: rgba(238, 238, 238, 0.8);
  --text-tertiary: rgba(238, 238, 238, 0.6);
  --border: rgba(255, 255, 255, 0.1);
  --accent: #eee;
  --accent-secondary: #444;
}

[data-theme="vesper"] {
  --bg: #101010;
  --bg-secondary: #060606;
  --bg-tertiary: #000;
  --text: #ffffff;
  --text-secondary: rgba(255, 255, 255, 0.8);
  --text-tertiary: rgba(255, 255, 255, 0.6);
  --border: rgba(255, 255, 255, 0.1);
  --accent: #ffc799;
  --accent-secondary: #99ffe4;
}

[data-theme="voc"] {
  --bg: #190618;
  --bg-secondary: #0f000e;
  --bg-tertiary: #050004;
  --text: #eeeae4;
  --text-secondary: rgba(238, 234, 228, 0.8);
  --text-tertiary: rgba(238, 234, 228, 0.6);
  --border: rgba(255, 255, 255, 0.1);
  --accent: #e0caac;
  --accent-secondary: #4c1e48;
}

[data-theme="mountain"] {
  --bg: #0f0f0f;
  --bg-secondary: #050505;
  --bg-tertiary: #000;
  --text: #e7e7e7;
  --text-secondary: rgba(231, 231, 231, 0.8);
  --text-tertiary: rgba(231, 231, 231, 0.6);
  --border: rgba(255, 255, 255, 0.1);
  --accent: #e7e7e7;
  --accent-secondary: #4c4c4c;
}

[data-theme="arch"] {
  --bg: #0c0d11;
  --bg-secondary: #020307;
  --bg-tertiary: #000;
  --text: #f6f5f5;
  --text-secondary: rgba(246, 245, 245, 0.8);
  --text-tertiary: rgba(246, 245, 245, 0.6);
  --border: rgba(255, 255, 255, 0.1);
  --accent: #7ebab5;
  --accent-secondary: #454864;
}

[data-theme="incognito"] {
  --bg: #0e0e0e;
  --bg-secondary: #040404;
  --bg-tertiary: #000;
  --text: #c6c6c6;
  --text-secondary: rgba(198, 198, 198, 0.8);
  --text-tertiary: rgba(198, 198, 198, 0.6);
  --border: rgba(255, 255, 255, 0.1);
  --accent: #ff9900;
  --accent-secondary: #2f2f2f;
}

[data-theme="terra"] {
  --bg: #0c100e;
  --bg-secondary: #020604;
  --bg-tertiary: #000;
  --text: #f0edd1;
  --text-secondary: rgba(240, 237, 209, 0.8);
  --text-tertiary: rgba(240, 237, 209, 0.6);
  --border: rgba(255, 255, 255, 0.1);
  --accent: #89c559;
  --accent-secondary: #436029;
}

[data-theme="trance"] {
  --bg: #00021b;
  --bg-secondary: #000011;
  --bg-tertiary: #000007;
  --text: #fff;
  --text-secondary: rgba(255, 255, 255, 0.8);
  --text-tertiary: rgba(255, 255, 255, 0.6);
  --border: rgba(255, 255, 255, 0.1);
  --accent: #e51376;
  --accent-secondary: #3c4c79;
}

[data-theme="solarized_osaka"] {
  --bg: #00141a;
  --bg-secondary: #000a10;
  --bg-tertiary: #000006;
  --text: #b58900;
  --text-secondary: rgba(181, 137, 0, 0.8);
  --text-tertiary: rgba(181, 137, 0, 0.6);
  --border: rgba(255, 255, 255, 0.1);
  --accent: #859900;
  --accent-secondary: #2aa198;
}

[data-theme="iv_spade"] {
  --bg: #0c0c0c;
  --bg-secondary: #020202;
  --bg-tertiary: #000;
  --text: #d3c2c3;
  --text-secondary: rgba(211, 194, 195, 0.8);
  --text-tertiary: rgba(211, 194, 195, 0.6);
  --border: rgba(255, 255, 255, 0.1);
  --accent: #b7976a;
  --accent-secondary: #404040;
}

[data-theme="hammerhead"] {
  --bg: #030613;
  --bg-secondary: #000009;
  --bg-tertiary: #000;
  --text: #e2f1f5;
  --text-secondary: rgba(226, 241, 245, 0.8);
  --text-tertiary: rgba(226, 241, 245, 0.6);
  --border: rgba(255, 255, 255, 0.1);
  --accent: #4fcdb9;
  --accent-secondary: #213c53;
}

[data-theme="fire"] {
  --bg: #0f0000;
  --bg-secondary: #050000;
  --bg-tertiary: #000;
  --text: #ffffff;
  --text-secondary: rgba(255, 255, 255, 0.8);
  --text-tertiary: rgba(255, 255, 255, 0.6);
  --border: rgba(255, 255, 255, 0.1);
  --accent: #b31313;
  --accent-secondary: #683434;
}

[data-theme="stealth"] {
  --bg: #010203;
  --bg-secondary: #000;
  --bg-tertiary: #000;
  --text: #383e42;
  --text-secondary: rgba(56, 62, 66, 0.8);
  --text-tertiary: rgba(56, 62, 66, 0.6);
  --border: rgba(255, 255, 255, 0.1);
  --accent: #383e42;
  --accent-secondary: #5e676e;
}

[data-theme="husqy"] {
  --bg: #000000;
  --bg-secondary: #000;
  --bg-tertiary: #000;
  --text: #ebd7ff;
  --text-secondary: rgba(235, 215, 255, 0.8);
  --text-tertiary: rgba(235, 215, 255, 0.6);
  --border: rgba(255, 255, 255, 0.1);
  --accent: #c58aff;
  --accent-secondary: #972fff;
}

[data-theme="shadow"] {
  --bg: #000;
  --bg-secondary: #000;
  --bg-tertiary: #000;
  --text: #eee;
  --text-secondary: rgba(238, 238, 238, 0.8);
  --text-tertiary: rgba(238, 238, 238, 0.6);
  --border: rgba(255, 255, 255, 0.1);
  --accent: #eee;
  --accent-secondary: #444;
}

[data-theme="dracula_pro"] {
  --bg: #22212c;
  --bg-secondary: #1a1925;
  --bg-tertiary: #2d2c38;
  --text: #f8f8f2;
  --text-secondary: rgba(248, 248, 242, 0.8);
  --text-tertiary: rgba(248, 248, 242, 0.6);
  --border: rgba(255, 255, 255, 0.1);
  --accent: #ff80bf;
  --accent-secondary: #9580ff;
}

[data-theme="eclipse"] {
  --bg: #09090d;
  --bg-secondary: #040406;
  --bg-tertiary: #121218;
  --text: #c9ced7;
  --text-secondary: rgba(201, 206, 215, 0.8);
  --text-tertiary: rgba(201, 206, 215, 0.6);
  --border: rgba(255, 255, 255, 0.1);
  --accent: #f19d1a;
  --accent-secondary: #e68a00;
}

[data-theme="hypersonic"] {
  --bg: #141c2e;
  --bg-secondary: #0d1420;
  --bg-tertiary: #1e283c;
  --text: #a0c8dd;
  --text-secondary: rgba(160, 200, 221, 0.8);
  --text-tertiary: rgba(160, 200, 221, 0.6);
  --border: rgba(255, 255, 255, 0.1);
  --accent: #5ee7ff;
  --accent-secondary: #00bcd4;
}

[data-theme="jones"] {
  --bg: #262a2d;
  --bg-secondary: #1f2225;
  --bg-tertiary: #303438;
  --text: #d1c2a6;
  --text-secondary: rgba(209, 194, 166, 0.8);
  --text-tertiary: rgba(209, 194, 166, 0.6);
  --border: rgba(255, 255, 255, 0.1);
  --accent: #edb54b;
  --accent-secondary: #d9a13c;
}

[data-theme="linux"] {
  --bg: #0d0d0d;
  --bg-secondary: #060606;
  --bg-tertiary: #181818;
  --text: #ffffff;
  --text-secondary: rgba(255, 255, 255, 0.8);
  --text-tertiary: rgba(255, 255, 255, 0.6);
  --border: rgba(255, 255, 255, 0.1);
  --accent: #38ad00;
  --accent-secondary: #2d8a00;
}

[data-theme="nether"] {
  --bg: #2b1b17;
  --bg-secondary: #1f1311;
  --bg-tertiary: #3a2521;
  --text: #f2c894;
  --text-secondary: rgba(242, 200, 148, 0.8);
  --text-tertiary: rgba(242, 200, 148, 0.6);
  --border: rgba(255, 255, 255, 0.1);
  --accent: #8b2500;
  --accent-secondary: #ff4500;
}

[data-theme="noel"] {
  --bg: #1d1e21;
  --bg-secondary: #16171a;
  --bg-tertiary: #282a2e;
  --text: #edeff0;
  --text-secondary: rgba(237, 239, 240, 0.8);
  --text-tertiary: rgba(237, 239, 240, 0.6);
  --border: rgba(255, 255, 255, 0.1);
  --accent: #ff4a4a;
  --accent-secondary: #d63a3a;
}

[data-theme="nord_kaolin"] {
  --bg: #e8e0d4;
  --bg-secondary: #ddd5c8;
  --bg-tertiary: #d2cabc;
  --text: #534f4c;
  --text-secondary: rgba(83, 79, 76, 0.8);
  --text-tertiary: rgba(83, 79, 76, 0.6);
  --border: rgba(0, 0, 0, 0.1);
  --accent: #e4643c;
  --accent-secondary: #c75030;
}

[data-theme="oni"] {
  --bg: #1a1b26;
  --bg-secondary: #13141d;
  --bg-tertiary: #24252f;
  --text: #b9b9b9;
  --text-secondary: rgba(185, 185, 185, 0.8);
  --text-tertiary: rgba(185, 185, 185, 0.6);
  --border: rgba(255, 255, 255, 0.1);
  --accent: #e84d4d;
  --accent-secondary: #c93e3e;
}

[data-theme="phosphor"] {
  --bg: #222c28;
  --bg-secondary: #1a2420;
  --bg-tertiary: #2d3832;
  --text: #c7ffb1;
  --text-secondary: rgba(199, 255, 177, 0.8);
  --text-tertiary: rgba(199, 255, 177, 0.6);
  --border: rgba(255, 255, 255, 0.1);
  --accent: #89f94f;
  --accent-secondary: #68d834;
}

[data-theme="sakura"] {
  --bg: #fbf2e3;
  --bg-secondary: #f0e7d7;
  --bg-tertiary: #e5dccb;
  --text: #3b3b3d;
  --text-secondary: rgba(59, 59, 61, 0.8);
  --text-tertiary: rgba(59, 59, 61, 0.6);
  --border: rgba(0, 0, 0, 0.1);
  --accent: #e889a0;
  --accent-secondary: #d96e87;
}

[data-theme="serenity"] {
  --bg: #1a1a2e;
  --bg-secondary: #131322;
  --bg-tertiary: #242440;
  --text: #eaeaea;
  --text-secondary: rgba(234, 234, 234, 0.8);
  --text-tertiary: rgba(234, 234, 234, 0.6);
  --border: rgba(255, 255, 255, 0.1);
  --accent: #e94560;
  --accent-secondary: #d03550;
}

[data-theme="soul"] {
  --bg: #1c1c1e;
  --bg-secondary: #151517;
  --bg-tertiary: #262628;
  --text: #cebebe;
  --text-secondary: rgba(206, 190, 190, 0.8);
  --text-tertiary: rgba(206, 190, 190, 0.6);
  --border: rgba(255, 255, 255, 0.1);
  --accent: #e78b8b;
  --accent-secondary: #d67575;
}

[data-theme="tribal"] {
  --bg: #162327;
  --bg-secondary: #0f1a1d;
  --bg-tertiary: #203035;
  --text: #8cc8b3;
  --text-secondary: rgba(140, 200, 179, 0.8);
  --text-tertiary: rgba(140, 200, 179, 0.6);
  --border: rgba(255, 255, 255, 0.1);
  --accent: #e06847;
  --accent-secondary: #c85738;
}

[data-theme="twilight"] {
  --bg: #1e1e1e;
  --bg-secondary: #171717;
  --bg-tertiary: #282828;
  --text: #d5d8dc;
  --text-secondary: rgba(213, 216, 220, 0.8);
  --text-tertiary: rgba(213, 216, 220, 0.6);
  --border: rgba(255, 255, 255, 0.1);
  --accent: #9a79b0;
  --accent-secondary: #8565a0;
}

[data-theme="yuri"] {
  --bg: #f8e8e8;
  --bg-secondary: #eddcdc;
  --bg-tertiary: #e2d0d0;
  --text: #6b4c4c;
  --text-secondary: rgba(107, 76, 76, 0.8);
  --text-tertiary: rgba(107, 76, 76, 0.6);
  --border: rgba(0, 0, 0, 0.1);
  --accent: #e7a192;
  --accent-secondary: #d88f80;
}

[data-theme="zen"] {
  --bg: #efeee9;
  --bg-secondary: #e4e3dd;
  --bg-tertiary: #d9d8d1;
  --text: #3e3e3e;
  --text-secondary: rgba(62, 62, 62, 0.8);
  --text-tertiary: rgba(62, 62, 62, 0.6);
  --border: rgba(0, 0, 0, 0.1);
  --accent: #47817f;
  --accent-secondary: #386a68;
}

[data-theme="superuser_light"] {
  --bg: #fafbf6;
  --bg-secondary: #eff0ea;
  --bg-tertiary: #e4e5de;
  --text: #373a3e;
  --text-secondary: rgba(55, 58, 62, 0.8);
  --text-tertiary: rgba(55, 58, 62, 0.6);
  --border: rgba(0, 0, 0, 0.1);
  --accent: #00d983;
  --accent-secondary: #00b86e;
}

[data-theme="carrot"] {
  --bg: #09090d;
  --bg-secondary: #040406;
  --bg-tertiary: #121218;
  --text: #c9ced7;
  --text-secondary: rgba(201, 206, 215, 0.8);
  --text-tertiary: rgba(201, 206, 215, 0.6);
  --border: rgba(255, 255, 255, 0.1);
  --accent: #ff6600;
  --accent-secondary: #e65c00;
}

/* ===================== RESET ===================== */

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

html {
  height: 100%;
}

body {
  min-height: 100%;
  font-family: var(--font);
  font-size: 15px;
  line-height: 1.5;
  color: var(--text);
  background: var(--bg);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

/* ===================== APP ===================== */

.app {
  min-height: 100vh;
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 40px 80px;
}

/* ===================== AURORA WAVE ===================== */

.aurora-wave {
  --aurora-x: 0%;
  --aurora-y: 0%;
  --aurora-rotate: 0deg;
  --aurora-scale: 1;

  position: fixed;
  inset: 0;
  z-index: 0;
  overflow: hidden;
  pointer-events: none;
}

.aurora-wave::before,
.aurora-wave::after {
  content: '';
  position: absolute;
  width: 200%;
  height: 200%;
  top: -50%;
  left: -50%;
  opacity: 0.12;
  transition: all 2s cubic-bezier(0.4, 0, 0.2, 1);
}

.aurora-wave::before {
  background:
    radial-gradient(ellipse 50% 80% at 30% 50%, var(--accent), transparent 60%),
    radial-gradient(ellipse 80% 50% at 70% 30%, var(--accent-secondary), transparent 50%),
    radial-gradient(ellipse 60% 60% at 50% 70%, var(--accent), transparent 55%);
  filter: blur(60px);
  transform:
    translate(var(--aurora-x), var(--aurora-y))
    rotate(var(--aurora-rotate))
    scale(var(--aurora-scale));
  animation: aurora-wave-move 120s ease-in-out infinite;
}

.aurora-wave::after {
  background:
    radial-gradient(ellipse 70% 40% at 60% 40%, var(--accent-secondary), transparent 50%),
    radial-gradient(ellipse 40% 70% at 40% 60%, var(--accent), transparent 55%);
  filter: blur(80px);
  opacity: 0.08;
  transform:
    translate(calc(var(--aurora-x) * -0.5), calc(var(--aurora-y) * -0.5))
    rotate(calc(var(--aurora-rotate) + 45deg))
    scale(calc(var(--aurora-scale) * 1.2));
  animation: aurora-wave-move-alt 90s ease-in-out infinite reverse;
}

@keyframes aurora-wave-move {
  0%, 100% {
    transform:
      translate(var(--aurora-x), var(--aurora-y))
      rotate(var(--aurora-rotate))
      scale(var(--aurora-scale));
  }
  25% {
    transform:
      translate(calc(var(--aurora-x) + 10%), calc(var(--aurora-y) - 5%))
      rotate(calc(var(--aurora-rotate) + 15deg))
      scale(calc(var(--aurora-scale) * 1.05));
  }
  50% {
    transform:
      translate(calc(var(--aurora-x) - 5%), calc(var(--aurora-y) + 10%))
      rotate(calc(var(--aurora-rotate) + 30deg))
      scale(calc(var(--aurora-scale) * 0.95));
  }
  75% {
    transform:
      translate(calc(var(--aurora-x) + 5%), calc(var(--aurora-y) + 5%))
      rotate(calc(var(--aurora-rotate) + 20deg))
      scale(var(--aurora-scale));
  }
}

@keyframes aurora-wave-move-alt {
  0%, 100% {
    transform:
      translate(calc(var(--aurora-x) * -0.5), calc(var(--aurora-y) * -0.5))
      rotate(calc(var(--aurora-rotate) + 45deg))
      scale(calc(var(--aurora-scale) * 1.2));
  }
  33% {
    transform:
      translate(calc(var(--aurora-x) * -0.5 - 8%), calc(var(--aurora-y) * -0.5 + 6%))
      rotate(calc(var(--aurora-rotate) + 60deg))
      scale(calc(var(--aurora-scale) * 1.1));
  }
  66% {
    transform:
      translate(calc(var(--aurora-x) * -0.5 + 6%), calc(var(--aurora-y) * -0.5 - 8%))
      rotate(calc(var(--aurora-rotate) + 75deg))
      scale(calc(var(--aurora-scale) * 1.25));
  }
}

/* Ensure app content is above aurora */
.app {
  position: relative;
  z-index: 1;
}

/* ===================== HEADER ===================== */

.header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 24px 0;
  margin-bottom: 20px;
}

/* Logo - Text Only (Landing, Auth - always white) */
.logo-text-only {
  font-size: 22px;
  font-weight: 800;
  letter-spacing: -0.5px;
  color: #fff;
}

/* Logo - Themed (Dashboard, Admin - changes with theme) */
.logo-text-themed {
  font-size: 22px;
  font-weight: 800;
  letter-spacing: -0.5px;
  color: var(--accent);
}

.logo-with-badge {
  display: flex;
  align-items: center;
  gap: 10px;
}

/* Legacy support */
.logo {
  display: flex;
  align-items: center;
  gap: 12px;
}

.logo-text {
  font-size: 20px;
  font-weight: 700;
  letter-spacing: -0.3px;
}

.header-nav {
  display: flex;
  align-items: center;
  gap: 8px;
}

.nav-btn {
  width: 44px;
  height: 44px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: transparent;
  border: none;
  border-radius: var(--radius-md);
  color: var(--text-secondary);
  cursor: pointer;
  transition: all 0.2s;
}

.nav-btn:hover {
  background: var(--bg-secondary);
  color: var(--text);
}

.user-btn {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 6px 16px 6px 6px;
  background: var(--bg-secondary);
  border: 1px solid var(--border);
  border-radius: 100px;
  cursor: pointer;
  transition: all 0.2s;
}

.user-btn:hover {
  background: var(--bg-tertiary);
  border-color: var(--border-strong);
}

.user-avatar {
  width: 32px;
  height: 32px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(135deg, var(--accent), var(--accent-secondary));
  border-radius: 50%;
  font-size: 13px;
  font-weight: 600;
  color: white;
}

.user-name {
  font-size: 14px;
  font-weight: 500;
  color: var(--text);
}

/* ===================== HERO ===================== */

.hero {
  text-align: center;
  margin-bottom: 48px;
}

.hero-title {
  font-size: 56px;
  font-weight: 700;
  letter-spacing: -2px;
  margin-bottom: 8px;
  line-height: 1.1;
}

.hero-subtitle {
  font-size: 18px;
  color: var(--text-secondary);
  margin-bottom: 40px;
}

.stats-row {
  display: flex;
  justify-content: center;
  gap: 16px;
  margin-bottom: 40px;
}

.stat-card {
  padding: 24px 40px;
  background: rgba(0, 0, 0, 0.4);
  border: 1px solid var(--border);
  border-radius: var(--radius-xl);
  text-align: center;
  min-width: 160px;
  backdrop-filter: blur(20px);
}

/* Light themes - lighter cards */
[data-theme="light"] .stat-card,
[data-theme="serika_light"] .stat-card,
[data-theme="honey"] .stat-card,
[data-theme="dino"] .stat-card,
[data-theme="magic_girl"] .stat-card,
[data-theme="milkshake"] .stat-card,
[data-theme="modern_ink"] .stat-card,
[data-theme="ms_cupcakes"] .stat-card,
[data-theme="sewing_tin_light"] .stat-card,
[data-theme="lilac_mist"] .stat-card,
[data-theme="rose_pine_dawn"] .stat-card,
[data-theme="soaring_skies"] .stat-card,
[data-theme="rainbow_trail"] .stat-card,
[data-theme="nord_light"] .stat-card,
[data-theme="solarized_light"] .stat-card,
[data-theme="tangerine"] .stat-card,
[data-theme="camping"] .stat-card,
[data-theme="slambook"] .stat-card,
[data-theme="paper"] .stat-card,
[data-theme="desert_oasis"] .stat-card,
[data-theme="iceberg_light"] .stat-card,
[data-theme="cheesecake"] .stat-card,
[data-theme="9009"] .stat-card,
[data-theme="lil_dragon"] .stat-card,
[data-theme="blueberry_light"] .stat-card,
[data-theme="witch_girl"] .stat-card,
[data-theme="terrazzo"] .stat-card,
[data-theme="darling"] .stat-card,
[data-theme="serika"] .stat-card,
[data-theme="gruvbox_light"] .stat-card,
[data-theme="repose_light"] .stat-card,
[data-theme="godspeed"] .stat-card,
[data-theme="dollar"] .stat-card,
[data-theme="dmg"] .stat-card,
[data-theme="modern_dolch_light"] .stat-card,
[data-theme="olive"] .stat-card,
[data-theme="taro"] .stat-card,
[data-theme="shoko"] .stat-card,
[data-theme="beach"] .stat-card,
[data-theme="breeze"] .stat-card,
[data-theme="froyo"] .stat-card,
[data-theme="mr_sleeves"] .stat-card,
[data-theme="fruit_chew"] .stat-card,
[data-theme="peaches"] .stat-card,
[data-theme="hanok"] .stat-card,
[data-theme="retro"] .stat-card,
[data-theme="pastel"] .stat-card,
[data-theme="frozen_llama"] .stat-card,
[data-theme="mizu_light"] .stat-card,
[data-theme="pink_lemonade"] .stat-card,
[data-theme="tiramisu"] .stat-card,
[data-theme="macroblank"] .stat-card,
[data-theme="snes"] .stat-card,
[data-theme="strawberry"] .stat-card,
[data-theme="creamsicle"] .stat-card,
[data-theme="lavender_light"] .stat-card,
[data-theme="bingsu"] .stat-card,
[data-theme="cafe_light"] .stat-card,
[data-theme="fleuriste"] .stat-card,
[data-theme="miami"] .stat-card,
[data-theme="iv_clover"] .stat-card,
[data-theme="mexican"] .stat-card,
[data-theme="olivia"] .stat-card,
[data-theme="copper"] .stat-card,
[data-theme="mashu"] .stat-card,
[data-theme="superuser_light"] .stat-card,
[data-theme="zen"] .stat-card,
[data-theme="alduin"] .stat-card,
[data-theme="yuri"] .stat-card,
[data-theme="sakura"] .stat-card,
[data-theme="nord_kaolin"] .stat-card {
  background: rgba(255, 255, 255, 0.5);
}

.stat-value {
  font-size: 36px;
  font-weight: 700;
  letter-spacing: -1px;
  font-variant-numeric: tabular-nums;
  color: var(--text);
  line-height: 1.1;
}

.stat-label {
  font-size: 13px;
  color: var(--text-tertiary);
  margin-top: 4px;
}

/* ===================== ACTIONS ===================== */

.actions {
  display: flex;
  justify-content: center;
  gap: 12px;
}

.action-btn {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 14px 28px;
  background: var(--bg-secondary);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  color: var(--text);
  font-size: 15px;
  font-weight: 500;
  font-family: var(--font);
  cursor: pointer;
  transition: all 0.2s;
  backdrop-filter: blur(10px);
}

.action-btn:hover {
  background: var(--bg-tertiary);
  border-color: var(--border-strong);
  transform: translateY(-2px);
}

.action-btn.primary {
  background: var(--accent);
  border-color: var(--accent);
  color: white;
  box-shadow: 0 4px 15px var(--accent-glow);
}

.action-btn.primary:hover {
  filter: brightness(1.1);
  background: var(--accent);
  box-shadow: 0 8px 25px var(--accent-glow);
}

.action-btn svg {
  flex-shrink: 0;
}

/* ===================== SUBSCRIPTION BANNER ===================== */

.subscription-banner {
  margin: 0 0 32px;
  padding: 20px 24px;
  background: linear-gradient(135deg, rgba(10, 132, 255, 0.15) 0%, rgba(94, 92, 230, 0.15) 100%);
  border: 1px solid rgba(10, 132, 255, 0.3);
  border-radius: var(--radius-xl);
  position: relative;
  overflow: hidden;
}

.subscription-banner::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.05), transparent);
  animation: banner-shimmer 3s infinite;
}

@keyframes banner-shimmer {
  0% { transform: translateX(-100%); }
  100% { transform: translateX(100%); }
}

.subscription-banner-content {
  display: flex;
  align-items: center;
  gap: 20px;
  position: relative;
  z-index: 1;
}

.subscription-banner-icon {
  width: 48px;
  height: 48px;
  background: var(--accent);
  border-radius: var(--radius-md);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.subscription-banner-icon svg {
  stroke: white;
}

.subscription-banner-text {
  flex: 1;
}

.subscription-banner-title {
  font-size: 16px;
  font-weight: 600;
  color: var(--text);
  margin-bottom: 4px;
}

.subscription-banner-desc {
  font-size: 13px;
  color: var(--text-secondary);
  line-height: 1.4;
}

.subscription-banner-btn {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 12px 20px;
  background: var(--accent);
  color: white;
  font-size: 14px;
  font-weight: 600;
  border: none;
  border-radius: var(--radius-md);
  text-decoration: none;
  white-space: nowrap;
  transition: all 0.2s;
}

.subscription-banner-btn:hover {
  filter: brightness(1.1);
  transform: translateY(-1px);
}

.subscription-banner-btn svg {
  stroke: white;
}

.subscription-banner-close {
  position: absolute;
  top: 12px;
  right: 12px;
  width: 28px;
  height: 28px;
  background: rgba(255, 255, 255, 0.1);
  border: none;
  border-radius: var(--radius-sm);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background 0.2s;
  z-index: 2;
}

.subscription-banner-close:hover {
  background: rgba(255, 255, 255, 0.2);
}

.subscription-banner-close svg {
  stroke: var(--text-secondary);
}

@media (max-width: 768px) {
  .subscription-banner {
    padding: 16px;
  }

  .subscription-banner-content {
    flex-direction: column;
    text-align: center;
    gap: 16px;
  }

  .subscription-banner-btn {
    width: 100%;
    justify-content: center;
  }
}

/* ===================== BOTS SECTION ===================== */

.bots-section {
  margin-top: 60px;
}

.section-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 28px;
}

.section-title {
  font-size: 28px;
  font-weight: 600;
  letter-spacing: -0.5px;
}

.search-box {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 12px 18px;
  background: var(--bg-secondary);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  min-width: 280px;
  transition: all 0.2s;
}

.search-box:focus-within {
  border-color: var(--accent);
  background: var(--bg-tertiary);
}

.search-box svg {
  color: var(--text-tertiary);
  flex-shrink: 0;
}

.search-box input {
  flex: 1;
  background: none;
  border: none;
  outline: none;
  font-size: 15px;
  font-family: var(--font);
  color: var(--text);
}

.search-box input::placeholder {
  color: var(--text-tertiary);
}

/* ===================== BOTS GRID ===================== */

.bots-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
}

.bot-card {
  display: flex;
  flex-direction: column;
  padding: 24px;
  background: rgba(0, 0, 0, 0.4);
  border: 1px solid var(--border);
  border-radius: var(--radius-xl);
  cursor: pointer;
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  position: relative;
  backdrop-filter: blur(20px);
}

.bot-card:hover {
  background: rgba(0, 0, 0, 0.5);
  border-color: var(--accent);
  transform: translateY(-4px);
  box-shadow: 0 20px 40px -15px rgba(0, 0, 0, 0.3);
}

/* Light themes - lighter cards */
[data-theme="light"] .bot-card,
[data-theme="serika_light"] .bot-card,
[data-theme="honey"] .bot-card,
[data-theme="dino"] .bot-card,
[data-theme="magic_girl"] .bot-card,
[data-theme="milkshake"] .bot-card,
[data-theme="modern_ink"] .bot-card,
[data-theme="ms_cupcakes"] .bot-card,
[data-theme="sewing_tin_light"] .bot-card,
[data-theme="lilac_mist"] .bot-card,
[data-theme="rose_pine_dawn"] .bot-card,
[data-theme="soaring_skies"] .bot-card,
[data-theme="rainbow_trail"] .bot-card,
[data-theme="nord_light"] .bot-card,
[data-theme="solarized_light"] .bot-card,
[data-theme="tangerine"] .bot-card,
[data-theme="camping"] .bot-card,
[data-theme="slambook"] .bot-card,
[data-theme="paper"] .bot-card,
[data-theme="desert_oasis"] .bot-card,
[data-theme="iceberg_light"] .bot-card,
[data-theme="cheesecake"] .bot-card,
[data-theme="9009"] .bot-card,
[data-theme="lil_dragon"] .bot-card,
[data-theme="blueberry_light"] .bot-card,
[data-theme="witch_girl"] .bot-card,
[data-theme="terrazzo"] .bot-card,
[data-theme="darling"] .bot-card,
[data-theme="serika"] .bot-card,
[data-theme="gruvbox_light"] .bot-card,
[data-theme="repose_light"] .bot-card,
[data-theme="godspeed"] .bot-card,
[data-theme="dollar"] .bot-card,
[data-theme="dmg"] .bot-card,
[data-theme="modern_dolch_light"] .bot-card,
[data-theme="olive"] .bot-card,
[data-theme="taro"] .bot-card,
[data-theme="shoko"] .bot-card,
[data-theme="beach"] .bot-card,
[data-theme="breeze"] .bot-card,
[data-theme="froyo"] .bot-card,
[data-theme="mr_sleeves"] .bot-card,
[data-theme="fruit_chew"] .bot-card,
[data-theme="peaches"] .bot-card,
[data-theme="hanok"] .bot-card,
[data-theme="retro"] .bot-card,
[data-theme="pastel"] .bot-card,
[data-theme="frozen_llama"] .bot-card,
[data-theme="mizu_light"] .bot-card,
[data-theme="pink_lemonade"] .bot-card,
[data-theme="tiramisu"] .bot-card,
[data-theme="macroblank"] .bot-card,
[data-theme="snes"] .bot-card,
[data-theme="strawberry"] .bot-card,
[data-theme="creamsicle"] .bot-card,
[data-theme="lavender_light"] .bot-card,
[data-theme="bingsu"] .bot-card,
[data-theme="cafe_light"] .bot-card,
[data-theme="fleuriste"] .bot-card,
[data-theme="miami"] .bot-card,
[data-theme="iv_clover"] .bot-card,
[data-theme="mexican"] .bot-card,
[data-theme="olivia"] .bot-card,
[data-theme="copper"] .bot-card,
[data-theme="mashu"] .bot-card,
[data-theme="superuser_light"] .bot-card,
[data-theme="zen"] .bot-card,
[data-theme="alduin"] .bot-card,
[data-theme="yuri"] .bot-card,
[data-theme="sakura"] .bot-card,
[data-theme="nord_kaolin"] .bot-card {
  background: rgba(255, 255, 255, 0.5);
}

[data-theme="light"] .bot-card:hover,
[data-theme="serika_light"] .bot-card:hover,
[data-theme="honey"] .bot-card:hover,
[data-theme="dino"] .bot-card:hover,
[data-theme="magic_girl"] .bot-card:hover,
[data-theme="milkshake"] .bot-card:hover,
[data-theme="modern_ink"] .bot-card:hover,
[data-theme="ms_cupcakes"] .bot-card:hover,
[data-theme="sewing_tin_light"] .bot-card:hover,
[data-theme="lilac_mist"] .bot-card:hover,
[data-theme="rose_pine_dawn"] .bot-card:hover,
[data-theme="soaring_skies"] .bot-card:hover,
[data-theme="rainbow_trail"] .bot-card:hover,
[data-theme="nord_light"] .bot-card:hover,
[data-theme="solarized_light"] .bot-card:hover,
[data-theme="tangerine"] .bot-card:hover,
[data-theme="camping"] .bot-card:hover,
[data-theme="slambook"] .bot-card:hover,
[data-theme="paper"] .bot-card:hover,
[data-theme="desert_oasis"] .bot-card:hover,
[data-theme="iceberg_light"] .bot-card:hover,
[data-theme="cheesecake"] .bot-card:hover,
[data-theme="9009"] .bot-card:hover,
[data-theme="lil_dragon"] .bot-card:hover,
[data-theme="blueberry_light"] .bot-card:hover,
[data-theme="witch_girl"] .bot-card:hover,
[data-theme="terrazzo"] .bot-card:hover,
[data-theme="darling"] .bot-card:hover,
[data-theme="serika"] .bot-card:hover,
[data-theme="gruvbox_light"] .bot-card:hover,
[data-theme="repose_light"] .bot-card:hover,
[data-theme="godspeed"] .bot-card:hover,
[data-theme="dollar"] .bot-card:hover,
[data-theme="dmg"] .bot-card:hover,
[data-theme="modern_dolch_light"] .bot-card:hover,
[data-theme="olive"] .bot-card:hover,
[data-theme="taro"] .bot-card:hover,
[data-theme="shoko"] .bot-card:hover,
[data-theme="beach"] .bot-card:hover,
[data-theme="breeze"] .bot-card:hover,
[data-theme="froyo"] .bot-card:hover,
[data-theme="mr_sleeves"] .bot-card:hover,
[data-theme="fruit_chew"] .bot-card:hover,
[data-theme="peaches"] .bot-card:hover,
[data-theme="hanok"] .bot-card:hover,
[data-theme="retro"] .bot-card:hover,
[data-theme="pastel"] .bot-card:hover,
[data-theme="frozen_llama"] .bot-card:hover,
[data-theme="mizu_light"] .bot-card:hover,
[data-theme="pink_lemonade"] .bot-card:hover,
[data-theme="tiramisu"] .bot-card:hover,
[data-theme="macroblank"] .bot-card:hover,
[data-theme="snes"] .bot-card:hover,
[data-theme="strawberry"] .bot-card:hover,
[data-theme="creamsicle"] .bot-card:hover,
[data-theme="lavender_light"] .bot-card:hover,
[data-theme="bingsu"] .bot-card:hover,
[data-theme="cafe_light"] .bot-card:hover,
[data-theme="fleuriste"] .bot-card:hover,
[data-theme="miami"] .bot-card:hover,
[data-theme="iv_clover"] .bot-card:hover,
[data-theme="mexican"] .bot-card:hover,
[data-theme="olivia"] .bot-card:hover,
[data-theme="copper"] .bot-card:hover,
[data-theme="mashu"] .bot-card:hover,
[data-theme="superuser_light"] .bot-card:hover,
[data-theme="zen"] .bot-card:hover,
[data-theme="alduin"] .bot-card:hover,
[data-theme="yuri"] .bot-card:hover,
[data-theme="sakura"] .bot-card:hover,
[data-theme="nord_kaolin"] .bot-card:hover {
  background: rgba(255, 255, 255, 0.7);
  box-shadow: 0 20px 40px -15px rgba(0, 0, 0, 0.15);
}

.bot-card-header {
  display: flex;
  align-items: center;
  gap: 16px;
  margin-bottom: 20px;
}

.bot-avatar {
  width: 52px;
  height: 52px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--bg-tertiary);
  border-radius: var(--radius-lg);
  font-size: 24px;
  overflow: hidden;
  flex-shrink: 0;
}

.bot-avatar-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: var(--radius-lg);
}

.bot-avatar-fallback {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 22px;
  font-weight: 700;
  color: #fff;
  text-transform: uppercase;
  border-radius: var(--radius-lg);
}

.bot-card:hover .bot-avatar {
  background: var(--bg-elevated);
}

.bot-info {
  flex: 1;
  min-width: 0;
}

.bot-name {
  font-size: 17px;
  font-weight: 600;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.bot-status {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 13px;
  color: var(--text-tertiary);
  margin-top: 4px;
}

.bot-status .dot {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--text-tertiary);
}

.bot-status.active {
  color: var(--green);
}

.bot-status.active .dot {
  background: var(--green);
}

.bot-card-stats {
  display: flex;
  gap: 20px;
}

.bot-stat {
  flex: 1;
}

.bot-stat-value {
  font-size: 22px;
  font-weight: 600;
  font-variant-numeric: tabular-nums;
  transition: transform 0.3s cubic-bezier(0.34, 1.56, 0.64, 1), color 0.3s ease;
}

.bot-stat-value.counter-update {
  animation: counter-bounce 0.4s cubic-bezier(0.34, 1.56, 0.64, 1);
}

@keyframes counter-bounce {
  0% { transform: scale(1); }
  30% { transform: scale(1.25); }
  60% { transform: scale(0.95); }
  100% { transform: scale(1); }
}

/* Subscriber pulse animation for bot card */
.bot-card.subscriber-pulse {
  animation: subscriber-pulse 0.6s ease-out;
}

@keyframes subscriber-pulse {
  0% {
    box-shadow: 0 0 0 0 var(--accent-glow);
  }
  50% {
    box-shadow: 0 0 0 12px transparent;
    border-color: var(--accent);
  }
  100% {
    box-shadow: 0 0 0 0 transparent;
  }
}

.bot-stat-label {
  font-size: 12px;
  color: var(--text-tertiary);
  margin-top: 2px;
}

.bot-actions {
  position: absolute;
  top: 20px;
  right: 20px;
  display: flex;
  gap: 6px;
  opacity: 0;
  transition: opacity 0.2s;
}

.bot-card:hover .bot-actions {
  opacity: 1;
}

.bot-action {
  width: 36px;
  height: 36px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--bg-elevated);
  border: none;
  border-radius: var(--radius-sm);
  color: var(--text-secondary);
  cursor: pointer;
  transition: all 0.15s;
}

.bot-action:hover {
  background: var(--accent);
  color: white;
}

.bot-action.danger:hover {
  background: var(--red);
}

/* Skeleton */
.skeleton-card {
  height: 160px;
  background: linear-gradient(90deg, var(--bg-secondary) 0%, var(--bg-tertiary) 50%, var(--bg-secondary) 100%);
  background-size: 200% 100%;
  border-radius: var(--radius-xl);
  animation: shimmer 1.5s infinite;
}

@keyframes shimmer {
  0% { background-position: 200% 0; }
  100% { background-position: -200% 0; }
}

/* Empty state */
.empty-state {
  grid-column: 1 / -1;
  text-align: center;
  padding: 100px 20px;
}

.empty-icon {
  font-size: 64px;
  margin-bottom: 24px;
  opacity: 0.5;
}

.empty-title {
  font-size: 20px;
  font-weight: 600;
  margin-bottom: 8px;
}

.empty-text {
  font-size: 15px;
  color: var(--text-tertiary);
}

/* ===================== DRAWER ===================== */

.drawer-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.5);
  backdrop-filter: blur(4px);
  opacity: 0;
  visibility: hidden;
  transition: all 0.3s;
  z-index: 100;
}

.drawer-overlay.show {
  opacity: 1;
  visibility: visible;
}

.drawer {
  position: fixed;
  top: 0;
  right: 0;
  bottom: 0;
  width: 500px;
  max-width: 100%;
  background: var(--bg-secondary);
  border-left: 1px solid var(--border-strong);
  transform: translateX(100%);
  transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  z-index: 101;
  display: flex;
  flex-direction: column;
  backdrop-filter: blur(20px);
  box-shadow: -20px 0 40px rgba(0, 0, 0, 0.3);
}

.drawer.open {
  transform: translateX(0);
}

.drawer-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 28px;
  border-bottom: 1px solid var(--border);
}

.drawer-bot-info {
  display: flex;
  align-items: center;
  gap: 16px;
}

.drawer-avatar {
  width: 56px;
  height: 56px;
  border-radius: var(--radius-lg);
  overflow: hidden;
  background: var(--bg-tertiary);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.drawer-avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.drawer-avatar .avatar-fallback {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 24px;
  font-weight: 700;
  color: #fff;
}

.drawer-title {
  display: flex;
  align-items: center;
  gap: 14px;
}

.drawer-name {
  font-size: 22px;
  font-weight: 600;
}

.drawer-badge {
  font-size: 11px;
  font-weight: 600;
  padding: 6px 14px;
  background: rgba(48, 209, 88, 0.15);
  color: var(--green);
  border-radius: 100px;
  text-transform: uppercase;
  letter-spacing: 0.3px;
}

.drawer-badge.paused {
  background: rgba(255, 159, 10, 0.15);
  color: var(--orange);
}

.drawer-close {
  width: 44px;
  height: 44px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--bg-secondary);
  border: none;
  border-radius: var(--radius-md);
  color: var(--text-secondary);
  cursor: pointer;
  transition: all 0.2s;
}

.drawer-close:hover {
  background: var(--bg-tertiary);
  color: var(--text);
}

.drawer-stats {
  display: flex;
  background: var(--bg-tertiary);
  border-bottom: 1px solid var(--border);
}

.drawer-stat {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 24px;
  position: relative;
}

.drawer-stat:not(:last-child)::after {
  content: '';
  position: absolute;
  right: 0;
  top: 20%;
  height: 60%;
  width: 1px;
  background: var(--border);
}

.drawer-stat-value {
  font-size: 28px;
  font-weight: 600;
  font-variant-numeric: tabular-nums;
}

.drawer-stat-label {
  font-size: 12px;
  color: var(--text-tertiary);
  text-transform: uppercase;
  margin-top: 4px;
  letter-spacing: 0.3px;
}

.drawer-body {
  flex: 1;
  overflow-y: auto;
  padding: 28px;
}

.field {
  margin-bottom: 32px;
}

.field-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 12px;
}

.field label {
  font-size: 13px;
  font-weight: 500;
  color: var(--text-secondary);
  text-transform: uppercase;
  letter-spacing: 0.3px;
}

.field-btn {
  padding: 8px 16px;
  background: var(--accent);
  border: none;
  border-radius: var(--radius-sm);
  color: white;
  font-size: 13px;
  font-weight: 500;
  font-family: var(--font);
  cursor: pointer;
  transition: filter 0.2s;
}

.field-btn:hover {
  filter: brightness(1.1);
}

.field textarea {
  width: 100%;
  padding: 16px;
  background: var(--bg-secondary);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  color: var(--text);
  font-size: 14px;
  font-family: 'SF Mono', 'JetBrains Mono', monospace;
  resize: vertical;
  outline: none;
  transition: border-color 0.2s;
}

.field textarea:focus {
  border-color: var(--accent);
}

.field textarea::placeholder {
  color: var(--text-tertiary);
}

/* Schedule Dates */
.schedule-dates {
  margin-top: 16px;
  padding: 16px;
  background: var(--bg-secondary);
  border-radius: var(--radius-md);
  border: 1px solid var(--border);
}

.modal-schedule-dates {
  margin-top: 20px;
}

.schedule-dates-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 14px;
}

.schedule-dates-label {
  font-size: 13px;
  font-weight: 500;
  color: var(--text-secondary);
}

.schedule-status {
  font-size: 12px;
  padding: 4px 10px;
  border-radius: 20px;
  font-weight: 500;
}

.schedule-status.active {
  background: rgba(48, 209, 88, 0.15);
  color: var(--green);
}

.schedule-status.inactive {
  background: rgba(255, 159, 10, 0.15);
  color: var(--orange);
}

.schedule-status.expired {
  background: rgba(255, 69, 58, 0.15);
  color: var(--red);
}

.schedule-dates-row {
  display: flex;
  gap: 12px;
  margin-bottom: 12px;
}

.schedule-dates-row:last-of-type {
  margin-bottom: 0;
}

.date-field {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.date-field label {
  font-size: 12px;
  color: var(--text-tertiary);
}

.date-field input,
.date-field select {
  width: 100%;
  padding: 10px 12px;
  background: var(--bg-tertiary);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  color: var(--text);
  font-size: 14px;
  font-family: var(--font);
  outline: none;
  transition: border-color 0.2s;
}

.date-field input:focus,
.date-field select:focus {
  border-color: var(--accent);
}

.date-field input[type="date"] {
  cursor: pointer;
}

.date-field input[type="date"]::-webkit-calendar-picker-indicator {
  filter: invert(0.8);
  cursor: pointer;
}

.date-field-mode {
  max-width: 140px;
}

.schedule-dates-info {
  margin-top: 12px;
  padding: 10px 12px;
  background: var(--bg-tertiary);
  border-radius: var(--radius-sm);
  font-size: 13px;
  color: var(--text-secondary);
}

.schedule-dates-info:empty {
  display: none;
}

/* Subscription Plans */
.plans-grid {
  display: flex;
  flex-direction: column;
  gap: 20px;
  margin-bottom: 24px;
}

.plan-group {
  background: var(--bg-secondary);
  border-radius: var(--radius-lg);
  padding: 20px;
  border: 1px solid var(--border);
}

.plan-group-title {
  font-size: 20px;
  font-weight: 700;
  color: var(--text);
  margin-bottom: 8px;
}

.plan-group-features {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 16px;
}

.plan-group-features span {
  font-size: 12px;
  color: var(--text-secondary);
  background: var(--bg-tertiary);
  padding: 4px 10px;
  border-radius: 100px;
}

.plan-options {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 10px;
}

.plan-option {
  position: relative;
  padding: 16px 12px;
  background: var(--bg-tertiary);
  border: 2px solid transparent;
  border-radius: var(--radius-md);
  cursor: pointer;
  text-align: center;
  transition: all 0.2s;
}

.plan-option:hover {
  border-color: var(--border-strong);
}

.plan-option.selected {
  border-color: var(--accent);
  background: rgba(10, 132, 255, 0.1);
}

.plan-option .plan-badge {
  position: absolute;
  top: -8px;
  right: -8px;
  font-size: 10px;
  padding: 3px 6px;
  background: var(--orange);
  color: white;
  border-radius: 4px;
  font-weight: 600;
}

.plan-option .plan-badge.best {
  background: var(--green);
}

.plan-option-name {
  font-size: 13px;
  color: var(--text-secondary);
  margin-bottom: 4px;
}

.plan-option-price {
  font-size: 18px;
  font-weight: 700;
  color: var(--text);
}

/* Legacy plan-card styles kept for compatibility */
.plan-card {
  padding: 20px;
  background: var(--bg-secondary);
  border: 2px solid var(--border);
  border-radius: var(--radius-lg);
  cursor: pointer;
  transition: all 0.2s;
}

.plan-card:hover {
  border-color: var(--accent);
}

.plan-card.selected {
  border-color: var(--accent);
  background: rgba(var(--accent-rgb, 10, 132, 255), 0.1);
}

.plan-card-header {
  margin-bottom: 12px;
}

.plan-name {
  font-size: 18px;
  font-weight: 600;
  color: var(--text);
  margin-bottom: 4px;
}

.plan-price {
  font-size: 28px;
  font-weight: 700;
  color: var(--accent);
}

.plan-price span {
  font-size: 14px;
  font-weight: 400;
  color: var(--text-secondary);
}

.plan-features {
  list-style: none;
  padding: 0;
  margin: 0;
}

.plan-features li {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 6px 0;
  font-size: 14px;
  color: var(--text-secondary);
}

.plan-features li::before {
  content: '✓';
  color: var(--green);
  font-weight: 600;
}

.plan-badge {
  display: inline-block;
  padding: 4px 8px;
  background: var(--accent);
  color: white;
  font-size: 11px;
  font-weight: 600;
  border-radius: 4px;
  margin-left: 8px;
}

/* Promo Section */
.promo-section {
  margin-bottom: 20px;
}

.promo-input-wrap {
  display: flex;
  gap: 12px;
}

.promo-input-wrap input {
  flex: 1;
  padding: 12px 16px;
  background: var(--bg-secondary);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  color: var(--text);
  font-size: 14px;
  font-family: var(--font);
  outline: none;
  text-transform: uppercase;
}

.promo-input-wrap input:focus {
  border-color: var(--accent);
}

.promo-apply-btn {
  padding: 12px 20px;
  background: var(--bg-tertiary);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  color: var(--text);
  font-size: 14px;
  font-weight: 500;
  cursor: pointer;
  transition: all 0.2s;
}

.promo-apply-btn:hover {
  background: var(--bg-elevated);
}

.promo-result {
  margin-top: 12px;
  padding: 12px 16px;
  border-radius: var(--radius-sm);
  font-size: 14px;
}

.promo-result:empty {
  display: none;
}

.promo-result.success {
  background: rgba(48, 209, 88, 0.1);
  color: var(--green);
}

.promo-result.error {
  background: rgba(255, 69, 58, 0.1);
  color: var(--red);
}

/* Payment Summary */
.payment-summary {
  padding: 20px;
  background: var(--bg-secondary);
  border-radius: var(--radius-md);
  border: 1px solid var(--border);
}

.summary-row {
  display: flex;
  justify-content: space-between;
  padding: 8px 0;
  font-size: 14px;
  color: var(--text-secondary);
}

.summary-row.total {
  padding-top: 12px;
  margin-top: 8px;
  border-top: 1px solid var(--border);
  font-size: 18px;
  font-weight: 600;
  color: var(--text);
}

.summary-row.total span:last-child {
  color: var(--accent);
}

.logs-stats {
  display: flex;
  gap: 24px;
  margin: 12px 0;
  font-size: 14px;
}

.log-ok {
  color: var(--green);
}

.log-err {
  color: var(--red);
}

.logs-list {
  max-height: 160px;
  overflow-y: auto;
  padding: 14px;
  background: var(--bg-secondary);
  border-radius: var(--radius-md);
}

.logs-date {
  padding: 10px 14px;
  margin-bottom: 8px;
  background: var(--bg-tertiary);
  border-radius: var(--radius-sm);
  font-size: 12px;
  color: var(--text-secondary);
  text-align: center;
}

.log-item {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 10px 14px;
  border-radius: var(--radius-sm);
  font-size: 13px;
}

.log-item:not(:last-child) {
  margin-bottom: 6px;
}

.log-item.ok {
  background: rgba(48, 209, 88, 0.1);
  color: var(--green);
}

.log-item.error {
  background: rgba(255, 69, 58, 0.1);
  color: var(--red);
}

.log-item-main {
  display: flex;
  flex-direction: column;
  gap: 2px;
  flex: 1;
  min-width: 0;
}

.log-user {
  font-family: var(--font);
  font-weight: 500;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.log-time {
  font-size: 11px;
  opacity: 0.7;
  font-family: 'SF Mono', monospace;
}

.log-status {
  margin-left: 12px;
  flex-shrink: 0;
}

.drawer-footer {
  display: flex;
  gap: 12px;
  padding: 24px 28px;
  border-top: 1px solid var(--border);
}

.drawer-btn {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 16px;
  background: var(--bg-secondary);
  border: none;
  border-radius: var(--radius-md);
  color: var(--text);
  font-size: 14px;
  font-weight: 500;
  font-family: var(--font);
  cursor: pointer;
  transition: background 0.2s;
}

.drawer-btn:hover {
  background: var(--bg-tertiary);
}

.drawer-btn.danger {
  color: var(--red);
}

.drawer-btn.danger:hover {
  background: rgba(255, 69, 58, 0.15);
}

/* ===================== MODALS ===================== */

.modal {
  position: fixed;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px;
  background: rgba(0, 0, 0, 0.6);
  backdrop-filter: blur(8px);
  opacity: 0;
  visibility: hidden;
  transition: all 0.2s;
  z-index: 200;
}

.modal.show {
  opacity: 1;
  visibility: visible;
}

.modal-card {
  width: 100%;
  max-width: 480px;
  background: var(--bg-secondary);
  border: 1px solid var(--border-strong);
  border-radius: var(--radius-2xl);
  transform: scale(0.95);
  transition: transform 0.2s;
  box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.5);
  backdrop-filter: blur(20px);
}

.modal.show .modal-card {
  transform: scale(1);
}

.modal-card.modal-wide {
  max-width: 580px;
}

.modal-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 28px;
  border-bottom: 1px solid var(--border);
}

.modal-header h3 {
  font-size: 20px;
  font-weight: 600;
}

.modal-close {
  width: 40px;
  height: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--bg-secondary);
  border: none;
  border-radius: var(--radius-sm);
  color: var(--text-secondary);
  cursor: pointer;
  transition: all 0.2s;
}

.modal-close:hover {
  background: var(--bg-tertiary);
  color: var(--text);
}

.modal-body {
  padding: 28px;
}

.modal-hint {
  font-size: 15px;
  color: var(--text-secondary);
  margin-bottom: 20px;
  line-height: 1.5;
}

.modal-body textarea {
  width: 100%;
  padding: 16px;
  background: var(--bg-secondary);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  color: var(--text);
  font-size: 14px;
  font-family: 'SF Mono', monospace;
  resize: vertical;
  outline: none;
}

.modal-body textarea:focus {
  border-color: var(--accent);
}

.modal-body textarea::placeholder {
  color: var(--text-tertiary);
}

.modal-footer {
  display: flex;
  justify-content: flex-end;
  gap: 12px;
  padding: 24px 28px;
  border-top: 1px solid var(--border);
}

.modal-btn {
  padding: 14px 28px;
  border: none;
  border-radius: var(--radius-md);
  font-size: 15px;
  font-weight: 500;
  font-family: var(--font);
  cursor: pointer;
  transition: all 0.2s;
}

.modal-btn.secondary {
  background: var(--bg-secondary);
  color: var(--text);
}

.modal-btn.secondary:hover {
  background: var(--bg-tertiary);
}

.modal-btn.primary {
  background: var(--accent);
  color: white;
}

.modal-btn.primary:hover {
  filter: brightness(1.1);
}

/* Settings */
.settings-label {
  display: block;
  font-size: 12px;
  font-weight: 600;
  color: var(--text-tertiary);
  text-transform: uppercase;
  letter-spacing: 0.5px;
  margin-bottom: 16px;
}

.settings-label:not(:first-child) {
  margin-top: 32px;
}

.theme-search {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 14px 18px;
  background: var(--bg-secondary);
  border-radius: var(--radius-md);
  margin-bottom: 16px;
}

.theme-search svg {
  width: 18px;
  height: 18px;
  color: var(--text-tertiary);
}

.theme-search input {
  flex: 1;
  background: none;
  border: none;
  outline: none;
  font-size: 15px;
  font-family: var(--font);
  color: var(--text);
}

.theme-search input::placeholder {
  color: var(--text-tertiary);
}

.theme-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 10px;
  max-height: 320px;
  overflow-y: auto;
}

.theme-option {
  padding: 16px 10px;
  background: var(--bg-secondary);
  border: 2px solid transparent;
  border-radius: var(--radius-md);
  text-align: center;
  cursor: pointer;
  transition: all 0.2s;
}

.theme-option:hover {
  background: var(--bg-tertiary);
}

.theme-option.active {
  border-color: var(--accent);
}

.theme-option-preview {
  display: flex;
  gap: 4px;
  justify-content: center;
  margin-bottom: 10px;
}

.theme-option-preview span {
  width: 18px;
  height: 18px;
  border-radius: 50%;
  border: 1px solid rgba(255, 255, 255, 0.1);
}

.theme-option-name {
  font-size: 12px;
  font-weight: 500;
}

.shortcuts {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.shortcut {
  display: flex;
  align-items: center;
  gap: 14px;
  font-size: 14px;
  color: var(--text-secondary);
}

.shortcut kbd {
  padding: 6px 14px;
  background: var(--bg-secondary);
  border-radius: var(--radius-sm);
  font-size: 13px;
  font-family: var(--font);
  font-weight: 500;
  color: var(--text);
}

/* ===================== COMMAND PALETTE ===================== */

.cmd-palette {
  position: fixed;
  inset: 0;
  display: flex;
  align-items: flex-start;
  justify-content: center;
  padding: 140px 24px 24px;
  background: rgba(0, 0, 0, 0.6);
  backdrop-filter: blur(8px);
  opacity: 0;
  visibility: hidden;
  transition: all 0.2s;
  z-index: 300;
}

.cmd-palette.show {
  opacity: 1;
  visibility: visible;
}

.cmd-card {
  width: 100%;
  max-width: 640px;
  background: var(--bg);
  border: 1px solid var(--border);
  border-radius: var(--radius-xl);
  box-shadow: 0 24px 80px -12px rgba(0, 0, 0, 0.6);
  transform: scale(0.96) translateY(-10px);
  transition: transform 0.2s;
}

.cmd-palette.show .cmd-card {
  transform: scale(1) translateY(0);
}

.cmd-input-wrap {
  display: flex;
  align-items: center;
  gap: 16px;
  padding: 20px 28px;
  border-bottom: 1px solid var(--border);
}

.cmd-input-wrap svg {
  color: var(--text-tertiary);
  flex-shrink: 0;
}

.cmd-input-wrap input {
  flex: 1;
  background: none;
  border: none;
  outline: none;
  font-size: 18px;
  font-family: var(--font);
  color: var(--text);
}

.cmd-input-wrap input::placeholder {
  color: var(--text-tertiary);
}

.cmd-input-wrap kbd {
  padding: 6px 12px;
  background: var(--bg-secondary);
  border-radius: var(--radius-sm);
  font-size: 12px;
  font-family: var(--font);
  color: var(--text-tertiary);
}

.cmd-results {
  max-height: 360px;
  overflow-y: auto;
  padding: 12px;
}

.cmd-item {
  display: flex;
  align-items: center;
  gap: 16px;
  padding: 14px 18px;
  border-radius: var(--radius-md);
  cursor: pointer;
  transition: background 0.15s;
}

.cmd-item:hover,
.cmd-item.active {
  background: var(--bg-secondary);
}

.cmd-item-icon {
  font-size: 22px;
}

.cmd-item-text {
  flex: 1;
}

.cmd-item-title {
  font-size: 16px;
  font-weight: 500;
}

.cmd-item-hint {
  font-size: 13px;
  color: var(--text-tertiary);
  margin-top: 2px;
}

/* ===================== TOASTS ===================== */

.toasts {
  position: fixed;
  bottom: 32px;
  right: 32px;
  display: flex;
  flex-direction: column;
  gap: 12px;
  z-index: 500;
}

.toast {
  padding: 18px 28px;
  background: var(--bg-secondary);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  font-size: 15px;
  animation: toast-in 0.3s ease;
  box-shadow: 0 8px 30px -8px rgba(0, 0, 0, 0.4);
}

@keyframes toast-in {
  from {
    opacity: 0;
    transform: translateX(100%);
  }
  to {
    opacity: 1;
    transform: translateX(0);
  }
}

.toast.success {
  border-left: 4px solid var(--green);
}

.toast.error {
  border-left: 4px solid var(--red);
}

.toast.info {
  border-left: 4px solid var(--accent);
}

/* ===================== SCROLLBAR ===================== */

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

::-webkit-scrollbar-track {
  background: transparent;
}

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

::-webkit-scrollbar-thumb:hover {
  background: var(--text-tertiary);
}

/* ===================== RESPONSIVE: TABLET ===================== */

@media (max-width: 1024px) {
  .app {
    padding: 0 32px 60px;
  }

  .hero-title {
    font-size: 44px;
  }

  .bots-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

/* ===================== RESPONSIVE: MOBILE ===================== */

@media (max-width: 768px) {
  .app {
    padding: 0 16px 60px;
  }

  .header {
    padding: 16px 0;
    margin-bottom: 8px;
  }

  .logo-text {
    display: none;
  }

  .user-name {
    display: none;
  }

  .user-btn {
    display: none;
  }

  .hero {
    margin-bottom: 32px;
  }

  .hero-title {
    font-size: 32px;
    letter-spacing: -1px;
  }

  .hero-subtitle {
    font-size: 15px;
    margin-bottom: 28px;
  }

  .stats-row {
    flex-wrap: wrap;
    gap: 12px;
    margin-bottom: 28px;
  }

  .stat-card {
    flex: 1;
    min-width: calc(50% - 6px);
    padding: 16px 20px;
  }

  .stat-value {
    font-size: 26px;
  }

  .stat-label {
    font-size: 12px;
  }

  .actions {
    flex-wrap: wrap;
    gap: 10px;
  }

  .action-btn {
    flex: 1;
    min-width: calc(50% - 5px);
    justify-content: center;
    padding: 12px 16px;
    font-size: 14px;
  }

  .action-btn span {
    display: none;
  }

  .bots-section {
    margin-top: 40px;
  }

  .section-header {
    flex-direction: column;
    align-items: stretch;
    gap: 16px;
    margin-bottom: 20px;
  }

  .section-title {
    font-size: 22px;
  }

  .search-box {
    width: 100%;
    min-width: 0;
  }

  .bots-grid {
    grid-template-columns: 1fr;
    gap: 12px;
  }

  .bot-card {
    padding: 16px;
  }

  .bot-card-header {
    margin-bottom: 14px;
  }

  .bot-avatar {
    width: 44px;
    height: 44px;
  }

  .bot-name {
    font-size: 15px;
  }

  .bot-stat-value {
    font-size: 18px;
  }

  .bot-actions {
    opacity: 1;
  }

  .drawer {
    width: 100%;
  }

  .drawer-header {
    padding: 20px;
  }

  .drawer-name {
    font-size: 18px;
  }

  .drawer-stat {
    padding: 16px;
  }

  .drawer-stat-value {
    font-size: 22px;
  }

  .drawer-body {
    padding: 20px;
  }

  .drawer-footer {
    padding: 16px 20px;
  }

  .drawer-btn {
    padding: 12px;
  }

  .modal-card {
    border-radius: var(--radius-xl);
  }

  .modal-header, .modal-body, .modal-footer {
    padding: 20px;
  }

  .theme-grid {
    grid-template-columns: repeat(3, 1fr);
  }

  .cmd-palette {
    padding: 80px 16px 16px;
  }

  .toasts {
    bottom: 16px;
    right: 16px;
    left: 16px;
  }

  .toast {
    width: 100%;
    padding: 14px 20px;
  }
}

/* ===================== RESPONSIVE: SMALL MOBILE ===================== */

@media (max-width: 400px) {
  .stat-card {
    min-width: 100%;
  }

  .action-btn {
    min-width: 100%;
  }

  .theme-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

/* ===================== PLAN BADGES ===================== */

.plan-badge {
  font-size: 10px;
  font-weight: 600;
  padding: 4px 10px;
  border-radius: 100px;
  text-transform: uppercase;
  letter-spacing: 0.3px;
  background: var(--bg-tertiary);
  color: var(--text-secondary);
}

.plan-badge.beta {
  background: rgba(255, 159, 10, 0.15);
  color: var(--orange);
}

.plan-badge.pro {
  background: rgba(10, 132, 255, 0.15);
  color: var(--accent);
}

.plan-badge.enterprise {
  background: rgba(189, 147, 249, 0.15);
  color: #bd93f9;
}

.plan-badge.clickable {
  cursor: pointer;
  transition: transform 0.15s ease, box-shadow 0.15s ease;
}

.plan-badge.clickable:hover {
  transform: scale(1.05);
  box-shadow: 0 2px 8px var(--accent-glow);
}

.plan-badge.clickable:active {
  transform: scale(0.98);
}

.bot-limit-info {
  font-size: 13px;
  color: var(--text-tertiary);
  margin-bottom: 16px;
  padding: 12px 16px;
  background: var(--bg-secondary);
  border-radius: var(--radius-md);
  text-align: center;
}

.bot-limit-info.limit-reached {
  background: rgba(255, 69, 58, 0.1);
  color: var(--red);
}

/* ===================== LANDING PAGE ===================== */

.landing-body {
  background: var(--bg);
  min-height: 100vh;
  overflow-x: hidden;
  width: 100%;
}

/* Aurora Background */
.aurora-container {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 0;
  overflow: hidden;
  pointer-events: none;
  width: 100vw;
  height: 100vh;
}

.aurora-layer {
  position: absolute;
  width: 120vw;
  height: 120vh;
  border-radius: 50%;
  filter: blur(100px);
  opacity: 0.5;
  will-change: transform;
}

.aurora-1 {
  background: radial-gradient(circle, var(--accent) 0%, transparent 60%);
  top: -40%;
  left: -20%;
  animation: aurora-float-1 25s ease-in-out infinite;
}

.aurora-2 {
  background: radial-gradient(circle, #5e5ce6 0%, transparent 60%);
  top: 10%;
  right: -30%;
  animation: aurora-float-2 30s ease-in-out infinite;
}

.aurora-3 {
  background: radial-gradient(circle, #00d4aa 0%, transparent 60%);
  bottom: -30%;
  left: 10%;
  animation: aurora-float-3 20s ease-in-out infinite;
}

@keyframes aurora-float-1 {
  0%, 100% { transform: translate(0, 0) scale(1) rotate(0deg); opacity: 0.5; }
  25% { transform: translate(50px, -40px) scale(1.15) rotate(10deg); opacity: 0.6; }
  50% { transform: translate(-30px, 30px) scale(0.9) rotate(-5deg); opacity: 0.4; }
  75% { transform: translate(40px, 20px) scale(1.05) rotate(5deg); opacity: 0.55; }
}

@keyframes aurora-float-2 {
  0%, 100% { transform: translate(0, 0) scale(1) rotate(0deg); opacity: 0.4; }
  33% { transform: translate(-60px, 30px) scale(1.1) rotate(-8deg); opacity: 0.5; }
  66% { transform: translate(40px, -50px) scale(0.95) rotate(12deg); opacity: 0.35; }
}

@keyframes aurora-float-3 {
  0%, 100% { transform: translate(0, 0) scale(1) rotate(0deg); opacity: 0.45; }
  20% { transform: translate(30px, -20px) scale(1.2) rotate(5deg); opacity: 0.55; }
  40% { transform: translate(-50px, 10px) scale(0.85) rotate(-10deg); opacity: 0.3; }
  60% { transform: translate(20px, 40px) scale(1.1) rotate(8deg); opacity: 0.5; }
  80% { transform: translate(-30px, -30px) scale(0.95) rotate(-3deg); opacity: 0.4; }
}

/* 3D Canvas */
#telegram3d {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 100%;
  height: 100%;
  max-width: 600px;
  max-height: 600px;
  pointer-events: none;
}

.landing-nav {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 100;
  padding: 16px 0;
  background: rgba(0, 0, 0, 0.8);
  backdrop-filter: blur(20px);
  border-bottom: 1px solid var(--border);
}

.landing-nav-inner {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 40px;
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.landing-nav-links {
  display: flex;
  gap: 40px;
}

.landing-nav-links a {
  color: var(--text-secondary);
  text-decoration: none;
  font-size: 15px;
  font-weight: 500;
  transition: color 0.2s;
}

.landing-nav-links a:hover {
  color: var(--text);
}

.landing-nav-actions {
  display: flex;
  align-items: center;
  gap: 16px;
}

.nav-link-btn {
  color: var(--text-secondary);
  text-decoration: none;
  font-size: 15px;
  font-weight: 500;
  transition: color 0.2s;
}

.nav-link-btn:hover {
  color: var(--text);
}

.nav-cta-btn {
  padding: 12px 24px;
  background: var(--accent);
  color: white;
  text-decoration: none;
  font-size: 14px;
  font-weight: 600;
  border-radius: var(--radius-md);
  transition: filter 0.2s;
}

.nav-cta-btn:hover {
  filter: brightness(1.1);
}

.landing-hero {
  max-width: 1200px;
  margin: 0 auto;
  padding: 160px 40px 100px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 80px;
  align-items: center;
  position: relative;
  z-index: 1;
  overflow: visible;
}

.landing-badge {
  display: inline-block;
  padding: 10px 20px;
  background: rgba(255, 255, 255, 0.1);
  backdrop-filter: blur(20px);
  border: 1px solid rgba(255, 255, 255, 0.15);
  border-radius: 100px;
  font-size: 13px;
  font-weight: 700;
  color: var(--accent);
  margin-bottom: 24px;
}

.landing-title {
  font-size: 56px;
  font-weight: 700;
  line-height: 1.1;
  letter-spacing: -2px;
  margin-bottom: 24px;
}

.gradient-text {
  background: linear-gradient(135deg, var(--accent), var(--accent-secondary));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.landing-subtitle {
  font-size: 18px;
  color: var(--text-secondary);
  line-height: 1.6;
  margin-bottom: 40px;
  max-width: 480px;
}

.landing-hero-actions {
  display: flex;
  gap: 16px;
  margin-bottom: 60px;
}

.landing-btn {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 16px 28px;
  border-radius: var(--radius-md);
  font-size: 16px;
  font-weight: 600;
  text-decoration: none;
  transition: all 0.2s;
}

.landing-btn.primary {
  background: var(--accent);
  color: white;
}

.landing-btn.primary:hover {
  filter: brightness(1.1);
  transform: translateY(-2px);
}

.landing-btn.secondary {
  background: var(--bg-secondary);
  color: var(--text);
  border: 1px solid var(--border);
}

.landing-btn.secondary:hover {
  background: var(--bg-tertiary);
}

.landing-btn.large {
  padding: 20px 36px;
  font-size: 18px;
}

.landing-hero-stats {
  display: flex;
  gap: 48px;
}

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

.hero-stat-value {
  font-size: 32px;
  font-weight: 700;
  color: var(--text);
}

.hero-stat-label {
  font-size: 14px;
  color: var(--text-tertiary);
  margin-top: 4px;
}

.landing-hero-visual {
  display: flex;
  justify-content: center;
  align-items: center;
  min-height: 500px;
  height: 100%;
  position: relative;
  overflow: visible;
}

.hero-mockup {
  width: 100%;
  max-width: 420px;
  background: var(--bg-secondary);
  border: 1px solid var(--border);
  border-radius: var(--radius-xl);
  overflow: hidden;
  box-shadow: 0 40px 100px -20px rgba(10, 132, 255, 0.2);
}

.mockup-header {
  display: flex;
  gap: 8px;
  padding: 16px 20px;
  background: var(--bg-tertiary);
  border-bottom: 1px solid var(--border);
}

.mockup-dot {
  width: 12px;
  height: 12px;
  border-radius: 50%;
  background: var(--border-strong);
}

.mockup-content {
  padding: 20px;
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.mockup-card {
  padding: 16px;
  background: var(--bg-tertiary);
  border-radius: var(--radius-md);
}

.mockup-card-title {
  font-size: 15px;
  font-weight: 600;
  margin-bottom: 8px;
}

.mockup-card-stats {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 13px;
  color: var(--text-secondary);
}

.mockup-badge {
  padding: 4px 10px;
  background: rgba(48, 209, 88, 0.15);
  color: var(--green);
  border-radius: 100px;
  font-size: 11px;
  font-weight: 600;
}

.landing-section {
  max-width: 1200px;
  margin: 0 auto;
  padding: 100px 40px;
  position: relative;
  z-index: 1;
}

.landing-section.dark {
  background: transparent;
  max-width: 100%;
  margin: 0;
}

.landing-section.dark > * {
  max-width: 1200px;
  margin-left: auto;
  margin-right: auto;
}

.section-header-center {
  text-align: center;
  margin-bottom: 60px;
}

.landing-section-title {
  font-size: 40px;
  font-weight: 700;
  letter-spacing: -1px;
  margin-bottom: 16px;
}

.landing-section-subtitle {
  font-size: 18px;
  color: var(--text-secondary);
}

.features-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}

.feature-card {
  padding: 32px;
  background: rgba(255, 255, 255, 0.05);
  backdrop-filter: blur(20px);
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: var(--radius-xl);
  transition: transform 0.3s, box-shadow 0.3s, background 0.3s;
}

.feature-card:hover {
  transform: translateY(-4px);
  background: rgba(255, 255, 255, 0.08);
  box-shadow: 0 20px 40px -20px rgba(0, 0, 0, 0.4);
}

.feature-icon {
  width: 56px;
  height: 56px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(10, 132, 255, 0.1);
  border-radius: var(--radius-md);
  color: var(--accent);
  margin-bottom: 20px;
}

.feature-title {
  font-size: 18px;
  font-weight: 600;
  margin-bottom: 12px;
}

.feature-desc {
  font-size: 15px;
  color: var(--text-secondary);
  line-height: 1.6;
}

/* Pricing Period Selector */
.pricing-period-selector {
  display: flex;
  justify-content: center;
  gap: 8px;
  margin-bottom: 48px;
  padding: 6px;
  background: rgba(255, 255, 255, 0.05);
  border-radius: 100px;
  width: fit-content;
  margin-left: auto;
  margin-right: auto;
}

.period-btn {
  padding: 12px 24px;
  background: transparent;
  border: none;
  border-radius: 100px;
  font-size: 14px;
  font-weight: 500;
  color: var(--text-secondary);
  cursor: pointer;
  transition: all 0.2s;
  display: flex;
  align-items: center;
  gap: 8px;
}

.period-btn:hover {
  color: var(--text);
}

.period-btn.active {
  background: var(--accent);
  color: white;
}

.period-btn .discount-badge {
  padding: 2px 8px;
  background: rgba(48, 209, 88, 0.2);
  color: var(--green);
  font-size: 11px;
  font-weight: 600;
  border-radius: 100px;
}

.period-btn.active .discount-badge {
  background: rgba(255, 255, 255, 0.2);
  color: white;
}

.period-total {
  display: block;
  font-size: 12px;
  color: var(--text-tertiary);
  margin-top: 4px;
}

@media (max-width: 640px) {
  .pricing-period-selector {
    flex-direction: column;
    width: calc(100% - 32px);
    margin: 0 16px 32px;
  }

  .period-btn {
    justify-content: center;
    padding: 14px 20px;
  }
}

.pricing-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  padding: 0 40px;
}

.pricing-card {
  position: relative;
  padding: 40px 32px;
  background: rgba(255, 255, 255, 0.05);
  backdrop-filter: blur(20px);
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: var(--radius-xl);
  text-align: center;
  transition: transform 0.3s, background 0.3s;
}

.pricing-card:hover {
  transform: translateY(-4px);
  background: rgba(255, 255, 255, 0.08);
}

.pricing-card.popular {
  border-color: var(--accent);
  background: rgba(255, 255, 255, 0.08);
  box-shadow: 0 0 0 1px var(--accent), 0 20px 60px -20px rgba(10, 132, 255, 0.3);
}

.popular-badge {
  position: absolute;
  top: -12px;
  left: 50%;
  transform: translateX(-50%);
  padding: 6px 16px;
  background: var(--accent);
  color: white;
  font-size: 12px;
  font-weight: 600;
  border-radius: 100px;
}

.pricing-header {
  margin-bottom: 32px;
}

.pricing-name {
  font-size: 20px;
  font-weight: 600;
  margin-bottom: 16px;
}

.pricing-price {
  display: flex;
  align-items: baseline;
  justify-content: center;
  gap: 4px;
}

.price-value {
  font-size: 48px;
  font-weight: 700;
}

.price-currency {
  font-size: 24px;
  color: var(--text-secondary);
}

.pricing-period {
  font-size: 14px;
  color: var(--text-tertiary);
  margin-top: 8px;
}

.pricing-features {
  list-style: none;
  text-align: left;
  margin-bottom: 32px;
}

.pricing-features li {
  position: relative;
  padding: 10px 0 10px 20px;
  font-size: 15px;
  border-bottom: 1px solid var(--border);
}

.pricing-features li::before {
  content: '';
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  width: 6px;
  height: 6px;
  background: var(--accent);
  border-radius: 50%;
}

.pricing-features li:last-child {
  border-bottom: none;
}

.pricing-features li.disabled {
  color: var(--text-tertiary);
}

.pricing-features li.disabled::before {
  background: var(--text-tertiary);
}

.pricing-btn {
  display: block;
  width: 100%;
  padding: 16px;
  background: var(--bg-secondary);
  border: none;
  border-radius: var(--radius-md);
  color: var(--text);
  font-size: 15px;
  font-weight: 600;
  text-decoration: none;
  cursor: pointer;
  transition: background 0.2s;
}

.pricing-btn:hover {
  background: var(--bg-tertiary);
}

.pricing-btn.primary {
  background: var(--accent);
  color: white;
}

.pricing-btn.primary:hover {
  filter: brightness(1.1);
}

.faq-list {
  max-width: 800px;
  margin: 0 auto;
}

.faq-item {
  border-bottom: 1px solid var(--border);
}

.faq-question {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 24px 0;
  cursor: pointer;
  font-size: 17px;
  font-weight: 500;
}

.faq-question svg {
  color: var(--text-tertiary);
  transition: transform 0.2s;
}

.faq-item.open .faq-question svg {
  transform: rotate(180deg);
}

.faq-answer {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.3s;
}

.faq-item.open .faq-answer {
  max-height: 200px;
}

.faq-answer p {
  padding-bottom: 24px;
  color: var(--text-secondary);
  line-height: 1.6;
}

.landing-cta {
  text-align: center;
  padding: 100px 40px;
  background: linear-gradient(180deg, transparent 0%, rgba(0, 0, 0, 0.3) 100%);
  position: relative;
  z-index: 1;
}

.cta-content {
  max-width: 600px;
  margin: 0 auto;
}

.cta-title {
  font-size: 40px;
  font-weight: 700;
  margin-bottom: 16px;
}

.cta-subtitle {
  font-size: 18px;
  color: var(--text-secondary);
  margin-bottom: 32px;
}

.landing-footer {
  background: rgba(0, 0, 0, 0.5);
  backdrop-filter: blur(20px);
  border-top: 1px solid var(--border);
  padding: 60px 40px 32px;
  position: relative;
  z-index: 1;
}

.footer-inner {
  max-width: 1200px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 2fr;
  gap: 60px;
}

.footer-desc {
  color: var(--text-tertiary);
  font-size: 14px;
  margin-top: 16px;
}

.footer-links {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 40px;
}

.footer-col {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.footer-col-title {
  font-size: 12px;
  font-weight: 600;
  text-transform: uppercase;
  color: var(--text-tertiary);
  margin-bottom: 8px;
}

.footer-col a {
  color: var(--text-secondary);
  text-decoration: none;
  font-size: 14px;
  transition: color 0.2s;
}

.footer-col a:hover {
  color: var(--text);
}

.footer-bottom {
  max-width: 1200px;
  margin: 40px auto 0;
  padding-top: 24px;
  border-top: 1px solid var(--border);
  text-align: center;
  font-size: 13px;
  color: var(--text-tertiary);
}

/* ===================== AUTH PAGE ===================== */

.auth-body {
  background: #0a0a0a;
  min-height: 100vh;
  position: relative;
  overflow: hidden;
}

/* Aurora Background */
.aurora-bg {
  position: fixed;
  inset: 0;
  z-index: 0;
  overflow: hidden;
}

.aurora-gradient {
  --aurora-1: #0a84ff;
  --aurora-2: #5e5ce6;
  --aurora-3: #bf5af2;
  position: absolute;
  width: 150%;
  height: 150%;
  top: -25%;
  left: -25%;
  background:
    radial-gradient(ellipse 80% 50% at 20% 40%, var(--aurora-1), transparent 50%),
    radial-gradient(ellipse 60% 40% at 70% 60%, var(--aurora-2), transparent 50%),
    radial-gradient(ellipse 50% 60% at 50% 30%, var(--aurora-3), transparent 50%);
  filter: blur(60px);
  opacity: 0.4;
  animation: aurora-move 20s ease-in-out infinite;
  transition: --aurora-1 1s ease, --aurora-2 1s ease, --aurora-3 1s ease;
}

@property --aurora-1 {
  syntax: '<color>';
  initial-value: #0a84ff;
  inherits: false;
}

@property --aurora-2 {
  syntax: '<color>';
  initial-value: #5e5ce6;
  inherits: false;
}

@property --aurora-3 {
  syntax: '<color>';
  initial-value: #bf5af2;
  inherits: false;
}

@keyframes aurora-move {
  0%, 100% {
    transform: translate(0, 0) rotate(0deg);
  }
  25% {
    transform: translate(5%, -5%) rotate(3deg);
  }
  50% {
    transform: translate(-3%, 5%) rotate(-2deg);
  }
  75% {
    transform: translate(-5%, -3%) rotate(2deg);
  }
}

.auth-container {
  display: grid;
  grid-template-columns: 1fr 1fr;
  min-height: 100vh;
  position: relative;
  z-index: 1;
}

.auth-left {
  background: transparent;
  padding: 40px;
  display: flex;
  flex-direction: column;
}

.auth-logo {
  font-size: 24px;
  font-weight: 800;
  letter-spacing: -0.5px;
  color: #fff;
  text-decoration: none;
}

.auth-slider {
  flex: 1;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  padding: 40px 0;
}

.auth-slides {
  position: relative;
  width: 100%;
  max-width: 340px;
  height: 200px;
}

.auth-slide {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  opacity: 0;
  transform: translateX(20px);
  transition: all 0.4s ease;
  pointer-events: none;
}

.auth-slide.active {
  opacity: 1;
  transform: translateX(0);
  pointer-events: auto;
}

.slide-icon {
  width: 72px;
  height: 72px;
  background: rgba(255, 255, 255, 0.1);
  backdrop-filter: blur(10px);
  border-radius: 18px;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 20px;
  color: #fff;
}

.auth-slide h2 {
  font-size: 24px;
  font-weight: 700;
  margin-bottom: 10px;
  color: #fff;
}

.auth-slide p {
  font-size: 15px;
  color: rgba(255, 255, 255, 0.7);
  line-height: 1.5;
  max-width: 300px;
}

.auth-dots {
  display: flex;
  gap: 8px;
  margin-top: 32px;
}

.auth-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.3);
  border: none;
  cursor: pointer;
  transition: all 0.3s;
  padding: 0;
}

.auth-dot:hover {
  background: rgba(255, 255, 255, 0.5);
}

.auth-dot.active {
  background: #fff;
  width: 24px;
  border-radius: 4px;
}

.auth-right {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 40px;
  background: rgba(0, 0, 0, 0.6);
  backdrop-filter: blur(20px);
}

.auth-card {
  width: 100%;
  max-width: 360px;
}

.auth-card.hidden {
  display: none;
}

.auth-title {
  font-size: 28px;
  font-weight: 700;
  margin-bottom: 6px;
  color: #fff;
}

.auth-subtitle {
  font-size: 14px;
  color: rgba(255, 255, 255, 0.6);
  margin-bottom: 24px;
}

.auth-form {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.auth-body .form-group label {
  display: block;
  font-size: 13px;
  font-weight: 500;
  color: rgba(255, 255, 255, 0.6);
  margin-bottom: 6px;
}

.auth-body .form-group input {
  width: 100%;
  padding: 12px 14px;
  background: rgba(255, 255, 255, 0.08);
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: var(--radius-md);
  color: #fff;
  font-size: 14px;
  font-family: var(--font);
  outline: none;
  transition: all 0.2s;
}

.auth-body .form-group input:focus {
  background: rgba(255, 255, 255, 0.12);
  border-color: rgba(255, 255, 255, 0.3);
}

.auth-body .form-group input::placeholder {
  color: rgba(255, 255, 255, 0.4);
}

.form-group label {
  display: block;
  font-size: 13px;
  font-weight: 500;
  color: var(--text-secondary);
  margin-bottom: 6px;
}

.form-group input {
  width: 100%;
  padding: 12px 14px;
  background: var(--bg-secondary);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  color: var(--text);
  font-size: 14px;
  font-family: var(--font);
  outline: none;
  transition: border-color 0.2s;
}

.form-group input:focus {
  border-color: var(--accent);
}

.form-group input::placeholder {
  color: var(--text-tertiary);
}

.password-input {
  position: relative;
}

.password-input input {
  padding-right: 50px;
}

.toggle-password {
  position: absolute;
  right: 14px;
  top: 50%;
  transform: translateY(-50%);
  background: none;
  border: none;
  color: var(--text-tertiary);
  cursor: pointer;
  padding: 4px;
}

.auth-body .toggle-password {
  color: rgba(255, 255, 255, 0.4);
}

.auth-body .toggle-password:hover {
  color: rgba(255, 255, 255, 0.7);
}

.toggle-password:hover {
  color: var(--text-secondary);
}

.form-error {
  color: #ff453a;
  font-size: 13px;
  min-height: 18px;
}

.auth-submit {
  width: 100%;
  padding: 14px;
  background: #fff;
  border: none;
  border-radius: var(--radius-md);
  color: #000;
  font-size: 15px;
  font-weight: 600;
  font-family: var(--font);
  cursor: pointer;
  transition: all 0.2s;
  margin-top: 4px;
}

.auth-submit:hover {
  background: rgba(255, 255, 255, 0.9);
  transform: translateY(-1px);
}

.auth-footer {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  margin-top: 24px;
  font-size: 14px;
  color: rgba(255, 255, 255, 0.5);
}

.auth-switch {
  background: none;
  border: none;
  color: #fff;
  font-size: 14px;
  font-weight: 500;
  cursor: pointer;
}

.auth-switch:hover {
  text-decoration: underline;
}

/* ===================== ADMIN PAGE ===================== */

.admin-app {
  background: transparent;
}

.admin-badge {
  padding: 4px 10px;
  background: rgba(255, 69, 58, 0.15);
  color: var(--red);
  font-size: 11px;
  font-weight: 600;
  border-radius: 100px;
  text-transform: uppercase;
}

.nav-btn.danger {
  color: var(--red);
}

.nav-btn.danger:hover {
  background: rgba(255, 69, 58, 0.1);
}

.admin-table-wrap {
  overflow-x: auto;
  background: var(--bg-secondary);
  border-radius: var(--radius-xl);
  border: 1px solid var(--border);
}

.admin-table {
  width: 100%;
  border-collapse: collapse;
}

.admin-table th,
.admin-table td {
  padding: 16px 20px;
  text-align: left;
  border-bottom: 1px solid var(--border);
}

.admin-table th {
  font-size: 12px;
  font-weight: 600;
  text-transform: uppercase;
  color: var(--text-tertiary);
  background: var(--bg-tertiary);
}

.admin-table th:first-child {
  border-radius: var(--radius-xl) 0 0 0;
}

.admin-table th:last-child {
  border-radius: 0 var(--radius-xl) 0 0;
}

.admin-table tr:last-child td {
  border-bottom: none;
}

.admin-table tr:hover td {
  background: var(--bg-tertiary);
}

.user-cell {
  display: flex;
  align-items: center;
  gap: 12px;
}

.user-avatar-small {
  width: 36px;
  height: 36px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--bg-tertiary);
  border-radius: 50%;
  font-size: 14px;
  font-weight: 600;
}

.user-username {
  font-weight: 500;
}

.plan-expiry {
  font-size: 11px;
  color: var(--text-tertiary);
  margin-top: 4px;
}

.table-actions {
  display: flex;
  gap: 8px;
}

.table-btn {
  width: 36px;
  height: 36px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--bg-tertiary);
  border: none;
  border-radius: var(--radius-sm);
  color: var(--text-secondary);
  cursor: pointer;
  transition: all 0.2s;
}

.table-btn:hover {
  background: var(--accent);
  color: white;
}

.table-btn.danger:hover {
  background: var(--red);
}

.empty-table {
  text-align: center;
  padding: 60px 20px !important;
  color: var(--text-tertiary);
}

.modal-card.modal-small {
  max-width: 400px;
}

.modal-btn.danger {
  background: var(--red);
  color: white;
}

.modal-btn.danger:hover {
  filter: brightness(1.1);
}

/* Promocodes Admin */
.add-btn {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 10px 16px;
  background: var(--accent);
  color: white;
  border: none;
  border-radius: var(--radius-md);
  font-size: 14px;
  font-weight: 500;
  cursor: pointer;
  transition: all 0.2s;
}

.add-btn:hover {
  filter: brightness(1.1);
  transform: translateY(-1px);
}

.promo-code-display {
  font-family: 'SF Mono', Monaco, monospace;
  font-size: 14px;
  font-weight: 600;
  padding: 4px 8px;
  background: var(--bg-tertiary);
  border-radius: 4px;
  color: var(--accent);
}

.promo-desc {
  font-size: 12px;
  color: var(--text-tertiary);
  margin-top: 4px;
}

.badge-expired {
  display: inline-block;
  margin-left: 8px;
  padding: 2px 6px;
  background: rgba(255, 69, 58, 0.15);
  color: var(--red);
  font-size: 10px;
  font-weight: 600;
  border-radius: 4px;
  text-transform: uppercase;
}

.admin-table tr.inactive td {
  opacity: 0.5;
}

.field-hint {
  display: block;
  margin-top: 4px;
  font-size: 12px;
  color: var(--text-tertiary);
}

.form-select,
.form-input {
  width: 100%;
  padding: 14px 18px;
  background: var(--bg-secondary);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  color: var(--text);
  font-size: 15px;
  font-family: var(--font);
  outline: none;
  transition: border-color 0.2s;
}

.form-select:focus,
.form-input:focus {
  border-color: var(--accent);
}

.edit-user-info {
  margin-bottom: 24px;
  padding: 20px;
  background: var(--bg-secondary);
  border-radius: var(--radius-md);
  text-align: center;
}

.edit-user-name {
  font-size: 20px;
  font-weight: 600;
  margin-bottom: 4px;
}

.edit-user-email {
  font-size: 14px;
  color: var(--text-secondary);
}

.log-empty {
  padding: 20px;
  text-align: center;
  color: var(--text-tertiary);
  font-size: 14px;
}

/* ===================== LANDING RESPONSIVE ===================== */

@media (max-width: 1024px) {
  .landing-hero {
    grid-template-columns: 1fr;
    padding: 110px 32px 50px;
    gap: 32px;
    text-align: center;
    overflow: hidden;
  }

  .landing-hero-content {
    display: flex;
    flex-direction: column;
    align-items: center;
  }

  .landing-hero-visual {
    order: -1;
    height: 280px;
    min-height: 280px;
    max-height: 280px;
    overflow: hidden;
  }

  .landing-title {
    font-size: 42px;
  }

  .landing-subtitle {
    max-width: 100%;
    font-size: 16px;
  }

  .hero-mockup {
    max-width: 360px;
  }

  .features-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .pricing-grid {
    grid-template-columns: 1fr;
    max-width: 380px;
    margin: 0 auto;
  }

  .footer-inner {
    grid-template-columns: 1fr;
    gap: 40px;
    text-align: center;
  }

  .cta-title {
    font-size: 32px;
  }

  .cta-subtitle {
    font-size: 16px;
  }
}

@media (max-width: 768px) {
  /* Prevent horizontal scroll */
  .landing-body {
    overflow-x: hidden;
  }

  /* Aurora - reduce for performance */
  .aurora-layer {
    filter: blur(60px);
    opacity: 0.3;
    width: 100vw;
    height: 100vh;
  }

  /* Nav */
  .landing-nav {
    padding: 10px 0;
  }

  .landing-nav-inner {
    padding: 0 16px;
  }

  .landing-nav-links {
    display: none;
  }

  .nav-link-btn {
    display: none;
  }

  .nav-cta-btn {
    padding: 10px 16px;
    font-size: 13px;
  }

  /* Hero */
  .landing-hero {
    padding: 80px 16px 32px;
    gap: 24px;
    overflow: hidden;
  }

  .landing-hero-visual {
    height: 180px;
    min-height: 180px;
    max-height: 180px;
    overflow: hidden;
    transform: scale(0.85);
  }

  .landing-badge {
    padding: 6px 14px;
    font-size: 11px;
    margin-bottom: 12px;
  }

  .landing-title {
    font-size: 28px;
    letter-spacing: -0.5px;
    margin-bottom: 12px;
  }

  .landing-title br {
    display: none;
  }

  .landing-subtitle {
    font-size: 14px;
    margin-bottom: 24px;
    line-height: 1.5;
  }

  .landing-hero-actions {
    flex-direction: column;
    width: 100%;
    gap: 10px;
  }

  .landing-btn {
    width: 100%;
    justify-content: center;
    padding: 12px 20px;
    font-size: 14px;
  }

  .landing-hero-stats {
    flex-wrap: wrap;
    gap: 12px;
    justify-content: center;
    margin-top: 8px;
  }

  .hero-stat {
    min-width: 85px;
  }

  .hero-stat-value {
    font-size: 22px;
  }

  .hero-stat-label {
    font-size: 10px;
  }

  /* Sections */
  .landing-section {
    padding: 50px 16px;
  }

  .section-header-center {
    margin-bottom: 32px;
  }

  .landing-section-title {
    font-size: 24px;
    margin-bottom: 8px;
  }

  .landing-section-subtitle {
    font-size: 14px;
  }

  /* Features */
  .features-grid {
    grid-template-columns: 1fr;
    gap: 16px;
  }

  .feature-card {
    padding: 24px;
  }

  .feature-icon {
    width: 44px;
    height: 44px;
  }

  .feature-title {
    font-size: 16px;
  }

  .feature-desc {
    font-size: 13px;
  }

  /* Pricing */
  .pricing-grid {
    gap: 16px;
    max-width: 100%;
  }

  .pricing-card {
    padding: 28px 24px;
  }

  .pricing-card.popular {
    transform: none;
  }

  .popular-badge {
    font-size: 11px;
    padding: 4px 12px;
  }

  .pricing-name {
    font-size: 18px;
  }

  .price-value {
    font-size: 36px;
  }

  .pricing-features {
    font-size: 14px;
  }

  .pricing-features li {
    padding: 10px 0;
  }

  .pricing-btn {
    padding: 12px 20px;
    font-size: 14px;
  }

  /* FAQ */
  .faq-list {
    gap: 10px;
  }

  .faq-item {
    border-radius: var(--radius-md);
  }

  .faq-question {
    padding: 16px;
    font-size: 14px;
  }

  .faq-answer p {
    padding: 0 16px 16px;
    font-size: 13px;
  }

  /* CTA */
  .landing-cta {
    padding: 60px 16px;
  }

  .cta-title {
    font-size: 26px;
  }

  .cta-subtitle {
    font-size: 14px;
    margin-bottom: 24px;
  }

  .landing-cta .landing-btn.large {
    width: 100%;
  }

  /* Footer */
  .landing-footer {
    padding: 40px 16px 24px;
  }

  .footer-inner {
    gap: 32px;
  }

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

  .footer-links {
    grid-template-columns: 1fr 1fr;
    gap: 24px;
  }

  .footer-col {
    gap: 10px;
  }

  .footer-col-title {
    font-size: 11px;
    margin-bottom: 4px;
  }

  .footer-col a {
    font-size: 13px;
  }

  .footer-bottom {
    margin-top: 24px;
    padding-top: 16px;
    font-size: 12px;
  }

  /* Auth */
  .auth-container {
    grid-template-columns: 1fr;
  }

  .auth-left {
    display: none;
  }

  .auth-right {
    padding: 40px 24px;
    background: rgba(0, 0, 0, 0.7);
  }

  .aurora-gradient {
    opacity: 0.3;
  }

  /* Admin */
  .admin-table th,
  .admin-table td {
    padding: 12px 16px;
    font-size: 14px;
  }

  .admin-table th:nth-child(3),
  .admin-table td:nth-child(3),
  .admin-table th:nth-child(4),
  .admin-table td:nth-child(4),
  .admin-table th:nth-child(5),
  .admin-table td:nth-child(5) {
    display: none;
  }
}

/* Extra small phones */
@media (max-width: 380px) {
  .landing-hero {
    padding: 75px 12px 24px;
    gap: 16px;
  }

  .landing-hero-visual {
    height: 140px;
    min-height: 140px;
    max-height: 140px;
    transform: scale(0.7);
  }

  .landing-badge {
    padding: 5px 12px;
    font-size: 10px;
  }

  .landing-title {
    font-size: 24px;
  }

  .landing-subtitle {
    font-size: 13px;
    margin-bottom: 20px;
  }

  .landing-btn {
    padding: 11px 16px;
    font-size: 13px;
  }

  .landing-hero-stats {
    gap: 8px;
  }

  .hero-stat {
    min-width: 75px;
  }

  .hero-stat-value {
    font-size: 18px;
  }

  .hero-stat-label {
    font-size: 9px;
  }

  .landing-section {
    padding: 36px 12px;
  }

  .landing-section-title {
    font-size: 20px;
  }

  .landing-section-subtitle {
    font-size: 13px;
  }

  .feature-card {
    padding: 18px;
  }

  .feature-title {
    font-size: 15px;
  }

  .feature-desc {
    font-size: 12px;
  }

  .pricing-card {
    padding: 20px 16px;
  }

  .pricing-name {
    font-size: 16px;
  }

  .price-value {
    font-size: 28px;
  }

  .pricing-features li {
    font-size: 13px;
    padding: 8px 0;
  }

  .pricing-btn {
    padding: 10px 16px;
    font-size: 13px;
  }

  .faq-question {
    padding: 14px;
    font-size: 13px;
  }

  .faq-answer p {
    font-size: 12px;
    padding: 0 14px 14px;
  }

  .cta-title {
    font-size: 20px;
  }

  .cta-subtitle {
    font-size: 13px;
  }

  .footer-links {
    grid-template-columns: 1fr;
    text-align: center;
  }

  .footer-col a {
    font-size: 12px;
  }
}

/* ===================== COOKIE BANNER ===================== */

.cookie-banner {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 9999;
  padding: 20px;
  transform: translateY(100%);
  transition: transform 0.4s cubic-bezier(0.16, 1, 0.3, 1);
}

.cookie-banner.show {
  transform: translateY(0);
}

.cookie-content {
  max-width: 800px;
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  padding: 20px 28px;
  background: rgba(255, 255, 255, 0.08);
  backdrop-filter: blur(24px);
  -webkit-backdrop-filter: blur(24px);
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: var(--radius-xl);
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.3);
}

.cookie-content p {
  margin: 0;
  font-size: 14px;
  line-height: 1.6;
  color: var(--text-secondary);
}

.cookie-btn {
  flex-shrink: 0;
  padding: 12px 28px;
  background: var(--accent);
  color: #fff;
  font-size: 14px;
  font-weight: 600;
  border: none;
  border-radius: var(--radius-md);
  cursor: pointer;
  transition: all 0.2s ease;
  white-space: nowrap;
}

.cookie-btn:hover {
  background: var(--accent-secondary);
  transform: translateY(-2px);
  box-shadow: 0 4px 16px var(--accent-glow);
}

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

@media (max-width: 640px) {
  .cookie-content {
    flex-direction: column;
    text-align: center;
    padding: 20px;
  }

  .cookie-content p {
    font-size: 13px;
  }

  .cookie-btn {
    width: 100%;
  }
}

/* ===================== LEGAL PAGES ===================== */

.legal-body {
  background: var(--bg);
  min-height: 100vh;
  overflow-x: hidden;
}

.legal-content {
  max-width: 800px;
  margin: 0 auto;
  padding: 120px 24px 80px;
  position: relative;
  z-index: 1;
}

.legal-container {
  background: rgba(255, 255, 255, 0.03);
  backdrop-filter: blur(20px);
  border: 1px solid var(--border);
  border-radius: var(--radius-xl);
  padding: 48px;
}

.legal-container h1 {
  font-size: 36px;
  font-weight: 700;
  margin-bottom: 8px;
  letter-spacing: -1px;
}

.legal-updated {
  font-size: 14px;
  color: var(--text-tertiary);
  margin-bottom: 40px;
  padding-bottom: 24px;
  border-bottom: 1px solid var(--border);
}

.legal-section {
  margin-bottom: 40px;
}

.legal-section:last-child {
  margin-bottom: 0;
}

.legal-section h2 {
  font-size: 20px;
  font-weight: 600;
  margin-bottom: 16px;
  color: var(--text);
}

.legal-section h3 {
  font-size: 16px;
  font-weight: 600;
  margin: 20px 0 12px;
  color: var(--text);
}

.legal-section p {
  font-size: 15px;
  line-height: 1.7;
  color: var(--text-secondary);
  margin-bottom: 12px;
}

.legal-section ul {
  list-style: none;
  padding: 0;
  margin: 0 0 16px;
}

.legal-section li {
  font-size: 15px;
  line-height: 1.7;
  color: var(--text-secondary);
  padding-left: 24px;
  position: relative;
  margin-bottom: 8px;
}

.legal-section li::before {
  content: '';
  position: absolute;
  left: 8px;
  top: 10px;
  width: 6px;
  height: 6px;
  background: var(--accent);
  border-radius: 50%;
}

.legal-section li strong {
  color: var(--text);
}

.legal-section a {
  color: var(--accent);
  text-decoration: none;
  transition: opacity 0.2s;
}

.legal-section a:hover {
  opacity: 0.8;
}

.legal-acceptance {
  background: rgba(10, 132, 255, 0.1);
  border: 1px solid rgba(10, 132, 255, 0.2);
  border-radius: var(--radius-md);
  padding: 20px;
  margin-top: 40px;
}

.legal-acceptance p {
  margin: 0;
  text-align: center;
}

.legal-footer {
  background: rgba(0, 0, 0, 0.5);
  backdrop-filter: blur(20px);
  border-top: 1px solid var(--border);
  padding: 24px;
  position: relative;
  z-index: 1;
}

.legal-footer-inner {
  max-width: 800px;
  margin: 0 auto;
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 14px;
  color: var(--text-tertiary);
}

.legal-footer-links {
  display: flex;
  gap: 24px;
}

.legal-footer-links a {
  color: var(--text-secondary);
  text-decoration: none;
  transition: color 0.2s;
}

.legal-footer-links a:hover {
  color: var(--text);
}

@media (max-width: 768px) {
  .legal-content {
    padding: 100px 16px 60px;
  }

  .legal-container {
    padding: 32px 24px;
  }

  .legal-container h1 {
    font-size: 28px;
  }

  .legal-section h2 {
    font-size: 18px;
  }

  .legal-section p,
  .legal-section li {
    font-size: 14px;
  }

  .legal-footer-inner {
    flex-direction: column;
    gap: 16px;
    text-align: center;
  }

  .legal-footer-links {
    gap: 16px;
  }
}
