@import url('https://fonts.googleapis.com/css2?family=Rajdhani:wght@400;500;600;700&family=Space+Grotesk:wght@400;500;600;700&display=swap');

:root {
    --wa-bg:        #0b0b12;
    --wa-surface:   #13131e;
    --wa-surface-2: #1b1b2a;
    --wa-primary:   #7c3aed;
    --wa-accent:    #a855f7;
    --wa-cyan:      #22d3ee;
    --wa-highlight: #f59e0b;
    --wa-glow:      rgba(124, 58, 237, 0.45);
    --wa-text:      #e2e8f0;
    --wa-text-muted:#8892a4;
    --wa-border:    rgba(124, 58, 237, 0.22);
    --wa-navbar-height: 60px;
}

/* ── Global ─────────────────────────────────────────── */
html, body {
    font-family: 'Space Grotesk', 'Segoe UI', system-ui, sans-serif;
    background-color: var(--wa-bg);
    color: var(--wa-text);
    scroll-behavior: smooth;
}

h1, h2, h3, h4, h5 {
    font-family: 'Rajdhani', 'Space Grotesk', system-ui, sans-serif;
    font-weight: 700;
    color: var(--wa-text);
    letter-spacing: 0.01em;
}

a { color: var(--wa-accent); }
a:hover { color: #c084fc; }

.text-muted { color: var(--wa-text-muted) !important; }

/* ── Navbar ─────────────────────────────────────────── */
.wa-navbar {
    background-color: rgba(11, 11, 18, 0.88) !important;
    backdrop-filter: blur(14px);
    -webkit-backdrop-filter: blur(14px);
    border-bottom: 1px solid var(--wa-border);
    min-height: var(--wa-navbar-height);
}

.wa-brand-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 32px;
    height: 32px;
    background: linear-gradient(135deg, var(--wa-primary), var(--wa-accent));
    border-radius: 8px;
    font-weight: 900;
    font-size: 1rem;
    color: white;
    flex-shrink: 0;
    box-shadow: 0 0 14px var(--wa-glow);
}

.wa-navbar .navbar-brand span.fw-bold {
    font-family: 'Rajdhani', sans-serif;
    font-size: 1.2rem;
    letter-spacing: 0.04em;
}

.wa-navbar .nav-link {
    color: rgba(226,232,240,0.65) !important;
    font-size: 0.88rem;
    font-weight: 500;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    padding: 0.4rem 0.8rem;
    transition: color 0.15s;
}

.wa-navbar .nav-link:hover,
.wa-navbar .nav-link.active {
    color: var(--wa-accent) !important;
}

/* ── Main ────────────────────────────────────────────── */
.wa-main {
    padding-top: var(--wa-navbar-height);
    min-height: calc(100vh - var(--wa-navbar-height));
    display: flex;
    flex-direction: column;
    background-color: var(--wa-bg);
}

/* ── Hero ────────────────────────────────────────────── */
.wa-hero {
    position: relative;
    overflow: hidden;
    padding: 9rem 0 7rem;
    color: var(--wa-text);
    background-color: var(--wa-bg);
}

.wa-hero::before {
    content: '';
    position: absolute;
    inset: 0;
    background-image:
        linear-gradient(rgba(124, 58, 237, 0.07) 1px, transparent 1px),
        linear-gradient(90deg, rgba(124, 58, 237, 0.07) 1px, transparent 1px);
    background-size: 48px 48px;
    pointer-events: none;
}

.wa-hero::after {
    content: '';
    position: absolute;
    inset: 0;
    background:
        radial-gradient(ellipse at 15% 60%, rgba(124, 58, 237, 0.22) 0%, transparent 55%),
        radial-gradient(ellipse at 85% 25%, rgba(34, 211, 238, 0.10) 0%, transparent 45%);
    pointer-events: none;
}

.wa-hero > .container { position: relative; z-index: 1; }

.wa-hero h1 {
    font-size: clamp(2.4rem, 5.5vw, 4rem);
    color: #fff;
    text-shadow: 0 0 40px rgba(168, 85, 247, 0.4);
}

/* ── Page header (inner pages) ───────────────────────── */
.wa-page-header {
    position: relative;
    overflow: hidden;
    padding: 5rem 0 3.5rem;
    color: var(--wa-text);
    background-color: var(--wa-bg);
    border-bottom: 1px solid var(--wa-border);
}

.wa-page-header::before {
    content: '';
    position: absolute;
    inset: 0;
    background-image:
        linear-gradient(rgba(124, 58, 237, 0.06) 1px, transparent 1px),
        linear-gradient(90deg, rgba(124, 58, 237, 0.06) 1px, transparent 1px);
    background-size: 48px 48px;
    pointer-events: none;
}

.wa-page-header::after {
    content: '';
    position: absolute;
    inset: 0;
    background: radial-gradient(ellipse at 50% 120%, rgba(124, 58, 237, 0.2) 0%, transparent 65%);
    pointer-events: none;
}

.wa-page-header > .container { position: relative; z-index: 1; }

/* ── Sections ────────────────────────────────────────── */
.wa-section { padding: 5rem 0; }
.wa-section-alt { background-color: var(--wa-surface); }

/* ── Cards ───────────────────────────────────────────── */
.card {
    background-color: var(--wa-surface) !important;
    color: var(--wa-text) !important;
    border-color: var(--wa-border) !important;
}

.wa-section-alt .card,
.wa-section-alt .wa-card {
    background-color: var(--wa-surface-2) !important;
}

.wa-card {
    border: 1px solid var(--wa-border) !important;
    border-radius: 12px !important;
    transition: transform 0.2s, box-shadow 0.2s, border-color 0.2s;
}

.wa-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 8px 36px rgba(124, 58, 237, 0.22) !important;
    border-color: rgba(168, 85, 247, 0.45) !important;
}

.wa-icon-circle {
    width: 64px;
    height: 64px;
    border-radius: 50%;
    background: rgba(124, 58, 237, 0.12);
    border: 1px solid rgba(124, 58, 237, 0.3);
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto 1rem;
}

/* ── Skill badges ────────────────────────────────────── */
.skill-badge {
    display: inline-block;
    background: rgba(124, 58, 237, 0.1);
    color: var(--wa-accent);
    border: 1px solid rgba(124, 58, 237, 0.28);
    border-radius: 4px;
    padding: 0.25rem 0.75rem;
    font-size: 0.8rem;
    font-family: 'Courier New', monospace;
    margin: 0.2rem;
    letter-spacing: 0.02em;
}

/* ── CTA box ─────────────────────────────────────────── */
.wa-cta-box {
    background: linear-gradient(135deg, rgba(124, 58, 237, 0.25) 0%, rgba(168, 85, 247, 0.15) 100%);
    border: 1px solid rgba(124, 58, 237, 0.38);
    border-radius: 16px;
    padding: 3rem;
    color: white;
    box-shadow: 0 0 48px rgba(124, 58, 237, 0.14), inset 0 1px 0 rgba(255,255,255,0.06);
}

/* ── Buttons ─────────────────────────────────────────── */
.btn-primary {
    background: linear-gradient(135deg, var(--wa-primary), var(--wa-accent)) !important;
    border: none !important;
    box-shadow: 0 4px 18px rgba(124, 58, 237, 0.38);
    font-weight: 600;
    letter-spacing: 0.03em;
}

.btn-primary:hover, .btn-primary:focus {
    background: linear-gradient(135deg, #6d28d9, var(--wa-primary)) !important;
    box-shadow: 0 4px 24px rgba(124, 58, 237, 0.55) !important;
}

.btn-outline-light {
    border-color: rgba(255,255,255,0.3);
    color: rgba(255,255,255,0.85);
    font-weight: 600;
    letter-spacing: 0.03em;
}

.btn-outline-light:hover {
    background-color: rgba(255,255,255,0.1);
    border-color: white;
    color: white;
}

.btn-outline-primary {
    color: var(--wa-accent) !important;
    border-color: var(--wa-accent) !important;
    font-weight: 600;
    letter-spacing: 0.03em;
}

.btn-outline-primary:hover {
    background-color: var(--wa-primary) !important;
    border-color: var(--wa-primary) !important;
    color: white !important;
    box-shadow: 0 4px 18px rgba(124, 58, 237, 0.35);
}

/* ── Colour helpers ──────────────────────────────────── */
.text-primary  { color: var(--wa-accent) !important; }
.text-white-75 { color: rgba(226,232,240,0.75) !important; }
.text-success  { color: #4ade80 !important; }

/* ── Forms (dark) ────────────────────────────────────── */
.form-control, .form-select {
    background-color: var(--wa-surface-2) !important;
    border-color: var(--wa-border) !important;
    color: var(--wa-text) !important;
}

.form-control:focus, .form-select:focus {
    background-color: var(--wa-surface-2) !important;
    border-color: var(--wa-accent) !important;
    box-shadow: 0 0 0 0.2rem rgba(124, 58, 237, 0.25) !important;
    color: var(--wa-text) !important;
}

.form-control::placeholder { color: var(--wa-text-muted) !important; }
.form-label { color: var(--wa-text); }

/* ── Footer ──────────────────────────────────────────── */
.wa-footer {
    background-color: var(--wa-surface) !important;
    border-top: 1px solid var(--wa-border) !important;
}

.footer-link { transition: color 0.15s; }
.footer-link:hover { color: var(--wa-accent) !important; }

/* ── Tables (dark) ───────────────────────────────────── */
.table {
    --bs-table-bg: transparent;
    --bs-table-color: var(--wa-text);
    --bs-table-border-color: var(--wa-border);
    --bs-table-hover-bg: rgba(124, 58, 237, 0.07);
    --bs-table-striped-bg: var(--wa-surface-2);
    color: var(--wa-text) !important;
}
.table thead th {
    background-color: var(--wa-surface-2) !important;
    color: var(--wa-text-muted) !important;
    border-bottom-color: var(--wa-border) !important;
    font-size: 0.78rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}
.table-light { --bs-table-bg: var(--wa-surface-2) !important; }
.card-header, .card-footer {
    background-color: var(--wa-surface-2) !important;
    border-color: var(--wa-border) !important;
    color: var(--wa-text) !important;
}
.bg-white { background-color: var(--wa-surface) !important; }
.badge.bg-light { background-color: var(--wa-surface-2) !important; color: var(--wa-text-muted) !important; }
.modal-content {
    background-color: var(--wa-surface) !important;
    border-color: var(--wa-border) !important;
    color: var(--wa-text) !important;
}

/* ── Dashboard / private ─────────────────────────────── */
.wa-stat-card {
    border-radius: 12px;
    border: 1px solid var(--wa-border);
    padding: 1.5rem;
    background: var(--wa-surface);
    color: var(--wa-text);
    transition: box-shadow 0.2s;
}
.wa-stat-card:hover { box-shadow: 0 4px 20px rgba(124, 58, 237, 0.2); }

.wa-stat-icon {
    width: 48px;
    height: 48px;
    border-radius: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.4rem;
}

/* ── Upload area ─────────────────────────────────────── */
.wa-upload-area {
    border: 2px dashed rgba(124, 58, 237, 0.3);
    border-radius: 12px;
    padding: 2.5rem;
    text-align: center;
    cursor: pointer;
    transition: border-color 0.2s, background 0.2s;
    background: var(--wa-surface-2);
    color: var(--wa-text-muted);
}
.wa-upload-area:hover, .wa-upload-area.dragging {
    border-color: var(--wa-accent);
    background: rgba(124, 58, 237, 0.07);
    color: var(--wa-text);
}

/* ── Form validation ─────────────────────────────────── */
.valid.modified:not([type=checkbox]) { outline: 1px solid #22c55e; }
.invalid { outline: 1px solid #ef4444; }
.validation-message { color: #f87171; }
.text-danger { color: #f87171 !important; }

/* ── Alert override ──────────────────────────────────── */
.alert-success {
    background-color: rgba(34, 197, 94, 0.12) !important;
    border-color: rgba(34, 197, 94, 0.3) !important;
    color: #86efac !important;
}

/* ── Blazor error UI ─────────────────────────────────── */
#blazor-error-ui {
    background: var(--wa-surface);
    border-top: 1px solid rgba(239, 68, 68, 0.4);
    color: var(--wa-text);
    bottom: 0;
    box-shadow: 0 -2px 12px rgba(0,0,0,0.4);
    display: none;
    left: 0;
    padding: 0.6rem 1.25rem 0.7rem;
    position: fixed;
    width: 100%;
    z-index: 9999;
}
#blazor-error-ui .dismiss {
    cursor: pointer;
    position: absolute;
    right: 0.75rem;
    top: 0.5rem;
}
.blazor-error-boundary {
    background: rgba(239, 68, 68, 0.15);
    border: 1px solid rgba(239, 68, 68, 0.4);
    padding: 1rem 1rem 1rem 3.7rem;
    color: #fca5a5;
    border-radius: 8px;
}
.blazor-error-boundary::after { content: "An error has occurred." }
