/* Theme: Sky (sky) */
/* A playful retro ecommerce interface balancing compact high-contrast layout, tactile shadows, and soft sky-blue radial washes. */

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

@import url("https://fonts.googleapis.com/css2?family=DM+Sans: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=Bricolage+Grotesque: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 {
    /* Balanced slate grey matching the brand's physical neutral ramp. */
    --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;
    /* Deep charcoal ink anchoring the retro-minimalist framework. */
    --palette-brand-100: #FAFAFA;
    --palette-brand-150: #F9F9F9;
    --palette-brand-200: #F4F4F4;
    --palette-brand-250: #ECECEC;
    --palette-brand-300: #E1E1E1;
    --palette-brand-350: #D3D3D3;
    --palette-brand-400: #C1C1C1;
    --palette-brand-450: #ACACAC;
    --palette-brand-500: #949494;
    --palette-brand-550: #787878;
    --palette-brand-600: #5F5F5F;
    --palette-brand-650: #4A4A4A;
    --palette-brand-700: #383838;
    --palette-brand-750: #2B2B2B;
    --palette-brand-800: #212121;
    --palette-brand-850: #1B1B1B;
    --palette-brand-900: #1A1A1A;
    --palette-danger-100: #FEF9FA;
    --palette-danger-150: #FEF7F9;
    --palette-danger-200: #FEF0F3;
    --palette-danger-250: #FCE5EA;
    --palette-danger-300: #FBD5DD;
    --palette-danger-350: #F8C1CD;
    --palette-danger-400: #F5A8B9;
    --palette-danger-450: #F18BA1;
    --palette-danger-500: #EC6A87;
    --palette-danger-550: #E62F57;
    --palette-danger-600: #C5173D;
    --palette-danger-650: #9A112F;
    --palette-danger-700: #770D24;
    --palette-danger-750: #5C091B;
    --palette-danger-800: #480715;
    --palette-danger-850: #3C0612;
    --palette-danger-900: #380611;
    --palette-warning-100: #FFF9F1;
    --palette-warning-150: #FFF8EC;
    --palette-warning-200: #FEF3E0;
    --palette-warning-250: #FEEBCA;
    --palette-warning-300: #FDDFAC;
    --palette-warning-350: #FBD086;
    --palette-warning-400: #FABD58;
    --palette-warning-450: #F7A822;
    --palette-warning-500: #CE8508;
    --palette-warning-550: #A76B06;
    --palette-warning-600: #855504;
    --palette-warning-650: #684203;
    --palette-warning-700: #503302;
    --palette-warning-750: #3D2702;
    --palette-warning-800: #2F1E01;
    --palette-warning-850: #271901;
    --palette-warning-900: #251701;
    --palette-success-100: #EEFEF9;
    --palette-success-150: #EAFDF7;
    --palette-success-200: #DCFCF2;
    --palette-success-250: #C6FBE9;
    --palette-success-300: #A7F8DD;
    --palette-success-350: #7FF5CE;
    --palette-success-400: #4EF1BB;
    --palette-success-450: #15EBA4;
    --palette-success-500: #0FA976;
    --palette-success-550: #0C895F;
    --palette-success-600: #096D4C;
    --palette-success-650: #07553B;
    --palette-success-700: #05412E;
    --palette-success-750: #043223;
    --palette-success-800: #03271B;
    --palette-success-850: #032117;
    --palette-success-900: #021F15;
    --palette-info-100: #EFFDFF;
    --palette-info-150: #EBFCFF;
    --palette-info-200: #DDFAFE;
    --palette-info-250: #C6F6FE;
    --palette-info-300: #A6F1FD;
    --palette-info-350: #7DEAFC;
    --palette-info-400: #4BE1FB;
    --palette-info-450: #11D7F9;
    --palette-info-500: #05A3BE;
    --palette-info-550: #04849A;
    --palette-info-600: #03697B;
    --palette-info-650: #025260;
    --palette-info-700: #013F4A;
    --palette-info-750: #013139;
    --palette-info-800: #01262C;
    --palette-info-850: #012025;
    --palette-info-900: #001E23;
    --palette-accent-100: #F5FBFF;
    --palette-accent-150: #F1FAFF;
    --palette-accent-200: #E5F6FF;
    --palette-accent-250: #D1EEFF;
    --palette-accent-300: #B5E4FF;
    --palette-accent-350: #91D7FF;
    --palette-accent-400: #65C6FF;
    --palette-accent-450: #32B3FF;
    --palette-accent-500: #009AF7;
    --palette-accent-550: #007DC8;
    --palette-accent-600: #0063A0;
    --palette-accent-650: #004D7D;
    --palette-accent-700: #003C60;
    --palette-accent-750: #002E4A;
    --palette-accent-800: #00243A;
    --palette-accent-850: #001E30;
    --palette-accent-900: #001C2D;
  }

  :root {
    --radius: 1.125rem;
    --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: #0A0A0A;
    --card: var(--palette-neutral-100);
    --card-foreground: var(--palette-neutral-900);
    --popover: var(--palette-neutral-100);
    --popover-foreground: var(--palette-neutral-900);
    --primary: var(--palette-brand-900);
    --primary-foreground: var(--palette-neutral-100);
    --secondary: var(--palette-neutral-200);
    --secondary-foreground: var(--palette-neutral-900);
    --muted: var(--palette-neutral-150);
    --muted-foreground: var(--palette-neutral-700);
    --accent: var(--palette-neutral-200);
    --accent-foreground: var(--palette-neutral-900);
    --destructive: var(--palette-danger-600);
    --destructive-foreground: var(--palette-neutral-100);
    --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-success-500);
    --chart-4: var(--palette-warning-500);
    --chart-5: var(--palette-danger-500);
    --sidebar: var(--palette-neutral-150);
    --sidebar-foreground: var(--palette-neutral-900);
    --sidebar-primary: var(--palette-brand-900);
    --sidebar-primary-foreground: var(--palette-neutral-100);
    --sidebar-accent: var(--palette-neutral-250);
    --sidebar-accent-foreground: var(--palette-neutral-900);
    --sidebar-border: var(--palette-neutral-200);
    --sidebar-ring: var(--palette-brand-500);
    --font-sans: "DM Sans", system-ui, sans-serif;
    --font-display: "Bricolage Grotesque", system-ui, sans-serif;
    --font-mono: "DM Sans", ui-monospace, monospace;
    --text-hero: 400 3.5rem/3.75rem var(--font-display);
    --text-hero-tracking: -0.01em;
    --text-title: 400 2.25rem/2.625rem var(--font-display);
    --text-heading: 400 1.5rem/2rem var(--font-display);
    --text-body: 400 0.875rem/0.875rem var(--font-sans);
    --text-body-transform: uppercase;
    --text-caption: 400 0.75rem/0.8125rem var(--font-sans);
    --text-caption-transform: uppercase;
    --text-label: 400 0.875rem/0.875rem var(--font-sans);
    --text-label-transform: uppercase;
    --text-overline: 400 0.75rem/0.8125rem 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: color(srgb 1 1 1 / 0.1) 0px 0px 0px 1px inset, color(srgb 1 1 1 / 0.9) 1.8px 3px 0px -2px inset, color(srgb 1 1 1 / 0.8) -2px -2px 0px -2px inset, color(srgb 1 1 1 / 0.6) -3px -8px 1px -6px inset, color(srgb 0 0 0 / 0.12) -0.3px -1px 4px 0px inset, color(srgb 0 0 0 / 0.2) -1.5px 2.5px 0px -2px inset, color(srgb 0 0 0 / 0.2) 0px 3px 4px -2px inset, color(srgb 0 0 0 / 0.1) 2px -6.5px 1px -4px inset, color(srgb 0 0 0 / 0.1) 0px 1px 5px 0px, color(srgb 0 0 0 / 0.08) 0px 6px 16px 0px;
    --shadow-md: color(srgb 1 1 1 / 0.1) 0px 0px 0px 1px inset, color(srgb 0 0 0 / 0.15) 0px 8px 24px 0px;
    --shadow-lg: color(srgb 1 1 1 / 0.1) 0px 0px 0px 1px inset, color(srgb 0 0 0 / 0.2) 0px 12px 32px 0px;
    --shadow-xl: color(srgb 1 1 1 / 0.1) 0px 0px 0px 1px inset, color(srgb 0 0 0 / 0.25) 0px 20px 48px 0px;
    --gradient-brand_wash: radial-gradient(at 50% 30%, #9DD5F1, #8FD5FF);
  }

  .dark {
    --background: var(--palette-neutral-900);
    --foreground: var(--palette-neutral-100);
    --card: var(--palette-neutral-850);
    --card-foreground: var(--palette-neutral-100);
    --popover: var(--palette-neutral-850);
    --popover-foreground: var(--palette-neutral-100);
    --primary: var(--palette-brand-100);
    --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-350);
    --accent: var(--palette-neutral-800);
    --accent-foreground: var(--palette-neutral-100);
    --destructive: var(--palette-danger-400);
    --destructive-foreground: var(--palette-neutral-900);
    --border: var(--palette-neutral-800);
    --input: var(--palette-neutral-700);
    --ring: var(--palette-brand-400);
    --chart-1: var(--palette-brand-300);
    --chart-2: var(--palette-accent-300);
    --chart-3: var(--palette-success-300);
    --chart-4: var(--palette-warning-300);
    --chart-5: var(--palette-danger-300);
    --sidebar: var(--palette-neutral-900);
    --sidebar-foreground: var(--palette-neutral-100);
    --sidebar-primary: var(--palette-brand-100);
    --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-400);
  }
}

@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);
  }
  .text-heading {
    font: var(--text-heading);
  }
  .text-body {
    font: var(--text-body);
    text-transform: var(--text-body-transform);
  }
  .text-caption {
    font: var(--text-caption);
    text-transform: var(--text-caption-transform);
  }
  .text-label {
    font: var(--text-label);
    text-transform: var(--text-label-transform);
  }
  .text-overline {
    font: var(--text-overline);
    letter-spacing: var(--text-overline-tracking);
    text-transform: var(--text-overline-transform);
  }
}