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

/* DEFAULT THEME VARIABLE DEFINITIONS */
:root {
    /* --- 1. CORE DESIGN TOKENS --- */
    /* --- Extensive Color Palette --- */

    /* Neutral Colors */
    --color-white: #ffffff;
    --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-xs: 0.75rem;   /* 12px */
    --font-size-sm: 0.875rem;  /* 14px */
    --font-size-base: 1rem;     /* 16px */
    --font-size-lg: 1.125rem;  /* 18px */
    --font-size-xl: 1.25rem;   /* 20px */
    --font-size-2xl: 1.5rem;   /* 24px */
    --font-size-3xl: 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-sm: 4px;
    --border-radius-md: 8px;
    --border-radius-lg: 16px;
    --border-radius-full: 9999px;

    /* Shadows */
    --shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
    --shadow-md: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -1px rgba(0, 0, 0, 0.06);
    --shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -2px rgba(0, 0, 0, 0.05);


    /* --- 2. SEMANTIC & ALIAS TOKENS --- */
    /* Maps core tokens to their intended purpose. */

    /* Brand & Intentional Colors */
    --color-brand-primary: var(--color-blue-600);
    --color-brand-primary-hover: var(--color-blue-700);
    --color-brand-primary-active: var(--color-blue-800);
    
    --color-intent-success: var(--color-green-500);
    --color-intent-success-hover: var(--color-green-600);
    --color-intent-success-active: var(--color-green-700);
    
    --color-intent-warning: var(--color-amber-500);
    --color-intent-warning-hover: var(--color-amber-600);
    --color-intent-warning-active: var(--color-amber-700);

    --color-intent-danger: var(--color-red-500);
    --color-intent-danger-hover: var(--color-red-600);
    --color-intent-danger-active: var(--color-red-700);
    
    --color-intent-info: var(--color-sky-500);

    /* Text Colors */
    --color-text-primary: var(--color-gray-800);
    --color-text-secondary: var(--color-gray-500);
    --color-text-on-brand: var(--color-white);
    --color-text-placeholder: var(--color-gray-400);

    /* Surface & Border Colors */
    --color-surface-page: var(--color-white);
    --color-surface-card: var(--color-white);
    --color-surface-hover: var(--color-gray-50);
    --color-surface-active: var(--color-gray-100);
    --color-border-default: var(--color-gray-300);
    --color-border-interactive: var(--color-gray-400);
    
    /* Typography */
    --font-family-base: var(--font-family-sans);
    --font-family-heading: var(--font-family-sans);

    /* Shadows */
    --shadow-interactive: var(--shadow-sm);
    --shadow-card: var(--shadow-lg);

    /* Focus Ring */
    --focus-ring-shadow: 0 0 0 3px color-mix(in srgb, var(--color-brand-primary) 40%, transparent);

    /* --- 3. COMPONENT-SPECIFIC VARIABLES --- */
    /* Consumed by components. They inherit from semantic tokens. */

    /* Buttons (dn-button) */
    --dn-button-font-weight: var(--font-weight-semibold);
    --dn-button-border-radius: var(--border-radius-md);
    --dn-button-pill-border-radius: var(--border-radius-full);
    --dn-button-focus-shadow: var(--focus-ring-shadow);

    --dn-button-primary-bg: var(--color-brand-primary);
    --dn-button-primary-color: var(--color-text-on-brand);
    --dn-button-primary-bg-hover: var(--color-brand-primary-hover);
    --dn-button-primary-bg-active: var(--color-brand-primary-active);
    
    --dn-button-secondary-bg: transparent;
    --dn-button-secondary-color: var(--color-text-primary);
    --dn-button-secondary-border-color: var(--color-border-default);
    --dn-button-secondary-bg-hover: var(--color-surface-hover);
    --dn-button-secondary-bg-active: var(--color-surface-active);
    --dn-button-secondary-border-color-active: var(--color-border-interactive);
    
    --dn-button-danger-bg: var(--color-intent-danger);
    --dn-button-danger-color: var(--color-text-on-brand);
    --dn-button-danger-bg-hover: var(--color-intent-danger-hover);
    --dn-button-danger-bg-active: var(--color-intent-danger-active);
    
    --dn-button-success-bg: var(--color-intent-success);
    --dn-button-success-color: var(--color-text-on-brand);
    --dn-button-success-bg-hover: var(--color-intent-success-hover);
    --dn-button-success-bg-active: var(--color-intent-success-active);
    
    --dn-button-warning-bg: var(--color-intent-warning);
    --dn-button-warning-color: var(--color-text-on-brand);
    --dn-button-warning-bg-hover: var(--color-intent-warning-hover);
    --dn-button-warning-bg-active: var(--color-intent-warning-active);
    
    --dn-button-clear-bg: transparent;
    --dn-button-clear-color: var(--color-text-secondary);
    --dn-button-clear-bg-hover: var(--color-surface-hover);
    --dn-button-clear-color-hover: var(--color-text-primary);
    --dn-button-clear-bg-active: var(--color-surface-active);

    /* Inputs (BaseInput) */
    --dn-input-border-radius: var(--border-radius-md);
    --dn-input-border-color: var(--color-border-default);
    --dn-input-border-color-focus: var(--color-brand-primary);
    --dn-input-border-color-invalid: var(--color-intent-danger);
    --dn-input-label-color: var(--color-text-secondary);
    --dn-input-label-color-focus: var(--color-brand-primary);
    --dn-input-label-color-invalid: var(--color-intent-danger);
    --dn-input-box-shadow-focus: var(--focus-ring-shadow);


    /* --- 4. NEED TO BE DEPRECATED/CHANGED TO THE NEW STRUCTURE --- */

    /* Menu */
    --menu-width: 18em;

    /* Colors */
    --primary-color: #2160F4;
    /* TODO: Implement secondary and tertiary accents... */
    --secondary-color: var(--primary-color);
    --tertiary-color: var(--primary-color);
    --background: white;
    --border-color: #ddd;
    --success-color: #41B549;
    --green-color: #41B549;
    --information-color: #4179b5;
    --yellow-color: #FFD012;
    --warning-color: #f48b36;
    --red-color: #DB4437;
    --danger-color: #f4364c;
    --discard-color: #f4364c;
    --default-grey-color: #B4B6B8;
    --light-grey-color: #D8D8D8;
    --extra-light-grey-color: #f7f7f7;
    --dark-grey-color: #6D7381;
    --visited-color: #551a8b;
    --icon-color: #B4B6B8;

    /* opacity */
    --primary-opacity-1: color-mix(in srgb, var(--range-primary) 4%, transparent);
    --primary-opacity-2: color-mix(in srgb, var(--range-primary) 12%, transparent);
    --primary-opacity-3: color-mix(in srgb, var(--range-primary) 16%, transparent);
    --primary-opacity-4: color-mix(in srgb, var(--range-primary) 24%, transparent);
    --primary-opacity-5: color-mix(in srgb, var(--range-primary) 38%, transparent);
    --primary-opacity-6: color-mix(in srgb, var(--range-primary) 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 */
    --font-family: 'Nunito Sans', sans-serif;
    --font-size: 16px;
    --font-weight: 400;
    --letter-spacing: 0.009375em;
    --text-color: black;
    --heading-font-family: 'Nunito Sans', sans-serif;
    --heading-1-size: 28px;
    --heading-1-weight: 800;
    --heading-2-size: 26px;
    --heading-2-weight: 600;
    --heading-3-size: 24px;
    --heading-3-weight: 500;
    --heading-4-size: 22px;
    --heading-4-weight: 400;
    --heading-5-size: 20px;
    --heading-5-weight: 400;
    --heading-6-size: 18px;
    --heading-6-weight: 400;

    /* Shadows */
    --navbar-shadow: rgba(0, 0, 0, 0.15) 0px 2px 5px;
    --navbar-height: 55px;
    --bottombar-shadow: rgba(0, 0, 0, 0.15) 0px -2px 5px;
    --card-shadow: rgba(0, 0, 0, 0.12) 0px 5px 15px;
    --button-shadow:  0 4px 6px 0 rgba(0, 0, 0, 0.2);
    --button-shadow-hover: 0 4px 6px 0 rgba(0, 0, 0, 0.3);

    /* --- dn-common-button --- */

    /* General */
    --dn-button-font-family: 'Inter', sans-serif;
    --dn-button-font-weight: 600;
    --dn-button-focus-shadow: 0 0 0 3px rgba(33, 96, 244, 0.5);

    /* Sizes */
    --dn-button-sm-padding: 0.375rem 0.75rem;
    --dn-button-sm-font-size: 0.875rem;
    --dn-button-md-padding: 0.625rem 1.25rem;
    --dn-button-md-font-size: 1rem;
    --dn-button-lg-padding: 0.875rem 1.75rem;
    --dn-button-lg-font-size: 1.125rem;

    /* Shapes */
    --dn-button-border-radius: 8px; /* Standard shape */
    --dn-button-pill-border-radius: 9999px;
    --dn-button-circle-border-radius: 50%;
    --dn-button-circle-sm-size: 2rem; /* 32px */
    --dn-button-circle-md-size: 2.5rem; /* 40px */
    --dn-button-circle-lg-size: 3rem; /* 48px */

    /* Primary Variant */
    --dn-button-primary-bg: #2160F4;
    --dn-button-primary-color: white;
    --dn-button-primary-bg-hover: #1a4dcc;
    --dn-button-primary-bg-active: #123e9c;

    /* Secondary Variant */
    --dn-button-secondary-bg: transparent;
    --dn-button-secondary-color: #1f2937;
    --dn-button-secondary-border-color: #d1d5db;
    --dn-button-secondary-bg-hover: #f9fafb;
    --dn-button-secondary-bg-active: #e5e7eb;
    --dn-button-secondary-border-color-active: #9ca3af;

    /* Tertiary Variant */
    --dn-button-tertiary-bg: transparent;
    --dn-button-tertiary-color: #1f2937;
    --dn-button-tertiary-bg-hover: #f9fafb;
    --dn-button-tertiary-bg-active: #e5e7eb;

    /* Danger Variant */
    --dn-button-danger-bg: #ef4444;
    --dn-button-danger-color: white;
    --dn-button-danger-bg-hover: #dc2626;
    --dn-button-danger-bg-active: #b91c1c;

    /* Success Variant */
    --dn-button-success-bg: #22c55e;
    --dn-button-success-color: white;
    --dn-button-success-bg-hover: #16a34a;
    --dn-button-success-bg-active: #15803d;

    /* Warning Variant */
    --dn-button-warning-bg: #f59e0b;
    --dn-button-warning-color: white;
    --dn-button-warning-bg-hover: #d97706;
    --dn-button-warning-bg-active: #b45309;
    
    /* Clear Variant */
    --dn-button-clear-bg: transparent;
    --dn-button-clear-color: #4b5563;
    --dn-button-clear-bg-hover: #f9fafb;
    --dn-button-clear-color-hover: #1f2937;
    --dn-button-clear-bg-active: #f3f4f6;


    --button-primary: var(--primary-color);
    --button-primary-background: var(--primary-color);
    --button-primary-color: white;
    --button-primary-border: 1px solid var(--primary-color);
    --button-primary-hover: var(--button-shadow-hover);
    --button-secondary-background: transparent;
    --button-secondary-color: var(--secondary-color);
    --button-secondary-border: 1px solid var(--secondary-color);
    --button-secondary-hover: var(--button-shadow-hover);
    --button-tertiary-background: transparent;
    --button-tertiary-color: var(--tertiary-color);
    --button-tertiary-border: 1px solid var(--tertiary-color);
    --button-tertiary-hover: var(--button-shadow-hover);
    --button-warning-background: var(--warning-color);
    --button-warning-color: var(--background);
    --button-warning-border: 1px solid var(--warning-color);
    --button-warning-hover: var(--button-shadow-hover);
    --button-danger-background: var(--danger-color);
    --button-danger-color: var(--background);
    --button-danger-border: 1px solid var(--danger-color);
    --button-danger-hover: var(--button-shadow-hover);
    --button-success-background: var(--success-color);
    --button-success-color: var(--background);
    --button-success-border: 1px solid var(--success-color);
    --button-success-hover: var(--button-shadow-hover);
    --button-grey-background: var(--background);
    --button-grey-color: var(--dark-grey-color);
    --button-grey-border: 0;
    --button-grey-hover: var(--button-shadow-hover);

    /* Disabled Inputs */
    --disabled-opacity: 0.9;
    --disabled-opacity-color: 90%;

    /* 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);
}

/* 2. GLOBAL & STRUCTURAL STYLES */
body {
    -webkit-font-smoothing: antialiased;
    font-display: block;
    font-family: var(--font-family);
    font-size: var(--font-size);
    font-weight: var(--font-weight);
    letter-spacing: var(--letter-spacing);
    text-decoration: inherit;
    text-transform: inherit;
}

/* 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;
	}
} */

@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;
    }
}

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

h1 {
    font-size: var(--heading-1-size);
    font-weight: var(--heading-1-weight);
    font-family: var(--heading-font-family);
}

h2 {
    font-size: var(--heading-2-size);
    font-weight: var(--heading-2-weight);
    font-family: var(--heading-font-family);
}

h3 {
    font-size: var(--heading-3-size);
    font-weight: var(--heading-3-weight);
    font-family: var(--heading-font-family);
}

h4 {
    font-size: var(--heading-4-size);
    font-weight: var(--heading-4-weight);
    font-family: var(--heading-font-family);
}

h5 {
    font-size: var(--heading-5-size);
    font-weight: var(--heading-5-weight);
    font-family: var(--heading-font-family);
}

h6 {
    font-size: var(--heading-6-size);
    font-weight: var(--heading-6-weight);
    font-family: var(--heading-font-family);
}

.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;
    margin-right: -5px;
    margin-left: -5px;
}

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

.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;
}



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

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

.dn-button {
    background-color: var(--primary-color) !important;
}

.dn-button:hover {
    box-shadow: var(--button-shadow-hover) !important;
}

.dn-button--secondary {
    background-color: transparent !important;
    color: var(--secondary-color) !important;
    border: 1px solid var(--secondary-color) !important;
}

.dn-button--secondary:hover {
    box-shadow: var(--button-shadow-hover) !important;
}

.dn-button--tertiary {
    background-color: transparent !important;
    color: var(--tertiary-color) !important;
}

.dn-button--tertiary:hover {
    background-color: #F2F2F2 !important;
}

.dn-button--success {
    background-color: var(--success-color) !important;
    color: var(--background) !important;
}

.dn-button--success:hover {
    box-shadow: var(--button-shadow-hover) !important;
}

.dn-button--danger {
    background-color: var(--danger-color) !important;
    color: var(--background) !important;
}

.dn-button--grey {
    background-color: var(--background) !important;
    color: var(--dark-grey-color) !important;
    border: 0 !important;
}

.dn-button--grey:hover {
    box-shadow: var(--button-shadow-hover) !important;
}

.dn-card {
    background-color: var(--background);
    border: 1px solid var(--border-color);
    border-radius: 4px;
    box-shadow: -2px 2px 4px rgba(0, 0, 0, 0.13);
}

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

.dn-tile-grid .dn-tile {
    border-radius: 5px;
    border: 1px solid #D5DAE0;
    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);
}

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

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

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

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

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

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

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

.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);
}

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

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

.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%;
    }
}
