/* JA Jayagiri Sans — loaded directly from brand_assets */
@font-face {
  font-family: 'JA Jayagiri Sans';
  src: url('brand_assets/fonts/Sans/Sans.woff') format('woff'),
       url('brand_assets/fonts/Sans/Sans.ttf')  format('truetype');
  font-weight: 100 900;
  font-style: normal;
  font-display: swap;
}

/* IBM Plex Sans — self-hosted (GDPR-safe, no Google Fonts) */
/* Variable font: one file covers weights 300–700 */
@font-face {
  font-family: 'IBM Plex Sans';
  font-style: normal;
  font-weight: 300 700;
  font-display: swap;
  src: url('fonts/ibm-plex-sans-latin-ext.woff2') format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
  font-family: 'IBM Plex Sans';
  font-style: normal;
  font-weight: 300 700;
  font-display: swap;
  src: url('fonts/ibm-plex-sans-latin.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: 'IBM Plex Sans';
  font-style: italic;
  font-weight: 400;
  font-display: swap;
  src: url('fonts/ibm-plex-sans-italic-latin-ext.woff2') format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
  font-family: 'IBM Plex Sans';
  font-style: italic;
  font-weight: 400;
  font-display: swap;
  src: url('fonts/ibm-plex-sans-italic-latin.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

/* IBM Plex Mono — self-hosted */
@font-face {
  font-family: 'IBM Plex Mono';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url('fonts/ibm-plex-mono-400-latin-ext.woff2') format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
  font-family: 'IBM Plex Mono';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url('fonts/ibm-plex-mono-400-latin.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: 'IBM Plex Mono';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url('fonts/ibm-plex-mono-500-latin-ext.woff2') format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
  font-family: 'IBM Plex Mono';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url('fonts/ibm-plex-mono-500-latin.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: 'IBM Plex Mono';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url('fonts/ibm-plex-mono-600-latin-ext.woff2') format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
  font-family: 'IBM Plex Mono';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url('fonts/ibm-plex-mono-600-latin.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

:root {
  /* Hawk Colour Tokens */
  --hawk-teal: #2C7A7B;
  --hawk-teal-bright: #3D9B9C;
  --hawk-green: #6B9F7D;
  --hawk-charcoal: #2D3748;
  --hawk-grey: #E5E7EB;
  --hawk-purple: #7C3AED;

  /* Background layers */
  --bg-base: #0D1117;
  --bg-surface: #161B22;
  --bg-elevated: #21262D;
  --bg-deep: #0A0E14;

  /* Innovation Centre - flipped/inverted palette */
  --inv-bg: #1F2733;
  --inv-surface: #2D3748;
  --inv-text: #F6F5F9;
  --inv-accent: #9F7AEA;
  --inv-teal: #4FD1C5;

  /* Border Radius */
  --radius-btn: 12px;
  --radius-pill-sm: 6px;
  --radius-pill-md: 8px;
  --radius-pill-lg: 12px;
  --radius-card: 16px;

  /* Box Shadows */
  --shadow-1: 0px 1px 2px 0px rgba(16,24,40,0.04);
  --shadow-2: 0px 1px 4px 0px rgba(16,24,40,0.04);
  --shadow-3: 0px 4px 8px -2px rgba(16,24,40,0.07);
  --shadow-4: 0px 12px 16px -4px rgba(16,24,40,0.06);
  --shadow-6: 0px 24px 48px -12px rgba(16,24,40,0.18);
  --shadow-teal: 0px 0px 40px -8px rgba(44,122,123,0.3);

  /* Typography Sizes */
  --fs-caption: 0.5rem;
  --fs-body-2: 0.875rem;
  --fs-body-1: 1rem;
  --fs-heading-3: 1.5rem;
  --fs-heading-2: 2rem;
  --fs-heading-1: 2.625rem;
  --fs-display-1: 3.5rem;

  /* Font Families */
  --font-body: "IBM Plex Sans", Helvetica, Arial, sans-serif;
  --font-mono: "IBM Plex Mono", Helvetica, Arial, monospace;
  --font-brand: "JA Jayagiri Sans", "IBM Plex Sans", sans-serif;

  /* Spacing tokens */
  --space-1: 4px;
  --space-2: 8px;
  --space-3: 12px;
  --space-4: 16px;
  --space-5: 20px;
  --space-6: 24px;
  --space-8: 32px;
  --space-10: 40px;
  --space-12: 48px;
  --space-16: 64px;
  --space-20: 80px;
  --space-24: 96px;
}

*, *::before, *::after {
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  box-sizing: border-box;
}

body {
  font-family: var(--font-body);
  font-size: var(--fs-body-1);
  line-height: 1.6;
  color: #FFFFFF;
  background-color: var(--bg-base);
  margin: 0;
  padding: 0;
}

/* SVG rendering — improves crispness on Safari/Retina (Fix 5) */
img[src$=".svg"] {
  image-rendering: -webkit-optimize-contrast;
}
svg {
  shape-rendering: geometricPrecision;
}
