/*
 * Main Stylesheet
 * Contains the default theme variables and all structural styles.
 * Default Primary Color: #2160F4
*/

@layer reset {
  *,
  *::before,
  *::after {
    box-sizing: border-box;
  }

  html {
    -moz-text-size-adjust: none;
    -webkit-text-size-adjust: none;
    text-size-adjust: none;
  }

  body,
  h1,
  h2,
  h3,
  h4,
  p,
  figure,
  blockquote,
  dl,
  dd {
    margin: 0;
  }

  [role="list"] {
    list-style: none;
    margin: 0;
    padding: 0;
  }

  body {
    min-block-size: 100vh;
    line-height: 1.6;
  }

  h1,
  h2,
  h3,
  button,
  input,
  label {
    line-height: 1.1;
  }

  h1,
  h2,
  h3,
  h4 {
    text-wrap: balance;
  }

  p,
  li {
    text-wrap: pretty;
  }

  img,
  picture {
    max-inline-size: 100%;
    display: block;
  }

  input,
  button,
  textarea,
  select {
    font: inherit;
  }
}

@layer base {
  :root {
    /* --- 1. CORE DESIGN TOKENS --- */
    /* --- Extensive Color Palette --- */

    /* Neutral Colors */
    --color-white: #ffffff;
    --color-slight-white: #f7f7f7;
    --color-darker-white: #d1d1d1;
    --color-black: #000000;
    
    --color-slate-50: #f8fafc;
    --color-slate-100: #f1f5f9;
    --color-slate-200: #e2e8f0;
    --color-slate-300: #cbd5e1;
    --color-slate-400: #94a3b8;
    --color-slate-500: #64748b;
    --color-slate-600: #475569;
    --color-slate-700: #334155;
    --color-slate-800: #1e293b;
    --color-slate-900: #0f172a;

    --color-gray-50: #f9fafb;
    --color-gray-100: #f3f4f6;
    --color-gray-200: #e5e7eb;
    --color-gray-300: #d1d5db;
    --color-gray-400: #9ca3af;
    --color-gray-500: #6b7280;
    --color-gray-600: #4b5563;
    --color-gray-700: #374151;
    --color-gray-800: #1f2937;
    --color-gray-900: #111827;

    /* Red Colors */
    --color-red-50: #fef2f2;
    --color-red-100: #fee2e2;
    --color-red-200: #fecaca;
    --color-red-300: #fca5a5;
    --color-red-400: #f87171;
    --color-red-500: #ef4444;
    --color-red-600: #dc2626;
    --color-red-700: #b91c1c;
    --color-red-800: #991b1b;
    --color-red-900: #7f1d1d;

    /* Orange Colors */
    --color-orange-50: #fff7ed;
    --color-orange-100: #ffedd5;
    --color-orange-200: #fed7aa;
    --color-orange-300: #fdba74;
    --color-orange-400: #fb923c;
    --color-orange-500: #f97316;
    --color-orange-600: #ea580c;
    --color-orange-700: #c2410c;
    --color-orange-800: #9a3412;
    --color-orange-900: #7c2d12;
    
    /* Amber Colors */
    --color-amber-50: #fffbeb;
    --color-amber-100: #fef3c7;
    --color-amber-200: #fde68a;
    --color-amber-300: #fcd34d;
    --color-amber-400: #fbbf24;
    --color-amber-500: #f59e0b;
    --color-amber-600: #d97706;
    --color-amber-700: #b45309;
    --color-amber-800: #92400e;
    --color-amber-900: #78350f;

    /* Yellow Colors */
    --color-yellow-50: #fefce8;
    --color-yellow-100: #fef9c3;
    --color-yellow-200: #fef08a;
    --color-yellow-300: #fde047;
    --color-yellow-400: #facc15;
    --color-yellow-500: #eab308;
    --color-yellow-600: #ca8a04;
    --color-yellow-700: #a16207;
    --color-yellow-800: #854d0e;
    --color-yellow-900: #713f12;

    /* Lime Colors */
    --color-lime-50: #f7fee7;
    --color-lime-100: #ecfccb;
    --color-lime-200: #d9f99d;
    --color-lime-300: #bef264;
    --color-lime-400: #a3e635;
    --color-lime-500: #84cc16;
    --color-lime-600: #65a30d;
    --color-lime-700: #4d7c0f;
    --color-lime-800: #3f6212;
    --color-lime-900: #365314;

    /* Green Colors */
    --color-green-50: #f0fdf4;
    --color-green-100: #dcfce7;
    --color-green-200: #bbf7d0;
    --color-green-300: #86efac;
    --color-green-400: #4ade80;
    --color-green-500: #22c55e;
    --color-green-600: #16a34a;
    --color-green-700: #15803d;
    --color-green-800: #166534;
    --color-green-900: #14532d;
    
    /* Emerald Colors */
    --color-emerald-50: #ecfdf5;
    --color-emerald-100: #d1fae5;
    --color-emerald-200: #a7f3d0;
    --color-emerald-300: #6ee7b7;
    --color-emerald-400: #34d399;
    --color-emerald-500: #10b981;
    --color-emerald-600: #059669;
    --color-emerald-700: #047857;
    --color-emerald-800: #065f46;
    --color-emerald-900: #064e3b;
    
    /* Teal Colors */
    --color-teal-50: #f0fdfa;
    --color-teal-100: #ccfbf1;
    --color-teal-200: #99f6e4;
    --color-teal-300: #5eead4;
    --color-teal-400: #2dd4bf;
    --color-teal-500: #14b8a6;
    --color-teal-600: #0d9488;
    --color-teal-700: #0f766e;
    --color-teal-800: #115e59;
    --color-teal-900: #134e4a;
    
    /* Cyan Colors */
    --color-cyan-50: #ecfeff;
    --color-cyan-100: #cffafe;
    --color-cyan-200: #a5f3fc;
    --color-cyan-300: #67e8f9;
    --color-cyan-400: #22d3ee;
    --color-cyan-500: #06b6d4;
    --color-cyan-600: #0891b2;
    --color-cyan-700: #0e7490;
    --color-cyan-800: #155e75;
    --color-cyan-900: #164e63;

    /* Sky Colors */
    --color-sky-50: #f0f9ff;
    --color-sky-100: #e0f2fe;
    --color-sky-200: #bae6fd;
    --color-sky-300: #7dd3fc;
    --color-sky-400: #38bdf8;
    --color-sky-500: #0ea5e9;
    --color-sky-600: #0284c7;
    --color-sky-700: #0369a1;
    --color-sky-800: #075985;
    --color-sky-900: #0c4a6e;
    
    /* Blue Colors */
    --color-blue-50: #eff6ff;
    --color-blue-100: #dbeafe;
    --color-blue-200: #bfdbfe;
    --color-blue-300: #93c5fd;
    --color-blue-400: #60a5fa;
    --color-blue-500: #3b82f6;
    --color-blue-600: #2563eb;
    --color-blue-700: #1d4ed8;
    --color-blue-800: #1e40af;
    --color-blue-900: #1e3a8a;

    /* Indigo Colors */
    --color-indigo-50: #eef2ff;
    --color-indigo-100: #e0e7ff;
    --color-indigo-200: #c7d2fe;
    --color-indigo-300: #a5b4fc;
    --color-indigo-400: #818cf8;
    --color-indigo-500: #6366f1;
    --color-indigo-600: #4f46e5;
    --color-indigo-700: #4338ca;
    --color-indigo-800: #3730a3;
    --color-indigo-900: #312e81;

    /* Violet Colors */
    --color-violet-50: #f5f3ff;
    --color-violet-100: #ede9fe;
    --color-violet-200: #ddd6fe;
    --color-violet-300: #c4b5fd;
    --color-violet-400: #a78bfa;
    --color-violet-500: #8b5cf6;
    --color-violet-600: #7c3aed;
    --color-violet-700: #6d28d9;
    --color-violet-800: #5b21b6;
    --color-violet-900: #4c1d95;

    /* Purple Colors */
    --color-purple-50: #faf5ff;
    --color-purple-100: #f3e8ff;
    --color-purple-200: #e9d5ff;
    --color-purple-300: #d8b4fe;
    --color-purple-400: #c084fc;
    --color-purple-500: #a855f7;
    --color-purple-600: #9333ea;
    --color-purple-700: #7e22ce;
    --color-purple-800: #6b21a8;
    --color-purple-900: #581c87;

    /* Fuchsia Colors */
    --color-fuchsia-50: #fdf4ff;
    --color-fuchsia-100: #fae8ff;
    --color-fuchsia-200: #f5d0fe;
    --color-fuchsia-300: #f0abfc;
    --color-fuchsia-400: #e879f9;
    --color-fuchsia-500: #d946ef;
    --color-fuchsia-600: #c026d3;
    --color-fuchsia-700: #a21caf;
    --color-fuchsia-800: #86198f;
    --color-fuchsia-900: #701a75;
    
    /* Pink Colors */
    --color-pink-50: #fdf2f8;
    --color-pink-100: #fce7f3;
    --color-pink-200: #fbcfe8;
    --color-pink-300: #f9a8d4;
    --color-pink-400: #f472b6;
    --color-pink-500: #ec4899;
    --color-pink-600: #db2777;
    --color-pink-700: #be185d;
    --color-pink-800: #9d174d;
    --color-pink-900: #831843;
    
    /* Rose Colors */
    --color-rose-50: #fff1f2;
    --color-rose-100: #ffe4e6;
    --color-rose-200: #fecdd3;
    --color-rose-300: #fda4af;
    --color-rose-400: #fb7185;
    --color-rose-500: #f43f5e;
    --color-rose-600: #e11d48;
    --color-rose-700: #be123c;
    --color-rose-800: #9f1239;
    --color-rose-900: #881337;

    /* --- Other Core Tokens --- */
    
    /* Typography */
    --font-family-sans: 'Nunito Sans', 'Inter', sans-serif;
    --font-size-extra-small: 0.75rem;   /* 12px */
    --font-size-small: 0.875rem;  /* 14px */
    --font-size-base: 1rem;     /* 16px */
    --font-size-large: 1.125rem;  /* 18px */
    --font-size-extra-large: 1.25rem;   /* 20px */
    --font-size-2-extra-large: 1.5rem;   /* 24px */
    --font-size-3-extra-large: 1.875rem; /* 30px */
    --font-weight-regular: 400;
    --font-weight-medium: 500;
    --font-weight-semibold: 600;
    --font-weight-bold: 700;
    --font-weight-extrabold: 800;

    /* Spacing & Sizing */
    --spacing-unit: 0.25rem; /* 4px */
    --border-radius-small: 5px;
    --border-radius-medium: 10px;
    --border-radius-large: 15px;
    --border-radius-full: 9999px;

    /* Padding */
    --padding-2-extra-small: 2px;
    --padding-extra-small: 4px;
    --padding-small: 8px;
    --padding-medium: 12px;
    --padding-large: 16px;
    --padding-extra-large: 24px;
    --padding-2-extra-large: 32px;
    --padding-3-extra-large: 48px;

    /* Shadows */
    --shadow-extra-small: rgba(0, 0, 0, 0.12) 0px 1px 3px, rgba(0, 0, 0, 0.24) 0px 1px 2px;
    --shadow-extra-small-hover: rgba(0, 0, 0, 0.16) 0px 3px 6px, rgba(0, 0, 0, 0.23) 0px 3px 6px;

    --shadow-small: rgba(0, 0, 0, 0.18) 0px 2px 4px;
    --shadow-small-hover: rgba(0, 0, 0, 0.22) 0px 4px 10px;

    --shadow-medium: rgba(0, 0, 0, 0.05) 0px 6px 24px 0px, rgba(0, 0, 0, 0.08) 0px 0px 0px 1px;
    --shadow-medium-hover: rgba(0, 0, 0, 0.16) 0px 10px 36px 0px, rgba(0, 0, 0, 0.06) 0px 0px 0px 1px;

    --shadow-large: rgba(0, 0, 0, 0.15) 0px -2px 5px;
    --shadow-large-hover:  rgba(0, 0, 0, 0.20) 0px -4px 12px;

    --shadow-extra-large: rgba(0, 0, 0, 0.56) 0px 22px 70px 4px;
    --shadow-extra-large-hover: rgba(0, 0, 0, 0.60) 0px 26px 90px 6px;

    @media (width < 760px) {
        --font-size-extra-small: 0.5rem;
        --font-size-small: 0.75rem;
        --font-size-base: 0.8175rem;
        --font-size-large: 1rem;
        --font-size-extra-large: 1.125rem;
        --font-size-2-extra-large: 1.25rem;
        --font-size-3-extra-large: 1.5rem;
    }
  }
}

/* Branding definitions */
@layer brand {
    html {
        /* Colors */
        --primary-color: var(--color-blue-600);
        --secondary-color: var(--color-indigo-600);
        --tertiary-color: var(--color-teal-600);
        --border-color: var(--color-gray-200);
        --success-color: var(--color-green-600);
        --green-color: var(--success-color);
        --information-color: var(--color-blue-500);
        --warning-color: var(--color-amber-400);
        --yellow-color: var(--warning-color);
        --grey-color: var(--color-gray-500);
        --danger-color: var(--color-red-600);
        --discard-color: var(--danger-color);
        --red-color: var(--danger-color);

        --default-grey-color: var(--color-gray-400);
        --light-grey-color: var(--color-gray-300);
        --extra-light-grey-color: var(--color-gray-100);
        --dark-grey-color: var(--color-gray-500);

        --visited-color: var(--color-purple-900);
       
        /* Same color as myamigo logo... */
        --icon-color: #092741;

         /* Auto-derived light/dark with fallbacks */
        --primary-color-light: var(--auto-primary-color-light, var(--color-blue-400));
        --primary-color-dark:  var(--auto-primary-color-dark,  var(--color-blue-900));

        --secondary-color-light: var(--auto-secondary-color-light, var(--color-indigo-400));
        --secondary-color-dark:  var(--auto-secondary-color-dark,  var(--color-indigo-900));

        --tertiary-color-light: var(--auto-tertiary-color-light, var(--color-teal-400));
        --tertiary-color-dark:  var(--auto-tertiary-color-dark,  var(--color-teal-900));

        --border-color-light: var(--auto-border-color-light, var(--color-gray-100));
        --border-color-dark:  var(--auto-border-color-dark,  var(--color-gray-300));

        --success-color-light: var(--auto-success-color-light, var(--color-green-600));
        --success-color-dark:  var(--auto-success-color-dark,  var(--color-green-900));

        --information-color-light: var(--auto-information-color-light, var(--color-blue-300));
        --information-color-dark:  var(--auto-information-color-dark,  var(--color-blue-900));

        --warning-color-light: var(--auto-warning-color-light, var(--color-amber-400));
        --warning-color-dark:  var(--auto-warning-color-dark,  var(--color-amber-500));

        --grey-color-light: var(--auto-warning-color-light, var(--color-gray-500));
        --grey-color-dark:  var(--auto-warning-color-dark,  var(--color-gray-800));

        --danger-color-light: var(--auto-danger-color-light, var(--color-red-500));
        --danger-color-dark:  var(--auto-danger-color-dark,  var(--color-red-900));

        --discard-color-light: var(--auto-danger-color-light, var(--color-red-500));
        --discard-color-dark:  var(--auto-danger-color-dark,  var(--color-red-900));

        /* Backgrounds */
        --background-accent-light: var(--primary-color-light);
        --background-accent-main: var(--primary-color);
        --background-accent-dark: var(--primary-color-dark);
        --background-main: var(--color-white);
        --background-dark: var(--color-slight-white);
        --background-extra-dark: var(--color-darker-white);

        /* App */
        --app-background: var(--color-white);
        --background: var(--color-slight-white);

        /* Opacity */
        --primary-opacity-1: color-mix(in srgb, var(--primary-color) 4%, transparent);
        --primary-opacity-2: color-mix(in srgb, var(--primary-color) 12%, transparent);
        --primary-opacity-3: color-mix(in srgb, var(--primary-color) 16%, transparent);
        --primary-opacity-4: color-mix(in srgb, var(--primary-color) 24%, transparent);
        --primary-opacity-5: color-mix(in srgb, var(--primary-color) 38%, transparent);
        --primary-opacity-6: color-mix(in srgb, var(--primary-color) 87%, transparent);

        /* Utils */
        --full-viewport-height: 100dvh;
        --full-viewport-width: 100dvw;

        /* Page */
        --page-padding: 3em;
        --page-padding-top: 0;
        --page-title-size: 24px;
        --page-title-weight: 800;
        
        /* Typography */
        --base-font-family: Nunito Sans, sans-serif;
        --base-font-size: var(--font-size-base);
        --base-font-weight: 400;
        --base-letter-spacing: 0px;

        --alternative-font-family: 'Inter', sans-serif;

        --text-white: var(--color-white);
        --text-main: var(--color-gray-800);
        --text-black: var(--color-black);
        --text-brand: var(--primary-color);
        --text-brand-light: var(--primary-color-light);
        --text-brand-dark: var(--primary-color-dark);

        /* Readable text for brand surfaces (computed) */
        --on-primary-text:      var(--on-primary-text, #ffffff); /* JS will set; fallback white */
        --on-secondary-text:    var(--on-secondary-text, #ffffff);
        --on-tertiary-text:     var(--on-tertiary-text, #ffffff);
        --on-success-text:      var(--on-success-text, #000000);
        --on-warning-text:      var(--on-warning-text, #000000);
        --on-grey-text:         var(--on-grey-text, #ffffff);
        --on-danger-text:       var(--on-danger-text, #ffffff);
        --on-discard-text:      var(--on-danger-text, #ffffff);

        /* Readable text on background surface (computed) */
        --on-background-text:  var(--on-background-text, var(--text-black));

        /* Headings: target the surface text token so headings remain readable on current background */
        --heading-1-color: var(--on-background-text);
        --heading-2-color: var(--on-background-text);
        --heading-3-color: var(--on-background-text);
        --heading-4-color: var(--on-background-text);
        --heading-5-color: var(--on-background-text);
        --heading-6-color: var(--on-background-text);

        --heading-1-font-family: var(--base-font-family);
        --heading-1-size: var(--font-size-2-extra-large);
        --heading-1-weight: var(--font-weight-extrabold);
        --heading-1-padding: var(--padding-medium);
        --heading-2-font-family: var(--base-font-family);
        --heading-2-size: var(--font-size-extra-large);
        --heading-2-weight: var(--font-weight-bold);
        --heading-2-padding: var(--padding-medium);
        --heading-3-font-family: var(--base-font-family);
        --heading-3-size: var(--font-size-large);
        --heading-3-weight: var(--font-weight-semibold);
        --heading-3-padding: var(--padding-medium);
        --heading-4-font-family: var(--base-font-family);
        --heading-4-size: var(--font-size-base);
        --heading-4-weight: var(--font-weight-regular);
        --heading-4-padding: var(--padding-medium);
        --heading-5-font-family: var(--base-font-family);
        --heading-5-size: var(--font-size-base);
        --heading-5-weight: var(--font-weight-regular);
        --heading-5-padding: var(--padding-small);
        --heading-6-font-family: var(--base-font-family);
        --heading-6-size: var(--font-size-base);
        --heading-6-weight: var(--font-weight-regular);
        --heading-6-padding: var(--padding-small);

        /* bottom bar */
        --bottombar-shadow: var(--shadow-extra-small);

        /* modals */
        --modal-title-color: var(--on-primary-text);
        --modal-shadow: var(--shadow-extra-large);
        --modal-border-radius: var(--border-radius-medium);
        --modal-transition: all 0.1s ease-in-out;

        /* cards */
        --card-shadow: var(--shadow-small);
        --card-background: var(--app-background);
        --card-border-radius: var(--border-radius-medium);
        --card-border: 1px solid var(--color-darker-white);
        --card-transition: unset;

        /* inputs */
        --input-shadow: var(--shadow-medium);
        --input-shadow-hover: var(--shadow-medium-hover);
        --input-border-radius: var(--border-radius-small);
        --input-border: 0px;
        --input-transition: all 0.2s ease-in-out;

        /* checkboxes */
        --checkbox-color: var(--primary-color);

        /* buttons */
        --button-shadow: var(--shadow-extra-small);
        --button-shadow-hover: var(--shadow-extra-small-hover);
        --button-border-radius: var(--border-radius-small);
        --button-border: 0px;
        --button-transition: all 0.2s ease-in-out;

        /* Disabled Inputs */
        --disabled-opacity: 0.8;
        --disabled-opacity-color: 80%;

        /* dropdowns */
        --dropdown-shadow: var(--input-shadow);
        --dropdown-shadow-hover: var(--input-shadow-hover);
        --dropdown-border-radius: var(--border-radius-small);
        --dropdown-border: 0px;
        --dropdown-transition: all 0.2s ease-in-out;

        /* navbar */
        --navbar-shadow: 0px;
        --navbar-background: rgb(255 255 255 / 80%);
        --navbar-blur: blur(10px);
        --navbar-border: 1px solid var(--border-color);
        --navbar-height: 55px;

        /* menu */
        --menu-width: 18em;
        --menu-shadow: 0px;
        --menu-blur: blur(0px);
        --menu-border: 1px solid var(--border-color);
    }
}

@layer components {
    html, body {
        /* --- Buttons --- */

        /* General */
        --button-font-family:                   var(--alternative-font-family);
        --button-font-weight:                   var(--font-weight-semibold);

        /* Sizes */
        --button-small-padding:                 0.375rem 0.75rem;
        --button-small-font-size:               0.875rem;
        --button-medium-padding:                0.625rem 1.25rem;
        --button-medium-font-size:              1rem;
        --button-large-padding:                 0.875rem 1.75rem;
        --button-large-font-size:               1.125rem;

        /* Shapes */
        --button-pill-border-radius:            9999px;
        --button-circle-border-radius:          50%;
        --button-circle-small-size:             2rem; /* 32px */
        --button-circle-medium-size:            2.5rem; /* 40px */
        --button-circle-large-size:             3rem; /* 48px */

        /* Primary Variant */
        --button-primary-default-background:    var(--primary-color);
        --button-primary-default-color:         var(--on-primary-text);
        --button-primary-default-border:        1px solid var(--primary-color);

        --button-primary-active-background:      var(--primary-color-light);
        --button-primary-active-color:           var(--on-primary-text);
        --button-primary-active-border:          1px solid var(--primary-color);

        --button-primary-hover-background:     var(--primary-color-dark);
        --button-primary-hover-color:          var(--on-primary-text);
        --button-primary-hover-border:         1px solid var(--primary-color-light);

        --button-primary-disabled-background:   var(--primary-color-light);
        --button-primary-disabled-color:        var(--on-primary-text);
        --button-primary-disabled-border:       1px solid var(--primary-color-light);

        /* Secondary Variant */
        --button-secondary-default-background:    var(--secondary-color);
        --button-secondary-default-color:         var(--on-secondary-text);
        --button-secondary-default-border:        1px solid var(--secondary-color);

        --button-secondary-active-background:      var(--secondary-color-light);
        --button-secondary-active-color:           var(--on-secondary-text);
        --button-secondary-active-border:          1px solid var(--secondary-color);

        --button-secondary-hover-background:     var(--secondary-color-dark);
        --button-secondary-hover-color:          var(--on-secondary-text);
        --button-secondary-hover-border:         1px solid var(--secondary-color-light);

        --button-secondary-disabled-background:   var(--secondary-color-light);
        --button-secondary-disabled-color:        var(--on-secondary-text);
        --button-secondary-disabled-border:       1px solid var(--secondary-color-light);

        /* Tertiary Variant */
        --button-tertiary-default-background:    var(--tertiary-color);
        --button-tertiary-default-color:         var(--on-tertiary-text); 
        --button-tertiary-default-border:        1px solid var(--tertiary-color);

        --button-tertiary-active-background:      var(--tertiary-color-light);
        --button-tertiary-active-color:           var(--on-tertiary-text); 
        --button-tertiary-active-border:          1px solid var(--tertiary-color);

        --button-tertiary-hover-background:     var(--tertiary-color-dark);
        --button-tertiary-hover-color:          var(--on-tertiary-text); 
        --button-tertiary-hover-border:         1px solid var(--tertiary-color-light);

        --button-tertiary-disabled-background:   var(--tertiary-color-light);
        --button-tertiary-disabled-color:        var(--on-tertiary-text); 
        --button-tertiary-disabled-border:       1px solid var(--tertiary-color-light);

        /* Discard Variant */
        --button-discard-default-background:    var(--discard-color);
        --button-discard-default-color:         var(--on-danger-text); 
        --button-discard-default-border:        1px solid var(--discard-color);

        --button-discard-active-background:      var(--discard-color-light);
        --button-discard-active-color:           var(--on-danger-text); 
        --button-discard-active-border:          1px solid var(--discard-color);

        --button-discard-hover-background:       var(--discard-color-dark);
        --button-discard-hover-color:            var(--on-danger-text); 
        --button-discard-hover-border:           1px solid var(--discard-color-light);

        --button-discard-disabled-background:   var(--discard-color-light);
        --button-discard-disabled-color:        var(--on-danger-text); 
        --button-discard-disabled-border:       1px solid var(--discard-color-light);

        /* Danger Variant */
        --button-danger-default-background:    var(--danger-color);
        --button-danger-default-color:         var(--on-danger-text); 
        --button-danger-default-border:        1px solid var(--danger-color);

        --button-danger-active-background:      var(--danger-color-light);
        --button-danger-active-color:           var(--on-danger-text); 
        --button-danger-active-border:          1px solid var(--danger-color);

        --button-danger-hover-background:     var(--danger-color-dark);
        --button-danger-hover-color:          var(--on-danger-text); 
        --button-danger-hover-border:         1px solid var(--danger-color-light);

        --button-danger-disabled-background:   var(--danger-color-light);
        --button-danger-disabled-color:        var(--on-danger-text); 
        --button-danger-disabled-border:       1px solid var(--danger-color-light);

        /* Success Variant */
        --button-success-default-background:    var(--success-color);
        --button-success-default-color:         var(--on-success-text); 
        --button-success-default-border:        1px solid var(--success-color);

        --button-success-active-background:      var(--success-color-light);
        --button-success-active-color:           var(--on-success-text); 
        --button-success-active-border:          1px solid var(--success-color);

        --button-success-hover-background:     var(--success-color-dark);
        --button-success-hover-color:          var(--on-success-text); 
        --button-success-hover-border:         1px solid var(--success-color-light);

        --button-success-disabled-background:   var(--success-color-light);
        --button-success-disabled-color:        var(--on-success-text); 
        --button-success-disabled-border:       1px solid var(--success-color-light);

        /* Warning Variant */
        --button-warning-default-background:    var(--warning-color);
        --button-warning-default-color:         var(--on-warning-text); 
        --button-warning-default-border:        1px solid var(--warning-color);

        --button-warning-active-background:     var(--warning-color-light);
        --button-warning-active-color:          var(--on-warning-text);
        --button-warning-active-border:         1px solid var(--warning-color);

        --button-warning-hover-background:      var(--warning-color-dark);
        --button-warning-hover-color:           var(--on-warning-text);
        --button-warning-hover-border:          1px solid var(--warning-color-light);

        --button-warning-disabled-background:   var(--warning-color-light);
        --button-warning-disabled-color:        var(--on-warning-text);
        --button-warning-disabled-border:       1px solid var(--warning-color-light);

        /* Grey Variant */
        --button-grey-default-background:       var(--grey-color);
        --button-grey-default-color:            var(--on-grey-text);
        --button-grey-default-border:           1px solid var(--grey-color);

        --button-grey-active-background:        var(--grey-color-light);
        --button-grey-active-color:             var(--on-grey-text);
        --button-grey-active-border:            1px solid var(--grey-color);

        --button-grey-hover-background:         var(--grey-color-dark);
        --button-grey-hover-color:              var(--on-grey-text);
        --button-grey-hover-border:             1px solid var(--dark-grey-color);

        --button-grey-disabled-background:      var(--grey-color-light);
        --button-grey-disabled-color:           var(--on-grey-text);
        --button-grey-disabled-border:          1px solid var(--grey-color-light);

        /* Clear Variant */
        --button-clear-default-background:    transparent;
        --button-clear-default-color:         var(--text-main, initial);
        --button-clear-default-border:        0;
        --button-clear-default-shadow:        none;

        --button-clear-active-background:      var(--background-dark);
        --button-clear-active-color:           var(--on-background-text);
        --button-clear-active-border:          1px solid var(--light-grey-color);
        --button-clear-active-shadow:          none;

        --button-clear-hover-background:     var(--background-extra-dark);
        --button-clear-hover-color:          var(--on-background-text);
        --button-clear-hover-border:         1px solid var(--dark-grey-color);
        --button-clear-hover-shadow:         none;

        --button-clear-disabled-background:   var(--background-main);
        --button-clear-disabled-color:        var(--on-background-text);
        --button-clear-disabled-border:       1px solid var(--light-grey-color);
        --button-clear-disabled-shadow:       none;

        /* Legacy Button styling wiring */
        
        /* Keep existing custom props but map to new ones when available */

        /* Size defaults (used if no size modifier is applied) */
        --button-padding:                  var(--button-medium-padding, 0 1.5em);
        --button-mobile-padding:           var(--button-mobile-padding, 0 0.5em);
        --button-tablet-padding:           var(--button-tablet-padding, 0 1em);
        --button-font-size:                var(--button-medium-font-size, 16px);

        /* === Primary (existing names keep working) === */
        --button-primary-background:       var(--button-primary-default-background, var(--button-primary, var(--primary-color)));
        --button-primary-color:            var(--button-primary-default-color, white);
        --button-primary-border:           var(--button-primary-default-border, 1px solid var(--primary-color));
        --button-primary-hover:            var(--button-primary-hover-background, var(--primary-color-light));

        /* Secondary */
        --button-secondary-background:     var(--button-secondary-default-background, var(--secondary-color));
        --button-secondary-color:          var(--button-secondary-default-color, white);
        --button-secondary-border:         var(--button-secondary-default-border, 1px solid var(--secondary-color));
        --button-secondary-hover:          var(--button-secondary-hover-background, var(--secondary-color-light));

        /* Tertiary */
        --button-tertiary-background:      var(--button-tertiary-default-background, var(--tertiary-color));
        --button-tertiary-color:           var(--button-tertiary-default-color, white);
        --button-tertiary-hover:           var(--button-tertiary-hover-background, var(--tertiary-color-light));

        /* Success */
        --button-success-background:       var(--button-success-default-background, var(--success-color));
        --button-success-color:            var(--button-success-default-color, white);
        --button-success-hover:            var(--button-success-hover-background, var(--success-color-light));

        /* Warning */
        --button-warning-background:       var(--button-warning-default-background, var(--warning-color));
        --button-warning-color:            var(--button-warning-default-color, black);
        --button-warning-hover:            var(--button-warning-hover-background, var(--warning-color-light));

        /* Discard */
        --button-discard-background:       var(--button-discard-default-background, var(--discard-color));
        --button-discard-color:            var(--button-discard-default-color, white);
        --button-discard-hover:            var(--button-discard-hover-background, var(--discard-color-light));

        /* Grey */
        --button-grey-background:          var(--button-grey-default-background, var(--background-main));
        --button-grey-color:               var(--button-grey-default-color, white);
        --button-grey-border:              var(--button-grey-default-border, 1px solid var(--default-grey-color));
        --button-grey-hover:               var(--button-grey-hover-background, var(--background-dark));

        /* Clear */
        --button-clear-background:         var(--button-clear-default-background, transparent);
        --button-clear-color:              var(--button-clear-default-color, var(--text-main, initial));
        --button-clear-hover-background:   var(--button-clear-hover-background, rgba(0,0,0,0.05));


        /* dn-range (using primary-color) */
        --range-primary: var(--primary-color);
        --range-light: #ffffff;
        --range-dark: #000000;
        --range-primary-opacity-1: color-mix(in srgb, var(--range-primary) 4%, transparent);
        --range-primary-opacity-2: color-mix(in srgb, var(--range-primary) 12%, transparent);
        --range-primary-opacity-3: color-mix(in srgb, var(--range-primary) 16%, transparent);
        --range-primary-opacity-4: color-mix(in srgb, var(--range-primary) 24%, transparent);
        --range-primary-opacity-5: color-mix(in srgb, var(--range-primary) 38%, transparent);
        --range-primary-opacity-6: color-mix(in srgb, var(--range-primary) 87%, transparent);
        --range-light-opacity-1: color-mix(in srgb, var(--range-light) 4%, transparent);
        --range-light-opacity-2: color-mix(in srgb, var(--range-light) 12%, transparent);
        --range-light-opacity-3: color-mix(in srgb, var(--range-light) 16%, transparent);
        --range-light-opacity-4: color-mix(in srgb, var(--range-light) 24%, transparent);
        --range-light-opacity-5: color-mix(in srgb, var(--range-light) 38%, transparent);
        --range-light-opacity-6: color-mix(in srgb, var(--range-light) 87%, transparent);
        --range-dark-opacity-1: color-mix(in srgb, var(--range-dark) 4%, transparent);
        --range-dark-opacity-2: color-mix(in srgb, var(--range-dark) 12%, transparent);
        --range-dark-opacity-3: color-mix(in srgb, var(--range-dark) 16%, transparent);
        --range-dark-opacity-4: color-mix(in srgb, var(--range-dark) 24%, transparent);
        --range-dark-opacity-5: color-mix(in srgb, var(--range-dark) 38%, transparent);
        --range-dark-opacity-6: color-mix(in srgb, var(--range-dark) 87%, transparent);

        /* Checkbox */
        --checkbox-color: var(--primary-color);
        --checkbox-disabled-color: var(--range-primary-opacity-5);
    }

    /* Component Styles */
    .box {
        background-color: var(--primary-color);
    }

    .button-shadow {
        box-shadow: var(--button-shadow);
    }

    .dn-card {
        background-color: var(--background);
        border-radius: var(--card-border-radius);
        border: var(--card-border);
        box-shadow: var(--card-shadow);
    }

    .dn-tile-grid {
        display: grid;
        grid-template-columns: repeat(auto-fill, minmax(20em, 1fr));
        grid-gap: 2em;
    }

    .dn-tile-grid .dn-tile {
        border-radius: var(--card-border-radius);
        border: var(--card-border);
        box-shadow: var(--card-shadow);
        height: 14vh;
        min-height: 10em;
        display: flex;
        flex-direction: column;
        justify-content: space-between;
        padding-left: 1em;
        padding-right: 1em;
    }

    .dn-icon--selected {
        color: var(--primary-color);
        background-color: color-mix(in srgb, var(--primary-color) 30%, transparent) !important;
    }

    .primary_icon,
    .assistance_tab_selected,
    .today_office_days,
    .today_label {
        color: var(--primary-color);
    }

    .modal_header {
        background-color: var(--primary-color);
    }

    .tab_selected {
        border-bottom: 4px solid var(--primary-color);
    }

    .calendar_today {
        background-color: var(--primary-color);
        color: var(--background);
    }

    .dayContainer .selected {
        background: var(--primary-color);
        border-color: var(--primary-color);
    }

    .today_office_days {
        color: var(--primary-color);
    }

    .today_label {
        color: var(--primary-color);
    }

    .slide-checkbox-switch_checked,
    .amount_of_selections,
    .amount_of_employee_selections,
    .amount_of_group_selections,
    .checkbox_checked,
    .support_button {
        background-color: var(--primary-color);
    }



    .amount_of_employee_selections {
        background-color: var(--primary-color);
    }

    .amount_of_group_selections {
        background-color: var(--primary-color);
    }

    .checkbox_checked {
        background-color: var(--primary-color);
    }


    .checkbox_checked_disabled {
        background-color: color-mix(in srgb, var(--primary-color) 30%, transparent);
        cursor: not-allowed;
    }

    .support_button {
        background-color: var(--primary-color);
    }

    .lightened_background {
        background-color: color-mix(in srgb, var(--primary-color) 4%, transparent);
        padding: 10px;
    }

    .navbar_item_label--selected {
        color: var(--primary-color);
        background-color: transparent !important;
    }

    .navbar_item--selected {
        background-color: color-mix(in srgb, var(--primary-color) 5%, transparent);
        padding-left: 7px !important;
    }

    .navbar_toggler:hover,
    .log_view_toggler:hover {
        background-color: var(--primary-color);
        color: var(--background);
    }

    .selected_slot {
        border: 2px solid color-mix(in srgb, var(--primary-color) 90%, transparent);
        background-color: color-mix(in srgb, var(--primary-color) 20%, transparent);
    }

    .tabulator .tabulator-header .tabulator-col .tabulator-col-content {
        color: var(--primary-color);
    }

    .tabulator .tabulator-header .tabulator-col .tabulator-col-content .tabulator-col-sorter .tabulator-arrow {
        border-bottom-color: var(--primary-color);
    }

}

@layer page-transitions {
    /* Global Page Transition Animation */
    /* @view-transition {
    navigation: auto;
    }

    html:active-view-transition-type(forwards, backwards) {
        :root {
            view-transition-name: none;
        }
        div#body {
            view-transition-name: content;
        }
        header#header {
            view-transition-name: header;
        }
        aside#menu {
            view-transition-name: menu;
        }
    }

    html:active-view-transition-type(forwards) {
        &::view-transition-old(content) {
            animation-name: slide-out-to-left;
        }
        &::view-transition-new(content) {
            animation-name: slide-in-from-right;
        }
    }

    html:active-view-transition-type(backwards) {
        &::view-transition-old(content) {
            animation-name: slide-out-to-right;
        }
        &::view-transition-new(content) {
            animation-name: slide-in-from-left;
        }
    } */
}

@layer global {
    /* Global & Structural Styles */
    body {
        -webkit-font-smoothing: antialiased;
        font-display: block;
        font-family: var(--base-font-family);
        font-size: var(--base-font-size);
        font-weight: var(--base-font-weight);
        letter-spacing: var(--base-letter-spacing);
        color: var(--text-main);
        text-decoration: inherit;
        text-transform: inherit;
    }

    /* Mobile Menu Overrides */
    body.menu-mobile {
        --menu-width: 0px;
    }

    body.menu-mobile.menu-closed #menu {
        pointer-events: none;
    }


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

    h1 {
        font-size: var(--heading-1-size);
        font-weight: var(--heading-1-weight);
        font-family: var(--heading-1-font-family);
        color: var(--heading-1-color);
        padding-top: var(--heading-1-padding);
        padding-bottom: var(--heading-1-padding);
    }

    h2 {
        font-size: var(--heading-2-size);
        font-weight: var(--heading-2-weight);
        font-family: var(--heading-2-font-family);
        color: var(--heading-2-color);
        padding-top: var(--heading-2-padding);
        padding-bottom: var(--heading-2-padding);
    }

    h3 {
        font-size: var(--heading-3-size);
        font-weight: var(--heading-3-weight);
        font-family: var(--heading-3-font-family);
        color: var(--heading-3-color);
        padding-top: var(--heading-3-padding);
        padding-bottom: var(--heading-3-padding);
    }

    h4 {
        font-size: var(--heading-4-size);
        font-weight: var(--heading-4-weight);
        font-family: var(--heading-4-font-family);
        color: var(--heading-4-color);
        padding-top: var(--heading-4-padding);
        padding-bottom: var(--heading-4-padding);
    }

    h5 {
        font-size: var(--heading-5-size);
        font-weight: var(--heading-5-weight);
        font-family: var(--heading-5-font-family);
        color: var(--heading-5-color);
        padding-top: var(--heading-5-padding);
        padding-bottom: var(--heading-5-padding);
    }

    h6 {
        font-size: var(--heading-6-size);
        font-weight: var(--heading-6-weight);
        font-family: var(--heading-6-font-family);
        color: var(--heading-6-color);
        padding-top: var(--heading-6-padding);
        padding-bottom: var(--heading-6-padding);
    }

    .btn:not(:disabled):not(.disabled)
    {
        cursor: pointer;
    }

    .btn:focus, .btn:hover
    {
        text-decoration: none;
    }

    [type=reset], [type=submit], button, html [type=button]
    {
        -webkit-appearance: button;
    }

    .btn {
        display: inline-block;
        font-weight: 400;
        text-align: center;
        white-space: nowrap;
        vertical-align: middle;
        -webkit-user-select: none;
        -moz-user-select: none;
        -ms-user-select: none;
        user-select: none;
        border: 1px solid transparent;
        padding: .375rem .75rem;
        font-size: 1rem;
        line-height: 1.5;
        border-radius: .25rem;
        transition: color .15s 
    ease-in-out, background-color .15s 
    ease-in-out, border-color .15s 
    ease-in-out, box-shadow .15s 
    ease-in-out;
    }


}

@layer animations {
    @keyframes slide-in-from-left {
        from {
            translate: -100% 0;
        }
    }
    @keyframes slide-in-from-right {
        from {
            translate: 100% 0;
        }
    }
    @keyframes slide-out-to-left {
        to {
            translate: -100% 0;
        }
    }
    @keyframes slide-out-to-right {
        to {
            translate: 100% 0;
        }
    }

    @keyframes fade-in {
        from {
            opacity: 1;
        }
        to {
            opacity: 0;
        }
    }

    @keyframes fade-out {
        from {
            opacity: 0;
        }
        to {
            opacity: 1;
        }
    }
}

@layer utilities {
    .yellow {
        background-color: var(--yellow-color);
    }

    .information {
        background-color: var(--information-color);
    }

    .red {
        background-color: var(--red-color);
    }

    .danger {
        background-color: var(--danger-color);
    }

    .green {
        background-color: var(--success-color);
    }

    .h-100
    {
        height: 100% !important;
    }

    .text-left
    {
        text-align: left !important;
    }

    .text-center 
    {
        text-align: center !important;
    }

    .text-right 
    {
        text-align: right !important;
    }

    .align-items-center
    {
        -ms-flex-align: center!important;
        align-items: center !important;
    }

    .justify-content-center {
        -ms-flex-pack: center!important;
        justify-content: center !important;
    }

    .form-row {
        display: -ms-flexbox;
        display: flex;
        -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    }

    .form-row>.col, .form-row>[class*=col-]
    {
        padding-right: 5px;
        padding-left: 5px;
    }

    .col, .col-1, .col-10, .col-11, .col-12, .col-2, .col-3, .col-4, .col-5, .col-6, .col-7, .col-8, .col-9, .col-auto, .col-lg, .col-lg-1, .col-lg-10, .col-lg-11, .col-lg-12, .col-lg-2, .col-lg-3, .col-lg-4, .col-lg-5, .col-lg-6, .col-lg-7, .col-lg-8, .col-lg-9, .col-lg-auto, .col-md, .col-md-1, .col-md-10, .col-md-11, .col-md-12, .col-md-2, .col-md-3, .col-md-4, .col-md-5, .col-md-6, .col-md-7, .col-md-8, .col-md-9, .col-md-auto, .col-sm, .col-sm-1, .col-sm-10, .col-sm-11, .col-sm-12, .col-sm-2, .col-sm-3, .col-sm-4, .col-sm-5, .col-sm-6, .col-sm-7, .col-sm-8, .col-sm-9, .col-sm-auto, .col-xl, .col-xl-1, .col-xl-10, .col-xl-11, .col-xl-12, .col-xl-2, .col-xl-3, .col-xl-4, .col-xl-5, .col-xl-6, .col-xl-7, .col-xl-8, .col-xl-9, .col-xl-auto {
        position: relative;
        width: 100%;
        min-height: 1px;
        padding-left: 15px;
        padding-right: 15px;
    }

    .col-1 {
        -ms-flex: 0 0 8.333333%;
        flex: 0 0 8.333333%;
        max-width: 8.333333%;
    }

    .col-2
    {
        -ms-flex: 0 0 16.666667%;
        flex: 0 0 16.666667%;
        max-width: 16.666667%;
    }

    .col-3
    {
        -ms-flex: 0 0 25%;
        flex: 0 0 25%;
        max-width: 25%;
    }

    .col-4 {
        -ms-flex: 0 0 33.333333%;
        flex: 0 0 33.333333%;
        max-width: 33.333333%;
    }

    .col-5 {
        -ms-flex: 0 0 41.666667%;
        flex: 0 0 41.666667%;
        max-width: 41.666667%;
    }

    .col-6
    {
        -ms-flex: 0 0 50%;
        flex: 0 0 50%;
        max-width: 50%;
    }

    .col-7
    {
        -ms-flex: 0 0 58.333333%;
        flex: 0 0 58.333333%;
        max-width: 58.333333%;
    }

    .col-8
    {
        -ms-flex: 0 0 66.666667%;
        flex: 0 0 66.666667%;
        max-width: 66.666667%;
    }

    .col-9
    {
        -ms-flex: 0 0 75%;
        flex: 0 0 75%;
        max-width: 75%;
    }

    .col-10 {
        -ms-flex: 0 0 83.333333%;
        flex: 0 0 83.333333%;
        max-width: 83.333333%;
    }

    .col-11 {
        -ms-flex: 0 0 91.666667%;
        flex: 0 0 91.666667%;
        max-width: 91.666667%;
    }

    .col-12 {
        -ms-flex: 0 0 100%;
        flex: 0 0 100%;
        max-width: 100%;
    }

    @media (min-width: 576px) {
        .col-sm-1 {
            -ms-flex: 0 0 8.333333%;
            flex: 0 0 8.333333%;
            max-width: 8.333333%;
        }

        .col-sm-2 {
            -ms-flex: 0 0 16.666667%;
            flex: 0 0 16.666667%;
            max-width: 16.666667%;
        }

        .col-sm-3
        {
            -ms-flex: 0 0 25%;
            flex: 0 0 25%;
            max-width: 25%;
        }

        .col-sm-4 {
            -ms-flex: 0 0 33.333333%;
            flex: 0 0 33.333333%;
            max-width: 33.333333%;
        }

        .col-sm-5
        {
            -ms-flex: 0 0 41.666667%;
            flex: 0 0 41.666667%;
            max-width: 41.666667%;
        }

        .col-sm-6
        {
            -ms-flex: 0 0 50%;
            flex: 0 0 50%;
            max-width: 50%;
        }

        .col-sm-7 {
            -ms-flex: 0 0 58.333333%;
            flex: 0 0 58.333333%;
            max-width: 58.333333%;
        }
        
        .col-sm-8 {
            -ms-flex: 0 0 66.666667%;
            flex: 0 0 66.666667%;
            max-width: 66.666667%;
        }

        .col-sm-9
        {
            -ms-flex: 0 0 75%;
            flex: 0 0 75%;
            max-width: 75%;
        }

        .col-sm-10 {
            -ms-flex: 0 0 83.333333%;
            flex: 0 0 83.333333%;
            max-width: 83.333333%;
        }

        .col-sm-11 {
            -ms-flex: 0 0 91.666667%;
            flex: 0 0 91.666667%;
            max-width: 91.666667%;
        }

        .col-sm-12 {
            -ms-flex: 0 0 100%;
            flex: 0 0 100%;
            max-width: 100%;
        }
    }

    @media (min-width: 768px) {
        .col-md-1 {
            -ms-flex: 0 0 8.333333%;
            flex: 0 0 8.333333%;
            max-width: 8.333333%;
        }

        .col-md-2 {
            -ms-flex: 0 0 16.666667%;
            flex: 0 0 16.666667%;
            max-width: 16.666667%;
        }

        .col-md-3
        {
            -ms-flex: 0 0 25%;
            flex: 0 0 25%;
            max-width: 25%;
        }

        .col-md-4 {
            -ms-flex: 0 0 33.333333%;
            flex: 0 0 33.333333%;
            max-width: 33.333333%;
        }

        .col-md-5 {
            -ms-flex: 0 0 41.666667%;
            flex: 0 0 41.666667%;
            max-width: 41.666667%;
        }

        .col-md-6 {
            -ms-flex: 0 0 50%;
            flex: 0 0 50%;
            max-width: 50%;
        }

        .col-md-7 {
            -ms-flex: 0 0 58.333333%;
            flex: 0 0 58.333333%;
            max-width: 58.333333%;
        }

        .col-md-8 {
            -ms-flex: 0 0 66.666667%;
            flex: 0 0 66.666667%;
            max-width: 66.666667%;
        }

        .col-md-9 {
            -ms-flex: 0 0 75%;
            flex: 0 0 75%;
            max-width: 75%;
        }

        .col-md-10 {
            -ms-flex: 0 0 83.333333%;
            flex: 0 0 83.333333%;
            max-width: 83.333333%;
        }

        .col-md-11 {
            -ms-flex: 0 0 91.666667%;
            flex: 0 0 91.666667%;
            max-width: 91.666667%;
        }

        .col-md-12 {
            -ms-flex: 0 0 100%;
            flex: 0 0 100%;
            max-width: 100%;
        }
    }


    @media (min-width: 992px) {
        .col-lg-1 {
            -ms-flex: 0 0 8.333333%;
            flex: 0 0 8.333333%;
            max-width: 8.333333%;
        }

        .col-lg-2
        {
            -ms-flex: 0 0 16.666667%;
            flex: 0 0 16.666667%;
            max-width: 16.666667%;
        }

        .col-lg-3 {
            -ms-flex: 0 0 25%;
            flex: 0 0 25%;
            max-width: 25%;
        }

        .col-lg-4 {
            -ms-flex: 0 0 33.333333%;
            flex: 0 0 33.333333%;
            max-width: 33.333333%;
        }

        .col-lg-5 {
            -ms-flex: 0 0 41.666667%;
            flex: 0 0 41.666667%;
            max-width: 41.666667%;
        }

        .col-lg-6 {
            -ms-flex: 0 0 50%;
            flex: 0 0 50%;
            max-width: 50%;
        }

        .col-lg-7
        {
            -ms-flex: 0 0 58.333333%;
            flex: 0 0 58.333333%;
            max-width: 58.333333%;
        }

        .col-lg-8
        {
            -ms-flex: 0 0 66.666667%;
            flex: 0 0 66.666667%;
            max-width: 66.666667%;
        }

        .col-lg-9 {
            -ms-flex: 0 0 75%;
            flex: 0 0 75%;
            max-width: 75%;
        }

        .col-lg-10 {
            -ms-flex: 0 0 83.333333%;
            flex: 0 0 83.333333%;
            max-width: 83.333333%;
        }

        .col-lg-11 {
            -ms-flex: 0 0 91.666667%;
            flex: 0 0 91.666667%;
            max-width: 91.666667%;
        }

        .col-lg-12 {
            -ms-flex: 0 0 100%;
            flex: 0 0 100%;
            max-width: 100%;
        }
    }

    @media (min-width: 1200px) {
        .col-xl-1 {
            -ms-flex: 0 0 8.333333%;
            flex: 0 0 8.333333%;
            max-width: 8.333333%;
        }

        .col-xl-2 {
            -ms-flex: 0 0 16.666667%;
            flex: 0 0 16.666667%;
            max-width: 16.666667%;
        }

        .col-xl-3
        {
            -ms-flex: 0 0 25%;
            flex: 0 0 25%;
            max-width: 25%;
        }

        .col-xl-4 {
            -ms-flex: 0 0 33.333333%;
            flex: 0 0 33.333333%;
            max-width: 33.333333%;
        }

        .col-xl-5
        {
            -ms-flex: 0 0 41.666667%;
            flex: 0 0 41.666667%;
            max-width: 41.666667%;
        }

        .col-xl-6 {
            -ms-flex: 0 0 50%;
            flex: 0 0 50%;
            max-width: 50%;
        }

        .col-xl-7 {
            -ms-flex: 0 0 58.333333%;
            flex: 0 0 58.333333%;
            max-width: 58.333333%;
        }

        .col-xl-8
        {
            -ms-flex: 0 0 66.666667%;
            flex: 0 0 66.666667%;
            max-width: 66.666667%;
        }

        .col-xl-9
        {
            -ms-flex: 0 0 75%;
            flex: 0 0 75%;
            max-width: 75%;
        }

        .col-xl-10 {
            -ms-flex: 0 0 83.333333%;
            flex: 0 0 83.333333%;
            max-width: 83.333333%;
        }

        .col-xl-11 {
            -ms-flex: 0 0 91.666667%;
            flex: 0 0 91.666667%;
            max-width: 91.666667%;
        }

        .col-xl-12 {
            -ms-flex: 0 0 100%;
            flex: 0 0 100%;
            max-width: 100%;
        }
        
    }

    @media (min-width: 1400px) {
        .col-xxl-1 {
            -ms-flex: 0 0 8.333333%;
            flex: 0 0 8.333333%;
            max-width: 8.333333%;
        }

        .col-xxl-2
        {
            -ms-flex: 0 0 16.666667%;
            flex: 0 0 16.666667%;
            max-width: 16.666667%;
        }

        .col-xxl-3 {
            -ms-flex: 0 0 25%;
            flex: 0 0 25%;
            max-width: 25%;
        }

        .col-xxl-4 {
            -ms-flex: 0 0 33.333333%;
            flex: 0 0 33.333333%;
            max-width: 33.333333%;
        }

        .col-xxl-5 {
            -ms-flex: 0 0 41.666667%;
            flex: 0 0 41.666667%;
            max-width: 41.666667%;
        }

        .col-xxl-6 {
            -ms-flex: 0 0 50%;
            flex: 0 0 50%;
            max-width: 50%;
        }

        .col-xxl-7
        {
            -ms-flex: 0 0 58.333333%;
            flex: 0 0 58.333333%;
            max-width: 58.333333%;
        }

        .col-xxl-8
        {
            -ms-flex: 0 0 66.666667%;
            flex: 0 0 66.666667%;
            max-width: 66.666667%;
        }

        .col-xxl-9 {
            -ms-flex: 0 0 75%;
            flex: 0 0 75%;
            max-width: 75%;
        }

        .col-xxl-10 {
            -ms-flex: 0 0 83.333333%;
            flex: 0 0 83.333333%;
            max-width: 83.333333%;
        }

        .col-xxl-11 {
            -ms-flex: 0 0 91.666667%;
            flex: 0 0 91.666667%;
            max-width: 91.666667%;
        }

        .col-xxl-12 {
            -ms-flex: 0 0 100%;
            flex: 0 0 100%;
            max-width: 100%;
        }
    }
}