

@font-face {
    font-family: "Sora";
    src: url("../Assets/Fonts/Sora-Medium.ttf");
    font-weight: 500;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'BebasNeue';
    src: url('../Assets/Fonts/bebas_neue/BebasNeue-Regular.ttf');
}

@font-face {
    font-family: 'Workbench';
    src: url('../Assets/Fonts/Workbench-Regular-VariableFont_BLED,SCAN.ttf');
}

@font-face {
    font-family: 'Ethnocentric';
    src: url('../Assets/Fonts/Ethnocentric-Regular.otf');
}




:root {

    --g-top: #29c7fa;
    --g-mid1: #25b8ea;
    --g-mid2: #1e98c7;
    --g-mid3: #136993;
    --g-mid4: #08395f;
    --g-bot: #022044;

    /* Pre-built gradients — use these rather than writing
       gradient values inline each time */
    --gradient-brand: linear-gradient(180deg, var(--g-top) 0%, var(--g-bot) 100%);
    --gradient-brand-h: linear-gradient(135deg, var(--g-top) 0%, var(--g-bot) 100%);
    --gradient-cta: linear-gradient(135deg, #0066ff, #00d4ff);
    --gradient-dark-card: linear-gradient(180deg, #303235, #000000);

    /* Semantic shorthand — use these in components */
    --accent: var(--g-top);
    --accent-2: var(--g-mid2);


    --bg: #0b0f14;
    /* page background                 */
    --bglight: #353535;
    /* lighter section background      */
    --surface: #0f1722;
    /* standard card / panel           */
    --surface-2: #0b1220;
    /* deeper nested panel             */


    /* ----------------------------------------------------------
       BORDER COLOURS
    ---------------------------------------------------------- */
    --border-subtle: rgba(255, 255, 255, 0.06);
    /* barely visible      */
    --border-default: rgba(255, 255, 255, 0.10);
    /* standard card edge  */
    --border-medium: rgba(255, 255, 255, 0.18);
    /* more prominent      */
    --border-accent: rgba(41, 199, 250, 0.22);
    /* cyan-tinted border  */
    --border-accent-strong: rgba(41, 199, 250, 0.4);


    /* ----------------------------------------------------------
       TEXT COLOURS
       1 = primary (near white), 2 = secondary, 3 = muted/hint
    ---------------------------------------------------------- */
    --text-1: rgba(255, 255, 255, 0.92);
    --text-2: rgba(255, 255, 255, 0.72);
    --text-3: rgba(255, 255, 255, 0.55);


    /* ----------------------------------------------------------
       TYPOGRAPHY SCALE
       Use these size tokens instead of writing px values inline.
       Named by visual role, not by pixel value — so you can
       adjust the scale here without hunting through files.
    ---------------------------------------------------------- */
    --font-body: system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
    --font-heading: "Sora", var(--font-body);
    --font-display: "BebasNeue", var(--font-heading);
    --font-tech: "Ethnocentric", var(--font-heading);
    --font-mono: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;

    /* Font sizes */
    --text-xs: 0.72rem;
    /* ~11.5px — eyebrows, labels, legal    */
    --text-sm: 0.85rem;
    /* ~13.5px — small captions, meta       */
    --text-base: 0.97rem;
    /* ~15.5px — body copy                  */
    --text-md: 1.05rem;
    /* ~17px   — slightly larger body       */
    --text-lg: 1.2rem;
    /* ~19px   — subheadings, card titles   */
    --text-xl: 1.45rem;
    /* ~23px   — section subheadings        */
    --text-2xl: clamp(1.8rem, 3vw, 2.5rem);
    /* section headings  */
    --text-3xl: clamp(2.2rem, 4vw, 3.6rem);
    /* major headings    */
    --text-hero: clamp(3rem, 7vw, 6rem);
    /* hero display      */

    /* Line heights */
    --leading-tight: 1.08;
    --leading-snug: 1.3;
    --leading-normal: 1.5;
    --leading-relaxed: 1.7;

    /* Letter spacing */
    --tracking-tight: -0.02em;
    --tracking-normal: 0em;
    --tracking-wide: 0.08em;
    --tracking-wider: 0.14em;
    --tracking-widest: 0.22em;


    /* ----------------------------------------------------------
       SPACING SCALE
       A consistent rhythm. Use multiples of 4px.
       --space-1 = 4px, --space-2 = 8px ... --space-16 = 64px
    ---------------------------------------------------------- */
    --space-1: 4px;
    --space-2: 8px;
    --space-3: 12px;
    --space-4: 16px;
    --space-5: 20px;
    --space-6: 24px;
    --space-7: 28px;
    --space-8: 32px;
    --space-10: 40px;
    --space-12: 48px;
    --space-14: 56px;
    --space-16: 64px;
    --space-20: 80px;
    --space-24: 96px;

    /* Section padding — use these on every <section> */
    --section-pad-y: 80px;
    --section-pad-x: 5%;


    /* ----------------------------------------------------------
       BORDER RADIUS SCALE
    ---------------------------------------------------------- */
    --radius-sm: 6px;
    --radius-md: 10px;
    --radius-lg: 16px;
    --radius-xl: 20px;
    --radius-2xl: 26px;
    --radius-full: 999px;


    /* ----------------------------------------------------------
       SHADOW SCALE
    ---------------------------------------------------------- */
    --shadow-sm: 0 4px 12px rgba(0, 0, 0, 0.25);
    --shadow-md: 0 8px 32px rgba(0, 0, 0, 0.37);
    --shadow-lg: 0 25px 60px rgba(2, 32, 68, 0.18);
    --shadow-cta: 0 4px 15px rgba(0, 102, 255, 0.3);
    --shadow-cta-hover: 0 6px 20px rgba(0, 102, 255, 0.5);
    --shadow-accent: 0 0 28px rgba(41, 199, 250, 0.12);

    /* Inset (glass top-edge highlight) */
    --shadow-inset-highlight: inset 0 1px 0 rgba(255, 255, 255, 0.07);

    /* Glass card standard combined shadow */
    --shadow-glass:
        0 8px 32px rgba(0, 0, 0, 0.37),
        inset 0 1px 0 rgba(255, 255, 255, 0.07);


    /* ----------------------------------------------------------
       TRANSITIONS
    ---------------------------------------------------------- */
    --transition-fast: all 0.2s ease;
    --transition-base: all 0.3s ease;
    --transition-slow: all 0.45s ease;
}


/* ============================================================
   GLOBAL RESET & BASE ELEMENT STYLES
   ============================================================ */

* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

html {
    color-scheme: dark;
    /* Hide scrollbar everywhere */
    scrollbar-width: none;
    -ms-overflow-style: none;
}

html::-webkit-scrollbar {
    display: none;
}

body {
    font-family: var(--font-body);
    background: var(--bglight);
    color: var(--text-1);
    line-height: var(--leading-normal);
    overflow-x: hidden;
}

h1,
h2,
h3,
h4,
h5,
h6 {
    font-family: var(--font-heading);
    color: var(--text-1);
}

p,
li,
small {
    color: var(--text-2);
}

a {
    color: var(--accent);
    text-decoration: none;
}

a:hover {
    text-decoration: underline;
}

::selection {
    background: rgba(41, 199, 250, 0.28);
}