/* =====================================================
   GILDED DARK THEME — MUSSKART TECHNOLOGY
   Based on the Gilded Print poster visual language
   Ndot 57 display font + Space Grotesk body font
   Deep brown/gold/cream palette
   ===================================================== */

/* Ndot 57 Display Font */
@font-face {
    font-family: "Ndot 57";
    src: url("https://db.onlinewebfonts.com/t/d7a74ed36ff0603a3e41b6da32c47f03.woff2") format("woff2"),
         url("https://db.onlinewebfonts.com/t/d7a74ed36ff0603a3e41b6da32c47f03.woff") format("woff"),
         url("https://db.onlinewebfonts.com/t/d7a74ed36ff0603a3e41b6da32c47f03.ttf") format("truetype");
    font-weight: normal;
    font-style: normal;
    font-display: swap;
}

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

/* 1. Design Tokens */
:root {
    /* Bootstrap variable overrides */
    --bs-primary: #d69f26;
    --bs-secondary: #2BA89E;
    --bs-success: #2BA89E;
    --bs-info: #E87040;
    --bs-warning: #F0A842;
    --bs-danger: #E87040;
    --bs-light: #1a1005;
    --bs-dark: #120a03;
    --bs-white: #fff8e9;
    --bs-body-rgb: 18, 10, 3;
    --bs-body-color: #c7aa69;
    --bs-body-bg: #120a03;
    --bs-primary-rgb: 214, 159, 38;
    --bs-secondary-rgb: 43, 168, 158;

    /* Gilded dark mode tokens */
    --dm-bg-deepest: #0e0803;
    --dm-bg-deep: #120a03;
    --dm-bg-surface: #1a1005;
    --dm-bg-elevated: #281606;
    --dm-bg-hover: #371f07;
    --dm-accent-primary: #d69f26;
    --dm-accent-primary-rgb: 214, 159, 38;
    --dm-accent-secondary: #2BA89E;
    --dm-accent-secondary-rgb: 43, 168, 158;
    --dm-accent-tertiary: #E87040;
    --dm-text-primary: #fff8e9;
    --dm-text-secondary: #c7aa69;
    --dm-text-muted: #8a6d3b;
    --dm-border: rgba(255, 226, 148, 0.16);
    --dm-border-glow: rgba(214, 159, 38, 0.3);

    /* Poster-specific tokens */
    --gold-100: #fff3cb;
    --gold-200: #f8dd8c;
    --gold-300: #efc756;
    --gold-400: #d69f26;
    --gold-500: #9c6507;
    --cream: #fff8e9;
    --sand: #ecd9aa;
    --muted: #c7aa69;
    --coffee: #4a2b08;
    --coral: #E87040;
    --amber: #F0A842;
    --aqua: #2BA89E;
    --ink-950: #120a03;
    --ink-900: #1a1005;
    --line: rgba(255, 228, 160, 0.22);
    --panel: rgba(18, 10, 4, 0.82);

    /* Font stacks */
    --display: "Ndot 57", "Space Grotesk", sans-serif;
    --body: "Space Grotesk", sans-serif;
}

/* 2. Body base */
body {
    background-color: var(--dm-bg-deepest) !important;
    background-image:
        radial-gradient(circle at 20% 10%, rgba(245, 195, 92, 0.10), transparent 26%),
        radial-gradient(circle at 82% 16%, rgba(255, 123, 69, 0.07), transparent 22%),
        radial-gradient(circle at 50% 80%, rgba(43, 168, 158, 0.05), transparent 24%);
    background-attachment: fixed;
    color: var(--dm-text-secondary) !important;
    font-family: var(--body) !important;
    position: relative;
}

/* Page patterns are in page-patterns.css */

/* Shared pseudo-element base for patterns */
body::before, body::after {
    content: "";
    position: fixed;
    inset: 0;
    z-index: 0;
    pointer-events: none;
}
body > *:not(script):not(header) { position: relative; z-index: 1; }
body > header { position: sticky; top: 0; z-index: 9990; }

/* Default body::before — hidden until page-patterns.css activates it */
body::before { opacity: 0; }
body::after { opacity: 0; }

/* All per-page patterns are now in page-patterns.css */


h1, h2, h3, h4, h5, h6,
.h1, .h2, .h3, .h4, .h5, .h6,
.display-1, .display-2, .display-3, .display-4, .display-5, .display-6 {
    font-family: var(--display) !important;
    color: var(--cream) !important;
    letter-spacing: 0.02em;
}

h1, .h1 { text-transform: uppercase; }
h2, .h2 { text-transform: uppercase; }
h5, .h5 { letter-spacing: 0.12em; text-transform: uppercase; }

/* 4. Links */
a {
    color: var(--gold-200);
    transition: color 0.3s ease;
}
a:hover {
    color: var(--aqua);
}

/* 5. Bootstrap bg- utility overrides */
.bg-primary { background-color: var(--dm-accent-primary) !important; }
.bg-secondary { background-color: var(--dm-accent-secondary) !important; }
.bg-light { background-color: var(--dm-bg-surface) !important; }
.bg-dark { background-color: var(--dm-bg-deep) !important; }
.bg-white { background-color: var(--dm-bg-surface) !important; }

/* 6. Bootstrap text- utility overrides */
.text-primary { color: var(--gold-300) !important; }
.text-secondary { color: var(--aqua) !important; }
.text-light { color: var(--dm-text-secondary) !important; }
.text-dark { color: var(--dm-text-primary) !important; }
.text-white { color: var(--cream) !important; }
.text-white-50 { color: rgba(255, 248, 233, 0.5) !important; }
.text-muted { color: var(--dm-text-muted) !important; }
.text-body { color: var(--dm-text-secondary) !important; }

/* 7. Bootstrap btn- overrides */
.btn-primary {
    background: linear-gradient(135deg, #fff0b4, #efc756 50%, #d69f26) !important;
    border: none !important;
    color: #231305 !important;
    font-family: var(--body) !important;
    font-weight: 700 !important;
}
.btn-primary:hover, .btn-primary:focus {
    background: linear-gradient(135deg, #fff5cc, #f8dd8c 50%, #efc756) !important;
    box-shadow: 0 10px 24px rgba(214, 159, 38, 0.3);
    color: #231305 !important;
    transform: translateY(-1px);
}

.btn-secondary {
    background: linear-gradient(135deg, #5CC8C0, #2BA89E 55%, #1A857E) !important;
    border: none !important;
    color: #062220 !important;
    font-family: var(--body) !important;
    font-weight: 700 !important;
}
.btn-secondary:hover, .btn-secondary:focus {
    background: linear-gradient(135deg, #7DD8D2, #3DBAB0 55%, #2BA89E) !important;
    box-shadow: 0 10px 24px rgba(43, 168, 158, 0.3);
    color: #062220 !important;
    transform: translateY(-1px);
}

.btn-light {
    background-color: var(--dm-bg-elevated) !important;
    border-color: var(--dm-border) !important;
    color: var(--cream) !important;
}
.btn-light:hover {
    background-color: var(--dm-bg-hover) !important;
    color: var(--cream) !important;
}

.btn-dark {
    background-color: var(--dm-bg-deep) !important;
    border-color: var(--dm-border) !important;
    color: var(--cream) !important;
}

.btn-outline-primary {
    color: var(--gold-300) !important;
    border-color: var(--gold-300) !important;
}
.btn-outline-primary:hover {
    background: linear-gradient(135deg, #fff0b4, #efc756 50%, #d69f26) !important;
    color: #231305 !important;
    border-color: var(--gold-300) !important;
    box-shadow: 0 0 15px rgba(214, 159, 38, 0.3);
}

.btn-outline-secondary {
    color: var(--aqua) !important;
    border-color: var(--aqua) !important;
}
.btn-outline-secondary:hover {
    background: linear-gradient(135deg, #5CC8C0, #2BA89E) !important;
    color: #062220 !important;
    border-color: var(--aqua) !important;
    box-shadow: 0 0 15px rgba(43, 168, 158, 0.3);
}

/* 8. Border overrides */
.border { border-color: var(--dm-border) !important; }
.border-primary { border-color: rgba(255, 226, 148, 0.25) !important; }
.border-secondary { border-color: rgba(43, 168, 158, 0.25) !important; }
.border-white { border-color: var(--dm-border) !important; }
.border-top { border-top-color: var(--dm-border) !important; }
.border-bottom { border-bottom-color: var(--dm-border) !important; }

/* 9. Form controls */
.form-control,
.form-select {
    background-color: rgba(18, 10, 4, 0.90) !important;
    border: 1px solid var(--dm-border) !important;
    color: var(--cream) !important;
    font-family: var(--body) !important;
}
.form-control:focus,
.form-select:focus {
    background-color: rgba(40, 22, 6, 0.90) !important;
    border-color: var(--gold-400) !important;
    box-shadow: 0 0 0 0.25rem rgba(214, 159, 38, 0.20),
                0 0 15px rgba(214, 159, 38, 0.10) !important;
    color: var(--cream) !important;
}
.form-control::placeholder {
    color: var(--dm-text-muted) !important;
}

/* 10. Dropdown menus */
.dropdown-menu {
    background-color: var(--dm-bg-elevated) !important;
    border: 1px solid var(--dm-border) !important;
    box-shadow: 0 14px 40px rgba(0, 0, 0, 0.5);
}
.dropdown-item {
    color: var(--dm-text-secondary) !important;
    font-family: var(--display) !important;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}
.dropdown-item:hover, .dropdown-item:focus {
    background-color: var(--dm-bg-hover) !important;
    color: var(--gold-200) !important;
}

/* 11. Cards */
.card {
    background-color: var(--dm-bg-surface) !important;
    border: 1px solid var(--dm-border) !important;
}

/* 12. Tables */
.table {
    color: var(--dm-text-secondary);
    border-color: var(--dm-border);
}
.table > :not(caption) > * > * {
    background-color: transparent;
    color: var(--dm-text-secondary);
    border-bottom-color: var(--dm-border);
}

/* 13. Breadcrumb */
.breadcrumb-item + .breadcrumb-item::before {
    color: var(--dm-text-muted) !important;
}
.breadcrumb-item a {
    color: var(--gold-200) !important;
}
.breadcrumb-item.active {
    color: var(--cream) !important;
}

/* 14. Horizontal rules */
hr {
    color: var(--dm-border);
    opacity: 0.5;
}

/* 15. List groups */
.list-group-item {
    background-color: var(--dm-bg-surface);
    border-color: var(--dm-border);
    color: var(--dm-text-secondary);
}

/* 16. Paragraph text */
p {
    color: var(--dm-text-secondary);
    font-family: var(--body);
}

/* 17. Shadow override */
.shadow {
    box-shadow: 0 14px 28px rgba(7, 3, 1, 0.4) !important;
}

/* 18. Alert overrides for gilded theme */
.alert-success {
    background-color: rgba(43, 168, 158, 0.15) !important;
    border-color: rgba(43, 168, 158, 0.3) !important;
    color: var(--aqua) !important;
}
.alert-success .alert-link {
    color: var(--gold-200) !important;
}
