/* =====================================================
   NET GLOW STUDIOS — Global Styles (Glassmorphism)
   ===================================================== */

:root {
    /* Brand colours */
    --ngs-primary:        #DA4167;
    --ngs-primary-rgb:    218, 65, 103;
    --ngs-secondary:      #71a4f1;
    --ngs-secondary-rgb:  113, 164, 241;

    /* Gradient used on brand text & tile headers */
    --ngs-gradient: linear-gradient(90deg,
        rgb(63, 96, 159)      0%,
        rgba(102, 80, 215, 1) 5%,
        rgba(167, 32, 177, 1) 15%,
        rgba(255, 0, 101, 1)  100%);

    /* Background */
    --bg-base:  #06060f;
    --bg-mid:   #0b0b1c;

    /* Glass card */
    --glass-bg:        rgba(255, 255, 255, 0.055);
    --glass-bg-hover:  rgba(255, 255, 255, 0.09);
    --glass-border:    rgba(255, 255, 255, 0.1);
    --glass-blur:      blur(22px);
    --glass-shadow:    0 8px 32px rgba(0, 0, 0, 0.45);

    /* Text */
    --text-primary:   #f0f0fa;
    --text-secondary: #9898b8;
    --text-muted:     #55556a;

    /* Navbar */
    --navbar-h:       64px;
    --navbar-brand-h: 64px;
}

/* ── Base ──────────────────────────────────────────── */

html {
    font-size: 16px;
    scroll-behavior: smooth;
    /* offset anchor jumps for the fixed navbar */
    scroll-padding-top: var(--navbar-h);
}

body {
    margin: 0;
    padding: 0;
    font-family: 'Quicksand', sans-serif;
    color: var(--text-primary);
    background: var(--bg-base);
    min-height: 100vh;
    overflow-x: hidden;
}

/* Deep radial background glow */
body::before {
    content: '';
    position: fixed;
    inset: 0;
    z-index: -2;
    background:
        radial-gradient(ellipse 80% 60% at 20% 10%,
            rgba(var(--ngs-primary-rgb), 0.07) 0%, transparent 60%),
        radial-gradient(ellipse 60% 50% at 80% 85%,
            rgba(var(--ngs-secondary-rgb), 0.07) 0%, transparent 60%),
        linear-gradient(160deg, var(--bg-mid) 0%, var(--bg-base) 100%);
}

/* Subtle noise / texture overlay */
body::after {
    content: '';
    position: fixed;
    inset: 0;
    z-index: -1;
    background-image: url('/content/img/dark.png');
    background-repeat: repeat;
    opacity: 0.08;
    pointer-events: none;
}

h1, h2, h3, h4, h5 {
    font-family: "Tektur", serif !important;
    color: var(--text-primary);
}

a { color: var(--text-primary); }

/* ── Bootstrap overrides ───────────────────────────── */

.btn-primary {
    --bs-btn-color:               #fff;
    --bs-btn-bg:                  var(--ngs-primary);
    --bs-btn-border-color:        var(--ngs-primary);
    --bs-btn-hover-bg:            #e34a70;
    --bs-btn-hover-border-color:  var(--ngs-primary);
    --bs-btn-active-bg:           var(--ngs-primary);
    --bs-btn-active-border-color: var(--ngs-primary);
    --bs-btn-disabled-bg:         rgba(var(--ngs-primary-rgb), 0.4);
    --bs-btn-disabled-border-color: transparent;
}

.btn-outline-light {
    --bs-btn-color:               rgba(255,255,255,0.85);
    --bs-btn-border-color:        rgba(255,255,255,0.3);
    --bs-btn-hover-bg:            rgba(255,255,255,0.1);
    --bs-btn-hover-color:         #fff;
    --bs-btn-hover-border-color:  rgba(255,255,255,0.6);
}

.btn:focus, .btn:active:focus {
    box-shadow: 0 0 0 0.15rem rgba(var(--ngs-primary-rgb), 0.4);
}

.text-primary   { color: var(--ngs-primary)   !important; }
.text-secondary { color: var(--ngs-secondary)  !important; }
.text-muted     { color: var(--text-secondary) !important; }

/* ── Utilities ─────────────────────────────────────── */

.text-primary-gradient {
    background: var(--ngs-gradient);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

.font-electrolize { font-family: 'Electrolize', sans-serif; }
.font-tektur      { font-family: 'Tektur', serif; }
.font-mono        { font-family: 'Share Tech Mono', monospace; letter-spacing: -0.5px; }

/* ── Social links ──────────────────────────────────── */

.social-link {
    display: inline-block;
    margin: 0.25rem;
    font-size: 1.8rem;
    line-height: 1;
    text-decoration: none;
    transition: transform 0.2s ease, opacity 0.2s ease;
}

.social-link:hover {
    transform: scale(1.2);
    opacity: 0.8;
}

/* ── Form controls on dark background ─────────────── */

.form-control,
.form-select {
    background-color: rgba(255, 255, 255, 0.07);
    border: 1px solid rgba(255, 255, 255, 0.15);
    color: var(--text-primary);
}

.form-control:focus,
.form-select:focus {
    background-color: rgba(255, 255, 255, 0.1);
    border-color: rgba(var(--ngs-primary-rgb), 0.6);
    color: var(--text-primary);
    box-shadow: 0 0 0 0.2rem rgba(var(--ngs-primary-rgb), 0.2);
}

.form-control::placeholder { color: var(--text-muted); }
.form-label { color: var(--text-secondary); font-size: 0.88rem; }

.form-select option {
    background: var(--bg-mid);
    color: var(--text-primary);
}

/* ── Blazor error boundary ─────────────────────────── */

.blazor-error-boundary {
    background: #b32121;
    padding: 1rem;
    color: white;
}

.blazor-error-boundary::after { content: "An error has occurred." }

/* ── Form validation ───────────────────────────────── */

.valid.modified:not([type=checkbox]) { outline: 1px solid #26b050; }
.invalid                             { outline: 1px solid #e50000; }
.validation-message                  { color: #e50000; }
