﻿/* =============================================================================
   Dark, Futuristic Theme for _Layout.cshtml
   =============================================================================
   - Base on your logo’s gradient blues, deep charcoals, and high-contrast accents
   - Uses CSS custom properties for easy theming
   - Modern geometric sans-serif typography
   - Subtle transitions and micro-interactions
   ============================================================================= */

/* Import modern geometric font */
/*@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;600;700&display=swap');*/

/* │────────────────────────────────────────────────────────────────────────────│
   │   CSS VARIABLES                                                         │
   │────────────────────────────────────────────────────────────────────────────│ */
:root {
    /* Color Palette */
    --color-bg: #12171f;
    --color-surface: #1e2530;
    --color-border: #2a2f3c;
    --color-primary: #4e94e0;
    --color-primary-dark: #1861ac;
    --color-accent: #00ecff;
    --color-text: #e0e0e0;
    --color-text-secondary: #a0a0a0;
    /* Typography */
    --font-sans: 'Inter', sans-serif;
    --base-font-size: 16px;
    /* Spacing & Transitions */
    --spacing-sm: 0.5rem;
    --spacing-md: 1rem;
    --spacing-lg: 1.5rem;
    --transition-fast: 0.2s ease-in-out;
    --transition-medium: 0.4s ease-in-out;
}

/* │────────────────────────────────────────────────────────────────────────────│
   │   GLOBAL RESET & BASE STYLES                                            │
   │────────────────────────────────────────────────────────────────────────────│ */
*,
*::before,
*::after {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
}

html {
    font-size: var(--base-font-size);
    scroll-behavior: smooth;
    background-color: var(--color-bg);
    color: var(--color-text);
}

body {
    background-color: var(--color-bg) !important;
}


body {
    font-family: var(--font-sans);
    line-height: 1.6;
    background-color: var(--color-bg);
    color: var(--color-text);
}

/* Links & Interactive Elements */
a {
    color: var(--color-primary);
    text-decoration: none;
    transition: color var(--transition-fast);
}

a:hover,
a:focus {
    color: var(--color-accent);
}

/* Buttons */
.btn-primary {
    display: inline-block;
    font-weight: 600;
    color: #fff;
    background-color: var(--color-primary);
    border: 2px solid var(--color-primary-dark);
    padding: var(--spacing-sm) var(--spacing-md);
    border-radius: 0.5rem;
    transition: background-color var(--transition-fast), transform var(--transition-fast), box-shadow var(--transition-medium);
}

.btn-primary:hover,
.btn-primary:focus {
    background-color: var(--color-primary-dark);
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.4);
}

/* │────────────────────────────────────────────────────────────────────────────│
   │   NAVIGATION BAR                                                        │
   │────────────────────────────────────────────────────────────────────────────│ */
.navbar {
    background-color: var(--color-surface);
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.7);
}

a.navbar-brand {
    color: var(--color-primary);
    font-size: 1.5rem;
    font-weight: 600;
    text-align: center;
    word-break: break-all;
    padding: var(--spacing-md) 0;
}

.nav-pills .nav-link {
    color: var(--color-text-secondary);
    padding: var(--spacing-sm) var(--spacing-md);
    transition: color var(--transition-fast), background-color var(--transition-fast);
}

.nav-pills .nav-link:hover {
    color: var(--color-text);
}

.nav-pills .nav-link.active,
.nav-pills .show > .nav-link {
    color: #fff;
    background-color: var(--color-primary);
    border-radius: 0.375rem;
}

/*.light-pills .nav-link {*/
    /*background-color: #f0f0f0;*/ /* light background */
    /*color: #f0f0f0;*/ /* #000; */ /* dark text */
/*}*/

/*.light-pills .nav-link {
    background-color: #000;*/ /* light background */
    /*color: #f0f0f0;*/ /* dark text */
/*}

 .light-pills .nav-link.active {
     background-color: #007bff;*/ /* blue active pill */
     /*color: #fff;
 }

.navbar-toggler-icon {
    background-image: url("data:image/svg+xml;charset=utf8,%3Csvg viewBox='0 0 30 30' ... %3C/svg%3E");
    filter: invert(100%);*/ /* makes it white on dark backgrounds */
/*}*/


/* │────────────────────────────────────────────────────────────────────────────│
   │   CONTAINERS & UTILITIES                                                │
   │────────────────────────────────────────────────────────────────────────────│ */
.border-top {
    border-top: 1px solid var(--color-border);
}

.border-bottom {
    border-bottom: 1px solid var(--color-border);
}

.box-shadow {
    box-shadow: 0 0.5rem 1rem rgba(0, 0, 0, 0.5);
}

/* │────────────────────────────────────────────────────────────────────────────│
   │   FOOTER                                                                │
   │────────────────────────────────────────────────────────────────────────────│ */
.footer {
    background-color: var(--color-surface);
    border-top: 1px solid var(--color-border);
    position: absolute;
    bottom: 0;
    width: 100%;
    text-align: center;
    color: var(--color-text-secondary);
    padding: var(--spacing-md) 0;
    font-size: 0.875rem;
}

/* │────────────────────────────────────────────────────────────────────────────│
   │   MICRO-INTERACTIONS & ACCESSIBILITY                                    │
   │────────────────────────────────────────────────────────────────────────────│ */
button,
input,
select,
textarea {
    font-family: var(--font-sans);
    transition: box-shadow var(--transition-fast), border-color var(--transition-fast);
}

button:focus,
input:focus,
select:focus,
textarea:focus {
    outline: none;
    box-shadow: 0 0 0 3px rgba(78, 148, 224, 0.4);
    border-color: var(--color-primary);
}

/*************************/

#page-loader {
    position: fixed;
    inset: 0;
    background-color: var(--color-bg);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 9999;
    transition: opacity var(--transition-fast);
}

#page-loader img {
    width: 64px;
    height: 64px;
    animation: spin 1.5s linear infinite;
}

@keyframes spin {
    to {
        transform: rotate(360deg);
    }
}

#page-loader.loaded {
    opacity: 0;
    pointer-events: none;
}

/* ─── Light/Dark Theme Overrides ───────────────────────────────────────────── */
:root[data-theme="light"] {
    --color-bg: #f0f0f0;
    --color-surface: #fff;
    --color-border: #ddd;
    --color-primary: #1861ac;
    --color-accent: #0077cc;
    --color-text: #12171f;
    --color-text-secondary: #555;
}

/* ─── Floating Contact Button ──────────────────────────────────────────────── */
#contactBtn {
    position: fixed;
    bottom: 2rem;
    right: 2rem;
    z-index: 1050;
    width: 56px;
    height: 56px;
    border-radius: 50%;
    font-size: 1.5rem;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 2px 8px rgba(0,0,0,0.5);
    transition: transform var(--transition-fast), background-color var(--transition-fast);
    background-color: var(--color-primary);
    color: #fff;
    border: none;
}

#contactBtn:hover {
    transform: scale(1.1);
    background-color: var(--color-accent);
}

/* ─── Validation Shake Animation ──────────────────────────────────────────── */
@keyframes shake {
    0%, 100% {
        transform: translateX(0);
    }

    20%, 60% {
        transform: translateX(-4px);
    }

    40%, 80% {
        transform: translateX(4px);
    }
}

.was-validated .form-control:invalid {
    animation: shake var(--transition-fast) ease-in-out;
}

/* ─── Success Message Animation ───────────────────────────────────────────── */
.animate-on-show {
    opacity: 0;
    transform: scale(0.9);
    transition: opacity var(--transition-medium), transform var(--transition-medium);
}

.animate-on-show.show {
    opacity: 1;
    transform: scale(1);
}

/* ─── Dark-Mode Offcanvas Overrides ───────────────────────────────────────── */

/* Base offcanvas background & text */
:root[data-theme="dark"] .offcanvas {
    background-color: var(--color-surface) !important;
    color: var(--color-text) !important;
}

/* Offcanvas header & body inherit */
:root[data-theme="dark"] .offcanvas-header,
:root[data-theme="dark"] .offcanvas-body {
    background-color: var(--color-surface) !important;
}

/* Invert the close icon so it’s visible on dark bg */
:root[data-theme="dark"] .offcanvas .btn-close {
    filter: invert(1);
}

/* Form controls inside offcanvas */
:root[data-theme="dark"] .offcanvas .form-control {
    background-color: var(--color-bg);
    color: var(--color-text);
    border: 1px solid var(--color-border);
}

/* Ensure invalid-state styling still shows up */
:root[data-theme="dark"] .offcanvas .was-validated .form-control:invalid {
    animation: shake var(--transition-fast) ease-in-out;
}

/* Button in offcanvas uses primary palette */
:root[data-theme="dark"] .offcanvas .btn-primary {
    background-color: var(--color-primary);
    border-color: var(--color-primary-dark);
}



/* Gradient Animation */
@keyframes gradientShift {
    0% {
        background-position: 0% 50%;
    }

    50% {
        background-position: 100% 50%;
    }

    100% {
        background-position: 0% 50%;
    }
}

/* Apply to hero sections */
.hero-gradient {
    position: relative;
    background: linear-gradient(270deg, var(--color-primary), var(--color-accent));
    background-size: 400% 400%;
    animation: gradientShift 15s ease infinite;
    padding: var(--spacing-lg) 0;
    overflow: hidden;
    border-radius: 1rem;
    color: #fff;
}



.line-accent {
    width: 100%;
    height: 0.5rem;
    margin-bottom: var(--spacing-sm);
}

    .line-accent path {
        stroke-dasharray: 200;
        stroke-dashoffset: 200;
        animation: drawLine 1s ease forwards;
    }

@keyframes drawLine {
    to {
        stroke-dashoffset: 0;
    }
}


.animate-on-scroll {
    opacity: 0;
    transform: translateY(2rem);
    transition: opacity var(--transition-medium), transform var(--transition-medium);
}

.animate-on-scroll.enter-view {
    opacity: 1;
    transform: translateY(0);
}


#page-loader {
    position: fixed;
    inset: 0;
    background-color: var(--color-bg);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 9999;
    transition: opacity var(--transition-fast);
}

    #page-loader img {
        width: 64px;
        height: 64px;
        animation: spin 1.5s linear infinite;
    }

@keyframes spin {
    to {
        transform: rotate(360deg);
    }
}

#page-loader.loaded {
    opacity: 0;
    pointer-events: none;
}


