/* Theme: Vortex (vortex) */
/* A premium dark workspace for software architects, blending sharp architectural lines with soft atmospheric glass overlays. */

@tailwind base;
@tailwind components;
@tailwind utilities;

@import url("https://fonts.googleapis.com/css2?family=Source+Serif+4:ital,wght@0,100;0,200;0,300;0,400;0,500;0,600;0,700;0,800;0,900;1,100;1,200;1,300;1,400;1,500;1,600;1,700;1,800;1,900&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Inter:ital,wght@0,100;0,200;0,300;0,400;0,500;0,600;0,700;0,800;0,900;1,100;1,200;1,300;1,400;1,500;1,600;1,700;1,800;1,900&display=swap");
@import url("https://fonts.googleapis.com/css2?family=JetBrains+Mono:ital,wght@0,100;0,200;0,300;0,400;0,500;0,600;0,700;0,800;0,900;1,100;1,200;1,300;1,400;1,500;1,600;1,700;1,800;1,900&display=swap");

@layer base {
  :root {
    /* Custom neutral ramp matched precisely to the observed grey progression. */
    --palette-neutral-100: #FAFAFA;
    --palette-neutral-150: #F9F9F9;
    --palette-neutral-200: #F4F4F4;
    --palette-neutral-250: #ECECEC;
    --palette-neutral-300: #E1E1E1;
    --palette-neutral-350: #D3D3D3;
    --palette-neutral-400: #C1C1C1;
    --palette-neutral-450: #ACACAC;
    --palette-neutral-500: #949494;
    --palette-neutral-550: #787878;
    --palette-neutral-600: #5F5F5F;
    --palette-neutral-650: #4A4A4A;
    --palette-neutral-700: #383838;
    --palette-neutral-750: #2B2B2B;
    --palette-neutral-800: #212121;
    --palette-neutral-850: #1B1B1B;
    --palette-neutral-900: #1A1A1A;
    /* Vivid cool brand violet serving as the core interactive anchor. */
    --palette-brand-100: #FAFAFF;
    --palette-brand-150: #F9F8FF;
    --palette-brand-200: #F3F3FF;
    --palette-brand-250: #EBE9FF;
    --palette-brand-300: #DFDCFF;
    --palette-brand-350: #CFCCFF;
    --palette-brand-400: #BCB8FF;
    --palette-brand-450: #A7A0FF;
    --palette-brand-500: #8E85FF;
    --palette-brand-550: #4D41FF;
    --palette-brand-600: #1504FF;
    --palette-brand-650: #0B00D8;
    --palette-brand-700: #0800B0;
    --palette-brand-750: #060090;
    --palette-brand-800: #050079;
    --palette-brand-850: #04006B;
    --palette-brand-900: #040067;
    --palette-danger-100: #FFF9F9;
    --palette-danger-150: #FFF7F7;
    --palette-danger-200: #FFEFEF;
    --palette-danger-250: #FFE3E3;
    --palette-danger-300: #FFD2D2;
    --palette-danger-350: #FFBCBC;
    --palette-danger-400: #FFA1A1;
    --palette-danger-450: #FF8181;
    --palette-danger-500: #FF5D5D;
    --palette-danger-550: #FF1919;
    --palette-danger-600: #E10000;
    --palette-danger-650: #AF0000;
    --palette-danger-700: #870000;
    --palette-danger-750: #670000;
    --palette-danger-800: #500000;
    --palette-danger-850: #420000;
    --palette-danger-900: #3E0000;
    --palette-warning-100: #FFFAEE;
    --palette-warning-150: #FFF9E9;
    --palette-warning-200: #FFF5DB;
    --palette-warning-250: #FFEFC3;
    --palette-warning-300: #FFE6A2;
    --palette-warning-350: #FFDA78;
    --palette-warning-400: #FFCC44;
    --palette-warning-450: #FFBB08;
    --palette-warning-500: #C18B00;
    --palette-warning-550: #9C7100;
    --palette-warning-600: #7C5900;
    --palette-warning-650: #614600;
    --palette-warning-700: #4B3600;
    --palette-warning-750: #392900;
    --palette-warning-800: #2C2000;
    --palette-warning-850: #251A00;
    --palette-warning-900: #221900;
    --palette-success-100: #EBFFF6;
    --palette-success-150: #E6FFF3;
    --palette-success-200: #D7FFEC;
    --palette-success-250: #BEFFE0;
    --palette-success-300: #9BFFCF;
    --palette-success-350: #6EFFB9;
    --palette-success-400: #37FF9E;
    --palette-success-450: #00F77E;
    --palette-success-500: #00AB58;
    --palette-success-550: #008B47;
    --palette-success-600: #006E38;
    --palette-success-650: #00562C;
    --palette-success-700: #004222;
    --palette-success-750: #00331A;
    --palette-success-800: #002814;
    --palette-success-850: #002111;
    --palette-success-900: #001F10;
    --palette-info-100: #F4FBFF;
    --palette-info-150: #F0FAFF;
    --palette-info-200: #E4F6FE;
    --palette-info-250: #D0F0FE;
    --palette-info-300: #B4E6FD;
    --palette-info-350: #90DAFC;
    --palette-info-400: #64CBFA;
    --palette-info-450: #31BAF7;
    --palette-info-500: #099EE1;
    --palette-info-550: #0780B7;
    --palette-info-600: #056692;
    --palette-info-650: #034F72;
    --palette-info-700: #023D58;
    --palette-info-750: #022F44;
    --palette-info-800: #012535;
    --palette-info-850: #011F2C;
    --palette-info-900: #011D29;
    --palette-accent-100: #FAFAFD;
    --palette-accent-150: #F8F9FD;
    --palette-accent-200: #F2F4FB;
    --palette-accent-250: #E9EBF7;
    --palette-accent-300: #DBE0F3;
    --palette-accent-350: #CAD1ED;
    --palette-accent-400: #B6BFE5;
    --palette-accent-450: #9EAADB;
    --palette-accent-500: #8392D0;
    --palette-accent-550: #5469C0;
    --palette-accent-600: #3A4EA3;
    --palette-accent-650: #2D3D81;
    --palette-accent-700: #232F65;
    --palette-accent-750: #1B2550;
    --palette-accent-800: #151D40;
    --palette-accent-850: #121936;
    --palette-accent-900: #111833;
  }

  :root {
    --radius: 1rem;
    --radius-sm: calc(var(--radius) - 4px);
    --radius-md: calc(var(--radius) - 2px);
    --radius-lg: var(--radius);
    --radius-xl: calc(var(--radius) + 4px);
    --background: #FFFFFF;
    --foreground: #0F1010;
    --card: var(--palette-neutral-200);
    --card-foreground: var(--palette-neutral-900);
    --popover: var(--palette-neutral-100);
    --popover-foreground: var(--palette-neutral-900);
    --primary: var(--palette-brand-600);
    --primary-foreground: #FFFFFF;
    --secondary: var(--palette-neutral-200);
    --secondary-foreground: var(--palette-neutral-900);
    --muted: var(--palette-neutral-200);
    --muted-foreground: var(--palette-neutral-700);
    --accent: var(--palette-brand-100);
    --accent-foreground: var(--palette-brand-700);
    --destructive: var(--palette-danger-600);
    --destructive-foreground: #FFFFFF;
    --border: var(--palette-neutral-200);
    --input: var(--palette-neutral-300);
    --ring: var(--palette-brand-500);
    --chart-1: var(--palette-brand-500);
    --chart-2: var(--palette-accent-500);
    --chart-3: var(--palette-info-500);
    --chart-4: var(--palette-success-500);
    --chart-5: var(--palette-warning-500);
    --sidebar: var(--palette-neutral-100);
    --sidebar-foreground: var(--palette-neutral-800);
    --sidebar-primary: var(--palette-brand-600);
    --sidebar-primary-foreground: #FFFFFF;
    --sidebar-accent: var(--palette-neutral-200);
    --sidebar-accent-foreground: var(--palette-neutral-900);
    --sidebar-border: var(--palette-neutral-200);
    --sidebar-ring: var(--palette-brand-500);
    --font-sans: "Source Serif 4", system-ui, sans-serif;
    --font-display: "Inter", system-ui, sans-serif;
    --font-mono: "JetBrains Mono", ui-monospace, monospace;
    --text-hero: 400 2.625rem/2.875rem var(--font-display);
    --text-hero-tracking: -0.05em;
    --text-title: 400 2.25rem/2.5625rem var(--font-display);
    --text-title-tracking: -0.05em;
    --text-heading: 300 1.5rem/1.625rem var(--font-display);
    --text-body: 400 1.25rem/1.5rem var(--font-sans);
    --text-caption: 400 0.8125rem/1rem var(--font-display);
    --text-label: 400 1rem/1.25rem var(--font-sans);
    --text-overline: 600 0.8125rem/1rem var(--font-sans);
    --text-overline-tracking: 0.08em;
    --text-overline-transform: uppercase;
    --shadow-xs: 0 1px 2px rgba(0,0,0,0.05);
    --shadow-sm: rgba(255, 255, 255, 0.04) 0px 1px 0px 0px inset, rgba(0, 0, 0, 0.6) 0px 40px 80px -20px;
    --shadow-md: 0 4px 12px rgba(0,0,0,0.1);
    --shadow-lg: 0 12px 24px rgba(0,0,0,0.15);
    --shadow-xl: 0 20px 40px rgba(0,0,0,0.2);
    --gradient-brand_wash: radial-gradient(140% 130% at 18% 22%, rgba(143, 135, 255, 0.14) 0%, rgba(143, 135, 255, 0) 80%);
  }

  .dark {
    --background: #0F1010;
    --foreground: #FFFFFF;
    --card: var(--palette-neutral-900);
    --card-foreground: var(--palette-neutral-100);
    --popover: var(--palette-neutral-900);
    --popover-foreground: var(--palette-neutral-100);
    --primary: var(--palette-brand-500);
    --primary-foreground: var(--palette-neutral-900);
    --secondary: var(--palette-neutral-800);
    --secondary-foreground: var(--palette-neutral-100);
    --muted: var(--palette-neutral-800);
    --muted-foreground: var(--palette-neutral-400);
    --accent: var(--palette-neutral-800);
    --accent-foreground: var(--palette-neutral-100);
    --destructive: var(--palette-danger-500);
    --destructive-foreground: var(--palette-neutral-900);
    --border: var(--palette-neutral-800);
    --input: var(--palette-neutral-800);
    --ring: var(--palette-brand-500);
    --chart-1: var(--palette-brand-500);
    --chart-2: var(--palette-accent-500);
    --chart-3: var(--palette-info-500);
    --chart-4: var(--palette-success-500);
    --chart-5: var(--palette-warning-500);
    --sidebar: #0F1010;
    --sidebar-foreground: var(--palette-neutral-200);
    --sidebar-primary: var(--palette-brand-500);
    --sidebar-primary-foreground: var(--palette-neutral-900);
    --sidebar-accent: var(--palette-neutral-800);
    --sidebar-accent-foreground: var(--palette-neutral-100);
    --sidebar-border: var(--palette-neutral-800);
    --sidebar-ring: var(--palette-brand-500);
  }
}

@layer base {
  * { border-color: var(--border); }
  body { background-color: var(--background); color: var(--foreground); font-family: var(--font-sans); }
}

@layer components {
  .text-hero {
    font: var(--text-hero);
    letter-spacing: var(--text-hero-tracking);
  }
  .text-title {
    font: var(--text-title);
    letter-spacing: var(--text-title-tracking);
  }
  .text-heading {
    font: var(--text-heading);
  }
  .text-body {
    font: var(--text-body);
  }
  .text-caption {
    font: var(--text-caption);
  }
  .text-label {
    font: var(--text-label);
  }
  .text-overline {
    font: var(--text-overline);
    letter-spacing: var(--text-overline-tracking);
    text-transform: var(--text-overline-transform);
  }
}