/* Aces & Armour — Bundled CSS (auto-generated by build-css.mjs) */

/* Aces & Armour — Web fonts (self-hosted woff2)

   Futura is the studio's brand typeface — used non-bold (Medium 500) for all
   headings + UI per studio direction. Body = Rajdhani, mono = JetBrains Mono
   (both via Google Fonts <link>). The logo's distinctive face lives in the
   logo image itself, not as a webfont.
*/

/* ── Futura — headings / UI ── */
@font-face {
    font-family: 'Futura';
    src: url('/assets/fonts/futura/futura-medium.woff2?v=h1') format('woff2');
    font-weight: 500;
    font-style: normal;
    font-display: swap;
}
@font-face {
    font-family: 'Futura';
    src: url('/assets/fonts/futura/futura-medium-italic.woff2') format('woff2');
    font-weight: 500;
    font-style: italic;
    font-display: swap;
}
@font-face {
    font-family: 'Futura';
    src: url('/assets/fonts/futura/futura-bold.woff2?v=h1') format('woff2');
    font-weight: 700;
    font-style: normal;
    font-display: swap;
}
@font-face {
    font-family: 'Futura Condensed';
    src: url('/assets/fonts/futura/futura-cond-medium.woff2') format('woff2');
    font-weight: 500;
    font-style: normal;
    font-display: swap;
}
@font-face {
    font-family: 'Futura Condensed';
    src: url('/assets/fonts/futura/futura-cond-extrabold.woff2') format('woff2');
    font-weight: 800;
    font-style: normal;
    font-display: swap;
}

/* ── DIN Alternate — standard / body text (per studio direction) ──
   Regular (400) for body copy, Bold (700) for emphasis. */
@font-face {
    font-family: 'DIN Alternate';
    src: url('/assets/fonts/din/din-alternate-regular.woff2?v=h1') format('woff2');
    font-weight: 400;
    font-style: normal;
    font-display: swap;
}
@font-face {
    font-family: 'DIN Alternate';
    src: url('/assets/fonts/din/din-alternate-bold.woff2?v=h1') format('woff2');
    font-weight: 700;
    font-style: normal;
    font-display: swap;
}

/* Font Awesome 6.4.0 — self-hosted (woff2 only, ttf and v4compat stripped) */
/*!
 * Font Awesome Free 6.4.0 by @fontawesome - https://fontawesome.com
 * License - https://fontawesome.com/license/free (Icons: CC BY 4.0, Fonts: SIL OFL 1.1, Code: MIT License)
 * Copyright 2023 Fonticons, Inc.
 */
.fa{font-family:var(--fa-style-family,"Font Awesome 6 Free");font-weight:var(--fa-style,900)}.fa,.fa-brands,.fa-classic,.fa-regular,.fa-sharp,.fa-solid,.fab,.far,.fas{-moz-osx-font-smoothing:grayscale;-webkit-font-smoothing:antialiased;display:var(--fa-display,inline-block);font-style:normal;font-variant:normal;line-height:1;text-rendering:auto}.fa-classic,.fa-regular,.fa-solid,.far,.fas{font-family:"Font Awesome 6 Free"}.fa-brands,.fab{font-family:"Font Awesome 6 Brands"}.fa-1x{font-size:1em}.fa-2x{font-size:2em}.fa-3x{font-size:3em}.fa-4x{font-size:4em}.fa-5x{font-size:5em}.fa-6x{font-size:6em}.fa-7x{font-size:7em}.fa-8x{font-size:8em}.fa-9x{font-size:9em}.fa-10x{font-size:10em}.fa-2xs{font-size:.625em;line-height:.1em;vertical-align:.225em}.fa-xs{font-size:.75em;line-height:.08333em;vertical-align:.125em}.fa-sm{font-size:.875em;line-height:.07143em;vertical-align:.05357em}.fa-lg{font-size:1.25em;line-height:.05em;vertical-align:-.075em}.fa-xl{font-size:1.5em;line-height:.04167em;vertical-align:-.125em}.fa-2xl{font-size:2em;line-height:.03125em;vertical-align:-.1875em}.fa-fw{text-align:center;width:1.25em}.fa-ul{list-style-type:none;margin-left:var(--fa-li-margin,2.5em);padding-left:0}.fa-ul>li{position:relative}.fa-li{left:calc(var(--fa-li-width, 2em)*-1);position:absolute;text-align:center;width:var(--fa-li-width,2em);line-height:inherit}.fa-border{border-radius:var(--fa-border-radius,.1em);border:var(--fa-border-width,.08em) var(--fa-border-style,solid) var(--fa-border-color,#eee);padding:var(--fa-border-padding,.2em .25em .15em)}.fa-pull-left{float:left;margin-right:var(--fa-pull-margin,.3em)}.fa-pull-right{float:right;margin-left:var(--fa-pull-margin,.3em)}.fa-beat{-webkit-animation-name:fa-beat;animation-name:fa-beat;-webkit-animation-delay:var(--fa-animation-delay,0s);animation-delay:var(--fa-animation-delay,0s);-webkit-animation-direction:var(--fa-animation-direction,normal);animation-direction:var(--fa-animation-direction,normal);-webkit-animation-duration:var(--fa-animation-duration,1s);animation-duration:var(--fa-animation-duration,1s);-webkit-animation-iteration-count:var(--fa-animation-iteration-count,infinite);animation-iteration-count:var(--fa-animation-iteration-count,infinite);-webkit-animation-timing-function:var(--fa-animation-timing,ease-in-out);animation-timing-function:var(--fa-animation-timing,ease-in-out)}.fa-bounce{-webkit-animation-name:fa-bounce;animation-name:fa-bounce;-webkit-animation-delay:var(--fa-animation-delay,0s);animation-delay:var(--fa-animation-delay,0s);-webkit-animation-direction:var(--fa-animation-direction,normal);animation-direction:var(--fa-animation-direction,normal);-webkit-animation-duration:var(--fa-animation-duration,1s);animation-duration:var(--fa-animation-duration,1s);-webkit-animation-iteration-count:var(--fa-animation-iteration-count,infinite);animation-iteration-count:var(--fa-animation-iteration-count,infinite);-webkit-animation-timing-function:var(--fa-animation-timing,cubic-bezier(.28,.84,.42,1));animation-timing-function:var(--fa-animation-timing,cubic-bezier(.28,.84,.42,1))}.fa-fade{-webkit-animation-name:fa-fade;animation-name:fa-fade;-webkit-animation-iteration-count:var(--fa-animation-iteration-count,infinite);animation-iteration-count:var(--fa-animation-iteration-count,infinite);-webkit-animation-timing-function:var(--fa-animation-timing,cubic-bezier(.4,0,.6,1));animation-timing-function:var(--fa-animation-timing,cubic-bezier(.4,0,.6,1))}.fa-beat-fade,.fa-fade{-webkit-animation-delay:var(--fa-animation-delay,0s);animation-delay:var(--fa-animation-delay,0s);-webkit-animation-direction:var(--fa-animation-direction,normal);animation-direction:var(--fa-animation-direction,normal);-webkit-animation-duration:var(--fa-animation-duration,1s);animation-duration:var(--fa-animation-duration,1s)}.fa-beat-fade{-webkit-animation-name:fa-beat-fade;animation-name:fa-beat-fade;-webkit-animation-iteration-count:var(--fa-animation-iteration-count,infinite);animation-iteration-count:var(--fa-animation-iteration-count,infinite);-webkit-animation-timing-function:var(--fa-animation-timing,cubic-bezier(.4,0,.6,1));animation-timing-function:var(--fa-animation-timing,cubic-bezier(.4,0,.6,1))}.fa-flip{-webkit-animation-name:fa-flip;animation-name:fa-flip;-webkit-animation-delay:var(--fa-animation-delay,0s);animation-delay:var(--fa-animation-delay,0s);-webkit-animation-direction:var(--fa-animation-direction,normal);animation-direction:var(--fa-animation-direction,normal);-webkit-animation-duration:var(--fa-animation-duration,1s);animation-duration:var(--fa-animation-duration,1s);-webkit-animation-iteration-count:var(--fa-animation-iteration-count,infinite);animation-iteration-count:var(--fa-animation-iteration-count,infinite);-webkit-animation-timing-function:var(--fa-animation-timing,ease-in-out);animation-timing-function:var(--fa-animation-timing,ease-in-out)}.fa-shake{-webkit-animation-name:fa-shake;animation-name:fa-shake;-webkit-animation-duration:var(--fa-animation-duration,1s);animation-duration:var(--fa-animation-duration,1s);-webkit-animation-iteration-count:var(--fa-animation-iteration-count,infinite);animation-iteration-count:var(--fa-animation-iteration-count,infinite);-webkit-animation-timing-function:var(--fa-animation-timing,linear);animation-timing-function:var(--fa-animation-timing,linear)}.fa-shake,.fa-spin{-webkit-animation-delay:var(--fa-animation-delay,0s);animation-delay:var(--fa-animation-delay,0s);-webkit-animation-direction:var(--fa-animation-direction,normal);animation-direction:var(--fa-animation-direction,normal)}.fa-spin{-webkit-animation-name:fa-spin;animation-name:fa-spin;-webkit-animation-duration:var(--fa-animation-duration,2s);animation-duration:var(--fa-animation-duration,2s);-webkit-animation-iteration-count:var(--fa-animation-iteration-count,infinite);animation-iteration-count:var(--fa-animation-iteration-count,infinite);-webkit-animation-timing-function:var(--fa-animation-timing,linear);animation-timing-function:var(--fa-animation-timing,linear)}.fa-spin-reverse{--fa-animation-direction:reverse}.fa-pulse,.fa-spin-pulse{-webkit-animation-name:fa-spin;animation-name:fa-spin;-webkit-animation-direction:var(--fa-animation-direction,normal);animation-direction:var(--fa-animation-direction,normal);-webkit-animation-duration:var(--fa-animation-duration,1s);animation-duration:var(--fa-animation-duration,1s);-webkit-animation-iteration-count:var(--fa-animation-iteration-count,infinite);animation-iteration-count:var(--fa-animation-iteration-count,infinite);-webkit-animation-timing-function:var(--fa-animation-timing,steps(8));animation-timing-function:var(--fa-animation-timing,steps(8))}@media (prefers-reduced-motion:reduce){.fa-beat,.fa-beat-fade,.fa-bounce,.fa-fade,.fa-flip,.fa-pulse,.fa-shake,.fa-spin,.fa-spin-pulse{-webkit-animation-delay:-1ms;animation-delay:-1ms;-webkit-animation-duration:1ms;animation-duration:1ms;-webkit-animation-iteration-count:1;animation-iteration-count:1;-webkit-transition-delay:0s;transition-delay:0s;-webkit-transition-duration:0s;transition-duration:0s}}@-webkit-keyframes fa-beat{0%,90%{-webkit-transform:scale(1);transform:scale(1)}45%{-webkit-transform:scale(var(--fa-beat-scale,1.25));transform:scale(var(--fa-beat-scale,1.25))}}@keyframes fa-beat{0%,90%{-webkit-transform:scale(1);transform:scale(1)}45%{-webkit-transform:scale(var(--fa-beat-scale,1.25));transform:scale(var(--fa-beat-scale,1.25))}}@-webkit-keyframes fa-bounce{0%{-webkit-transform:scale(1) translateY(0);transform:scale(1) translateY(0)}10%{-webkit-transform:scale(var(--fa-bounce-start-scale-x,1.1),var(--fa-bounce-start-scale-y,.9)) translateY(0);transform:scale(var(--fa-bounce-start-scale-x,1.1),var(--fa-bounce-start-scale-y,.9)) translateY(0)}30%{-webkit-transform:scale(var(--fa-bounce-jump-scale-x,.9),var(--fa-bounce-jump-scale-y,1.1)) translateY(var(--fa-bounce-height,-.5em));transform:scale(var(--fa-bounce-jump-scale-x,.9),var(--fa-bounce-jump-scale-y,1.1)) translateY(var(--fa-bounce-height,-.5em))}50%{-webkit-transform:scale(var(--fa-bounce-land-scale-x,1.05),var(--fa-bounce-land-scale-y,.95)) translateY(0);transform:scale(var(--fa-bounce-land-scale-x,1.05),var(--fa-bounce-land-scale-y,.95)) translateY(0)}57%{-webkit-transform:scale(1) translateY(var(--fa-bounce-rebound,-.125em));transform:scale(1) translateY(var(--fa-bounce-rebound,-.125em))}64%{-webkit-transform:scale(1) translateY(0);transform:scale(1) translateY(0)}to{-webkit-transform:scale(1) translateY(0);transform:scale(1) translateY(0)}}@keyframes fa-bounce{0%{-webkit-transform:scale(1) translateY(0);transform:scale(1) translateY(0)}10%{-webkit-transform:scale(var(--fa-bounce-start-scale-x,1.1),var(--fa-bounce-start-scale-y,.9)) translateY(0);transform:scale(var(--fa-bounce-start-scale-x,1.1),var(--fa-bounce-start-scale-y,.9)) translateY(0)}30%{-webkit-transform:scale(var(--fa-bounce-jump-scale-x,.9),var(--fa-bounce-jump-scale-y,1.1)) translateY(var(--fa-bounce-height,-.5em));transform:scale(var(--fa-bounce-jump-scale-x,.9),var(--fa-bounce-jump-scale-y,1.1)) translateY(var(--fa-bounce-height,-.5em))}50%{-webkit-transform:scale(var(--fa-bounce-land-scale-x,1.05),var(--fa-bounce-land-scale-y,.95)) translateY(0);transform:scale(var(--fa-bounce-land-scale-x,1.05),var(--fa-bounce-land-scale-y,.95)) translateY(0)}57%{-webkit-transform:scale(1) translateY(var(--fa-bounce-rebound,-.125em));transform:scale(1) translateY(var(--fa-bounce-rebound,-.125em))}64%{-webkit-transform:scale(1) translateY(0);transform:scale(1) translateY(0)}to{-webkit-transform:scale(1) translateY(0);transform:scale(1) translateY(0)}}@-webkit-keyframes fa-fade{50%{opacity:var(--fa-fade-opacity,.4)}}@keyframes fa-fade{50%{opacity:var(--fa-fade-opacity,.4)}}@-webkit-keyframes fa-beat-fade{0%,to{opacity:var(--fa-beat-fade-opacity,.4);-webkit-transform:scale(1);transform:scale(1)}50%{opacity:1;-webkit-transform:scale(var(--fa-beat-fade-scale,1.125));transform:scale(var(--fa-beat-fade-scale,1.125))}}@keyframes fa-beat-fade{0%,to{opacity:var(--fa-beat-fade-opacity,.4);-webkit-transform:scale(1);transform:scale(1)}50%{opacity:1;-webkit-transform:scale(var(--fa-beat-fade-scale,1.125));transform:scale(var(--fa-beat-fade-scale,1.125))}}@-webkit-keyframes fa-flip{50%{-webkit-transform:rotate3d(var(--fa-flip-x,0),var(--fa-flip-y,1),var(--fa-flip-z,0),var(--fa-flip-angle,-180deg));transform:rotate3d(var(--fa-flip-x,0),var(--fa-flip-y,1),var(--fa-flip-z,0),var(--fa-flip-angle,-180deg))}}@keyframes fa-flip{50%{-webkit-transform:rotate3d(var(--fa-flip-x,0),var(--fa-flip-y,1),var(--fa-flip-z,0),var(--fa-flip-angle,-180deg));transform:rotate3d(var(--fa-flip-x,0),var(--fa-flip-y,1),var(--fa-flip-z,0),var(--fa-flip-angle,-180deg))}}@-webkit-keyframes fa-shake{0%{-webkit-transform:rotate(-15deg);transform:rotate(-15deg)}4%{-webkit-transform:rotate(15deg);transform:rotate(15deg)}8%,24%{-webkit-transform:rotate(-18deg);transform:rotate(-18deg)}12%,28%{-webkit-transform:rotate(18deg);transform:rotate(18deg)}16%{-webkit-transform:rotate(-22deg);transform:rotate(-22deg)}20%{-webkit-transform:rotate(22deg);transform:rotate(22deg)}32%{-webkit-transform:rotate(-12deg);transform:rotate(-12deg)}36%{-webkit-transform:rotate(12deg);transform:rotate(12deg)}40%,to{-webkit-transform:rotate(0deg);transform:rotate(0deg)}}@keyframes fa-shake{0%{-webkit-transform:rotate(-15deg);transform:rotate(-15deg)}4%{-webkit-transform:rotate(15deg);transform:rotate(15deg)}8%,24%{-webkit-transform:rotate(-18deg);transform:rotate(-18deg)}12%,28%{-webkit-transform:rotate(18deg);transform:rotate(18deg)}16%{-webkit-transform:rotate(-22deg);transform:rotate(-22deg)}20%{-webkit-transform:rotate(22deg);transform:rotate(22deg)}32%{-webkit-transform:rotate(-12deg);transform:rotate(-12deg)}36%{-webkit-transform:rotate(12deg);transform:rotate(12deg)}40%,to{-webkit-transform:rotate(0deg);transform:rotate(0deg)}}@-webkit-keyframes fa-spin{0%{-webkit-transform:rotate(0deg);transform:rotate(0deg)}to{-webkit-transform:rotate(1turn);transform:rotate(1turn)}}@keyframes fa-spin{0%{-webkit-transform:rotate(0deg);transform:rotate(0deg)}to{-webkit-transform:rotate(1turn);transform:rotate(1turn)}}.fa-rotate-90{-webkit-transform:rotate(90deg);transform:rotate(90deg)}.fa-rotate-180{-webkit-transform:rotate(180deg);transform:rotate(180deg)}.fa-rotate-270{-webkit-transform:rotate(270deg);transform:rotate(270deg)}.fa-flip-horizontal{-webkit-transform:scaleX(-1);transform:scaleX(-1)}.fa-flip-vertical{-webkit-transform:scaleY(-1);transform:scaleY(-1)}.fa-flip-both,.fa-flip-horizontal.fa-flip-vertical{-webkit-transform:scale(-1);transform:scale(-1)}.fa-rotate-by{-webkit-transform:rotate(var(--fa-rotate-angle,none));transform:rotate(var(--fa-rotate-angle,none))}.fa-stack{display:inline-block;height:2em;line-height:2em;position:relative;vertical-align:middle;width:2.5em}.fa-stack-1x,.fa-stack-2x{left:0;position:absolute;text-align:center;width:100%;z-index:var(--fa-stack-z-index,auto)}.fa-stack-1x{line-height:inherit}.fa-stack-2x{font-size:2em}.fa-inverse{color:var(--fa-inverse,#fff)}

.fa-0:before{content:"\30"}.fa-1:before{content:"\31"}.fa-2:before{content:"\32"}.fa-3:before{content:"\33"}.fa-4:before{content:"\34"}.fa-5:before{content:"\35"}.fa-6:before{content:"\36"}.fa-7:before{content:"\37"}.fa-8:before{content:"\38"}.fa-9:before{content:"\39"}.fa-fill-drip:before{content:"\f576"}.fa-arrows-to-circle:before{content:"\e4bd"}.fa-chevron-circle-right:before,.fa-circle-chevron-right:before{content:"\f138"}.fa-at:before{content:"\40"}.fa-trash-alt:before,.fa-trash-can:before{content:"\f2ed"}.fa-text-height:before{content:"\f034"}.fa-user-times:before,.fa-user-xmark:before{content:"\f235"}.fa-stethoscope:before{content:"\f0f1"}.fa-comment-alt:before,.fa-message:before{content:"\f27a"}.fa-info:before{content:"\f129"}.fa-compress-alt:before,.fa-down-left-and-up-right-to-center:before{content:"\f422"}.fa-explosion:before{content:"\e4e9"}.fa-file-alt:before,.fa-file-lines:before,.fa-file-text:before{content:"\f15c"}.fa-wave-square:before{content:"\f83e"}.fa-ring:before{content:"\f70b"}.fa-building-un:before{content:"\e4d9"}.fa-dice-three:before{content:"\f527"}.fa-calendar-alt:before,.fa-calendar-days:before{content:"\f073"}.fa-anchor-circle-check:before{content:"\e4aa"}.fa-building-circle-arrow-right:before{content:"\e4d1"}.fa-volleyball-ball:before,.fa-volleyball:before{content:"\f45f"}.fa-arrows-up-to-line:before{content:"\e4c2"}.fa-sort-desc:before,.fa-sort-down:before{content:"\f0dd"}.fa-circle-minus:before,.fa-minus-circle:before{content:"\f056"}.fa-door-open:before{content:"\f52b"}.fa-right-from-bracket:before,.fa-sign-out-alt:before{content:"\f2f5"}.fa-atom:before{content:"\f5d2"}.fa-soap:before{content:"\e06e"}.fa-heart-music-camera-bolt:before,.fa-icons:before{content:"\f86d"}.fa-microphone-alt-slash:before,.fa-microphone-lines-slash:before{content:"\f539"}.fa-bridge-circle-check:before{content:"\e4c9"}.fa-pump-medical:before{content:"\e06a"}.fa-fingerprint:before{content:"\f577"}.fa-hand-point-right:before{content:"\f0a4"}.fa-magnifying-glass-location:before,.fa-search-location:before{content:"\f689"}.fa-forward-step:before,.fa-step-forward:before{content:"\f051"}.fa-face-smile-beam:before,.fa-smile-beam:before{content:"\f5b8"}.fa-flag-checkered:before{content:"\f11e"}.fa-football-ball:before,.fa-football:before{content:"\f44e"}.fa-school-circle-exclamation:before{content:"\e56c"}.fa-crop:before{content:"\f125"}.fa-angle-double-down:before,.fa-angles-down:before{content:"\f103"}.fa-users-rectangle:before{content:"\e594"}.fa-people-roof:before{content:"\e537"}.fa-people-line:before{content:"\e534"}.fa-beer-mug-empty:before,.fa-beer:before{content:"\f0fc"}.fa-diagram-predecessor:before{content:"\e477"}.fa-arrow-up-long:before,.fa-long-arrow-up:before{content:"\f176"}.fa-burn:before,.fa-fire-flame-simple:before{content:"\f46a"}.fa-male:before,.fa-person:before{content:"\f183"}.fa-laptop:before{content:"\f109"}.fa-file-csv:before{content:"\f6dd"}.fa-menorah:before{content:"\f676"}.fa-truck-plane:before{content:"\e58f"}.fa-record-vinyl:before{content:"\f8d9"}.fa-face-grin-stars:before,.fa-grin-stars:before{content:"\f587"}.fa-bong:before{content:"\f55c"}.fa-pastafarianism:before,.fa-spaghetti-monster-flying:before{content:"\f67b"}.fa-arrow-down-up-across-line:before{content:"\e4af"}.fa-spoon:before,.fa-utensil-spoon:before{content:"\f2e5"}.fa-jar-wheat:before{content:"\e517"}.fa-envelopes-bulk:before,.fa-mail-bulk:before{content:"\f674"}.fa-file-circle-exclamation:before{content:"\e4eb"}.fa-circle-h:before,.fa-hospital-symbol:before{content:"\f47e"}.fa-pager:before{content:"\f815"}.fa-address-book:before,.fa-contact-book:before{content:"\f2b9"}.fa-strikethrough:before{content:"\f0cc"}.fa-k:before{content:"\4b"}.fa-landmark-flag:before{content:"\e51c"}.fa-pencil-alt:before,.fa-pencil:before{content:"\f303"}.fa-backward:before{content:"\f04a"}.fa-caret-right:before{content:"\f0da"}.fa-comments:before{content:"\f086"}.fa-file-clipboard:before,.fa-paste:before{content:"\f0ea"}.fa-code-pull-request:before{content:"\e13c"}.fa-clipboard-list:before{content:"\f46d"}.fa-truck-loading:before,.fa-truck-ramp-box:before{content:"\f4de"}.fa-user-check:before{content:"\f4fc"}.fa-vial-virus:before{content:"\e597"}.fa-sheet-plastic:before{content:"\e571"}.fa-blog:before{content:"\f781"}.fa-user-ninja:before{content:"\f504"}.fa-person-arrow-up-from-line:before{content:"\e539"}.fa-scroll-torah:before,.fa-torah:before{content:"\f6a0"}.fa-broom-ball:before,.fa-quidditch-broom-ball:before,.fa-quidditch:before{content:"\f458"}.fa-toggle-off:before{content:"\f204"}.fa-archive:before,.fa-box-archive:before{content:"\f187"}.fa-person-drowning:before{content:"\e545"}.fa-arrow-down-9-1:before,.fa-sort-numeric-desc:before,.fa-sort-numeric-down-alt:before{content:"\f886"}.fa-face-grin-tongue-squint:before,.fa-grin-tongue-squint:before{content:"\f58a"}.fa-spray-can:before{content:"\f5bd"}.fa-truck-monster:before{content:"\f63b"}.fa-w:before{content:"\57"}.fa-earth-africa:before,.fa-globe-africa:before{content:"\f57c"}.fa-rainbow:before{content:"\f75b"}.fa-circle-notch:before{content:"\f1ce"}.fa-tablet-alt:before,.fa-tablet-screen-button:before{content:"\f3fa"}.fa-paw:before{content:"\f1b0"}.fa-cloud:before{content:"\f0c2"}.fa-trowel-bricks:before{content:"\e58a"}.fa-face-flushed:before,.fa-flushed:before{content:"\f579"}.fa-hospital-user:before{content:"\f80d"}.fa-tent-arrow-left-right:before{content:"\e57f"}.fa-gavel:before,.fa-legal:before{content:"\f0e3"}.fa-binoculars:before{content:"\f1e5"}.fa-microphone-slash:before{content:"\f131"}.fa-box-tissue:before{content:"\e05b"}.fa-motorcycle:before{content:"\f21c"}.fa-bell-concierge:before,.fa-concierge-bell:before{content:"\f562"}.fa-pen-ruler:before,.fa-pencil-ruler:before{content:"\f5ae"}.fa-people-arrows-left-right:before,.fa-people-arrows:before{content:"\e068"}.fa-mars-and-venus-burst:before{content:"\e523"}.fa-caret-square-right:before,.fa-square-caret-right:before{content:"\f152"}.fa-cut:before,.fa-scissors:before{content:"\f0c4"}.fa-sun-plant-wilt:before{content:"\e57a"}.fa-toilets-portable:before{content:"\e584"}.fa-hockey-puck:before{content:"\f453"}.fa-table:before{content:"\f0ce"}.fa-magnifying-glass-arrow-right:before{content:"\e521"}.fa-digital-tachograph:before,.fa-tachograph-digital:before{content:"\f566"}.fa-users-slash:before{content:"\e073"}.fa-clover:before{content:"\e139"}.fa-mail-reply:before,.fa-reply:before{content:"\f3e5"}.fa-star-and-crescent:before{content:"\f699"}.fa-house-fire:before{content:"\e50c"}.fa-minus-square:before,.fa-square-minus:before{content:"\f146"}.fa-helicopter:before{content:"\f533"}.fa-compass:before{content:"\f14e"}.fa-caret-square-down:before,.fa-square-caret-down:before{content:"\f150"}.fa-file-circle-question:before{content:"\e4ef"}.fa-laptop-code:before{content:"\f5fc"}.fa-swatchbook:before{content:"\f5c3"}.fa-prescription-bottle:before{content:"\f485"}.fa-bars:before,.fa-navicon:before{content:"\f0c9"}.fa-people-group:before{content:"\e533"}.fa-hourglass-3:before,.fa-hourglass-end:before{content:"\f253"}.fa-heart-broken:before,.fa-heart-crack:before{content:"\f7a9"}.fa-external-link-square-alt:before,.fa-square-up-right:before{content:"\f360"}.fa-face-kiss-beam:before,.fa-kiss-beam:before{content:"\f597"}.fa-film:before{content:"\f008"}.fa-ruler-horizontal:before{content:"\f547"}.fa-people-robbery:before{content:"\e536"}.fa-lightbulb:before{content:"\f0eb"}.fa-caret-left:before{content:"\f0d9"}.fa-circle-exclamation:before,.fa-exclamation-circle:before{content:"\f06a"}.fa-school-circle-xmark:before{content:"\e56d"}.fa-arrow-right-from-bracket:before,.fa-sign-out:before{content:"\f08b"}.fa-chevron-circle-down:before,.fa-circle-chevron-down:before{content:"\f13a"}.fa-unlock-alt:before,.fa-unlock-keyhole:before{content:"\f13e"}.fa-cloud-showers-heavy:before{content:"\f740"}.fa-headphones-alt:before,.fa-headphones-simple:before{content:"\f58f"}.fa-sitemap:before{content:"\f0e8"}.fa-circle-dollar-to-slot:before,.fa-donate:before{content:"\f4b9"}.fa-memory:before{content:"\f538"}.fa-road-spikes:before{content:"\e568"}.fa-fire-burner:before{content:"\e4f1"}.fa-flag:before{content:"\f024"}.fa-hanukiah:before{content:"\f6e6"}.fa-feather:before{content:"\f52d"}.fa-volume-down:before,.fa-volume-low:before{content:"\f027"}.fa-comment-slash:before{content:"\f4b3"}.fa-cloud-sun-rain:before{content:"\f743"}.fa-compress:before{content:"\f066"}.fa-wheat-alt:before,.fa-wheat-awn:before{content:"\e2cd"}.fa-ankh:before{content:"\f644"}.fa-hands-holding-child:before{content:"\e4fa"}.fa-asterisk:before{content:"\2a"}.fa-check-square:before,.fa-square-check:before{content:"\f14a"}.fa-peseta-sign:before{content:"\e221"}.fa-header:before,.fa-heading:before{content:"\f1dc"}.fa-ghost:before{content:"\f6e2"}.fa-list-squares:before,.fa-list:before{content:"\f03a"}.fa-phone-square-alt:before,.fa-square-phone-flip:before{content:"\f87b"}.fa-cart-plus:before{content:"\f217"}.fa-gamepad:before{content:"\f11b"}.fa-circle-dot:before,.fa-dot-circle:before{content:"\f192"}.fa-dizzy:before,.fa-face-dizzy:before{content:"\f567"}.fa-egg:before{content:"\f7fb"}.fa-house-medical-circle-xmark:before{content:"\e513"}.fa-campground:before{content:"\f6bb"}.fa-folder-plus:before{content:"\f65e"}.fa-futbol-ball:before,.fa-futbol:before,.fa-soccer-ball:before{content:"\f1e3"}.fa-paint-brush:before,.fa-paintbrush:before{content:"\f1fc"}.fa-lock:before{content:"\f023"}.fa-gas-pump:before{content:"\f52f"}.fa-hot-tub-person:before,.fa-hot-tub:before{content:"\f593"}.fa-map-location:before,.fa-map-marked:before{content:"\f59f"}.fa-house-flood-water:before{content:"\e50e"}.fa-tree:before{content:"\f1bb"}.fa-bridge-lock:before{content:"\e4cc"}.fa-sack-dollar:before{content:"\f81d"}.fa-edit:before,.fa-pen-to-square:before{content:"\f044"}.fa-car-side:before{content:"\f5e4"}.fa-share-alt:before,.fa-share-nodes:before{content:"\f1e0"}.fa-heart-circle-minus:before{content:"\e4ff"}.fa-hourglass-2:before,.fa-hourglass-half:before{content:"\f252"}.fa-microscope:before{content:"\f610"}.fa-sink:before{content:"\e06d"}.fa-bag-shopping:before,.fa-shopping-bag:before{content:"\f290"}.fa-arrow-down-z-a:before,.fa-sort-alpha-desc:before,.fa-sort-alpha-down-alt:before{content:"\f881"}.fa-mitten:before{content:"\f7b5"}.fa-person-rays:before{content:"\e54d"}.fa-users:before{content:"\f0c0"}.fa-eye-slash:before{content:"\f070"}.fa-flask-vial:before{content:"\e4f3"}.fa-hand-paper:before,.fa-hand:before{content:"\f256"}.fa-om:before{content:"\f679"}.fa-worm:before{content:"\e599"}.fa-house-circle-xmark:before{content:"\e50b"}.fa-plug:before{content:"\f1e6"}.fa-chevron-up:before{content:"\f077"}.fa-hand-spock:before{content:"\f259"}.fa-stopwatch:before{content:"\f2f2"}.fa-face-kiss:before,.fa-kiss:before{content:"\f596"}.fa-bridge-circle-xmark:before{content:"\e4cb"}.fa-face-grin-tongue:before,.fa-grin-tongue:before{content:"\f589"}.fa-chess-bishop:before{content:"\f43a"}.fa-face-grin-wink:before,.fa-grin-wink:before{content:"\f58c"}.fa-deaf:before,.fa-deafness:before,.fa-ear-deaf:before,.fa-hard-of-hearing:before{content:"\f2a4"}.fa-road-circle-check:before{content:"\e564"}.fa-dice-five:before{content:"\f523"}.fa-rss-square:before,.fa-square-rss:before{content:"\f143"}.fa-land-mine-on:before{content:"\e51b"}.fa-i-cursor:before{content:"\f246"}.fa-stamp:before{content:"\f5bf"}.fa-stairs:before{content:"\e289"}.fa-i:before{content:"\49"}.fa-hryvnia-sign:before,.fa-hryvnia:before{content:"\f6f2"}.fa-pills:before{content:"\f484"}.fa-face-grin-wide:before,.fa-grin-alt:before{content:"\f581"}.fa-tooth:before{content:"\f5c9"}.fa-v:before{content:"\56"}.fa-bangladeshi-taka-sign:before{content:"\e2e6"}.fa-bicycle:before{content:"\f206"}.fa-rod-asclepius:before,.fa-rod-snake:before,.fa-staff-aesculapius:before,.fa-staff-snake:before{content:"\e579"}.fa-head-side-cough-slash:before{content:"\e062"}.fa-ambulance:before,.fa-truck-medical:before{content:"\f0f9"}.fa-wheat-awn-circle-exclamation:before{content:"\e598"}.fa-snowman:before{content:"\f7d0"}.fa-mortar-pestle:before{content:"\f5a7"}.fa-road-barrier:before{content:"\e562"}.fa-school:before{content:"\f549"}.fa-igloo:before{content:"\f7ae"}.fa-joint:before{content:"\f595"}.fa-angle-right:before{content:"\f105"}.fa-horse:before{content:"\f6f0"}.fa-q:before{content:"\51"}.fa-g:before{content:"\47"}.fa-notes-medical:before{content:"\f481"}.fa-temperature-2:before,.fa-temperature-half:before,.fa-thermometer-2:before,.fa-thermometer-half:before{content:"\f2c9"}.fa-dong-sign:before{content:"\e169"}.fa-capsules:before{content:"\f46b"}.fa-poo-bolt:before,.fa-poo-storm:before{content:"\f75a"}.fa-face-frown-open:before,.fa-frown-open:before{content:"\f57a"}.fa-hand-point-up:before{content:"\f0a6"}.fa-money-bill:before{content:"\f0d6"}.fa-bookmark:before{content:"\f02e"}.fa-align-justify:before{content:"\f039"}.fa-umbrella-beach:before{content:"\f5ca"}.fa-helmet-un:before{content:"\e503"}.fa-bullseye:before{content:"\f140"}.fa-bacon:before{content:"\f7e5"}.fa-hand-point-down:before{content:"\f0a7"}.fa-arrow-up-from-bracket:before{content:"\e09a"}.fa-folder-blank:before,.fa-folder:before{content:"\f07b"}.fa-file-medical-alt:before,.fa-file-waveform:before{content:"\f478"}.fa-radiation:before{content:"\f7b9"}.fa-chart-simple:before{content:"\e473"}.fa-mars-stroke:before{content:"\f229"}.fa-vial:before{content:"\f492"}.fa-dashboard:before,.fa-gauge-med:before,.fa-gauge:before,.fa-tachometer-alt-average:before{content:"\f624"}.fa-magic-wand-sparkles:before,.fa-wand-magic-sparkles:before{content:"\e2ca"}.fa-e:before{content:"\45"}.fa-pen-alt:before,.fa-pen-clip:before{content:"\f305"}.fa-bridge-circle-exclamation:before{content:"\e4ca"}.fa-user:before{content:"\f007"}.fa-school-circle-check:before{content:"\e56b"}.fa-dumpster:before{content:"\f793"}.fa-shuttle-van:before,.fa-van-shuttle:before{content:"\f5b6"}.fa-building-user:before{content:"\e4da"}.fa-caret-square-left:before,.fa-square-caret-left:before{content:"\f191"}.fa-highlighter:before{content:"\f591"}.fa-key:before{content:"\f084"}.fa-bullhorn:before{content:"\f0a1"}.fa-globe:before{content:"\f0ac"}.fa-synagogue:before{content:"\f69b"}.fa-person-half-dress:before{content:"\e548"}.fa-road-bridge:before{content:"\e563"}.fa-location-arrow:before{content:"\f124"}.fa-c:before{content:"\43"}.fa-tablet-button:before{content:"\f10a"}.fa-building-lock:before{content:"\e4d6"}.fa-pizza-slice:before{content:"\f818"}.fa-money-bill-wave:before{content:"\f53a"}.fa-area-chart:before,.fa-chart-area:before{content:"\f1fe"}.fa-house-flag:before{content:"\e50d"}.fa-person-circle-minus:before{content:"\e540"}.fa-ban:before,.fa-cancel:before{content:"\f05e"}.fa-camera-rotate:before{content:"\e0d8"}.fa-air-freshener:before,.fa-spray-can-sparkles:before{content:"\f5d0"}.fa-star:before{content:"\f005"}.fa-repeat:before{content:"\f363"}.fa-cross:before{content:"\f654"}.fa-box:before{content:"\f466"}.fa-venus-mars:before{content:"\f228"}.fa-arrow-pointer:before,.fa-mouse-pointer:before{content:"\f245"}.fa-expand-arrows-alt:before,.fa-maximize:before{content:"\f31e"}.fa-charging-station:before{content:"\f5e7"}.fa-shapes:before,.fa-triangle-circle-square:before{content:"\f61f"}.fa-random:before,.fa-shuffle:before{content:"\f074"}.fa-person-running:before,.fa-running:before{content:"\f70c"}.fa-mobile-retro:before{content:"\e527"}.fa-grip-lines-vertical:before{content:"\f7a5"}.fa-spider:before{content:"\f717"}.fa-hands-bound:before{content:"\e4f9"}.fa-file-invoice-dollar:before{content:"\f571"}.fa-plane-circle-exclamation:before{content:"\e556"}.fa-x-ray:before{content:"\f497"}.fa-spell-check:before{content:"\f891"}.fa-slash:before{content:"\f715"}.fa-computer-mouse:before,.fa-mouse:before{content:"\f8cc"}.fa-arrow-right-to-bracket:before,.fa-sign-in:before{content:"\f090"}.fa-shop-slash:before,.fa-store-alt-slash:before{content:"\e070"}.fa-server:before{content:"\f233"}.fa-virus-covid-slash:before{content:"\e4a9"}.fa-shop-lock:before{content:"\e4a5"}.fa-hourglass-1:before,.fa-hourglass-start:before{content:"\f251"}.fa-blender-phone:before{content:"\f6b6"}.fa-building-wheat:before{content:"\e4db"}.fa-person-breastfeeding:before{content:"\e53a"}.fa-right-to-bracket:before,.fa-sign-in-alt:before{content:"\f2f6"}.fa-venus:before{content:"\f221"}.fa-passport:before{content:"\f5ab"}.fa-heart-pulse:before,.fa-heartbeat:before{content:"\f21e"}.fa-people-carry-box:before,.fa-people-carry:before{content:"\f4ce"}.fa-temperature-high:before{content:"\f769"}.fa-microchip:before{content:"\f2db"}.fa-crown:before{content:"\f521"}.fa-weight-hanging:before{content:"\f5cd"}.fa-xmarks-lines:before{content:"\e59a"}.fa-file-prescription:before{content:"\f572"}.fa-weight-scale:before,.fa-weight:before{content:"\f496"}.fa-user-friends:before,.fa-user-group:before{content:"\f500"}.fa-arrow-up-a-z:before,.fa-sort-alpha-up:before{content:"\f15e"}.fa-chess-knight:before{content:"\f441"}.fa-face-laugh-squint:before,.fa-laugh-squint:before{content:"\f59b"}.fa-wheelchair:before{content:"\f193"}.fa-arrow-circle-up:before,.fa-circle-arrow-up:before{content:"\f0aa"}.fa-toggle-on:before{content:"\f205"}.fa-person-walking:before,.fa-walking:before{content:"\f554"}.fa-l:before{content:"\4c"}.fa-fire:before{content:"\f06d"}.fa-bed-pulse:before,.fa-procedures:before{content:"\f487"}.fa-shuttle-space:before,.fa-space-shuttle:before{content:"\f197"}.fa-face-laugh:before,.fa-laugh:before{content:"\f599"}.fa-folder-open:before{content:"\f07c"}.fa-heart-circle-plus:before{content:"\e500"}.fa-code-fork:before{content:"\e13b"}.fa-city:before{content:"\f64f"}.fa-microphone-alt:before,.fa-microphone-lines:before{content:"\f3c9"}.fa-pepper-hot:before{content:"\f816"}.fa-unlock:before{content:"\f09c"}.fa-colon-sign:before{content:"\e140"}.fa-headset:before{content:"\f590"}.fa-store-slash:before{content:"\e071"}.fa-road-circle-xmark:before{content:"\e566"}.fa-user-minus:before{content:"\f503"}.fa-mars-stroke-up:before,.fa-mars-stroke-v:before{content:"\f22a"}.fa-champagne-glasses:before,.fa-glass-cheers:before{content:"\f79f"}.fa-clipboard:before{content:"\f328"}.fa-house-circle-exclamation:before{content:"\e50a"}.fa-file-arrow-up:before,.fa-file-upload:before{content:"\f574"}.fa-wifi-3:before,.fa-wifi-strong:before,.fa-wifi:before{content:"\f1eb"}.fa-bath:before,.fa-bathtub:before{content:"\f2cd"}.fa-underline:before{content:"\f0cd"}.fa-user-edit:before,.fa-user-pen:before{content:"\f4ff"}.fa-signature:before{content:"\f5b7"}.fa-stroopwafel:before{content:"\f551"}.fa-bold:before{content:"\f032"}.fa-anchor-lock:before{content:"\e4ad"}.fa-building-ngo:before{content:"\e4d7"}.fa-manat-sign:before{content:"\e1d5"}.fa-not-equal:before{content:"\f53e"}.fa-border-style:before,.fa-border-top-left:before{content:"\f853"}.fa-map-location-dot:before,.fa-map-marked-alt:before{content:"\f5a0"}.fa-jedi:before{content:"\f669"}.fa-poll:before,.fa-square-poll-vertical:before{content:"\f681"}.fa-mug-hot:before{content:"\f7b6"}.fa-battery-car:before,.fa-car-battery:before{content:"\f5df"}.fa-gift:before{content:"\f06b"}.fa-dice-two:before{content:"\f528"}.fa-chess-queen:before{content:"\f445"}.fa-glasses:before{content:"\f530"}.fa-chess-board:before{content:"\f43c"}.fa-building-circle-check:before{content:"\e4d2"}.fa-person-chalkboard:before{content:"\e53d"}.fa-mars-stroke-h:before,.fa-mars-stroke-right:before{content:"\f22b"}.fa-hand-back-fist:before,.fa-hand-rock:before{content:"\f255"}.fa-caret-square-up:before,.fa-square-caret-up:before{content:"\f151"}.fa-cloud-showers-water:before{content:"\e4e4"}.fa-bar-chart:before,.fa-chart-bar:before{content:"\f080"}.fa-hands-bubbles:before,.fa-hands-wash:before{content:"\e05e"}.fa-less-than-equal:before{content:"\f537"}.fa-train:before{content:"\f238"}.fa-eye-low-vision:before,.fa-low-vision:before{content:"\f2a8"}.fa-crow:before{content:"\f520"}.fa-sailboat:before{content:"\e445"}.fa-window-restore:before{content:"\f2d2"}.fa-plus-square:before,.fa-square-plus:before{content:"\f0fe"}.fa-torii-gate:before{content:"\f6a1"}.fa-frog:before{content:"\f52e"}.fa-bucket:before{content:"\e4cf"}.fa-image:before{content:"\f03e"}.fa-microphone:before{content:"\f130"}.fa-cow:before{content:"\f6c8"}.fa-caret-up:before{content:"\f0d8"}.fa-screwdriver:before{content:"\f54a"}.fa-folder-closed:before{content:"\e185"}.fa-house-tsunami:before{content:"\e515"}.fa-square-nfi:before{content:"\e576"}.fa-arrow-up-from-ground-water:before{content:"\e4b5"}.fa-glass-martini-alt:before,.fa-martini-glass:before{content:"\f57b"}.fa-rotate-back:before,.fa-rotate-backward:before,.fa-rotate-left:before,.fa-undo-alt:before{content:"\f2ea"}.fa-columns:before,.fa-table-columns:before{content:"\f0db"}.fa-lemon:before{content:"\f094"}.fa-head-side-mask:before{content:"\e063"}.fa-handshake:before{content:"\f2b5"}.fa-gem:before{content:"\f3a5"}.fa-dolly-box:before,.fa-dolly:before{content:"\f472"}.fa-smoking:before{content:"\f48d"}.fa-compress-arrows-alt:before,.fa-minimize:before{content:"\f78c"}.fa-monument:before{content:"\f5a6"}.fa-snowplow:before{content:"\f7d2"}.fa-angle-double-right:before,.fa-angles-right:before{content:"\f101"}.fa-cannabis:before{content:"\f55f"}.fa-circle-play:before,.fa-play-circle:before{content:"\f144"}.fa-tablets:before{content:"\f490"}.fa-ethernet:before{content:"\f796"}.fa-eur:before,.fa-euro-sign:before,.fa-euro:before{content:"\f153"}.fa-chair:before{content:"\f6c0"}.fa-check-circle:before,.fa-circle-check:before{content:"\f058"}.fa-circle-stop:before,.fa-stop-circle:before{content:"\f28d"}.fa-compass-drafting:before,.fa-drafting-compass:before{content:"\f568"}.fa-plate-wheat:before{content:"\e55a"}.fa-icicles:before{content:"\f7ad"}.fa-person-shelter:before{content:"\e54f"}.fa-neuter:before{content:"\f22c"}.fa-id-badge:before{content:"\f2c1"}.fa-marker:before{content:"\f5a1"}.fa-face-laugh-beam:before,.fa-laugh-beam:before{content:"\f59a"}.fa-helicopter-symbol:before{content:"\e502"}.fa-universal-access:before{content:"\f29a"}.fa-chevron-circle-up:before,.fa-circle-chevron-up:before{content:"\f139"}.fa-lari-sign:before{content:"\e1c8"}.fa-volcano:before{content:"\f770"}.fa-person-walking-dashed-line-arrow-right:before{content:"\e553"}.fa-gbp:before,.fa-pound-sign:before,.fa-sterling-sign:before{content:"\f154"}.fa-viruses:before{content:"\e076"}.fa-square-person-confined:before{content:"\e577"}.fa-user-tie:before{content:"\f508"}.fa-arrow-down-long:before,.fa-long-arrow-down:before{content:"\f175"}.fa-tent-arrow-down-to-line:before{content:"\e57e"}.fa-certificate:before{content:"\f0a3"}.fa-mail-reply-all:before,.fa-reply-all:before{content:"\f122"}.fa-suitcase:before{content:"\f0f2"}.fa-person-skating:before,.fa-skating:before{content:"\f7c5"}.fa-filter-circle-dollar:before,.fa-funnel-dollar:before{content:"\f662"}.fa-camera-retro:before{content:"\f083"}.fa-arrow-circle-down:before,.fa-circle-arrow-down:before{content:"\f0ab"}.fa-arrow-right-to-file:before,.fa-file-import:before{content:"\f56f"}.fa-external-link-square:before,.fa-square-arrow-up-right:before{content:"\f14c"}.fa-box-open:before{content:"\f49e"}.fa-scroll:before{content:"\f70e"}.fa-spa:before{content:"\f5bb"}.fa-location-pin-lock:before{content:"\e51f"}.fa-pause:before{content:"\f04c"}.fa-hill-avalanche:before{content:"\e507"}.fa-temperature-0:before,.fa-temperature-empty:before,.fa-thermometer-0:before,.fa-thermometer-empty:before{content:"\f2cb"}.fa-bomb:before{content:"\f1e2"}.fa-registered:before{content:"\f25d"}.fa-address-card:before,.fa-contact-card:before,.fa-vcard:before{content:"\f2bb"}.fa-balance-scale-right:before,.fa-scale-unbalanced-flip:before{content:"\f516"}.fa-subscript:before{content:"\f12c"}.fa-diamond-turn-right:before,.fa-directions:before{content:"\f5eb"}.fa-burst:before{content:"\e4dc"}.fa-house-laptop:before,.fa-laptop-house:before{content:"\e066"}.fa-face-tired:before,.fa-tired:before{content:"\f5c8"}.fa-money-bills:before{content:"\e1f3"}.fa-smog:before{content:"\f75f"}.fa-crutch:before{content:"\f7f7"}.fa-cloud-arrow-up:before,.fa-cloud-upload-alt:before,.fa-cloud-upload:before{content:"\f0ee"}.fa-palette:before{content:"\f53f"}.fa-arrows-turn-right:before{content:"\e4c0"}.fa-vest:before{content:"\e085"}.fa-ferry:before{content:"\e4ea"}.fa-arrows-down-to-people:before{content:"\e4b9"}.fa-seedling:before,.fa-sprout:before{content:"\f4d8"}.fa-arrows-alt-h:before,.fa-left-right:before{content:"\f337"}.fa-boxes-packing:before{content:"\e4c7"}.fa-arrow-circle-left:before,.fa-circle-arrow-left:before{content:"\f0a8"}.fa-group-arrows-rotate:before{content:"\e4f6"}.fa-bowl-food:before{content:"\e4c6"}.fa-candy-cane:before{content:"\f786"}.fa-arrow-down-wide-short:before,.fa-sort-amount-asc:before,.fa-sort-amount-down:before{content:"\f160"}.fa-cloud-bolt:before,.fa-thunderstorm:before{content:"\f76c"}.fa-remove-format:before,.fa-text-slash:before{content:"\f87d"}.fa-face-smile-wink:before,.fa-smile-wink:before{content:"\f4da"}.fa-file-word:before{content:"\f1c2"}.fa-file-powerpoint:before{content:"\f1c4"}.fa-arrows-h:before,.fa-arrows-left-right:before{content:"\f07e"}.fa-house-lock:before{content:"\e510"}.fa-cloud-arrow-down:before,.fa-cloud-download-alt:before,.fa-cloud-download:before{content:"\f0ed"}.fa-children:before{content:"\e4e1"}.fa-blackboard:before,.fa-chalkboard:before{content:"\f51b"}.fa-user-alt-slash:before,.fa-user-large-slash:before{content:"\f4fa"}.fa-envelope-open:before{content:"\f2b6"}.fa-handshake-alt-slash:before,.fa-handshake-simple-slash:before{content:"\e05f"}.fa-mattress-pillow:before{content:"\e525"}.fa-guarani-sign:before{content:"\e19a"}.fa-arrows-rotate:before,.fa-refresh:before,.fa-sync:before{content:"\f021"}.fa-fire-extinguisher:before{content:"\f134"}.fa-cruzeiro-sign:before{content:"\e152"}.fa-greater-than-equal:before{content:"\f532"}.fa-shield-alt:before,.fa-shield-halved:before{content:"\f3ed"}.fa-atlas:before,.fa-book-atlas:before{content:"\f558"}.fa-virus:before{content:"\e074"}.fa-envelope-circle-check:before{content:"\e4e8"}.fa-layer-group:before{content:"\f5fd"}.fa-arrows-to-dot:before{content:"\e4be"}.fa-archway:before{content:"\f557"}.fa-heart-circle-check:before{content:"\e4fd"}.fa-house-chimney-crack:before,.fa-house-damage:before{content:"\f6f1"}.fa-file-archive:before,.fa-file-zipper:before{content:"\f1c6"}.fa-square:before{content:"\f0c8"}.fa-glass-martini:before,.fa-martini-glass-empty:before{content:"\f000"}.fa-couch:before{content:"\f4b8"}.fa-cedi-sign:before{content:"\e0df"}.fa-italic:before{content:"\f033"}.fa-church:before{content:"\f51d"}.fa-comments-dollar:before{content:"\f653"}.fa-democrat:before{content:"\f747"}.fa-z:before{content:"\5a"}.fa-person-skiing:before,.fa-skiing:before{content:"\f7c9"}.fa-road-lock:before{content:"\e567"}.fa-a:before{content:"\41"}.fa-temperature-arrow-down:before,.fa-temperature-down:before{content:"\e03f"}.fa-feather-alt:before,.fa-feather-pointed:before{content:"\f56b"}.fa-p:before{content:"\50"}.fa-snowflake:before{content:"\f2dc"}.fa-newspaper:before{content:"\f1ea"}.fa-ad:before,.fa-rectangle-ad:before{content:"\f641"}.fa-arrow-circle-right:before,.fa-circle-arrow-right:before{content:"\f0a9"}.fa-filter-circle-xmark:before{content:"\e17b"}.fa-locust:before{content:"\e520"}.fa-sort:before,.fa-unsorted:before{content:"\f0dc"}.fa-list-1-2:before,.fa-list-numeric:before,.fa-list-ol:before{content:"\f0cb"}.fa-person-dress-burst:before{content:"\e544"}.fa-money-check-alt:before,.fa-money-check-dollar:before{content:"\f53d"}.fa-vector-square:before{content:"\f5cb"}.fa-bread-slice:before{content:"\f7ec"}.fa-language:before{content:"\f1ab"}.fa-face-kiss-wink-heart:before,.fa-kiss-wink-heart:before{content:"\f598"}.fa-filter:before{content:"\f0b0"}.fa-question:before{content:"\3f"}.fa-file-signature:before{content:"\f573"}.fa-arrows-alt:before,.fa-up-down-left-right:before{content:"\f0b2"}.fa-house-chimney-user:before{content:"\e065"}.fa-hand-holding-heart:before{content:"\f4be"}.fa-puzzle-piece:before{content:"\f12e"}.fa-money-check:before{content:"\f53c"}.fa-star-half-alt:before,.fa-star-half-stroke:before{content:"\f5c0"}.fa-code:before{content:"\f121"}.fa-glass-whiskey:before,.fa-whiskey-glass:before{content:"\f7a0"}.fa-building-circle-exclamation:before{content:"\e4d3"}.fa-magnifying-glass-chart:before{content:"\e522"}.fa-arrow-up-right-from-square:before,.fa-external-link:before{content:"\f08e"}.fa-cubes-stacked:before{content:"\e4e6"}.fa-krw:before,.fa-won-sign:before,.fa-won:before{content:"\f159"}.fa-virus-covid:before{content:"\e4a8"}.fa-austral-sign:before{content:"\e0a9"}.fa-f:before{content:"\46"}.fa-leaf:before{content:"\f06c"}.fa-road:before{content:"\f018"}.fa-cab:before,.fa-taxi:before{content:"\f1ba"}.fa-person-circle-plus:before{content:"\e541"}.fa-chart-pie:before,.fa-pie-chart:before{content:"\f200"}.fa-bolt-lightning:before{content:"\e0b7"}.fa-sack-xmark:before{content:"\e56a"}.fa-file-excel:before{content:"\f1c3"}.fa-file-contract:before{content:"\f56c"}.fa-fish-fins:before{content:"\e4f2"}.fa-building-flag:before{content:"\e4d5"}.fa-face-grin-beam:before,.fa-grin-beam:before{content:"\f582"}.fa-object-ungroup:before{content:"\f248"}.fa-poop:before{content:"\f619"}.fa-location-pin:before,.fa-map-marker:before{content:"\f041"}.fa-kaaba:before{content:"\f66b"}.fa-toilet-paper:before{content:"\f71e"}.fa-hard-hat:before,.fa-hat-hard:before,.fa-helmet-safety:before{content:"\f807"}.fa-eject:before{content:"\f052"}.fa-arrow-alt-circle-right:before,.fa-circle-right:before{content:"\f35a"}.fa-plane-circle-check:before{content:"\e555"}.fa-face-rolling-eyes:before,.fa-meh-rolling-eyes:before{content:"\f5a5"}.fa-object-group:before{content:"\f247"}.fa-chart-line:before,.fa-line-chart:before{content:"\f201"}.fa-mask-ventilator:before{content:"\e524"}.fa-arrow-right:before{content:"\f061"}.fa-map-signs:before,.fa-signs-post:before{content:"\f277"}.fa-cash-register:before{content:"\f788"}.fa-person-circle-question:before{content:"\e542"}.fa-h:before{content:"\48"}.fa-tarp:before{content:"\e57b"}.fa-screwdriver-wrench:before,.fa-tools:before{content:"\f7d9"}.fa-arrows-to-eye:before{content:"\e4bf"}.fa-plug-circle-bolt:before{content:"\e55b"}.fa-heart:before{content:"\f004"}.fa-mars-and-venus:before{content:"\f224"}.fa-home-user:before,.fa-house-user:before{content:"\e1b0"}.fa-dumpster-fire:before{content:"\f794"}.fa-house-crack:before{content:"\e3b1"}.fa-cocktail:before,.fa-martini-glass-citrus:before{content:"\f561"}.fa-face-surprise:before,.fa-surprise:before{content:"\f5c2"}.fa-bottle-water:before{content:"\e4c5"}.fa-circle-pause:before,.fa-pause-circle:before{content:"\f28b"}.fa-toilet-paper-slash:before{content:"\e072"}.fa-apple-alt:before,.fa-apple-whole:before{content:"\f5d1"}.fa-kitchen-set:before{content:"\e51a"}.fa-r:before{content:"\52"}.fa-temperature-1:before,.fa-temperature-quarter:before,.fa-thermometer-1:before,.fa-thermometer-quarter:before{content:"\f2ca"}.fa-cube:before{content:"\f1b2"}.fa-bitcoin-sign:before{content:"\e0b4"}.fa-shield-dog:before{content:"\e573"}.fa-solar-panel:before{content:"\f5ba"}.fa-lock-open:before{content:"\f3c1"}.fa-elevator:before{content:"\e16d"}.fa-money-bill-transfer:before{content:"\e528"}.fa-money-bill-trend-up:before{content:"\e529"}.fa-house-flood-water-circle-arrow-right:before{content:"\e50f"}.fa-poll-h:before,.fa-square-poll-horizontal:before{content:"\f682"}.fa-circle:before{content:"\f111"}.fa-backward-fast:before,.fa-fast-backward:before{content:"\f049"}.fa-recycle:before{content:"\f1b8"}.fa-user-astronaut:before{content:"\f4fb"}.fa-plane-slash:before{content:"\e069"}.fa-trademark:before{content:"\f25c"}.fa-basketball-ball:before,.fa-basketball:before{content:"\f434"}.fa-satellite-dish:before{content:"\f7c0"}.fa-arrow-alt-circle-up:before,.fa-circle-up:before{content:"\f35b"}.fa-mobile-alt:before,.fa-mobile-screen-button:before{content:"\f3cd"}.fa-volume-high:before,.fa-volume-up:before{content:"\f028"}.fa-users-rays:before{content:"\e593"}.fa-wallet:before{content:"\f555"}.fa-clipboard-check:before{content:"\f46c"}.fa-file-audio:before{content:"\f1c7"}.fa-burger:before,.fa-hamburger:before{content:"\f805"}.fa-wrench:before{content:"\f0ad"}.fa-bugs:before{content:"\e4d0"}.fa-rupee-sign:before,.fa-rupee:before{content:"\f156"}.fa-file-image:before{content:"\f1c5"}.fa-circle-question:before,.fa-question-circle:before{content:"\f059"}.fa-plane-departure:before{content:"\f5b0"}.fa-handshake-slash:before{content:"\e060"}.fa-book-bookmark:before{content:"\e0bb"}.fa-code-branch:before{content:"\f126"}.fa-hat-cowboy:before{content:"\f8c0"}.fa-bridge:before{content:"\e4c8"}.fa-phone-alt:before,.fa-phone-flip:before{content:"\f879"}.fa-truck-front:before{content:"\e2b7"}.fa-cat:before{content:"\f6be"}.fa-anchor-circle-exclamation:before{content:"\e4ab"}.fa-truck-field:before{content:"\e58d"}.fa-route:before{content:"\f4d7"}.fa-clipboard-question:before{content:"\e4e3"}.fa-panorama:before{content:"\e209"}.fa-comment-medical:before{content:"\f7f5"}.fa-teeth-open:before{content:"\f62f"}.fa-file-circle-minus:before{content:"\e4ed"}.fa-tags:before{content:"\f02c"}.fa-wine-glass:before{content:"\f4e3"}.fa-fast-forward:before,.fa-forward-fast:before{content:"\f050"}.fa-face-meh-blank:before,.fa-meh-blank:before{content:"\f5a4"}.fa-parking:before,.fa-square-parking:before{content:"\f540"}.fa-house-signal:before{content:"\e012"}.fa-bars-progress:before,.fa-tasks-alt:before{content:"\f828"}.fa-faucet-drip:before{content:"\e006"}.fa-cart-flatbed:before,.fa-dolly-flatbed:before{content:"\f474"}.fa-ban-smoking:before,.fa-smoking-ban:before{content:"\f54d"}.fa-terminal:before{content:"\f120"}.fa-mobile-button:before{content:"\f10b"}.fa-house-medical-flag:before{content:"\e514"}.fa-basket-shopping:before,.fa-shopping-basket:before{content:"\f291"}.fa-tape:before{content:"\f4db"}.fa-bus-alt:before,.fa-bus-simple:before{content:"\f55e"}.fa-eye:before{content:"\f06e"}.fa-face-sad-cry:before,.fa-sad-cry:before{content:"\f5b3"}.fa-audio-description:before{content:"\f29e"}.fa-person-military-to-person:before{content:"\e54c"}.fa-file-shield:before{content:"\e4f0"}.fa-user-slash:before{content:"\f506"}.fa-pen:before{content:"\f304"}.fa-tower-observation:before{content:"\e586"}.fa-file-code:before{content:"\f1c9"}.fa-signal-5:before,.fa-signal-perfect:before,.fa-signal:before{content:"\f012"}.fa-bus:before{content:"\f207"}.fa-heart-circle-xmark:before{content:"\e501"}.fa-home-lg:before,.fa-house-chimney:before{content:"\e3af"}.fa-window-maximize:before{content:"\f2d0"}.fa-face-frown:before,.fa-frown:before{content:"\f119"}.fa-prescription:before{content:"\f5b1"}.fa-shop:before,.fa-store-alt:before{content:"\f54f"}.fa-floppy-disk:before,.fa-save:before{content:"\f0c7"}.fa-vihara:before{content:"\f6a7"}.fa-balance-scale-left:before,.fa-scale-unbalanced:before{content:"\f515"}.fa-sort-asc:before,.fa-sort-up:before{content:"\f0de"}.fa-comment-dots:before,.fa-commenting:before{content:"\f4ad"}.fa-plant-wilt:before{content:"\e5aa"}.fa-diamond:before{content:"\f219"}.fa-face-grin-squint:before,.fa-grin-squint:before{content:"\f585"}.fa-hand-holding-dollar:before,.fa-hand-holding-usd:before{content:"\f4c0"}.fa-bacterium:before{content:"\e05a"}.fa-hand-pointer:before{content:"\f25a"}.fa-drum-steelpan:before{content:"\f56a"}.fa-hand-scissors:before{content:"\f257"}.fa-hands-praying:before,.fa-praying-hands:before{content:"\f684"}.fa-arrow-right-rotate:before,.fa-arrow-rotate-forward:before,.fa-arrow-rotate-right:before,.fa-redo:before{content:"\f01e"}.fa-biohazard:before{content:"\f780"}.fa-location-crosshairs:before,.fa-location:before{content:"\f601"}.fa-mars-double:before{content:"\f227"}.fa-child-dress:before{content:"\e59c"}.fa-users-between-lines:before{content:"\e591"}.fa-lungs-virus:before{content:"\e067"}.fa-face-grin-tears:before,.fa-grin-tears:before{content:"\f588"}.fa-phone:before{content:"\f095"}.fa-calendar-times:before,.fa-calendar-xmark:before{content:"\f273"}.fa-child-reaching:before{content:"\e59d"}.fa-head-side-virus:before{content:"\e064"}.fa-user-cog:before,.fa-user-gear:before{content:"\f4fe"}.fa-arrow-up-1-9:before,.fa-sort-numeric-up:before{content:"\f163"}.fa-door-closed:before{content:"\f52a"}.fa-shield-virus:before{content:"\e06c"}.fa-dice-six:before{content:"\f526"}.fa-mosquito-net:before{content:"\e52c"}.fa-bridge-water:before{content:"\e4ce"}.fa-person-booth:before{content:"\f756"}.fa-text-width:before{content:"\f035"}.fa-hat-wizard:before{content:"\f6e8"}.fa-pen-fancy:before{content:"\f5ac"}.fa-digging:before,.fa-person-digging:before{content:"\f85e"}.fa-trash:before{content:"\f1f8"}.fa-gauge-simple-med:before,.fa-gauge-simple:before,.fa-tachometer-average:before{content:"\f629"}.fa-book-medical:before{content:"\f7e6"}.fa-poo:before{content:"\f2fe"}.fa-quote-right-alt:before,.fa-quote-right:before{content:"\f10e"}.fa-shirt:before,.fa-t-shirt:before,.fa-tshirt:before{content:"\f553"}.fa-cubes:before{content:"\f1b3"}.fa-divide:before{content:"\f529"}.fa-tenge-sign:before,.fa-tenge:before{content:"\f7d7"}.fa-headphones:before{content:"\f025"}.fa-hands-holding:before{content:"\f4c2"}.fa-hands-clapping:before{content:"\e1a8"}.fa-republican:before{content:"\f75e"}.fa-arrow-left:before{content:"\f060"}.fa-person-circle-xmark:before{content:"\e543"}.fa-ruler:before{content:"\f545"}.fa-align-left:before{content:"\f036"}.fa-dice-d6:before{content:"\f6d1"}.fa-restroom:before{content:"\f7bd"}.fa-j:before{content:"\4a"}.fa-users-viewfinder:before{content:"\e595"}.fa-file-video:before{content:"\f1c8"}.fa-external-link-alt:before,.fa-up-right-from-square:before{content:"\f35d"}.fa-table-cells:before,.fa-th:before{content:"\f00a"}.fa-file-pdf:before{content:"\f1c1"}.fa-bible:before,.fa-book-bible:before{content:"\f647"}.fa-o:before{content:"\4f"}.fa-medkit:before,.fa-suitcase-medical:before{content:"\f0fa"}.fa-user-secret:before{content:"\f21b"}.fa-otter:before{content:"\f700"}.fa-female:before,.fa-person-dress:before{content:"\f182"}.fa-comment-dollar:before{content:"\f651"}.fa-briefcase-clock:before,.fa-business-time:before{content:"\f64a"}.fa-table-cells-large:before,.fa-th-large:before{content:"\f009"}.fa-book-tanakh:before,.fa-tanakh:before{content:"\f827"}.fa-phone-volume:before,.fa-volume-control-phone:before{content:"\f2a0"}.fa-hat-cowboy-side:before{content:"\f8c1"}.fa-clipboard-user:before{content:"\f7f3"}.fa-child:before{content:"\f1ae"}.fa-lira-sign:before{content:"\f195"}.fa-satellite:before{content:"\f7bf"}.fa-plane-lock:before{content:"\e558"}.fa-tag:before{content:"\f02b"}.fa-comment:before{content:"\f075"}.fa-birthday-cake:before,.fa-cake-candles:before,.fa-cake:before{content:"\f1fd"}.fa-envelope:before{content:"\f0e0"}.fa-angle-double-up:before,.fa-angles-up:before{content:"\f102"}.fa-paperclip:before{content:"\f0c6"}.fa-arrow-right-to-city:before{content:"\e4b3"}.fa-ribbon:before{content:"\f4d6"}.fa-lungs:before{content:"\f604"}.fa-arrow-up-9-1:before,.fa-sort-numeric-up-alt:before{content:"\f887"}.fa-litecoin-sign:before{content:"\e1d3"}.fa-border-none:before{content:"\f850"}.fa-circle-nodes:before{content:"\e4e2"}.fa-parachute-box:before{content:"\f4cd"}.fa-indent:before{content:"\f03c"}.fa-truck-field-un:before{content:"\e58e"}.fa-hourglass-empty:before,.fa-hourglass:before{content:"\f254"}.fa-mountain:before{content:"\f6fc"}.fa-user-doctor:before,.fa-user-md:before{content:"\f0f0"}.fa-circle-info:before,.fa-info-circle:before{content:"\f05a"}.fa-cloud-meatball:before{content:"\f73b"}.fa-camera-alt:before,.fa-camera:before{content:"\f030"}.fa-square-virus:before{content:"\e578"}.fa-meteor:before{content:"\f753"}.fa-car-on:before{content:"\e4dd"}.fa-sleigh:before{content:"\f7cc"}.fa-arrow-down-1-9:before,.fa-sort-numeric-asc:before,.fa-sort-numeric-down:before{content:"\f162"}.fa-hand-holding-droplet:before,.fa-hand-holding-water:before{content:"\f4c1"}.fa-water:before{content:"\f773"}.fa-calendar-check:before{content:"\f274"}.fa-braille:before{content:"\f2a1"}.fa-prescription-bottle-alt:before,.fa-prescription-bottle-medical:before{content:"\f486"}.fa-landmark:before{content:"\f66f"}.fa-truck:before{content:"\f0d1"}.fa-crosshairs:before{content:"\f05b"}.fa-person-cane:before{content:"\e53c"}.fa-tent:before{content:"\e57d"}.fa-vest-patches:before{content:"\e086"}.fa-check-double:before{content:"\f560"}.fa-arrow-down-a-z:before,.fa-sort-alpha-asc:before,.fa-sort-alpha-down:before{content:"\f15d"}.fa-money-bill-wheat:before{content:"\e52a"}.fa-cookie:before{content:"\f563"}.fa-arrow-left-rotate:before,.fa-arrow-rotate-back:before,.fa-arrow-rotate-backward:before,.fa-arrow-rotate-left:before,.fa-undo:before{content:"\f0e2"}.fa-hard-drive:before,.fa-hdd:before{content:"\f0a0"}.fa-face-grin-squint-tears:before,.fa-grin-squint-tears:before{content:"\f586"}.fa-dumbbell:before{content:"\f44b"}.fa-list-alt:before,.fa-rectangle-list:before{content:"\f022"}.fa-tarp-droplet:before{content:"\e57c"}.fa-house-medical-circle-check:before{content:"\e511"}.fa-person-skiing-nordic:before,.fa-skiing-nordic:before{content:"\f7ca"}.fa-calendar-plus:before{content:"\f271"}.fa-plane-arrival:before{content:"\f5af"}.fa-arrow-alt-circle-left:before,.fa-circle-left:before{content:"\f359"}.fa-subway:before,.fa-train-subway:before{content:"\f239"}.fa-chart-gantt:before{content:"\e0e4"}.fa-indian-rupee-sign:before,.fa-indian-rupee:before,.fa-inr:before{content:"\e1bc"}.fa-crop-alt:before,.fa-crop-simple:before{content:"\f565"}.fa-money-bill-1:before,.fa-money-bill-alt:before{content:"\f3d1"}.fa-left-long:before,.fa-long-arrow-alt-left:before{content:"\f30a"}.fa-dna:before{content:"\f471"}.fa-virus-slash:before{content:"\e075"}.fa-minus:before,.fa-subtract:before{content:"\f068"}.fa-chess:before{content:"\f439"}.fa-arrow-left-long:before,.fa-long-arrow-left:before{content:"\f177"}.fa-plug-circle-check:before{content:"\e55c"}.fa-street-view:before{content:"\f21d"}.fa-franc-sign:before{content:"\e18f"}.fa-volume-off:before{content:"\f026"}.fa-american-sign-language-interpreting:before,.fa-asl-interpreting:before,.fa-hands-american-sign-language-interpreting:before,.fa-hands-asl-interpreting:before{content:"\f2a3"}.fa-cog:before,.fa-gear:before{content:"\f013"}.fa-droplet-slash:before,.fa-tint-slash:before{content:"\f5c7"}.fa-mosque:before{content:"\f678"}.fa-mosquito:before{content:"\e52b"}.fa-star-of-david:before{content:"\f69a"}.fa-person-military-rifle:before{content:"\e54b"}.fa-cart-shopping:before,.fa-shopping-cart:before{content:"\f07a"}.fa-vials:before{content:"\f493"}.fa-plug-circle-plus:before{content:"\e55f"}.fa-place-of-worship:before{content:"\f67f"}.fa-grip-vertical:before{content:"\f58e"}.fa-arrow-turn-up:before,.fa-level-up:before{content:"\f148"}.fa-u:before{content:"\55"}.fa-square-root-alt:before,.fa-square-root-variable:before{content:"\f698"}.fa-clock-four:before,.fa-clock:before{content:"\f017"}.fa-backward-step:before,.fa-step-backward:before{content:"\f048"}.fa-pallet:before{content:"\f482"}.fa-faucet:before{content:"\e005"}.fa-baseball-bat-ball:before{content:"\f432"}.fa-s:before{content:"\53"}.fa-timeline:before{content:"\e29c"}.fa-keyboard:before{content:"\f11c"}.fa-caret-down:before{content:"\f0d7"}.fa-clinic-medical:before,.fa-house-chimney-medical:before{content:"\f7f2"}.fa-temperature-3:before,.fa-temperature-three-quarters:before,.fa-thermometer-3:before,.fa-thermometer-three-quarters:before{content:"\f2c8"}.fa-mobile-android-alt:before,.fa-mobile-screen:before{content:"\f3cf"}.fa-plane-up:before{content:"\e22d"}.fa-piggy-bank:before{content:"\f4d3"}.fa-battery-3:before,.fa-battery-half:before{content:"\f242"}.fa-mountain-city:before{content:"\e52e"}.fa-coins:before{content:"\f51e"}.fa-khanda:before{content:"\f66d"}.fa-sliders-h:before,.fa-sliders:before{content:"\f1de"}.fa-folder-tree:before{content:"\f802"}.fa-network-wired:before{content:"\f6ff"}.fa-map-pin:before{content:"\f276"}.fa-hamsa:before{content:"\f665"}.fa-cent-sign:before{content:"\e3f5"}.fa-flask:before{content:"\f0c3"}.fa-person-pregnant:before{content:"\e31e"}.fa-wand-sparkles:before{content:"\f72b"}.fa-ellipsis-v:before,.fa-ellipsis-vertical:before{content:"\f142"}.fa-ticket:before{content:"\f145"}.fa-power-off:before{content:"\f011"}.fa-long-arrow-alt-right:before,.fa-right-long:before{content:"\f30b"}.fa-flag-usa:before{content:"\f74d"}.fa-laptop-file:before{content:"\e51d"}.fa-teletype:before,.fa-tty:before{content:"\f1e4"}.fa-diagram-next:before{content:"\e476"}.fa-person-rifle:before{content:"\e54e"}.fa-house-medical-circle-exclamation:before{content:"\e512"}.fa-closed-captioning:before{content:"\f20a"}.fa-hiking:before,.fa-person-hiking:before{content:"\f6ec"}.fa-venus-double:before{content:"\f226"}.fa-images:before{content:"\f302"}.fa-calculator:before{content:"\f1ec"}.fa-people-pulling:before{content:"\e535"}.fa-n:before{content:"\4e"}.fa-cable-car:before,.fa-tram:before{content:"\f7da"}.fa-cloud-rain:before{content:"\f73d"}.fa-building-circle-xmark:before{content:"\e4d4"}.fa-ship:before{content:"\f21a"}.fa-arrows-down-to-line:before{content:"\e4b8"}.fa-download:before{content:"\f019"}.fa-face-grin:before,.fa-grin:before{content:"\f580"}.fa-backspace:before,.fa-delete-left:before{content:"\f55a"}.fa-eye-dropper-empty:before,.fa-eye-dropper:before,.fa-eyedropper:before{content:"\f1fb"}.fa-file-circle-check:before{content:"\e5a0"}.fa-forward:before{content:"\f04e"}.fa-mobile-android:before,.fa-mobile-phone:before,.fa-mobile:before{content:"\f3ce"}.fa-face-meh:before,.fa-meh:before{content:"\f11a"}.fa-align-center:before{content:"\f037"}.fa-book-dead:before,.fa-book-skull:before{content:"\f6b7"}.fa-drivers-license:before,.fa-id-card:before{content:"\f2c2"}.fa-dedent:before,.fa-outdent:before{content:"\f03b"}.fa-heart-circle-exclamation:before{content:"\e4fe"}.fa-home-alt:before,.fa-home-lg-alt:before,.fa-home:before,.fa-house:before{content:"\f015"}.fa-calendar-week:before{content:"\f784"}.fa-laptop-medical:before{content:"\f812"}.fa-b:before{content:"\42"}.fa-file-medical:before{content:"\f477"}.fa-dice-one:before{content:"\f525"}.fa-kiwi-bird:before{content:"\f535"}.fa-arrow-right-arrow-left:before,.fa-exchange:before{content:"\f0ec"}.fa-redo-alt:before,.fa-rotate-forward:before,.fa-rotate-right:before{content:"\f2f9"}.fa-cutlery:before,.fa-utensils:before{content:"\f2e7"}.fa-arrow-up-wide-short:before,.fa-sort-amount-up:before{content:"\f161"}.fa-mill-sign:before{content:"\e1ed"}.fa-bowl-rice:before{content:"\e2eb"}.fa-skull:before{content:"\f54c"}.fa-broadcast-tower:before,.fa-tower-broadcast:before{content:"\f519"}.fa-truck-pickup:before{content:"\f63c"}.fa-long-arrow-alt-up:before,.fa-up-long:before{content:"\f30c"}.fa-stop:before{content:"\f04d"}.fa-code-merge:before{content:"\f387"}.fa-upload:before{content:"\f093"}.fa-hurricane:before{content:"\f751"}.fa-mound:before{content:"\e52d"}.fa-toilet-portable:before{content:"\e583"}.fa-compact-disc:before{content:"\f51f"}.fa-file-arrow-down:before,.fa-file-download:before{content:"\f56d"}.fa-caravan:before{content:"\f8ff"}.fa-shield-cat:before{content:"\e572"}.fa-bolt:before,.fa-zap:before{content:"\f0e7"}.fa-glass-water:before{content:"\e4f4"}.fa-oil-well:before{content:"\e532"}.fa-vault:before{content:"\e2c5"}.fa-mars:before{content:"\f222"}.fa-toilet:before{content:"\f7d8"}.fa-plane-circle-xmark:before{content:"\e557"}.fa-cny:before,.fa-jpy:before,.fa-rmb:before,.fa-yen-sign:before,.fa-yen:before{content:"\f157"}.fa-rouble:before,.fa-rub:before,.fa-ruble-sign:before,.fa-ruble:before{content:"\f158"}.fa-sun:before{content:"\f185"}.fa-guitar:before{content:"\f7a6"}.fa-face-laugh-wink:before,.fa-laugh-wink:before{content:"\f59c"}.fa-horse-head:before{content:"\f7ab"}.fa-bore-hole:before{content:"\e4c3"}.fa-industry:before{content:"\f275"}.fa-arrow-alt-circle-down:before,.fa-circle-down:before{content:"\f358"}.fa-arrows-turn-to-dots:before{content:"\e4c1"}.fa-florin-sign:before{content:"\e184"}.fa-arrow-down-short-wide:before,.fa-sort-amount-desc:before,.fa-sort-amount-down-alt:before{content:"\f884"}.fa-less-than:before{content:"\3c"}.fa-angle-down:before{content:"\f107"}.fa-car-tunnel:before{content:"\e4de"}.fa-head-side-cough:before{content:"\e061"}.fa-grip-lines:before{content:"\f7a4"}.fa-thumbs-down:before{content:"\f165"}.fa-user-lock:before{content:"\f502"}.fa-arrow-right-long:before,.fa-long-arrow-right:before{content:"\f178"}.fa-anchor-circle-xmark:before{content:"\e4ac"}.fa-ellipsis-h:before,.fa-ellipsis:before{content:"\f141"}.fa-chess-pawn:before{content:"\f443"}.fa-first-aid:before,.fa-kit-medical:before{content:"\f479"}.fa-person-through-window:before{content:"\e5a9"}.fa-toolbox:before{content:"\f552"}.fa-hands-holding-circle:before{content:"\e4fb"}.fa-bug:before{content:"\f188"}.fa-credit-card-alt:before,.fa-credit-card:before{content:"\f09d"}.fa-automobile:before,.fa-car:before{content:"\f1b9"}.fa-hand-holding-hand:before{content:"\e4f7"}.fa-book-open-reader:before,.fa-book-reader:before{content:"\f5da"}.fa-mountain-sun:before{content:"\e52f"}.fa-arrows-left-right-to-line:before{content:"\e4ba"}.fa-dice-d20:before{content:"\f6cf"}.fa-truck-droplet:before{content:"\e58c"}.fa-file-circle-xmark:before{content:"\e5a1"}.fa-temperature-arrow-up:before,.fa-temperature-up:before{content:"\e040"}.fa-medal:before{content:"\f5a2"}.fa-bed:before{content:"\f236"}.fa-h-square:before,.fa-square-h:before{content:"\f0fd"}.fa-podcast:before{content:"\f2ce"}.fa-temperature-4:before,.fa-temperature-full:before,.fa-thermometer-4:before,.fa-thermometer-full:before{content:"\f2c7"}.fa-bell:before{content:"\f0f3"}.fa-superscript:before{content:"\f12b"}.fa-plug-circle-xmark:before{content:"\e560"}.fa-star-of-life:before{content:"\f621"}.fa-phone-slash:before{content:"\f3dd"}.fa-paint-roller:before{content:"\f5aa"}.fa-hands-helping:before,.fa-handshake-angle:before{content:"\f4c4"}.fa-location-dot:before,.fa-map-marker-alt:before{content:"\f3c5"}.fa-file:before{content:"\f15b"}.fa-greater-than:before{content:"\3e"}.fa-person-swimming:before,.fa-swimmer:before{content:"\f5c4"}.fa-arrow-down:before{content:"\f063"}.fa-droplet:before,.fa-tint:before{content:"\f043"}.fa-eraser:before{content:"\f12d"}.fa-earth-america:before,.fa-earth-americas:before,.fa-earth:before,.fa-globe-americas:before{content:"\f57d"}.fa-person-burst:before{content:"\e53b"}.fa-dove:before{content:"\f4ba"}.fa-battery-0:before,.fa-battery-empty:before{content:"\f244"}.fa-socks:before{content:"\f696"}.fa-inbox:before{content:"\f01c"}.fa-section:before{content:"\e447"}.fa-gauge-high:before,.fa-tachometer-alt-fast:before,.fa-tachometer-alt:before{content:"\f625"}.fa-envelope-open-text:before{content:"\f658"}.fa-hospital-alt:before,.fa-hospital-wide:before,.fa-hospital:before{content:"\f0f8"}.fa-wine-bottle:before{content:"\f72f"}.fa-chess-rook:before{content:"\f447"}.fa-bars-staggered:before,.fa-reorder:before,.fa-stream:before{content:"\f550"}.fa-dharmachakra:before{content:"\f655"}.fa-hotdog:before{content:"\f80f"}.fa-blind:before,.fa-person-walking-with-cane:before{content:"\f29d"}.fa-drum:before{content:"\f569"}.fa-ice-cream:before{content:"\f810"}.fa-heart-circle-bolt:before{content:"\e4fc"}.fa-fax:before{content:"\f1ac"}.fa-paragraph:before{content:"\f1dd"}.fa-check-to-slot:before,.fa-vote-yea:before{content:"\f772"}.fa-star-half:before{content:"\f089"}.fa-boxes-alt:before,.fa-boxes-stacked:before,.fa-boxes:before{content:"\f468"}.fa-chain:before,.fa-link:before{content:"\f0c1"}.fa-assistive-listening-systems:before,.fa-ear-listen:before{content:"\f2a2"}.fa-tree-city:before{content:"\e587"}.fa-play:before{content:"\f04b"}.fa-font:before{content:"\f031"}.fa-rupiah-sign:before{content:"\e23d"}.fa-magnifying-glass:before,.fa-search:before{content:"\f002"}.fa-ping-pong-paddle-ball:before,.fa-table-tennis-paddle-ball:before,.fa-table-tennis:before{content:"\f45d"}.fa-diagnoses:before,.fa-person-dots-from-line:before{content:"\f470"}.fa-trash-can-arrow-up:before,.fa-trash-restore-alt:before{content:"\f82a"}.fa-naira-sign:before{content:"\e1f6"}.fa-cart-arrow-down:before{content:"\f218"}.fa-walkie-talkie:before{content:"\f8ef"}.fa-file-edit:before,.fa-file-pen:before{content:"\f31c"}.fa-receipt:before{content:"\f543"}.fa-pen-square:before,.fa-pencil-square:before,.fa-square-pen:before{content:"\f14b"}.fa-suitcase-rolling:before{content:"\f5c1"}.fa-person-circle-exclamation:before{content:"\e53f"}.fa-chevron-down:before{content:"\f078"}.fa-battery-5:before,.fa-battery-full:before,.fa-battery:before{content:"\f240"}.fa-skull-crossbones:before{content:"\f714"}.fa-code-compare:before{content:"\e13a"}.fa-list-dots:before,.fa-list-ul:before{content:"\f0ca"}.fa-school-lock:before{content:"\e56f"}.fa-tower-cell:before{content:"\e585"}.fa-down-long:before,.fa-long-arrow-alt-down:before{content:"\f309"}.fa-ranking-star:before{content:"\e561"}.fa-chess-king:before{content:"\f43f"}.fa-person-harassing:before{content:"\e549"}.fa-brazilian-real-sign:before{content:"\e46c"}.fa-landmark-alt:before,.fa-landmark-dome:before{content:"\f752"}.fa-arrow-up:before{content:"\f062"}.fa-television:before,.fa-tv-alt:before,.fa-tv:before{content:"\f26c"}.fa-shrimp:before{content:"\e448"}.fa-list-check:before,.fa-tasks:before{content:"\f0ae"}.fa-jug-detergent:before{content:"\e519"}.fa-circle-user:before,.fa-user-circle:before{content:"\f2bd"}.fa-user-shield:before{content:"\f505"}.fa-wind:before{content:"\f72e"}.fa-car-burst:before,.fa-car-crash:before{content:"\f5e1"}.fa-y:before{content:"\59"}.fa-person-snowboarding:before,.fa-snowboarding:before{content:"\f7ce"}.fa-shipping-fast:before,.fa-truck-fast:before{content:"\f48b"}.fa-fish:before{content:"\f578"}.fa-user-graduate:before{content:"\f501"}.fa-adjust:before,.fa-circle-half-stroke:before{content:"\f042"}.fa-clapperboard:before{content:"\e131"}.fa-circle-radiation:before,.fa-radiation-alt:before{content:"\f7ba"}.fa-baseball-ball:before,.fa-baseball:before{content:"\f433"}.fa-jet-fighter-up:before{content:"\e518"}.fa-diagram-project:before,.fa-project-diagram:before{content:"\f542"}.fa-copy:before{content:"\f0c5"}.fa-volume-mute:before,.fa-volume-times:before,.fa-volume-xmark:before{content:"\f6a9"}.fa-hand-sparkles:before{content:"\e05d"}.fa-grip-horizontal:before,.fa-grip:before{content:"\f58d"}.fa-share-from-square:before,.fa-share-square:before{content:"\f14d"}.fa-child-combatant:before,.fa-child-rifle:before{content:"\e4e0"}.fa-gun:before{content:"\e19b"}.fa-phone-square:before,.fa-square-phone:before{content:"\f098"}.fa-add:before,.fa-plus:before{content:"\2b"}.fa-expand:before{content:"\f065"}.fa-computer:before{content:"\e4e5"}.fa-close:before,.fa-multiply:before,.fa-remove:before,.fa-times:before,.fa-xmark:before{content:"\f00d"}.fa-arrows-up-down-left-right:before,.fa-arrows:before{content:"\f047"}.fa-chalkboard-teacher:before,.fa-chalkboard-user:before{content:"\f51c"}.fa-peso-sign:before{content:"\e222"}.fa-building-shield:before{content:"\e4d8"}.fa-baby:before{content:"\f77c"}.fa-users-line:before{content:"\e592"}.fa-quote-left-alt:before,.fa-quote-left:before{content:"\f10d"}.fa-tractor:before{content:"\f722"}.fa-trash-arrow-up:before,.fa-trash-restore:before{content:"\f829"}.fa-arrow-down-up-lock:before{content:"\e4b0"}.fa-lines-leaning:before{content:"\e51e"}.fa-ruler-combined:before{content:"\f546"}.fa-copyright:before{content:"\f1f9"}.fa-equals:before{content:"\3d"}.fa-blender:before{content:"\f517"}.fa-teeth:before{content:"\f62e"}.fa-ils:before,.fa-shekel-sign:before,.fa-shekel:before,.fa-sheqel-sign:before,.fa-sheqel:before{content:"\f20b"}.fa-map:before{content:"\f279"}.fa-rocket:before{content:"\f135"}.fa-photo-film:before,.fa-photo-video:before{content:"\f87c"}.fa-folder-minus:before{content:"\f65d"}.fa-store:before{content:"\f54e"}.fa-arrow-trend-up:before{content:"\e098"}.fa-plug-circle-minus:before{content:"\e55e"}.fa-sign-hanging:before,.fa-sign:before{content:"\f4d9"}.fa-bezier-curve:before{content:"\f55b"}.fa-bell-slash:before{content:"\f1f6"}.fa-tablet-android:before,.fa-tablet:before{content:"\f3fb"}.fa-school-flag:before{content:"\e56e"}.fa-fill:before{content:"\f575"}.fa-angle-up:before{content:"\f106"}.fa-drumstick-bite:before{content:"\f6d7"}.fa-holly-berry:before{content:"\f7aa"}.fa-chevron-left:before{content:"\f053"}.fa-bacteria:before{content:"\e059"}.fa-hand-lizard:before{content:"\f258"}.fa-notdef:before{content:"\e1fe"}.fa-disease:before{content:"\f7fa"}.fa-briefcase-medical:before{content:"\f469"}.fa-genderless:before{content:"\f22d"}.fa-chevron-right:before{content:"\f054"}.fa-retweet:before{content:"\f079"}.fa-car-alt:before,.fa-car-rear:before{content:"\f5de"}.fa-pump-soap:before{content:"\e06b"}.fa-video-slash:before{content:"\f4e2"}.fa-battery-2:before,.fa-battery-quarter:before{content:"\f243"}.fa-radio:before{content:"\f8d7"}.fa-baby-carriage:before,.fa-carriage-baby:before{content:"\f77d"}.fa-traffic-light:before{content:"\f637"}.fa-thermometer:before{content:"\f491"}.fa-vr-cardboard:before{content:"\f729"}.fa-hand-middle-finger:before{content:"\f806"}.fa-percent:before,.fa-percentage:before{content:"\25"}.fa-truck-moving:before{content:"\f4df"}.fa-glass-water-droplet:before{content:"\e4f5"}.fa-display:before{content:"\e163"}.fa-face-smile:before,.fa-smile:before{content:"\f118"}.fa-thumb-tack:before,.fa-thumbtack:before{content:"\f08d"}.fa-trophy:before{content:"\f091"}.fa-person-praying:before,.fa-pray:before{content:"\f683"}.fa-hammer:before{content:"\f6e3"}.fa-hand-peace:before{content:"\f25b"}.fa-rotate:before,.fa-sync-alt:before{content:"\f2f1"}.fa-spinner:before{content:"\f110"}.fa-robot:before{content:"\f544"}.fa-peace:before{content:"\f67c"}.fa-cogs:before,.fa-gears:before{content:"\f085"}.fa-warehouse:before{content:"\f494"}.fa-arrow-up-right-dots:before{content:"\e4b7"}.fa-splotch:before{content:"\f5bc"}.fa-face-grin-hearts:before,.fa-grin-hearts:before{content:"\f584"}.fa-dice-four:before{content:"\f524"}.fa-sim-card:before{content:"\f7c4"}.fa-transgender-alt:before,.fa-transgender:before{content:"\f225"}.fa-mercury:before{content:"\f223"}.fa-arrow-turn-down:before,.fa-level-down:before{content:"\f149"}.fa-person-falling-burst:before{content:"\e547"}.fa-award:before{content:"\f559"}.fa-ticket-alt:before,.fa-ticket-simple:before{content:"\f3ff"}.fa-building:before{content:"\f1ad"}.fa-angle-double-left:before,.fa-angles-left:before{content:"\f100"}.fa-qrcode:before{content:"\f029"}.fa-clock-rotate-left:before,.fa-history:before{content:"\f1da"}.fa-face-grin-beam-sweat:before,.fa-grin-beam-sweat:before{content:"\f583"}.fa-arrow-right-from-file:before,.fa-file-export:before{content:"\f56e"}.fa-shield-blank:before,.fa-shield:before{content:"\f132"}.fa-arrow-up-short-wide:before,.fa-sort-amount-up-alt:before{content:"\f885"}.fa-house-medical:before{content:"\e3b2"}.fa-golf-ball-tee:before,.fa-golf-ball:before{content:"\f450"}.fa-chevron-circle-left:before,.fa-circle-chevron-left:before{content:"\f137"}.fa-house-chimney-window:before{content:"\e00d"}.fa-pen-nib:before{content:"\f5ad"}.fa-tent-arrow-turn-left:before{content:"\e580"}.fa-tents:before{content:"\e582"}.fa-magic:before,.fa-wand-magic:before{content:"\f0d0"}.fa-dog:before{content:"\f6d3"}.fa-carrot:before{content:"\f787"}.fa-moon:before{content:"\f186"}.fa-wine-glass-alt:before,.fa-wine-glass-empty:before{content:"\f5ce"}.fa-cheese:before{content:"\f7ef"}.fa-yin-yang:before{content:"\f6ad"}.fa-music:before{content:"\f001"}.fa-code-commit:before{content:"\f386"}.fa-temperature-low:before{content:"\f76b"}.fa-biking:before,.fa-person-biking:before{content:"\f84a"}.fa-broom:before{content:"\f51a"}.fa-shield-heart:before{content:"\e574"}.fa-gopuram:before{content:"\f664"}.fa-earth-oceania:before,.fa-globe-oceania:before{content:"\e47b"}.fa-square-xmark:before,.fa-times-square:before,.fa-xmark-square:before{content:"\f2d3"}.fa-hashtag:before{content:"\23"}.fa-expand-alt:before,.fa-up-right-and-down-left-from-center:before{content:"\f424"}.fa-oil-can:before{content:"\f613"}.fa-t:before{content:"\54"}.fa-hippo:before{content:"\f6ed"}.fa-chart-column:before{content:"\e0e3"}.fa-infinity:before{content:"\f534"}.fa-vial-circle-check:before{content:"\e596"}.fa-person-arrow-down-to-line:before{content:"\e538"}.fa-voicemail:before{content:"\f897"}.fa-fan:before{content:"\f863"}.fa-person-walking-luggage:before{content:"\e554"}.fa-arrows-alt-v:before,.fa-up-down:before{content:"\f338"}.fa-cloud-moon-rain:before{content:"\f73c"}.fa-calendar:before{content:"\f133"}.fa-trailer:before{content:"\e041"}.fa-bahai:before,.fa-haykal:before{content:"\f666"}.fa-sd-card:before{content:"\f7c2"}.fa-dragon:before{content:"\f6d5"}.fa-shoe-prints:before{content:"\f54b"}.fa-circle-plus:before,.fa-plus-circle:before{content:"\f055"}.fa-face-grin-tongue-wink:before,.fa-grin-tongue-wink:before{content:"\f58b"}.fa-hand-holding:before{content:"\f4bd"}.fa-plug-circle-exclamation:before{content:"\e55d"}.fa-chain-broken:before,.fa-chain-slash:before,.fa-link-slash:before,.fa-unlink:before{content:"\f127"}.fa-clone:before{content:"\f24d"}.fa-person-walking-arrow-loop-left:before{content:"\e551"}.fa-arrow-up-z-a:before,.fa-sort-alpha-up-alt:before{content:"\f882"}.fa-fire-alt:before,.fa-fire-flame-curved:before{content:"\f7e4"}.fa-tornado:before{content:"\f76f"}.fa-file-circle-plus:before{content:"\e494"}.fa-book-quran:before,.fa-quran:before{content:"\f687"}.fa-anchor:before{content:"\f13d"}.fa-border-all:before{content:"\f84c"}.fa-angry:before,.fa-face-angry:before{content:"\f556"}.fa-cookie-bite:before{content:"\f564"}.fa-arrow-trend-down:before{content:"\e097"}.fa-feed:before,.fa-rss:before{content:"\f09e"}.fa-draw-polygon:before{content:"\f5ee"}.fa-balance-scale:before,.fa-scale-balanced:before{content:"\f24e"}.fa-gauge-simple-high:before,.fa-tachometer-fast:before,.fa-tachometer:before{content:"\f62a"}.fa-shower:before{content:"\f2cc"}.fa-desktop-alt:before,.fa-desktop:before{content:"\f390"}.fa-m:before{content:"\4d"}.fa-table-list:before,.fa-th-list:before{content:"\f00b"}.fa-comment-sms:before,.fa-sms:before{content:"\f7cd"}.fa-book:before{content:"\f02d"}.fa-user-plus:before{content:"\f234"}.fa-check:before{content:"\f00c"}.fa-battery-4:before,.fa-battery-three-quarters:before{content:"\f241"}.fa-house-circle-check:before{content:"\e509"}.fa-angle-left:before{content:"\f104"}.fa-diagram-successor:before{content:"\e47a"}.fa-truck-arrow-right:before{content:"\e58b"}.fa-arrows-split-up-and-left:before{content:"\e4bc"}.fa-fist-raised:before,.fa-hand-fist:before{content:"\f6de"}.fa-cloud-moon:before{content:"\f6c3"}.fa-briefcase:before{content:"\f0b1"}.fa-person-falling:before{content:"\e546"}.fa-image-portrait:before,.fa-portrait:before{content:"\f3e0"}.fa-user-tag:before{content:"\f507"}.fa-rug:before{content:"\e569"}.fa-earth-europe:before,.fa-globe-europe:before{content:"\f7a2"}.fa-cart-flatbed-suitcase:before,.fa-luggage-cart:before{content:"\f59d"}.fa-rectangle-times:before,.fa-rectangle-xmark:before,.fa-times-rectangle:before,.fa-window-close:before{content:"\f410"}.fa-baht-sign:before{content:"\e0ac"}.fa-book-open:before{content:"\f518"}.fa-book-journal-whills:before,.fa-journal-whills:before{content:"\f66a"}.fa-handcuffs:before{content:"\e4f8"}.fa-exclamation-triangle:before,.fa-triangle-exclamation:before,.fa-warning:before{content:"\f071"}.fa-database:before{content:"\f1c0"}.fa-arrow-turn-right:before,.fa-mail-forward:before,.fa-share:before{content:"\f064"}.fa-bottle-droplet:before{content:"\e4c4"}.fa-mask-face:before{content:"\e1d7"}.fa-hill-rockslide:before{content:"\e508"}.fa-exchange-alt:before,.fa-right-left:before{content:"\f362"}.fa-paper-plane:before{content:"\f1d8"}.fa-road-circle-exclamation:before{content:"\e565"}.fa-dungeon:before{content:"\f6d9"}.fa-align-right:before{content:"\f038"}.fa-money-bill-1-wave:before,.fa-money-bill-wave-alt:before{content:"\f53b"}.fa-life-ring:before{content:"\f1cd"}.fa-hands:before,.fa-sign-language:before,.fa-signing:before{content:"\f2a7"}.fa-calendar-day:before{content:"\f783"}.fa-ladder-water:before,.fa-swimming-pool:before,.fa-water-ladder:before{content:"\f5c5"}.fa-arrows-up-down:before,.fa-arrows-v:before{content:"\f07d"}.fa-face-grimace:before,.fa-grimace:before{content:"\f57f"}.fa-wheelchair-alt:before,.fa-wheelchair-move:before{content:"\e2ce"}.fa-level-down-alt:before,.fa-turn-down:before{content:"\f3be"}.fa-person-walking-arrow-right:before{content:"\e552"}.fa-envelope-square:before,.fa-square-envelope:before{content:"\f199"}.fa-dice:before{content:"\f522"}.fa-bowling-ball:before{content:"\f436"}.fa-brain:before{content:"\f5dc"}.fa-band-aid:before,.fa-bandage:before{content:"\f462"}.fa-calendar-minus:before{content:"\f272"}.fa-circle-xmark:before,.fa-times-circle:before,.fa-xmark-circle:before{content:"\f057"}.fa-gifts:before{content:"\f79c"}.fa-hotel:before{content:"\f594"}.fa-earth-asia:before,.fa-globe-asia:before{content:"\f57e"}.fa-id-card-alt:before,.fa-id-card-clip:before{content:"\f47f"}.fa-magnifying-glass-plus:before,.fa-search-plus:before{content:"\f00e"}.fa-thumbs-up:before{content:"\f164"}.fa-user-clock:before{content:"\f4fd"}.fa-allergies:before,.fa-hand-dots:before{content:"\f461"}.fa-file-invoice:before{content:"\f570"}.fa-window-minimize:before{content:"\f2d1"}.fa-coffee:before,.fa-mug-saucer:before{content:"\f0f4"}.fa-brush:before{content:"\f55d"}.fa-mask:before{content:"\f6fa"}.fa-magnifying-glass-minus:before,.fa-search-minus:before{content:"\f010"}.fa-ruler-vertical:before{content:"\f548"}.fa-user-alt:before,.fa-user-large:before{content:"\f406"}.fa-train-tram:before{content:"\e5b4"}.fa-user-nurse:before{content:"\f82f"}.fa-syringe:before{content:"\f48e"}.fa-cloud-sun:before{content:"\f6c4"}.fa-stopwatch-20:before{content:"\e06f"}.fa-square-full:before{content:"\f45c"}.fa-magnet:before{content:"\f076"}.fa-jar:before{content:"\e516"}.fa-note-sticky:before,.fa-sticky-note:before{content:"\f249"}.fa-bug-slash:before{content:"\e490"}.fa-arrow-up-from-water-pump:before{content:"\e4b6"}.fa-bone:before{content:"\f5d7"}.fa-user-injured:before{content:"\f728"}.fa-face-sad-tear:before,.fa-sad-tear:before{content:"\f5b4"}.fa-plane:before{content:"\f072"}.fa-tent-arrows-down:before{content:"\e581"}.fa-exclamation:before{content:"\21"}.fa-arrows-spin:before{content:"\e4bb"}.fa-print:before{content:"\f02f"}.fa-try:before,.fa-turkish-lira-sign:before,.fa-turkish-lira:before{content:"\e2bb"}.fa-dollar-sign:before,.fa-dollar:before,.fa-usd:before{content:"\24"}.fa-x:before{content:"\58"}.fa-magnifying-glass-dollar:before,.fa-search-dollar:before{content:"\f688"}.fa-users-cog:before,.fa-users-gear:before{content:"\f509"}.fa-person-military-pointing:before{content:"\e54a"}.fa-bank:before,.fa-building-columns:before,.fa-institution:before,.fa-museum:before,.fa-university:before{content:"\f19c"}.fa-umbrella:before{content:"\f0e9"}.fa-trowel:before{content:"\e589"}.fa-d:before{content:"\44"}.fa-stapler:before{content:"\e5af"}.fa-masks-theater:before,.fa-theater-masks:before{content:"\f630"}.fa-kip-sign:before{content:"\e1c4"}.fa-hand-point-left:before{content:"\f0a5"}.fa-handshake-alt:before,.fa-handshake-simple:before{content:"\f4c6"}.fa-fighter-jet:before,.fa-jet-fighter:before{content:"\f0fb"}.fa-share-alt-square:before,.fa-square-share-nodes:before{content:"\f1e1"}.fa-barcode:before{content:"\f02a"}.fa-plus-minus:before{content:"\e43c"}.fa-video-camera:before,.fa-video:before{content:"\f03d"}.fa-graduation-cap:before,.fa-mortar-board:before{content:"\f19d"}.fa-hand-holding-medical:before{content:"\e05c"}.fa-person-circle-check:before{content:"\e53e"}.fa-level-up-alt:before,.fa-turn-up:before{content:"\f3bf"}
.fa-sr-only,.fa-sr-only-focusable:not(:focus),.sr-only,.sr-only-focusable:not(:focus){position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}:host,:root{--fa-style-family-brands:"Font Awesome 6 Brands";--fa-font-brands:normal 400 1em/1 "Font Awesome 6 Brands"}@font-face{font-family:"Font Awesome 6 Brands";font-style:normal;font-weight:400;font-display:block;src:url(/assets/fonts/fa/fa-brands-400.woff2) format("woff2")}.fa-brands,.fab{font-weight:400}.fa-monero:before{content:"\f3d0"}.fa-hooli:before{content:"\f427"}.fa-yelp:before{content:"\f1e9"}.fa-cc-visa:before{content:"\f1f0"}.fa-lastfm:before{content:"\f202"}.fa-shopware:before{content:"\f5b5"}.fa-creative-commons-nc:before{content:"\f4e8"}.fa-aws:before{content:"\f375"}.fa-redhat:before{content:"\f7bc"}.fa-yoast:before{content:"\f2b1"}.fa-cloudflare:before{content:"\e07d"}.fa-ups:before{content:"\f7e0"}.fa-wpexplorer:before{content:"\f2de"}.fa-dyalog:before{content:"\f399"}.fa-bity:before{content:"\f37a"}.fa-stackpath:before{content:"\f842"}.fa-buysellads:before{content:"\f20d"}.fa-first-order:before{content:"\f2b0"}.fa-modx:before{content:"\f285"}.fa-guilded:before{content:"\e07e"}.fa-vnv:before{content:"\f40b"}.fa-js-square:before,.fa-square-js:before{content:"\f3b9"}.fa-microsoft:before{content:"\f3ca"}.fa-qq:before{content:"\f1d6"}.fa-orcid:before{content:"\f8d2"}.fa-java:before{content:"\f4e4"}.fa-invision:before{content:"\f7b0"}.fa-creative-commons-pd-alt:before{content:"\f4ed"}.fa-centercode:before{content:"\f380"}.fa-glide-g:before{content:"\f2a6"}.fa-drupal:before{content:"\f1a9"}.fa-hire-a-helper:before{content:"\f3b0"}.fa-creative-commons-by:before{content:"\f4e7"}.fa-unity:before{content:"\e049"}.fa-whmcs:before{content:"\f40d"}.fa-rocketchat:before{content:"\f3e8"}.fa-vk:before{content:"\f189"}.fa-untappd:before{content:"\f405"}.fa-mailchimp:before{content:"\f59e"}.fa-css3-alt:before{content:"\f38b"}.fa-reddit-square:before,.fa-square-reddit:before{content:"\f1a2"}.fa-vimeo-v:before{content:"\f27d"}.fa-contao:before{content:"\f26d"}.fa-square-font-awesome:before{content:"\e5ad"}.fa-deskpro:before{content:"\f38f"}.fa-sistrix:before{content:"\f3ee"}.fa-instagram-square:before,.fa-square-instagram:before{content:"\e055"}.fa-battle-net:before{content:"\f835"}.fa-the-red-yeti:before{content:"\f69d"}.fa-hacker-news-square:before,.fa-square-hacker-news:before{content:"\f3af"}.fa-edge:before{content:"\f282"}.fa-napster:before{content:"\f3d2"}.fa-snapchat-square:before,.fa-square-snapchat:before{content:"\f2ad"}.fa-google-plus-g:before{content:"\f0d5"}.fa-artstation:before{content:"\f77a"}.fa-markdown:before{content:"\f60f"}.fa-sourcetree:before{content:"\f7d3"}.fa-google-plus:before{content:"\f2b3"}.fa-diaspora:before{content:"\f791"}.fa-foursquare:before{content:"\f180"}.fa-stack-overflow:before{content:"\f16c"}.fa-github-alt:before{content:"\f113"}.fa-phoenix-squadron:before{content:"\f511"}.fa-pagelines:before{content:"\f18c"}.fa-algolia:before{content:"\f36c"}.fa-red-river:before{content:"\f3e3"}.fa-creative-commons-sa:before{content:"\f4ef"}.fa-safari:before{content:"\f267"}.fa-google:before{content:"\f1a0"}.fa-font-awesome-alt:before,.fa-square-font-awesome-stroke:before{content:"\f35c"}.fa-atlassian:before{content:"\f77b"}.fa-linkedin-in:before{content:"\f0e1"}.fa-digital-ocean:before{content:"\f391"}.fa-nimblr:before{content:"\f5a8"}.fa-chromecast:before{content:"\f838"}.fa-evernote:before{content:"\f839"}.fa-hacker-news:before{content:"\f1d4"}.fa-creative-commons-sampling:before{content:"\f4f0"}.fa-adversal:before{content:"\f36a"}.fa-creative-commons:before{content:"\f25e"}.fa-watchman-monitoring:before{content:"\e087"}.fa-fonticons:before{content:"\f280"}.fa-weixin:before{content:"\f1d7"}.fa-shirtsinbulk:before{content:"\f214"}.fa-codepen:before{content:"\f1cb"}.fa-git-alt:before{content:"\f841"}.fa-lyft:before{content:"\f3c3"}.fa-rev:before{content:"\f5b2"}.fa-windows:before{content:"\f17a"}.fa-wizards-of-the-coast:before{content:"\f730"}.fa-square-viadeo:before,.fa-viadeo-square:before{content:"\f2aa"}.fa-meetup:before{content:"\f2e0"}.fa-centos:before{content:"\f789"}.fa-adn:before{content:"\f170"}.fa-cloudsmith:before{content:"\f384"}.fa-pied-piper-alt:before{content:"\f1a8"}.fa-dribbble-square:before,.fa-square-dribbble:before{content:"\f397"}.fa-codiepie:before{content:"\f284"}.fa-node:before{content:"\f419"}.fa-mix:before{content:"\f3cb"}.fa-steam:before{content:"\f1b6"}.fa-cc-apple-pay:before{content:"\f416"}.fa-scribd:before{content:"\f28a"}.fa-openid:before{content:"\f19b"}.fa-instalod:before{content:"\e081"}.fa-expeditedssl:before{content:"\f23e"}.fa-sellcast:before{content:"\f2da"}.fa-square-twitter:before,.fa-twitter-square:before{content:"\f081"}.fa-r-project:before{content:"\f4f7"}.fa-delicious:before{content:"\f1a5"}.fa-freebsd:before{content:"\f3a4"}.fa-vuejs:before{content:"\f41f"}.fa-accusoft:before{content:"\f369"}.fa-ioxhost:before{content:"\f208"}.fa-fonticons-fi:before{content:"\f3a2"}.fa-app-store:before{content:"\f36f"}.fa-cc-mastercard:before{content:"\f1f1"}.fa-itunes-note:before{content:"\f3b5"}.fa-golang:before{content:"\e40f"}.fa-kickstarter:before{content:"\f3bb"}.fa-grav:before{content:"\f2d6"}.fa-weibo:before{content:"\f18a"}.fa-uncharted:before{content:"\e084"}.fa-firstdraft:before{content:"\f3a1"}.fa-square-youtube:before,.fa-youtube-square:before{content:"\f431"}.fa-wikipedia-w:before{content:"\f266"}.fa-rendact:before,.fa-wpressr:before{content:"\f3e4"}.fa-angellist:before{content:"\f209"}.fa-galactic-republic:before{content:"\f50c"}.fa-nfc-directional:before{content:"\e530"}.fa-skype:before{content:"\f17e"}.fa-joget:before{content:"\f3b7"}.fa-fedora:before{content:"\f798"}.fa-stripe-s:before{content:"\f42a"}.fa-meta:before{content:"\e49b"}.fa-laravel:before{content:"\f3bd"}.fa-hotjar:before{content:"\f3b1"}.fa-bluetooth-b:before{content:"\f294"}.fa-sticker-mule:before{content:"\f3f7"}.fa-creative-commons-zero:before{content:"\f4f3"}.fa-hips:before{content:"\f452"}.fa-behance:before{content:"\f1b4"}.fa-reddit:before{content:"\f1a1"}.fa-discord:before{content:"\f392"}.fa-chrome:before{content:"\f268"}.fa-app-store-ios:before{content:"\f370"}.fa-cc-discover:before{content:"\f1f2"}.fa-wpbeginner:before{content:"\f297"}.fa-confluence:before{content:"\f78d"}.fa-mdb:before{content:"\f8ca"}.fa-dochub:before{content:"\f394"}.fa-accessible-icon:before{content:"\f368"}.fa-ebay:before{content:"\f4f4"}.fa-amazon:before{content:"\f270"}.fa-unsplash:before{content:"\e07c"}.fa-yarn:before{content:"\f7e3"}.fa-square-steam:before,.fa-steam-square:before{content:"\f1b7"}.fa-500px:before{content:"\f26e"}.fa-square-vimeo:before,.fa-vimeo-square:before{content:"\f194"}.fa-asymmetrik:before{content:"\f372"}.fa-font-awesome-flag:before,.fa-font-awesome-logo-full:before,.fa-font-awesome:before{content:"\f2b4"}.fa-gratipay:before{content:"\f184"}.fa-apple:before{content:"\f179"}.fa-hive:before{content:"\e07f"}.fa-gitkraken:before{content:"\f3a6"}.fa-keybase:before{content:"\f4f5"}.fa-apple-pay:before{content:"\f415"}.fa-padlet:before{content:"\e4a0"}.fa-amazon-pay:before{content:"\f42c"}.fa-github-square:before,.fa-square-github:before{content:"\f092"}.fa-stumbleupon:before{content:"\f1a4"}.fa-fedex:before{content:"\f797"}.fa-phoenix-framework:before{content:"\f3dc"}.fa-shopify:before{content:"\e057"}.fa-neos:before{content:"\f612"}.fa-hackerrank:before{content:"\f5f7"}.fa-researchgate:before{content:"\f4f8"}.fa-swift:before{content:"\f8e1"}.fa-angular:before{content:"\f420"}.fa-speakap:before{content:"\f3f3"}.fa-angrycreative:before{content:"\f36e"}.fa-y-combinator:before{content:"\f23b"}.fa-empire:before{content:"\f1d1"}.fa-envira:before{content:"\f299"}.fa-gitlab-square:before,.fa-square-gitlab:before{content:"\e5ae"}.fa-studiovinari:before{content:"\f3f8"}.fa-pied-piper:before{content:"\f2ae"}.fa-wordpress:before{content:"\f19a"}.fa-product-hunt:before{content:"\f288"}.fa-firefox:before{content:"\f269"}.fa-linode:before{content:"\f2b8"}.fa-goodreads:before{content:"\f3a8"}.fa-odnoklassniki-square:before,.fa-square-odnoklassniki:before{content:"\f264"}.fa-jsfiddle:before{content:"\f1cc"}.fa-sith:before{content:"\f512"}.fa-themeisle:before{content:"\f2b2"}.fa-page4:before{content:"\f3d7"}.fa-hashnode:before{content:"\e499"}.fa-react:before{content:"\f41b"}.fa-cc-paypal:before{content:"\f1f4"}.fa-squarespace:before{content:"\f5be"}.fa-cc-stripe:before{content:"\f1f5"}.fa-creative-commons-share:before{content:"\f4f2"}.fa-bitcoin:before{content:"\f379"}.fa-keycdn:before{content:"\f3ba"}.fa-opera:before{content:"\f26a"}.fa-itch-io:before{content:"\f83a"}.fa-umbraco:before{content:"\f8e8"}.fa-galactic-senate:before{content:"\f50d"}.fa-ubuntu:before{content:"\f7df"}.fa-draft2digital:before{content:"\f396"}.fa-stripe:before{content:"\f429"}.fa-houzz:before{content:"\f27c"}.fa-gg:before{content:"\f260"}.fa-dhl:before{content:"\f790"}.fa-pinterest-square:before,.fa-square-pinterest:before{content:"\f0d3"}.fa-xing:before{content:"\f168"}.fa-blackberry:before{content:"\f37b"}.fa-creative-commons-pd:before{content:"\f4ec"}.fa-playstation:before{content:"\f3df"}.fa-quinscape:before{content:"\f459"}.fa-less:before{content:"\f41d"}.fa-blogger-b:before{content:"\f37d"}.fa-opencart:before{content:"\f23d"}.fa-vine:before{content:"\f1ca"}.fa-paypal:before{content:"\f1ed"}.fa-gitlab:before{content:"\f296"}.fa-typo3:before{content:"\f42b"}.fa-reddit-alien:before{content:"\f281"}.fa-yahoo:before{content:"\f19e"}.fa-dailymotion:before{content:"\e052"}.fa-affiliatetheme:before{content:"\f36b"}.fa-pied-piper-pp:before{content:"\f1a7"}.fa-bootstrap:before{content:"\f836"}.fa-odnoklassniki:before{content:"\f263"}.fa-nfc-symbol:before{content:"\e531"}.fa-ethereum:before{content:"\f42e"}.fa-speaker-deck:before{content:"\f83c"}.fa-creative-commons-nc-eu:before{content:"\f4e9"}.fa-patreon:before{content:"\f3d9"}.fa-avianex:before{content:"\f374"}.fa-ello:before{content:"\f5f1"}.fa-gofore:before{content:"\f3a7"}.fa-bimobject:before{content:"\f378"}.fa-facebook-f:before{content:"\f39e"}.fa-google-plus-square:before,.fa-square-google-plus:before{content:"\f0d4"}.fa-mandalorian:before{content:"\f50f"}.fa-first-order-alt:before{content:"\f50a"}.fa-osi:before{content:"\f41a"}.fa-google-wallet:before{content:"\f1ee"}.fa-d-and-d-beyond:before{content:"\f6ca"}.fa-periscope:before{content:"\f3da"}.fa-fulcrum:before{content:"\f50b"}.fa-cloudscale:before{content:"\f383"}.fa-forumbee:before{content:"\f211"}.fa-mizuni:before{content:"\f3cc"}.fa-schlix:before{content:"\f3ea"}.fa-square-xing:before,.fa-xing-square:before{content:"\f169"}.fa-bandcamp:before{content:"\f2d5"}.fa-wpforms:before{content:"\f298"}.fa-cloudversify:before{content:"\f385"}.fa-usps:before{content:"\f7e1"}.fa-megaport:before{content:"\f5a3"}.fa-magento:before{content:"\f3c4"}.fa-spotify:before{content:"\f1bc"}.fa-optin-monster:before{content:"\f23c"}.fa-fly:before{content:"\f417"}.fa-aviato:before{content:"\f421"}.fa-itunes:before{content:"\f3b4"}.fa-cuttlefish:before{content:"\f38c"}.fa-blogger:before{content:"\f37c"}.fa-flickr:before{content:"\f16e"}.fa-viber:before{content:"\f409"}.fa-soundcloud:before{content:"\f1be"}.fa-digg:before{content:"\f1a6"}.fa-tencent-weibo:before{content:"\f1d5"}.fa-symfony:before{content:"\f83d"}.fa-maxcdn:before{content:"\f136"}.fa-etsy:before{content:"\f2d7"}.fa-facebook-messenger:before{content:"\f39f"}.fa-audible:before{content:"\f373"}.fa-think-peaks:before{content:"\f731"}.fa-bilibili:before{content:"\e3d9"}.fa-erlang:before{content:"\f39d"}.fa-cotton-bureau:before{content:"\f89e"}.fa-dashcube:before{content:"\f210"}.fa-42-group:before,.fa-innosoft:before{content:"\e080"}.fa-stack-exchange:before{content:"\f18d"}.fa-elementor:before{content:"\f430"}.fa-pied-piper-square:before,.fa-square-pied-piper:before{content:"\e01e"}.fa-creative-commons-nd:before{content:"\f4eb"}.fa-palfed:before{content:"\f3d8"}.fa-superpowers:before{content:"\f2dd"}.fa-resolving:before{content:"\f3e7"}.fa-xbox:before{content:"\f412"}.fa-searchengin:before{content:"\f3eb"}.fa-tiktok:before{content:"\e07b"}.fa-facebook-square:before,.fa-square-facebook:before{content:"\f082"}.fa-renren:before{content:"\f18b"}.fa-linux:before{content:"\f17c"}.fa-glide:before{content:"\f2a5"}.fa-linkedin:before{content:"\f08c"}.fa-hubspot:before{content:"\f3b2"}.fa-deploydog:before{content:"\f38e"}.fa-twitch:before{content:"\f1e8"}.fa-ravelry:before{content:"\f2d9"}.fa-mixer:before{content:"\e056"}.fa-lastfm-square:before,.fa-square-lastfm:before{content:"\f203"}.fa-vimeo:before{content:"\f40a"}.fa-mendeley:before{content:"\f7b3"}.fa-uniregistry:before{content:"\f404"}.fa-figma:before{content:"\f799"}.fa-creative-commons-remix:before{content:"\f4ee"}.fa-cc-amazon-pay:before{content:"\f42d"}.fa-dropbox:before{content:"\f16b"}.fa-instagram:before{content:"\f16d"}.fa-cmplid:before{content:"\e360"}.fa-facebook:before{content:"\f09a"}.fa-gripfire:before{content:"\f3ac"}.fa-jedi-order:before{content:"\f50e"}.fa-uikit:before{content:"\f403"}.fa-fort-awesome-alt:before{content:"\f3a3"}.fa-phabricator:before{content:"\f3db"}.fa-ussunnah:before{content:"\f407"}.fa-earlybirds:before{content:"\f39a"}.fa-trade-federation:before{content:"\f513"}.fa-autoprefixer:before{content:"\f41c"}.fa-whatsapp:before{content:"\f232"}.fa-slideshare:before{content:"\f1e7"}.fa-google-play:before{content:"\f3ab"}.fa-viadeo:before{content:"\f2a9"}.fa-line:before{content:"\f3c0"}.fa-google-drive:before{content:"\f3aa"}.fa-servicestack:before{content:"\f3ec"}.fa-simplybuilt:before{content:"\f215"}.fa-bitbucket:before{content:"\f171"}.fa-imdb:before{content:"\f2d8"}.fa-deezer:before{content:"\e077"}.fa-raspberry-pi:before{content:"\f7bb"}.fa-jira:before{content:"\f7b1"}.fa-docker:before{content:"\f395"}.fa-screenpal:before{content:"\e570"}.fa-bluetooth:before{content:"\f293"}.fa-gitter:before{content:"\f426"}.fa-d-and-d:before{content:"\f38d"}.fa-microblog:before{content:"\e01a"}.fa-cc-diners-club:before{content:"\f24c"}.fa-gg-circle:before{content:"\f261"}.fa-pied-piper-hat:before{content:"\f4e5"}.fa-kickstarter-k:before{content:"\f3bc"}.fa-yandex:before{content:"\f413"}.fa-readme:before{content:"\f4d5"}.fa-html5:before{content:"\f13b"}.fa-sellsy:before{content:"\f213"}.fa-sass:before{content:"\f41e"}.fa-wirsindhandwerk:before,.fa-wsh:before{content:"\e2d0"}.fa-buromobelexperte:before{content:"\f37f"}.fa-salesforce:before{content:"\f83b"}.fa-octopus-deploy:before{content:"\e082"}.fa-medapps:before{content:"\f3c6"}.fa-ns8:before{content:"\f3d5"}.fa-pinterest-p:before{content:"\f231"}.fa-apper:before{content:"\f371"}.fa-fort-awesome:before{content:"\f286"}.fa-waze:before{content:"\f83f"}.fa-cc-jcb:before{content:"\f24b"}.fa-snapchat-ghost:before,.fa-snapchat:before{content:"\f2ab"}.fa-fantasy-flight-games:before{content:"\f6dc"}.fa-rust:before{content:"\e07a"}.fa-wix:before{content:"\f5cf"}.fa-behance-square:before,.fa-square-behance:before{content:"\f1b5"}.fa-supple:before{content:"\f3f9"}.fa-rebel:before{content:"\f1d0"}.fa-css3:before{content:"\f13c"}.fa-staylinked:before{content:"\f3f5"}.fa-kaggle:before{content:"\f5fa"}.fa-space-awesome:before{content:"\e5ac"}.fa-deviantart:before{content:"\f1bd"}.fa-cpanel:before{content:"\f388"}.fa-goodreads-g:before{content:"\f3a9"}.fa-git-square:before,.fa-square-git:before{content:"\f1d2"}.fa-square-tumblr:before,.fa-tumblr-square:before{content:"\f174"}.fa-trello:before{content:"\f181"}.fa-creative-commons-nc-jp:before{content:"\f4ea"}.fa-get-pocket:before{content:"\f265"}.fa-perbyte:before{content:"\e083"}.fa-grunt:before{content:"\f3ad"}.fa-weebly:before{content:"\f5cc"}.fa-connectdevelop:before{content:"\f20e"}.fa-leanpub:before{content:"\f212"}.fa-black-tie:before{content:"\f27e"}.fa-themeco:before{content:"\f5c6"}.fa-python:before{content:"\f3e2"}.fa-android:before{content:"\f17b"}.fa-bots:before{content:"\e340"}.fa-free-code-camp:before{content:"\f2c5"}.fa-hornbill:before{content:"\f592"}.fa-js:before{content:"\f3b8"}.fa-ideal:before{content:"\e013"}.fa-git:before{content:"\f1d3"}.fa-dev:before{content:"\f6cc"}.fa-sketch:before{content:"\f7c6"}.fa-yandex-international:before{content:"\f414"}.fa-cc-amex:before{content:"\f1f3"}.fa-uber:before{content:"\f402"}.fa-github:before{content:"\f09b"}.fa-php:before{content:"\f457"}.fa-alipay:before{content:"\f642"}.fa-youtube:before{content:"\f167"}.fa-skyatlas:before{content:"\f216"}.fa-firefox-browser:before{content:"\e007"}.fa-replyd:before{content:"\f3e6"}.fa-suse:before{content:"\f7d6"}.fa-jenkins:before{content:"\f3b6"}.fa-twitter:before{content:"\f099"}.fa-rockrms:before{content:"\f3e9"}.fa-pinterest:before{content:"\f0d2"}.fa-buffer:before{content:"\f837"}.fa-npm:before{content:"\f3d4"}.fa-yammer:before{content:"\f840"}.fa-btc:before{content:"\f15a"}.fa-dribbble:before{content:"\f17d"}.fa-stumbleupon-circle:before{content:"\f1a3"}.fa-internet-explorer:before{content:"\f26b"}.fa-stubber:before{content:"\e5c7"}.fa-telegram-plane:before,.fa-telegram:before{content:"\f2c6"}.fa-old-republic:before{content:"\f510"}.fa-odysee:before{content:"\e5c6"}.fa-square-whatsapp:before,.fa-whatsapp-square:before{content:"\f40c"}.fa-node-js:before{content:"\f3d3"}.fa-edge-legacy:before{content:"\e078"}.fa-slack-hash:before,.fa-slack:before{content:"\f198"}.fa-medrt:before{content:"\f3c8"}.fa-usb:before{content:"\f287"}.fa-tumblr:before{content:"\f173"}.fa-vaadin:before{content:"\f408"}.fa-quora:before{content:"\f2c4"}.fa-reacteurope:before{content:"\f75d"}.fa-medium-m:before,.fa-medium:before{content:"\f23a"}.fa-amilia:before{content:"\f36d"}.fa-mixcloud:before{content:"\f289"}.fa-flipboard:before{content:"\f44d"}.fa-viacoin:before{content:"\f237"}.fa-critical-role:before{content:"\f6c9"}.fa-sitrox:before{content:"\e44a"}.fa-discourse:before{content:"\f393"}.fa-joomla:before{content:"\f1aa"}.fa-mastodon:before{content:"\f4f6"}.fa-airbnb:before{content:"\f834"}.fa-wolf-pack-battalion:before{content:"\f514"}.fa-buy-n-large:before{content:"\f8a6"}.fa-gulp:before{content:"\f3ae"}.fa-creative-commons-sampling-plus:before{content:"\f4f1"}.fa-strava:before{content:"\f428"}.fa-ember:before{content:"\f423"}.fa-canadian-maple-leaf:before{content:"\f785"}.fa-teamspeak:before{content:"\f4f9"}.fa-pushed:before{content:"\f3e1"}.fa-wordpress-simple:before{content:"\f411"}.fa-nutritionix:before{content:"\f3d6"}.fa-wodu:before{content:"\e088"}.fa-google-pay:before{content:"\e079"}.fa-intercom:before{content:"\f7af"}.fa-zhihu:before{content:"\f63f"}.fa-korvue:before{content:"\f42f"}.fa-pix:before{content:"\e43a"}.fa-steam-symbol:before{content:"\f3f6"}:host,:root{--fa-font-regular:normal 400 1em/1 "Font Awesome 6 Free"}@font-face{font-family:"Font Awesome 6 Free";font-style:normal;font-weight:400;font-display:block;src:url(/assets/fonts/fa/fa-regular-400.woff2) format("woff2")}.fa-regular,.far{font-weight:400}:host,:root{--fa-style-family-classic:"Font Awesome 6 Free";--fa-font-solid:normal 900 1em/1 "Font Awesome 6 Free"}@font-face{font-family:"Font Awesome 6 Free";font-style:normal;font-weight:900;font-display:block;src:url(/assets/fonts/fa/fa-solid-900.woff2) format("woff2")}.fa-solid,.fas{font-weight:900}@font-face{font-family:"Font Awesome 5 Brands";font-display:block;font-weight:400;src:url(/assets/fonts/fa/fa-brands-400.woff2) format("woff2")}@font-face{font-family:"Font Awesome 5 Free";font-display:block;font-weight:900;src:url(/assets/fonts/fa/fa-solid-900.woff2) format("woff2")}@font-face{font-family:"Font Awesome 5 Free";font-display:block;font-weight:400;src:url(/assets/fonts/fa/fa-regular-400.woff2) format("woff2")}@font-face{font-family:"FontAwesome";font-display:block;src:url(/assets/fonts/fa/fa-solid-900.woff2) format("woff2")}@font-face{font-family:"FontAwesome";font-display:block;src:url(/assets/fonts/fa/fa-brands-400.woff2) format("woff2")}@font-face{font-family:"FontAwesome";font-display:block;src:url(/assets/fonts/fa/fa-regular-400.woff2) format("woff2");unicode-range:u+f003,u+f006,u+f014,u+f016-f017,u+f01a-f01b,u+f01d,u+f022,u+f03e,u+f044,u+f046,u+f05c-f05d,u+f06e,u+f070,u+f087-f088,u+f08a,u+f094,u+f096-f097,u+f09d,u+f0a0,u+f0a2,u+f0a4-f0a7,u+f0c5,u+f0c7,u+f0e5-f0e6,u+f0eb,u+f0f6-f0f8,u+f10c,u+f114-f115,u+f118-f11a,u+f11c-f11d,u+f133,u+f147,u+f14e,u+f150-f152,u+f185-f186,u+f18e,u+f190-f192,u+f196,u+f1c1-f1c9,u+f1d9,u+f1db,u+f1e3,u+f1ea,u+f1f7,u+f1f9,u+f20a,u+f247-f248,u+f24a,u+f24d,u+f255-f25b,u+f25d,u+f271-f274,u+f278,u+f27b,u+f28c,u+f28e,u+f29c,u+f2b5,u+f2b7,u+f2ba,u+f2bc,u+f2be,u+f2c0-f2c1,u+f2c3,u+f2d0,u+f2d2,u+f2d4,u+f2dc}

/* =======================================
   ACES & ARMOUR - Design System v6
   Homepage overhaul:
   - Kickstarter topbar
   - Animated stats counters in hero
   - Merged news with horizontal scroll
   - Cinematic game feature showcase
   - FAQ as cards (top 3)
   - Museum photo carousel
   - Tier pricing cards for Patreon
   - Clean footer with social icons
   Fonts: Teko (headings) + Roboto (body)
   ======================================= */

/* --- Variables & Reset --- */
:root {
    --color-bg: #0E1620;
    --color-bg-section: #131E2A;
    --color-bg-card: #1B2638;
    --color-bg-border: #2B3A50;
    --color-bg-hover: #1E2A3E;
    --color-text: #E0E5EC;
    --color-text-muted: #9BA7B5;
    --color-text-bright: #FFFFFF;
    --color-primary: #F0A042;
    --color-primary-dark: #D88A2C;
}

/* ── Blueprint Zone — swap red accents to blue when roadmap is in view ── */
body.bp-zone {
    --color-primary: #4a7fff;
    --color-primary-dark: #3a6ae0;
}

/* ── Keyboard focus rings (WCAG 2.1 AA) ──
   :focus-visible only triggers on keyboard nav, NOT mouse clicks — so
   visual change is invisible to mouse users but essential for anyone
   tabbing through. Uses --color-primary so it auto-swaps to blue under
   bp-zone. Border-radius is inherited from the element via offset. */
:focus { outline: none; } /* kill default browser ring */

a:focus-visible,
button:focus-visible,
input:focus-visible,
select:focus-visible,
textarea:focus-visible,
[tabindex]:focus-visible,
[role="button"]:focus-visible {
    outline: 2px solid var(--color-primary);
    outline-offset: 2px;
    border-radius: 4px;
    transition: outline-offset 0.15s ease;
}

/* Custom-styled buttons / interactive elements that already have a
   border-radius and tight padding need a slightly different treatment:
   use a glow box-shadow instead of an outline so the ring follows the
   shape of the element. */
.btn:focus-visible,
.nav-icon-btn:focus-visible,
.nav-auth-btn:focus-visible,
.partner-logo:focus-visible,
.mobile-toggle:focus-visible,
.mobile-menu-close:focus-visible,
.mobile-auth-btn:focus-visible,
.mobile-nav-cta:focus-visible,
.lang-btn:focus-visible,
.garage-nation-card:focus-visible,
.garage-type-card:focus-visible,
.garage-veh-card:focus-visible,
.garage-back-btn:focus-visible,
.tier-cta:focus-visible,
.cb-banner-btn:focus-visible,
.cc-btn:focus-visible,
.cc-mini:focus-visible,
.err-btn:focus-visible,
.rmcs-back:focus-visible,
.hero-live-discord:focus-visible {
    outline: none;
    box-shadow: 0 0 0 2px rgba(0, 0, 0, 0.85),
                0 0 0 4px var(--color-primary),
                0 0 16px rgba(240, 160, 66, 0.3);
}

body.bp-zone .btn:focus-visible,
body.bp-zone .nav-icon-btn:focus-visible,
body.bp-zone .nav-auth-btn:focus-visible,
body.bp-zone .partner-logo:focus-visible,
body.bp-zone .mobile-toggle:focus-visible,
body.bp-zone .mobile-menu-close:focus-visible,
body.bp-zone .mobile-auth-btn:focus-visible,
body.bp-zone .mobile-nav-cta:focus-visible,
body.bp-zone .lang-btn:focus-visible,
body.bp-zone .err-btn:focus-visible,
body.bp-zone .rmcs-back:focus-visible {
    box-shadow: 0 0 0 2px rgba(0, 0, 0, 0.85),
                0 0 0 4px var(--color-primary),
                0 0 16px rgba(74, 127, 255, 0.4);
}

/* Smooth transitions on elements that use --color-primary */
.navbar {
    transition: box-shadow var(--transition-base), border-color 0.5s ease;
}
.nav-auth-btn--register {
    transition: all 0.5s ease;
}
.nav-divider-v {
    transition: background 0.5s ease;
}
.lang-btn.active {
    transition: all 0.5s ease;
}
::-webkit-scrollbar-thumb {
    transition: background 0.5s ease;
}

/* Direct overrides for hardcoded reds under bp-zone */
body.bp-zone .nav-auth-btn--register {
    background: var(--color-primary);
    border-color: var(--color-primary);
}
body.bp-zone .nav-auth-btn--register:hover {
    background: var(--color-primary-dark);
    border-color: var(--color-primary-dark);
}
body.bp-zone .nav-icon-btn:hover {
    color: var(--color-primary);
    border-color: rgba(74,127,255,0.4);
    background: rgba(74,127,255,0.08);
}
body.bp-zone .nav-divider-v {
    background: rgba(74,127,255,0.5);
}
body.bp-zone .lang-btn.active {
    background: var(--color-primary);
    box-shadow: 0 1px 4px rgba(74,127,255,0.3);
}
body.bp-zone .lang-btn--flag.active {
    background: transparent;
    border-color: var(--color-primary);
    box-shadow: 0 2px 8px rgba(0,0,0,0.45);
}
body.bp-zone .nav-auth-popup {
    --auth-popup-accent: rgba(74,127,255,0.5);
    --auth-popup-accent-strong: rgba(74,127,255,0.9);
    --auth-popup-glow: rgba(74,127,255,0.12);
    --auth-popup-icon-bg: rgba(74,127,255,0.14);
    --auth-popup-icon-border: rgba(74,127,255,0.4);
    --auth-popup-icon-color: rgba(74,127,255,0.95);
}
body.bp-zone .gp-mode-ribbon {
    background: linear-gradient(180deg, #4a7fff 0%, #3a6ae0 100%);
    box-shadow: 0 6px 18px rgba(0,0,0,0.55), 0 0 24px rgba(74,127,255,0.45), inset 0 1px 0 rgba(255,255,255,0.25), inset 0 -2px 0 rgba(0,0,0,0.3);
    animation: none;
}
body.bp-zone .gp-mode-ribbon-wrap::before,
body.bp-zone .gp-mode-ribbon-wrap::after {
    border-color: #1f3a8a;
    border-top-color: transparent;
    border-left-color: transparent;
}
body.bp-zone .gp-mode-ribbon-wrap::after {
    border-top-color: transparent;
    border-right-color: transparent;
    border-left-color: #1f3a8a;
    border-bottom-color: #1f3a8a;
}
body.bp-zone .store-soon-badge {
    border-color: rgba(74,127,255,0.5);
    border-top-color: rgba(74,127,255,0.9);
    box-shadow: 0 12px 50px rgba(0,0,0,0.6), 0 0 30px rgba(74,127,255,0.12);
}
body.bp-zone .store-soon-icon {
    background: rgba(74,127,255,0.14);
    border-color: rgba(74,127,255,0.4);
    color: rgba(74,127,255,0.95);
}
body.bp-zone .store-soon-eyebrow {
    color: rgba(74,127,255,0.95);
}
body.bp-zone .coming-soon-toast {
    border-color: rgba(74,127,255,0.4);
}
body.bp-zone .coming-soon-toast i {
    color: var(--color-primary);
}

/* ── Mobile menu: swap remaining hardcoded reds to blue under bp-zone ── */
body.bp-zone .mobile-toggle:hover {
    background: rgba(74, 127, 255, 0.1);
    border-color: rgba(74, 127, 255, 0.3);
}
body.bp-zone .nav-mobile.active a:hover,
body.bp-zone .nav-mobile.active a:active {
    background: rgba(74, 127, 255, 0.06);
    border-color: rgba(74, 127, 255, 0.2);
}
body.bp-zone .nav-mobile.active a i {
    background: rgba(74, 127, 255, 0.1);
    border-color: rgba(74, 127, 255, 0.2);
}
body.bp-zone .mobile-menu-close:hover {
    background: rgba(74, 127, 255, 0.12);
    border-color: rgba(74, 127, 255, 0.4);
    color: var(--color-primary);
}
body.bp-zone .nav-mobile.active .mobile-nav-cta:hover {
    background: var(--color-primary-dark);
}
body.bp-zone .nav-mobile.active .mobile-nav-cta--outline i {
    background: rgba(74, 127, 255, 0.1);
    border-color: rgba(74, 127, 255, 0.2);
    color: var(--color-primary);
}
body.bp-zone .mobile-auth-btn--register {
    background: var(--color-primary);
    border-color: var(--color-primary);
}
body.bp-zone .mobile-auth-btn--register:hover {
    background: var(--color-primary-dark);
    border-color: var(--color-primary-dark);
}
body.bp-zone .mobile-nav-socials a:hover {
    border-color: rgba(74, 127, 255, 0.4) !important;
    background: rgba(74, 127, 255, 0.08) !important;
}
body.bp-zone .mobile-nav-socials a:hover i {
    color: var(--color-primary) !important;
}

/* ── Mobile auth coming-soon popup (the "Account system is under
   development" toast that appears when LOG IN or REGISTER is tapped) ── */
body.bp-zone .mobile-auth-popup {
    border-color: rgba(74, 127, 255, 0.5);
    border-top-color: rgba(74, 127, 255, 0.9);
    box-shadow: 0 12px 40px rgba(0, 0, 0, 0.6), 0 0 20px rgba(74, 127, 255, 0.1);
}
body.bp-zone .map-icon {
    background: rgba(74, 127, 255, 0.14);
    border-color: rgba(74, 127, 255, 0.4);
    color: rgba(74, 127, 255, 0.95);
}
/* Logos: shift the red badge in brand artwork toward blue.
   hue-rotate(220deg) takes red (hue 0) to blue (hue ~220) without
   touching white, transparent, or grey pixels. */
body.bp-zone .logo-img,
body.bp-zone .footer-logo,
body.bp-zone .footer-partner-logos {
    filter: hue-rotate(220deg);
    transition: filter 0.5s ease;
}
.logo-img,
.footer-logo,
.footer-partner-logos {
    transition: filter 0.5s ease;
}

/* ── Cookie consent overrides ──
   cookie-consent.js injects its own <style> with hardcoded #F0A042 in
   ~10 spots. body.bp-zone selectors below out-specify those rules so
   the banner / preferences modal / minimized icon all render in blue
   whenever the blueprint zone is active (this includes the dedicated
   /roadmap.html page AND the homepage roadmap section while scrolled
   into view). */

/* Initial banner */
body.bp-zone .cb-banner-inner {
    border-color: rgba(74, 127, 255, 0.18);
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.5), 0 0 0 1px rgba(74, 127, 255, 0.08);
}
body.bp-zone .cb-banner-icon { color: #4a7fff; }
body.bp-zone .cb-banner-btn--accept { background: #4a7fff; }
body.bp-zone .cb-banner-btn--accept:hover { background: #3a6ae0; }

/* Preferences modal card */
body.bp-zone .cc-card {
    border-color: rgba(74, 127, 255, 0.22);
    box-shadow: 0 12px 40px rgba(0, 0, 0, 0.6), 0 0 0 1px rgba(74, 127, 255, 0.10);
}
body.bp-zone .cc-header-icon { color: #4a7fff; }
body.bp-zone .cc-toggle-track--on { background: #4a7fff; }
body.bp-zone .cc-btn--accept { background: #4a7fff; }
body.bp-zone .cc-btn--accept:hover { background: #3a6ae0; }

/* Minimized floating icon (bottom-right) */
body.bp-zone .cc-mini { border-color: rgba(74, 127, 255, 0.25); }
body.bp-zone .cc-mini:hover {
    color: #4a7fff;
    border-color: rgba(74, 127, 255, 0.5);
}

/* Smooth crossfades on the cookie pieces when bp-zone toggles on/off
   (matches the navbar/scrollbar transitions above). */
.cb-banner-inner,
.cb-banner-icon,
.cb-banner-btn--accept,
.cc-card,
.cc-header-icon,
.cc-toggle-track,
.cc-btn--accept,
.cc-mini {
    transition: background 0.5s ease, border-color 0.5s ease, color 0.5s ease, box-shadow 0.5s ease;
}

/* Scrollbar: must override at document level since pseudo-elements don't inherit from body */
body.bp-zone::-webkit-scrollbar-thumb {
    background: #4a7fff;
}
body.bp-zone::-webkit-scrollbar-thumb:hover {
    background: #3a6ae0;
}
:root {
    --color-accent-green: #05ce78;
    --color-accent-green-hover: #04b067;
    --font-heading: 'Futura', 'Century Gothic', 'Trebuchet MS', sans-serif;          /* headings + UI — Futura Medium 500 (non-bold) */
    --font-display: 'Futura', 'Century Gothic', 'Trebuchet MS', sans-serif;          /* big display titles — Futura Medium 500 */
    --font-body: 'DIN Alternate', 'Rajdhani', system-ui, -apple-system, 'Segoe UI', sans-serif;  /* standard text — DIN Alternate (Bold cut only) */
    --font-mono: 'JetBrains Mono', 'Roboto Mono', 'Courier New', monospace;
    --transition-fast: 0.2s ease;
    --transition-base: 0.3s ease;
    --transition-slow: 0.5s ease;
    --radius-sm: 3px;
    --radius-base: 4px;
    --radius-lg: 8px;
    --max-width: 1200px;
    --text-max-width: 720px;    /* readable column for long-form paragraphs */
}

html {
    scroll-behavior: smooth;
    scroll-padding-top: 120px;
}

*,
*::before,
*::after {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

html {
    scroll-behavior: smooth;
}

body {
    background: var(--color-bg);
    color: var(--color-text);
    font-family: var(--font-body);
    font-size: 19.5px;
    line-height: 1.7;
    overflow-x: hidden;
    -webkit-font-smoothing: antialiased;
}

h1,
h2,
h3,
h4,
h5,
h6 {
    font-family: var(--font-heading);
    font-weight: 600;
    line-height: 1.15;
    text-transform: uppercase;
    letter-spacing: 1px;
    color: var(--color-text-bright);
}

a {
    text-decoration: none;
    color: inherit;
    transition: color var(--transition-fast);
}

ul {
    list-style: none;
}

img {
    max-width: 100%;
    height: auto;        /* preserve intrinsic aspect ratio when only width is set
                            in CSS — without this, <img width="X" height="Y"> attrs
                            (added for CLS) cause stretching when CSS scales width */
    display: block;
}

.container {
    width: 100%;
    max-width: var(--max-width);
    margin: 0 auto;
    padding: 0 24px;
}

.text-primary {
    color: var(--color-primary);
}

.text-center {
    text-align: center;
}

section {
    padding: 6rem 0;
}

.section-title {
    font-size: clamp(1.85rem, 3.5vw, 2.77rem);
    font-weight: 600;
    margin-bottom: 1.5rem;
}

.section-tag {
    display: inline-block;
    font-family: var(--font-heading);
    font-size: 0.85rem;
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 4px;
    color: var(--color-primary);
    margin-bottom: 0.75rem;
    border-bottom: 2px solid var(--color-primary);
    padding-bottom: 0.25rem;
}

.section-header {
    margin-bottom: 3rem;
}

.section-header-flex {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 2rem;
    flex-wrap: wrap;
    gap: 1rem;
}

/* --- Buttons --- */
.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    padding: 0.6rem 1.5rem;
    font-family: var(--font-heading);
    font-size: 0.95rem;
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 1.5px;
    border-radius: var(--radius-base);
    cursor: pointer;
    transition: all var(--transition-base);
    border: 1px solid transparent;
}

.btn-lg {
    padding: 0.85rem 2rem;
    font-size: 1.05rem;
}

.btn-primary {
    background: var(--color-primary);
    color: #fff;
}

.btn-primary:hover {
    background: var(--color-primary-dark);
    transform: translateY(-1px);
}

.btn-outline {
    background: transparent;
    border-color: rgba(255, 255, 255, 0.2);
    color: #fff;
}

.btn-outline:hover {
    border-color: rgba(255, 255, 255, 0.5);
    color: #fff;
    background: rgba(255, 255, 255, 0.05);
}

/* ===========================
   SCROLL REVEAL SYSTEM
   =========================== */
.reveal {
    opacity: 0;
    transform: translateY(24px);
    transition: opacity 0.6s ease var(--reveal-delay, 0s),
        transform 0.6s ease var(--reveal-delay, 0s);
}

.reveal.visible {
    opacity: 1;
    /* 'none' (not translateY(0)) so the element drops its transform layer once
       revealed — a lingering transform can soften text rendering at 100% zoom. */
    transform: none;
}

/* ===========================
   KICKSTARTER TOPBAR
   =========================== */
.topbar {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    background: linear-gradient(90deg, #1a1a2e 0%, #16213e 50%, #1a1a2e 100%);
    border-bottom: 2px solid var(--color-primary);
    color: #fff;
    font-family: var(--font-heading);
    font-size: 0.8rem;
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 1.5px;
    padding: 0.45rem 0;
    z-index: 1100;
    transition: transform 0.4s ease, opacity 0.4s ease;
}

.topbar.hidden {
    transform: translateY(-100%);
    opacity: 0;
    pointer-events: none;
}

.topbar-inner {
    max-width: 1440px;
    margin: 0 auto;
    padding: 0 32px;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 1rem;
    flex-wrap: wrap;
}

.topbar-inner span {
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.topbar-btn {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    padding: 0.25rem 0.8rem;
    background: var(--color-primary);
    border-radius: var(--radius-sm);
    color: #fff;
    font-weight: 600;
    font-size: 0.75rem;
    letter-spacing: 1px;
    transition: background var(--transition-fast);
}

.topbar-btn:hover {
    background: rgba(0, 0, 0, 0.35);
}

.topbar-close {
    background: none;
    border: none;
    color: rgba(255, 255, 255, 0.7);
    cursor: pointer;
    font-size: 0.85rem;
    padding: 0.25rem;
    transition: color var(--transition-fast);
    margin-left: 0.5rem;
}

.topbar-close:hover {
    color: #fff;
}

/* ===========================
   NAVBAR — Option D+C Hybrid
   Secondary strip + logo-left main bar
   =========================== */

/* Outer header wrapper */
.navbar {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    z-index: 1000;
    background: rgba(8, 8, 12, 0.97);
    backdrop-filter: blur(12px);
    transition: box-shadow var(--transition-base);
    border-bottom: 2px solid var(--color-primary);
}

.navbar.scrolled {
    box-shadow: 0 2px 20px rgba(0, 0, 0, 0.6);
}

/* --- Secondary strip --- */
.nav-topstrip {
    background: #0d0d10;
    border-bottom: 1px solid rgba(255, 255, 255, 0.06);
}

.nav-topstrip-inner {
    max-width: 1440px;
    margin: 0 auto;
    padding: 0 32px;
    height: 30px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.25rem;
}

.nav-topstrip-left,
.nav-topstrip-right {
    display: flex;
    align-items: center;
    gap: 0.25rem;
}

.nav-topstrip-link {
    font-family: var(--font-heading);
    font-size: 0.78rem;
    font-weight: 400;
    text-transform: uppercase;
    letter-spacing: 1.5px;
    color: rgba(255, 255, 255, 0.4);
    text-decoration: none;
    padding: 0 0.6rem;
    transition: color var(--transition-fast);
}

.nav-topstrip-link:hover {
    color: rgba(255, 255, 255, 0.8);
}

.nav-topstrip-sep {
    color: rgba(255, 255, 255, 0.15);
    font-size: 0.7rem;
    flex-shrink: 0;
}

/* --- Main nav row --- */
.nav-container {
    display: flex;
    align-items: center;
    padding: 0 32px;
    max-width: 1440px;
    margin: 0 auto;
    height: 64px;
    gap: 0;
}

/* Logo — left anchored */
.logo {
    display: flex;
    align-items: center;
    flex-shrink: 0;
    text-decoration: none;
}

.logo-img {
    height: 40px;
    width: auto;
    transition: transform var(--transition-base);
}

.logo-img-lg {
    height: 32px;
}

.logo:hover .logo-img {
    transform: scale(1.04);
}

/* Vertical red divider after logo */
.nav-divider-v {
    width: 1px;
    height: 32px;
    background: rgba(240, 160, 66, 0.5);
    margin: 0 1.5rem;
    flex-shrink: 0;
}

/* Nav links — centered */
.nav-left {
    display: flex;
    align-items: center;
    flex: 1;
    justify-content: center;
    gap: 0;
}

.nav-list {
    display: flex;
    gap: 0;
}

.nav-link {
    font-family: var(--font-heading);
    font-size: 1.15rem;
    font-weight: 500;
    color: rgba(255, 255, 255, 0.9);
    text-transform: uppercase;
    letter-spacing: 1.5px;
    padding: 0.5rem 0.9rem;
    position: relative;
    transition: color var(--transition-fast);
    white-space: nowrap;
}

.nav-link:hover {
    color: #fff;
}

/* Underline handled by text-decoration in _includes/header.html
   (the old ::after grow-from-center bar desynced under the scaleX squash). */

/* Right side — actions */
.nav-right {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    flex-shrink: 0;
    margin-left: auto;
}

/* Thin vertical separator between button groups */
.nav-btn-sep {
    width: 1px;
    height: 22px;
    background: rgba(255, 255, 255, 0.12);
    flex-shrink: 0;
}

/* Small icon-only buttons (Store, Download) */
.nav-icon-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 36px;
    height: 36px;
    border-radius: var(--radius-base);
    color: rgba(255, 255, 255, 0.6);
    background: transparent;
    border: 1px solid rgba(255, 255, 255, 0.12);
    text-decoration: none;
    transition: all var(--transition-fast);
    font-size: 0.9rem;
    cursor: pointer;
    position: relative;
}

.nav-icon-btn:hover {
    color: #F0A042;
    border-color: rgba(240, 160, 66, 0.4);
    background: rgba(240, 160, 66, 0.08);
}

/* Tooltip labels */
.nav-icon-btn::after {
    content: attr(data-tooltip);
    position: absolute;
    bottom: -28px;
    left: 50%;
    transform: translateX(-50%) translateY(4px);
    font-family: var(--font-heading);
    font-size: 0.65rem;
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 1px;
    color: #fff;
    background: rgba(20, 20, 25, 0.95);
    border: 1px solid rgba(255, 255, 255, 0.1);
    padding: 0.2rem 0.5rem;
    border-radius: 3px;
    white-space: nowrap;
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.2s, transform 0.2s;
    z-index: 100;
}

.nav-icon-btn:hover::after {
    opacity: 1;
    transform: translateX(-50%) translateY(0);
}

/* Disabled "coming soon" state — shows the OS not-allowed cursor on hover */
.nav-icon-btn--disabled {
    cursor: not-allowed;
}

/* Store — outlined */
.nav-cta {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    padding: 0.42rem 1rem;
    border-radius: var(--radius-base);
    font-family: var(--font-heading);
    font-size: 0.9rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 1.5px;
    white-space: nowrap;
    transition: all var(--transition-base);
    text-decoration: none;
}

.nav-cta--store {
    color: rgba(255, 255, 255, 0.75);
    background: transparent;
    border: 1px solid rgba(255, 255, 255, 0.18);
}

.nav-cta--store:hover {
    color: #fff;
    border-color: rgba(255, 255, 255, 0.4);
    background: rgba(255, 255, 255, 0.05);
}

/* Download — red CTA, same size as auth buttons */
.nav-cta--download {
    color: #fff;
    background: var(--color-primary);
    border: 1px solid var(--color-primary);
}

.nav-cta--download:hover {
    background: var(--color-primary-dark);
    border-color: var(--color-primary-dark);
    transform: translateY(-1px);
}

/* Auth buttons */
.nav-auth-btn {
    font-family: var(--font-heading);
    font-size: 0.9rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 1.5px;
    padding: 0.42rem 1rem;
    border-radius: var(--radius-base);
    cursor: pointer;
    transition: all var(--transition-base);
    white-space: nowrap;
    text-decoration: none;
    display: inline-flex;
    align-items: center;
}

.nav-auth-btn--login {
    background: transparent;
    color: rgba(255, 255, 255, 0.8);
    border: 1px solid rgba(255, 255, 255, 0.2);
}

.nav-auth-btn--login:hover {
    color: #fff;
    border-color: rgba(255, 255, 255, 0.45);
    background: rgba(255, 255, 255, 0.05);
}

.nav-auth-btn--register {
    background: #F0A042;
    color: #fff;
    border: 1px solid #F0A042;
}

.nav-auth-btn--register:hover {
    background: #D88A2C;
    border-color: #D88A2C;
}

/* Mobile */
.mobile-toggle {
    display: none;
    background: none;
    border: none;
    color: #fff;
    font-size: 1.5rem;
    cursor: pointer;
}

.nav-mobile {
    display: none;
}

/* When mobile menu is open, boost the navbar z-index so the hamburger-X
   toggle stays clickable above the menu, but hide its red bottom border —
   otherwise it shows as a thin red strip across the top of the open menu. */
body.mobile-menu-open .navbar {
    z-index: 99999;
    border-bottom-color: transparent;
}

/* Lock background scroll while the mobile menu is open so swiping inside
   the menu doesn't bleed through to the page behind. */
body.mobile-menu-open {
    overflow: hidden;
}

/* ===========================
   AUTH MODALS
   =========================== */
.auth-modal-overlay {
    position: fixed;
    inset: 0;
    z-index: 10001;
    background: rgba(0, 0, 0, 0.8);
    backdrop-filter: blur(6px);
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.3s ease;
}

.auth-modal-overlay.active {
    opacity: 1;
    pointer-events: auto;
}

.auth-modal {
    width: 100%;
    max-width: 440px;
    background: rgba(14, 17, 23, 0.97);
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 12px;
    padding: 2.5rem;
    position: relative;
    transform: translateY(20px) scale(0.96);
    transition: transform 0.3s ease;
}

.auth-modal-overlay.active .auth-modal {
    transform: translateY(0) scale(1);
}

.auth-modal-close {
    position: absolute;
    top: 1rem;
    right: 1rem;
    background: none;
    border: none;
    color: var(--color-text-muted);
    font-size: 1.1rem;
    cursor: pointer;
    transition: color var(--transition-fast);
}

.auth-modal-close:hover {
    color: #fff;
}

.auth-modal-header {
    text-align: center;
    margin-bottom: 1.75rem;
}

.auth-modal-logo {
    height: 36px;
    margin-bottom: 1rem;
}

.auth-modal-header h2 {
    font-family: var(--font-heading);
    font-size: 1.5rem;
    text-transform: uppercase;
    letter-spacing: 2px;
    margin-bottom: 0.5rem;
}

.auth-modal-header p {
    color: var(--color-text-muted);
    font-size: 0.85rem;
}

.auth-form {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.auth-field label {
    display: block;
    font-family: var(--font-heading);
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 1.5px;
    color: var(--color-text-muted);
    margin-bottom: 0.4rem;
}

.auth-field label i {
    margin-right: 0.4rem;
    color: var(--color-primary);
}

.auth-field input {
    width: 100%;
    padding: 0.7rem 1rem;
    background: rgba(255, 255, 255, 0.04);
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 6px;
    color: #fff;
    font-size: 0.9rem;
    transition: border-color var(--transition-fast);
}

.auth-field input:focus {
    outline: none;
    border-color: var(--color-primary);
}

.auth-field input::placeholder {
    color: rgba(255, 255, 255, 0.25);
}

.auth-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.auth-checkbox {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    color: var(--color-text-muted);
    font-size: 0.82rem;
    cursor: pointer;
}

.auth-checkbox input[type="checkbox"] {
    width: 16px;
    height: 16px;
    accent-color: var(--color-primary);
}

.auth-link {
    color: var(--color-primary);
    font-size: 0.82rem;
    transition: color var(--transition-fast);
}

.auth-link:hover {
    color: #ff4a50;
}

.auth-submit {
    width: 100%;
    margin-top: 0.5rem;
    font-size: 0.85rem;
}

.auth-divider {
    display: flex;
    align-items: center;
    gap: 1rem;
    margin: 1.25rem 0;
    color: var(--color-text-muted);
    font-size: 0.78rem;
    text-transform: uppercase;
    letter-spacing: 1px;
}

.auth-divider::before,
.auth-divider::after {
    content: '';
    flex: 1;
    height: 1px;
    background: rgba(255, 255, 255, 0.08);
}

.auth-social {
    display: flex;
    gap: 0.75rem;
}

.auth-social-btn {
    flex: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    padding: 0.6rem;
    border-radius: 6px;
    font-family: var(--font-heading);
    font-size: 0.78rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 1px;
    cursor: pointer;
    transition: all var(--transition-base);
}

.auth-social-btn--discord {
    background: rgba(88, 101, 242, 0.15);
    border: 1px solid rgba(88, 101, 242, 0.3);
    color: #5865f2;
}

.auth-social-btn--discord:hover {
    background: rgba(88, 101, 242, 0.25);
}

.auth-social-btn--steam {
    background: rgba(255, 255, 255, 0.04);
    border: 1px solid rgba(255, 255, 255, 0.12);
    color: #fff;
}

.auth-social-btn--steam:hover {
    background: rgba(255, 255, 255, 0.08);
}

.auth-switch {
    text-align: center;
    margin-top: 1.25rem;
    color: var(--color-text-muted);
    font-size: 0.82rem;
}

.auth-switch a {
    color: var(--color-primary);
    font-weight: 600;
}

.auth-switch a:hover {
    color: #ff4a50;
}

/* ===========================
   FOOTER — K5 · Service Ribbon
   Symmetric center-pivot: Navigate · Logo+Socials · Legal
   =========================== */
.footer {
    border-top: 2px solid #F0A042;
    padding: 3rem 0 0;
    background: #080a0e;
}

.footer-row {
    display: grid;
    grid-template-columns: 1fr auto 1fr;
    gap: 3rem;
    align-items: center;
    padding-bottom: 2.75rem;
}

/* ─── Wings ─── */
.footer-wing {
    display: flex;
    flex-direction: column;
}

.footer-wing--left {
    text-align: right;
    align-items: flex-end;
}

.footer-wing--right {
    text-align: left;
    align-items: flex-start;
}

.footer-heading {
    font-family: var(--font-heading);
    font-size: 1rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 3px;
    color: #fff;
    margin: 0 0 1.25rem;
    padding-bottom: 0.75rem;
    border-bottom: 2px solid #F0A042;
    display: inline-block;
}

.footer-wing ul {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 0.65rem;
}

.footer-wing a {
    color: rgba(255, 255, 255, 0.55);
    font-family: var(--font-body);
    font-size: 0.95rem;
    font-weight: 500;
    letter-spacing: 0.2px;
    text-transform: none;
    transition: color 0.2s ease;
    text-decoration: none;
}

.footer-wing a:hover {
    color: #fff;
    text-decoration: none;
}

/* ─── Center column (ribbon · logo · socials · ribbon) ─── */
.footer-center {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 1rem;
    min-width: 320px;
}

.footer-logo {
    height: 52px;
    width: auto;
    margin: 0;
}

/* Three-rule tapered service ribbon */
.footer-ribbon {
    display: flex;
    flex-direction: column;
    gap: 3px;
    align-items: center;
}

.footer-ribbon span {
    display: block;
    height: 2px;
    background: #F0A042;
}

.footer-ribbon span:nth-child(1) {
    width: 100px;
}

.footer-ribbon span:nth-child(2) {
    width: 70px;
    background: rgba(240, 160, 66, 0.65);
}

.footer-ribbon span:nth-child(3) {
    width: 36px;
    background: rgba(240, 160, 66, 0.35);
}

/* Social icon row */
.footer-socials {
    display: flex;
    gap: 0.65rem;
}

.footer-socials a {
    width: 36px;
    height: 36px;
    border: 1px solid rgba(255, 255, 255, 0.15);
    display: flex;
    align-items: center;
    justify-content: center;
    color: rgba(255, 255, 255, 0.6);
    font-size: 0.95rem;
    transition: all 0.2s ease;
}

.footer-socials a:hover {
    border-color: rgba(240, 160, 66, 0.5);
    color: #F0A042;
    background: rgba(240, 160, 66, 0.08);
}

/* ─── Copyright bar ─── */
.footer-bottom {
    border-top: 1px solid rgba(255, 255, 255, 0.06);
    padding: 1.25rem 0;
    text-align: center;
}

.footer-bottom p {
    font-family: var(--font-mono);
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.18em;
    color: rgba(255, 255, 255, 0.35);
    margin: 0;
}

.main-content {
    padding-top: 0;
}

/* ─── Mobile collapse ─── */
@media (max-width: 860px) {
    .footer-row {
        grid-template-columns: 1fr;
        gap: 2rem;
    }

    .footer-wing--left,
    .footer-wing--right {
        text-align: center;
        align-items: center;
    }
}

/* ===========================
   FOOTER SIZE FIX
   =========================== */
.footer-partner-logos--small {
    height: 45px;
}

/* ===========================
   RED DIVIDER
   =========================== */
.red-divider {
    height: 3px;
    background: linear-gradient(90deg, var(--color-primary) 0%, var(--color-primary-dark) 50%, transparent 100%);
    width: 100%;
    margin: 0;
    padding: 0;
}

/* ===========================
   HERO
   =========================== */
.hero-section {
    position: relative;
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
    background: #000;
}

.hero-slideshow {
    position: absolute;
    inset: 0;
    z-index: 0;
}

.hero-slide {
    position: absolute;
    inset: 0;
    background-size: cover;
    background-position: center;
    opacity: 0;
    transform: scale(1.08);
    transition: opacity 1.5s ease, transform 8s ease;
}

.hero-slide.active {
    opacity: 1;
    transform: scale(1);
    animation: kenBurns 8s ease forwards;
}

@keyframes kenBurns {
    0% {
        transform: scale(1);
    }

    100% {
        transform: scale(1.06);
    }
}

.hero-overlay {
    position: absolute;
    inset: 0;
    z-index: 1;
    background:
        radial-gradient(ellipse at center, rgba(0, 0, 0, 0.1) 0%, rgba(0, 0, 0, 0.75) 100%),
        linear-gradient(to bottom, rgba(0, 0, 0, 0.5) 0%, transparent 25%, transparent 65%, rgba(0, 0, 0, 0.7) 100%);
}

.hero-scanlines {
    position: absolute;
    inset: 0;
    z-index: 2;
    background: repeating-linear-gradient(0deg,
            transparent,
            transparent 2px,
            rgba(0, 0, 0, 0.08) 2px,
            rgba(0, 0, 0, 0.08) 4px);
    pointer-events: none;
}

.hero-content {
    position: relative;
    z-index: 10;
    text-align: center;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 0 24px;
    max-width: 950px;
    width: 100%;
}

.hero-badge {
    font-family: var(--font-heading);
    font-size: 0.85rem;
    letter-spacing: 5px;
    text-transform: uppercase;
    color: rgba(255, 255, 255, 0.6);
    padding: 0.4rem 1.5rem;
    border: 1px solid rgba(255, 255, 255, 0.12);
    background: rgba(0, 0, 0, 0.3);
    backdrop-filter: blur(4px);
    margin-bottom: 1.5rem;
}

.hero-title {
    font-size: clamp(4.15rem, 10vw, 7.38rem);
    font-weight: 700;
    color: #fff;
    text-shadow: 0 4px 40px rgba(0, 0, 0, 0.8), 0 0 120px rgba(240, 160, 66, 0.15);
    margin-bottom: 1rem;
    line-height: 0.95;
    letter-spacing: 6px;
}

.hero-subtitle {
    font-family: var(--font-body);
    font-size: 1.1rem;
    color: rgba(255, 255, 255, 0.65);
    max-width: 580px;
    margin-bottom: 2.5rem;
    text-shadow: 0 2px 10px rgba(0, 0, 0, 0.5);
    font-weight: 300;
    text-transform: none;
    line-height: 1.7;
}

.hero-actions {
    display: flex;
    gap: 1rem;
    align-items: center;
    flex-wrap: wrap;
    justify-content: center;
    margin-bottom: 3rem;
}

.kickstarter-btn {
    display: inline-flex;
    flex-direction: column;
    align-items: center;
    background: var(--color-accent-green);
    color: #fff;
    padding: 0.8rem 2.5rem;
    border-radius: 5px;
    font-family: var(--font-heading);
    font-weight: 700;
    text-transform: uppercase;
    transition: all var(--transition-base);
    box-shadow: 0 6px 25px rgba(5, 206, 120, 0.3);
    text-align: center;
    line-height: 1.2;
}

.kickstarter-btn .ks-top {
    font-size: 0.75rem;
    letter-spacing: 3px;
    font-weight: 500;
}

.kickstarter-btn .ks-bottom {
    font-size: 1.8rem;
    letter-spacing: 2px;
    display: flex;
    align-items: center;
    gap: 0.3rem;
}

.kickstarter-btn .ks-bottom .ks-green {
    color: #000;
}

.kickstarter-btn:hover {
    background: var(--color-accent-green-hover);
    transform: translateY(-3px) scale(1.02);
    box-shadow: 0 10px 35px rgba(5, 206, 120, 0.45);
    color: #fff;
}

/* Stats strip with animated counters */
.hero-stats-strip {
    display: flex;
    align-items: center;
    gap: 2.5rem;
    padding: 1.5rem 3rem;
    background: rgba(10, 10, 15, 0.7);
    border: 1px solid rgba(255, 255, 255, 0.06);
    backdrop-filter: blur(10px);
}

.hero-stat {
    text-align: center;
    display: flex;
    flex-direction: column;
    align-items: center;
}

.hero-stat-num {
    display: inline;
    font-family: var(--font-heading);
    font-size: 2.03rem;
    font-weight: 700;
    color: #fff;
    letter-spacing: 2px;
    line-height: 1;
}

.hero-stat-suffix {
    font-family: var(--font-heading);
    font-size: 2.03rem;
    font-weight: 700;
    color: #fff;
    letter-spacing: 2px;
    line-height: 1;
}

.hero-stat-label {
    font-family: var(--font-heading);
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 3px;
    color: var(--color-text-muted);
    margin-top: 0.25rem;
}

.hero-stat-divider {
    width: 1px;
    height: 40px;
    background: rgba(255, 255, 255, 0.12);
}

/* Slide indicators */
.hero-slide-indicators {
    position: absolute;
    bottom: 5rem;
    left: 50%;
    transform: translateX(-50%);
    z-index: 10;
    display: flex;
    gap: 0.5rem;
}

.slide-dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    border: 1.5px solid rgba(255, 255, 255, 0.4);
    background: transparent;
    cursor: pointer;
    transition: all var(--transition-base);
    padding: 0;
}

.slide-dot.active {
    background: #fff;
    border-color: #fff;
    width: 24px;
    border-radius: 4px;
}

.slide-dot:hover {
    border-color: rgba(255, 255, 255, 0.8);
}

.scroll-indicator {
    position: absolute;
    bottom: 1.5rem;
    left: 50%;
    transform: translateX(-50%);
    z-index: 10;
    color: rgba(255, 255, 255, 0.3);
    font-size: 1.2rem;
    animation: bounceDown 2.5s infinite;
}

@keyframes bounceDown {

    0%,
    100% {
        transform: translateX(-50%) translateY(0);
        opacity: 0.3;
    }

    50% {
        transform: translateX(-50%) translateY(8px);
        opacity: 0.7;
    }
}

/* ===========================
   HERO — Split-Screen Vehicle Showcase
   =========================== */
.hero-split {
    position: relative;
    height: 100vh;
    display: grid;
    grid-template-columns: 1fr 1fr;
    grid-template-rows: 1fr;
    background: #000;
    overflow: hidden;
    padding: 0;
    /* override global section padding */
}

.hero-split-left {
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
    padding: 5rem 4rem 3rem;
    z-index: 2;
    overflow: hidden;
}

.hero-left-bg {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

/* Mobile poster — hidden on desktop, shown on mobile */
.hero-left-poster {
    display: none;
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center 30%;
}

.hero-left-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(135deg,
            rgba(8, 10, 14, 0.92) 0%,
            rgba(10, 12, 18, 0.88) 40%,
            rgba(15, 18, 25, 0.82) 100%);
    z-index: 1;
}

.hero-split-content {
    position: relative;
    z-index: 2;
    max-width: 540px;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
}

.hero-logo {
    height: 60px;
    width: auto;
    margin-bottom: 1.5rem;
    filter: drop-shadow(0 4px 12px rgba(0, 0, 0, 0.4));
}

.hero-accent-line {
    width: 60px;
    height: 3px;
    background: var(--color-primary);
    margin-bottom: 1.5rem;
    border-radius: 2px;
}

.hero-headline {
    font-size: clamp(1.85rem, 3.5vw, 2.95rem);
    font-weight: 700;
    color: #fff;
    line-height: 1.1;
    margin-bottom: 1.25rem;
    text-shadow: 0 2px 20px rgba(0, 0, 0, 0.5);
}

.hero-subtitle {
    color: rgba(255, 255, 255, 0.8);
    font-size: 1.1rem;
    line-height: 1.8;
    margin-bottom: 2rem;
    max-width: 460px;
}

.hero-badge {
    display: inline-flex;
    align-items: center;
    font-family: var(--font-heading);
    font-size: 0.85rem;
    text-transform: uppercase;
    letter-spacing: 3px;
    color: var(--color-accent-green);
    border: 1px solid rgba(5, 206, 120, 0.25);
    padding: 0.5rem 1.2rem;
    border-radius: var(--radius-sm);
    margin-bottom: 2rem;
    background: rgba(5, 206, 120, 0.06);
}

.hero-actions {
    display: flex;
    gap: 1rem;
    flex-wrap: wrap;
}

/* ===========================
   HERO IMPROVEMENTS
   =========================== */

/* Scan-line overlay */
.hero-scanlines {
    position: absolute;
    inset: 0;
    z-index: 3;
    pointer-events: none;
    background: repeating-linear-gradient(0deg,
            transparent,
            transparent 2px,
            rgba(0, 0, 0, 0.06) 2px,
            rgba(0, 0, 0, 0.06) 4px);
    mix-blend-mode: overlay;
}

/* Badge glow pulse */
.hero-badge--glow {
    animation: badgePulse 3s ease-in-out infinite;
}

@keyframes badgePulse {

    0%,
    100% {
        box-shadow: 0 0 8px rgba(240, 160, 66, 0.2), 0 0 20px rgba(240, 160, 66, 0.05);
    }

    50% {
        box-shadow: 0 0 16px rgba(240, 160, 66, 0.4), 0 0 40px rgba(240, 160, 66, 0.12);
    }
}

/* Live player count */
.hero-live-count {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    margin-top: 1.5rem;
    font-family: var(--font-heading);
    font-size: 0.95rem;
    text-transform: uppercase;
    letter-spacing: 1.5px;
    color: rgba(255, 255, 255, 0.75);
}

.hero-live-dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: #22c55e;
    animation: livePulse 2s ease-in-out infinite;
    flex-shrink: 0;
}

@keyframes livePulse {

    0%,
    100% {
        box-shadow: 0 0 4px rgba(34, 197, 94, 0.5);
        opacity: 1;
    }

    50% {
        box-shadow: 0 0 12px rgba(34, 197, 94, 0.8);
        opacity: 0.7;
    }
}

.hero-live-num {
    color: #22c55e;
    font-weight: 600;
}

.hero-live-discord {
    display: inline-flex;
    align-items: center;
    gap: 0.3rem;
    margin-left: 0.5rem;
    padding-left: 0.5rem;
    border-left: 1px solid rgba(255, 255, 255, 0.15);
    color: #7289da;
    font-size: 0.72rem;
    font-weight: 500;
    letter-spacing: 0.5px;
    text-decoration: none;
    transition: color 0.25s ease, border-left-color 0.25s ease, transform 0.25s ease;
}

.hero-live-discord:hover,
.hero-live-discord:focus-visible {
    color: #5865F2;
    border-left-color: rgba(88, 101, 242, 0.5);
    outline: none;
}

.hero-live-discord i {
    transition: transform 0.35s cubic-bezier(0.34, 1.56, 0.64, 1), filter 0.3s ease;
}

.hero-live-discord:hover i,
.hero-live-discord:focus-visible i {
    transform: translateY(-2px) scale(1.18);
    filter: drop-shadow(0 0 6px rgba(88, 101, 242, 0.85));
    animation: heroDiscordWiggle 0.6s ease-in-out;
}

@keyframes heroDiscordWiggle {
    0%   { transform: translateY(0) scale(1) rotate(0deg); }
    25%  { transform: translateY(-2px) scale(1.18) rotate(-8deg); }
    50%  { transform: translateY(-2px) scale(1.18) rotate(8deg); }
    75%  { transform: translateY(-2px) scale(1.18) rotate(-4deg); }
    100% { transform: translateY(-2px) scale(1.18) rotate(0deg); }
}

/* Typewriter cursor */
.hero-headline .typewriter-cursor {
    display: inline-block;
    width: 3px;
    height: 0.9em;
    background: var(--color-primary);
    margin-left: 2px;
    animation: blink 1s step-end infinite;
    vertical-align: baseline;
}

@keyframes blink {

    0%,
    100% {
        opacity: 1;
    }

    50% {
        opacity: 0;
    }
}

/* Hide truncated article summary in hero */
.news-hero-subtitle {
    display: none;
}

/* ═══════════════════════════════════════════════════════
   COMBAT BRIEFING — Interactive Feature Explorer
   ═══════════════════════════════════════════════════════ */
.cb-explorer {
    display: grid;
    grid-template-columns: 280px 1fr;
    gap: 0;
    border: 1px solid rgba(240, 160, 66, 0.15);
    border-radius: 10px;
    overflow: hidden;
    background: rgba(7, 8, 13, 0.6);
    min-height: 440px;
}

.cb-tabs {
    display: flex;
    flex-direction: column;
    background: rgba(0, 0, 0, 0.4);
    border-right: 1px solid rgba(240, 160, 66, 0.1);
}

.cb-tab {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding: 1.1rem 1.25rem;
    background: none;
    border: none;
    border-bottom: 1px solid rgba(255, 255, 255, 0.04);
    cursor: pointer;
    transition: all 0.3s ease;
    position: relative;
    text-align: left;
    flex: 1;
}

.cb-tab::before {
    content: '';
    position: absolute;
    left: 0;
    top: 0;
    bottom: 0;
    width: 3px;
    background: var(--color-primary);
    transform: scaleY(0);
    transition: transform 0.3s ease;
}

.cb-tab:hover { background: rgba(240, 160, 66, 0.05); }
.cb-tab.active { background: rgba(240, 160, 66, 0.08); }
.cb-tab.active::before { transform: scaleY(1); }

.cb-tab-index {
    font-family: var(--font-heading);
    font-size: 0.7rem;
    color: var(--color-primary);
    opacity: 0.5;
    letter-spacing: 1px;
    min-width: 20px;
    transition: opacity 0.3s;
}

.cb-tab.active .cb-tab-index { opacity: 1; }

.cb-tab-label {
    font-family: var(--font-heading);
    font-size: 0.95rem;
    color: rgba(255, 255, 255, 0.5);
    letter-spacing: 1.5px;
    text-transform: uppercase;
    transition: color 0.3s;
    flex: 1;
}

.cb-tab.active .cb-tab-label { color: #f0f0f0; }
.cb-tab:hover .cb-tab-label { color: rgba(255, 255, 255, 0.8); }

.cb-tab-arrow {
    font-size: 0.6rem;
    color: var(--color-primary);
    opacity: 0;
    transform: translateX(-4px);
    transition: all 0.3s ease;
}

.cb-tab.active .cb-tab-arrow { opacity: 1; transform: translateX(0); }

.cb-showcase {
    position: relative;
    overflow: hidden;
    min-height: 440px;
}

.cb-panel {
    position: absolute;
    inset: 0;
    display: flex;
    opacity: 0;
    transform: translateY(12px);
    transition: opacity 0.45s ease, transform 0.45s ease;
    pointer-events: none;
    z-index: 1;
}

.cb-panel.active {
    opacity: 1;
    transform: translateY(0);
    pointer-events: auto;
    z-index: 2;
}

.cb-panel-img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    background-size: cover;
    background-position: center;
    filter: brightness(0.25) saturate(0.6);
}

.cb-panel-content {
    position: relative;
    z-index: 2;
    padding: 2.5rem 2.5rem 2rem;
    display: flex;
    flex-direction: column;
    justify-content: center;
    max-width: 600px;
}

.cb-panel-icon {
    width: 48px;
    height: 48px;
    border-radius: 50%;
    background: rgba(240, 160, 66, 0.15);
    border: 1px solid rgba(240, 160, 66, 0.3);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.1rem;
    color: var(--color-primary);
    margin-bottom: 1.2rem;
}

.cb-panel-title {
    font-family: var(--font-heading);
    font-size: 1.8rem;
    font-weight: 700;
    color: #f0f0f0;
    text-transform: uppercase;
    letter-spacing: 2px;
    margin: 0 0 0.8rem;
}

.cb-panel-desc {
    font-family: var(--font-body);
    font-size: 0.9rem;
    color: rgba(255, 255, 255, 0.6);
    line-height: 1.7;
    margin-bottom: 1.2rem;
}

.cb-panel-points {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.cb-panel-points li {
    font-family: var(--font-body);
    font-size: 0.8rem;
    color: rgba(255, 255, 255, 0.65);
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.cb-panel-points li i { color: #4ade80; font-size: 0.7rem; }

.cb-progress {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    height: 3px;
    background: rgba(255, 255, 255, 0.06);
    z-index: 5;
}

.cb-progress-fill {
    height: 100%;
    background: var(--color-primary);
    width: 0;
    transition: none;
}

.cb-progress-fill.animating { transition: width linear; }

.cb-cta { text-align: center; margin-top: 2rem; }

.cb-cta-btn {
    display: inline-flex;
    align-items: center;
    gap: 0.7rem;
    background: linear-gradient(135deg, var(--color-primary) 0%, #c71a22 100%);
    color: #fff;
    font-family: var(--font-heading);
    font-size: 0.95rem;
    letter-spacing: 2.5px;
    text-transform: uppercase;
    padding: 0.85rem 2.2rem;
    border-radius: 5px;
    text-decoration: none;
    transition: all 0.3s ease;
    box-shadow: 0 4px 20px rgba(240, 160, 66, 0.2);
    position: relative;
    overflow: hidden;
}

.cb-cta-btn::before {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(135deg, rgba(255,255,255,0.1) 0%, transparent 50%);
    opacity: 0;
    transition: opacity 0.3s;
}

.cb-cta-btn:hover { transform: translateY(-2px); box-shadow: 0 6px 30px rgba(240, 160, 66, 0.35); }
.cb-cta-btn:hover::before { opacity: 1; }
.cb-cta-btn i { transition: transform 0.3s; }
.cb-cta-btn:hover i { transform: translateX(4px); }

@media (max-width: 900px) {
    .cb-explorer { grid-template-columns: 1fr; min-height: auto; }
    .cb-tabs {
        display: grid;
        grid-template-columns: repeat(3, 1fr);
        overflow-x: visible;
        border-right: none;
        border-bottom: 1px solid rgba(240, 160, 66, 0.1);
        gap: 0;
        background: rgba(0, 0, 0, 0.4);
    }
    .cb-tab {
        flex: unset;
        padding: 0.65rem 0.5rem;
        border-bottom: 1px solid rgba(255, 255, 255, 0.04);
        border-right: 1px solid rgba(255, 255, 255, 0.04);
        justify-content: center;
        text-align: center;
        gap: 0;
        white-space: nowrap;
    }
    .cb-tab:nth-child(3n) { border-right: none; }
    .cb-tab::before { left: 0; right: 0; top: auto; bottom: 0; width: auto; height: 2px; transform: scaleX(0); }
    .cb-tab.active::before { transform: scaleX(1); }
    .cb-tab-index { display: none; }
    .cb-tab-arrow { display: none; }
    .cb-tab-label { font-size: 0.75rem; letter-spacing: 0.3px; }
    .cb-showcase { min-height: 320px; }
    .cb-panel { flex-direction: column; }
    .cb-panel-img { min-height: 160px; height: 160px; }
    .cb-panel-content { padding: 1.25rem; }
    .cb-panel-title { font-size: 1.2rem; letter-spacing: 1px; }
    .cb-panel-desc { font-size: 0.85rem; line-height: 1.6; }
    .cb-panel-icon { width: 36px; height: 36px; font-size: 0.85rem; margin-bottom: 0.8rem; }
    .cb-panel-points { margin-top: 0.75rem; gap: 0.4rem; }
    .cb-panel-points li { font-size: 0.8rem; }
}

@media (max-width: 480px) {
    .cb-tab { padding: 0.55rem 0.4rem; }
    .cb-tab-label { font-size: 0.68rem; letter-spacing: 0.2px; }
    .cb-showcase { min-height: 300px; }
    .cb-panel-img { min-height: 140px; height: 140px; }
    .cb-panel-content { padding: 1rem; }
    .cb-panel-title { font-size: 1.05rem; letter-spacing: 0.5px; }
    .cb-panel-desc { font-size: 0.78rem; line-height: 1.55; }
    .cb-panel-icon { width: 32px; height: 32px; font-size: 0.8rem; margin-bottom: 0.6rem; }
}

/* ═══════════════════════════════════════════════════════
   COMMANDER'S BRIEFING — Feature Grid
   ═══════════════════════════════════════════════════════ */
.briefing-section {
    padding: 5rem 0;
    background: rgba(255, 255, 255, 0.015);
    border-top: 1px solid rgba(255, 255, 255, 0.04);
    border-bottom: 1px solid rgba(255, 255, 255, 0.04);
}

.briefing-subtitle {
    font-family: var(--font-body);
    font-size: 0.95rem;
    color: rgba(255, 255, 255, 0.4);
    margin-top: 0.6rem;
    letter-spacing: 0.5px;
}

.briefing-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.5rem;
    margin-top: 2.5rem;
}

.briefing-card {
    position: relative;
    background: rgba(255, 255, 255, 0.02);
    border: 1px solid rgba(255, 255, 255, 0.06);
    border-radius: 10px;
    padding: 2rem 1.8rem 2.2rem;
    transition: all 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94);
    overflow: hidden;
}

.briefing-card::before {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(135deg, rgba(240, 160, 66, 0.03) 0%, transparent 60%);
    opacity: 0;
    transition: opacity 0.4s ease;
}

.briefing-card:hover {
    border-color: rgba(240, 160, 66, 0.25);
    background: rgba(255, 255, 255, 0.04);
    transform: translateY(-4px);
    box-shadow: 0 12px 40px rgba(0, 0, 0, 0.3), 0 0 30px rgba(240, 160, 66, 0.06);
}

.briefing-card:hover::before {
    opacity: 1;
}

.briefing-card-number {
    position: absolute;
    top: 1.2rem;
    right: 1.4rem;
    font-family: var(--font-heading);
    font-size: 2.03rem;
    font-weight: 800;
    color: rgba(240, 160, 66, 0.07);
    letter-spacing: 2px;
    line-height: 1;
    transition: color 0.4s ease;
    user-select: none;
}

.briefing-card:hover .briefing-card-number {
    color: rgba(240, 160, 66, 0.15);
}

.briefing-card-icon {
    width: 44px;
    height: 44px;
    border-radius: 10px;
    background: rgba(240, 160, 66, 0.1);
    border: 1px solid rgba(240, 160, 66, 0.2);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1rem;
    color: var(--color-primary);
    margin-bottom: 1.2rem;
    transition: all 0.3s ease;
    position: relative;
    z-index: 1;
}

.briefing-card:hover .briefing-card-icon {
    background: rgba(240, 160, 66, 0.18);
    border-color: rgba(240, 160, 66, 0.35);
    transform: scale(1.05);
}

.briefing-card-title {
    font-family: var(--font-heading);
    font-size: 1.1rem;
    font-weight: 700;
    color: #e8e8e8;
    text-transform: uppercase;
    letter-spacing: 1.5px;
    margin: 0 0 0.8rem;
    position: relative;
    z-index: 1;
}

.briefing-card-desc {
    font-family: var(--font-body);
    font-size: 0.85rem;
    color: rgba(255, 255, 255, 0.45);
    line-height: 1.7;
    margin: 0;
    position: relative;
    z-index: 1;
    transition: color 0.3s ease;
}

.briefing-card:hover .briefing-card-desc {
    color: rgba(255, 255, 255, 0.6);
}

.briefing-card-accent {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    height: 2px;
    background: linear-gradient(90deg, var(--color-primary) 0%, transparent 100%);
    opacity: 0;
    transition: opacity 0.4s ease;
}

.briefing-card:hover .briefing-card-accent {
    opacity: 1;
}

@media (max-width: 900px) {
    .briefing-section { padding: 3rem 0; }
    .briefing-grid {
        grid-template-columns: repeat(2, 1fr);
        gap: 0.8rem;
    }
    .briefing-card { padding: 1.25rem 1.2rem 1.4rem; }
    .briefing-card-icon { width: 36px; height: 36px; font-size: 0.85rem; margin-bottom: 0.8rem; }
    .briefing-card-title { font-size: 0.9rem; letter-spacing: 1px; margin-bottom: 0.5rem; }
    .briefing-card-desc { font-size: 0.78rem; line-height: 1.6; }
    .briefing-card-number { font-size: 1.6rem; top: 0.8rem; right: 1rem; }
}

@media (max-width: 580px) {
    .briefing-grid {
        grid-template-columns: 1fr;
        gap: 0.7rem;
    }
    .briefing-card { padding: 1.1rem 1rem 1.2rem; }
    .briefing-card-number { font-size: 1.5rem; }
    .briefing-card-title { font-size: 0.85rem; }
}

/* ════════════════════════════════════════════════s
   CUSTOM SCROLLBAR (Match Webstore)
════════════════════════════════════════════════s */
::-webkit-scrollbar {
	width: 12px;
	height: 12px;
}
::-webkit-scrollbar-track {
	background: #08080c; /* matches body background roughly */
	border-left: 1px solid rgba(255, 255, 255, 0.05);
}
::-webkit-scrollbar-thumb {
	background: var(--color-primary);
	border: 2px solid #08080c;
    border-radius: 6px;
}
::-webkit-scrollbar-thumb:hover {
	background: var(--color-primary-dark);
}
* {
	scrollbar-width: thin;
	scrollbar-color: var(--color-primary) #08080c;
}

/* ── Language Switcher ── */
.lang-switcher {
    display: inline-flex;
    align-items: center;
    gap: 0.25rem;
    background: rgba(255,255,255,0.04);
    border-radius: 6px;
    padding: 0.15rem;
    margin-left: 0.25rem;
}

.lang-globe {
    font-size: 0.65rem;
    color: rgba(255,255,255,0.35);
    margin: 0 0.2rem 0 0.3rem;
}

.lang-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0.2rem 0.55rem;
    border: none;
    border-radius: 4px;
    background: transparent;
    color: rgba(255,255,255,0.4);
    font-family: var(--font-heading);
    font-size: 0.65rem;
    font-weight: 700;
    letter-spacing: 1px;
    cursor: pointer;
    transition: all 0.2s ease;
    line-height: 1;
}

.lang-btn:hover {
    color: rgba(255,255,255,0.8);
    background: rgba(255,255,255,0.06);
}

.lang-btn.active {
    background: var(--color-primary);
    color: #fff;
    box-shadow: 0 1px 4px rgba(240, 160, 66,0.3);
}

/* Flag-style language buttons (override .lang-btn defaults) */
.lang-btn--flag {
    padding: 0;
    width: 28px;
    height: 19px;
    border-radius: 3px;
    overflow: hidden;
    background: transparent;
    border: 2px solid transparent;
    box-shadow: none;
    opacity: 0.5;
    transition: opacity 0.2s ease, border-color 0.2s ease, transform 0.2s ease, box-shadow 0.2s ease;
}
.lang-btn--flag:hover {
    background: transparent;
    opacity: 0.85;
    transform: scale(1.04);
}
.lang-btn--flag.active {
    background: transparent;
    box-shadow: 0 2px 8px rgba(0,0,0,0.45);
    border-color: rgba(240, 160, 66,0.9);
    opacity: 1;
    transform: scale(1.06);
}
body.bp-zone .lang-btn--flag.active {
    background: transparent;
    border-color: var(--color-primary);
    box-shadow: 0 2px 8px rgba(0,0,0,0.45);
}
.flag-icon {
    width: 100%;
    height: 100%;
    display: block;
    pointer-events: none;
}

/* Mobile language switcher */
.mobile-lang-switcher {
    display: flex;
    align-items: center;
    gap: 0.35rem;
    padding: 1rem 1.5rem;
    border-top: 1px solid rgba(255,255,255,0.06);
    margin-top: 0.5rem;
}

.mobile-lang-switcher .lang-globe {
    font-size: 0.85rem;
    color: rgba(255,255,255,0.3);
    margin-right: 0.35rem;
}

.mobile-lang-switcher .lang-btn {
    flex: 1;
    padding: 0.5rem 0.75rem;
    font-size: 0.75rem;
    border-radius: 6px;
    border: 1px solid rgba(255,255,255,0.06);
    letter-spacing: 1.5px;
}

.mobile-lang-switcher .lang-btn:hover {
    border-color: rgba(255,255,255,0.12);
}

.mobile-lang-switcher .lang-btn.active {
    background: var(--color-primary);
    border-color: var(--color-primary);
    color: #fff;
    box-shadow: 0 2px 8px rgba(240, 160, 66,0.25);
}

.mobile-lang-switcher .lang-btn--flag {
    flex: 0 0 auto;
    width: 56px;
    height: 38px;
    padding: 0;
    border-radius: 5px;
    border: 2px solid rgba(255,255,255,0.08);
    overflow: hidden;
    background: transparent;
    opacity: 0.55;
    box-shadow: none;
}
.mobile-lang-switcher .lang-btn--flag:hover {
    border-color: rgba(255,255,255,0.2);
    opacity: 0.85;
}
.mobile-lang-switcher .lang-btn--flag.active {
    background: transparent;
    border-color: var(--color-primary);
    opacity: 1;
    box-shadow: 0 4px 12px rgba(0,0,0,0.5);
}

/* ===========================
   NEWS — Horizontal scroll
   =========================== */
.news-section {
    padding: 2rem 0 4rem;
    background: var(--color-bg-section);
}

.news-scroll-track {
    display: flex;
    gap: 1.25rem;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    scroll-behavior: smooth;
    padding-bottom: 1rem;
    -ms-overflow-style: none;
    scrollbar-width: thin;
    scrollbar-color: rgba(255, 255, 255, 0.15) transparent;
}

.news-scroll-track::-webkit-scrollbar {
    height: 6px;
}

.news-scroll-track::-webkit-scrollbar-track {
    background: transparent;
}

.news-scroll-track::-webkit-scrollbar-thumb {
    background: rgba(255, 255, 255, 0.15);
    border-radius: 3px;
}

.news-scroll-card {
    flex: 0 0 300px;
    scroll-snap-align: start;
    border-radius: var(--radius-lg);
    overflow: hidden;
    background: var(--color-bg-card);
    transition: transform var(--transition-base), box-shadow var(--transition-base);
}

.news-scroll-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 8px 30px rgba(0, 0, 0, 0.5);
}

.news-scroll-card--featured {
    flex: 0 0 420px;
}

.news-scroll-card a {
    display: block;
    position: relative;
    height: 100%;
    min-height: 320px;
}

.news-scroll-card--featured a {
    min-height: 380px;
}

.news-scroll-img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    position: absolute;
    inset: 0;
    transition: transform var(--transition-slow);
}

.news-scroll-card:hover .news-scroll-img {
    transform: scale(1.04);
}

.news-scroll-overlay {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    padding: 1.5rem;
    background: linear-gradient(transparent 0%, rgba(0, 0, 0, 0.9) 100%);
    z-index: 2;
}

.news-scroll-title {
    font-family: var(--font-heading);
    font-size: 1.15rem;
    color: #fff;
    margin-top: 0.4rem;
    line-height: 1.2;
}

.news-scroll-card--featured .news-scroll-title {
    font-size: 1.5rem;
}

.news-scroll-excerpt {
    color: var(--color-text-muted);
    font-size: 0.85rem;
    margin-top: 0.5rem;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.news-scroll-date {
    font-family: var(--font-heading);
    font-size: 0.75rem;
    color: var(--color-text-muted);
    text-transform: uppercase;
    letter-spacing: 1px;
    display: flex;
    align-items: center;
    gap: 0.4rem;
    margin-top: 0.5rem;
}

.category-badge {
    display: inline-block;
    background: rgba(0, 0, 0, 0.65);
    border: 1px solid rgba(255, 255, 255, 0.12);
    color: rgba(255, 255, 255, 0.9);
    font-family: var(--font-heading);
    padding: 0.15rem 0.6rem;
    font-size: 0.7rem;
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 1px;
}

/* CTA card at end of scroll */
.news-scroll-card--cta {
    flex: 0 0 180px;
    background: var(--color-bg-hover);
    border: 1px dashed rgba(255, 255, 255, 0.15);
    display: flex;
    align-items: center;
    justify-content: center;
}

.news-scroll-card--cta a {
    min-height: auto;
    display: flex;
    align-items: center;
    justify-content: center;
    height: 100%;
}

.news-cta-inner {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.75rem;
    color: var(--color-text-muted);
    font-family: var(--font-heading);
    font-size: 1rem;
    text-transform: uppercase;
    letter-spacing: 2px;
    transition: color var(--transition-fast);
}

.news-cta-inner i {
    font-size: 1.5rem;
    width: 50px;
    height: 50px;
    border-radius: 50%;
    border: 1px solid rgba(255, 255, 255, 0.2);
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all var(--transition-base);
}

.news-scroll-card--cta:hover .news-cta-inner {
    color: #fff;
}

.news-scroll-card--cta:hover .news-cta-inner i {
    border-color: var(--color-primary);
    color: var(--color-primary);
}

/* ===========================
   STATS BRIDGE
   =========================== */
.stats-bridge {
    padding: 2.5rem 0;
    background: rgba(15, 18, 25, 0.95);
    border-top: 1px solid rgba(255, 255, 255, 0.06);
    border-bottom: 1px solid rgba(255, 255, 255, 0.06);
}

.stats-bridge-strip {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 3rem;
}

.stats-bridge-item {
    display: flex;
    align-items: baseline;
    gap: 0.15rem;
    flex-wrap: wrap;
    justify-content: center;
}

.stats-bridge-num {
    font-family: var(--font-heading);
    font-size: 2.31rem;
    font-weight: 700;
    color: #fff;
    line-height: 1;
}

.stats-bridge-suffix {
    font-family: var(--font-heading);
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--color-primary);
}

.stats-bridge-label {
    width: 100%;
    text-align: center;
    font-family: var(--font-heading);
    font-size: 0.7rem;
    text-transform: uppercase;
    letter-spacing: 2.5px;
    color: var(--color-text-muted);
    margin-top: 0.25rem;
}

.stats-bridge-divider {
    width: 1px;
    height: 40px;
    background: rgba(255, 255, 255, 0.1);
}

/* ===========================
   STORE SHOWCASE — Product Carousel
   =========================== */
.store-showcase {
    padding: 3.5rem 0 4rem;
    background: linear-gradient(180deg, rgba(15, 18, 25, 0.95) 0%, var(--color-bg) 100%);
    overflow: hidden;
}

.store-showcase-header {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    margin-bottom: 2rem;
    gap: 1.5rem;
}

.store-showcase-title-group {
    flex: 1;
}

.store-browse-btn {
    flex-shrink: 0;
    white-space: nowrap;
}
.store-browse-btn--disabled {
    opacity: 0.45;
    cursor: not-allowed;
    pointer-events: none;
}

/* === Store coming soon — HUD-style scan overlay === */
.store-coming-soon {
    position: relative;
    isolation: isolate;
    overflow: hidden;
    border-radius: 8px;
}
.store-coming-soon .store-carousel {
    filter: blur(7px) saturate(0.55) brightness(0.85);
    pointer-events: none;
    user-select: none;
    transform: scale(1.02);
}
.store-coming-soon .store-carousel-arrow {
    visibility: hidden;
}
.store-soon-overlay {
    position: absolute;
    inset: 0;
    z-index: 3;
    display: flex;
    align-items: center;
    justify-content: center;
    pointer-events: none;
    overflow: hidden;
    background:
        linear-gradient(180deg, rgba(7,8,13,0.4) 0%, rgba(7,8,13,0.55) 100%);
}
/* Grid pattern overlay (HUD aesthetic), faded toward center */
.store-soon-overlay::before {
    content: '';
    position: absolute;
    inset: 0;
    background:
        repeating-linear-gradient(0deg, transparent 0, transparent 32px, rgba(240, 160, 66,0.07) 32px, rgba(240, 160, 66,0.07) 33px),
        repeating-linear-gradient(90deg, transparent 0, transparent 32px, rgba(240, 160, 66,0.07) 32px, rgba(240, 160, 66,0.07) 33px);
    -webkit-mask-image: radial-gradient(ellipse at center, transparent 28%, rgba(0,0,0,0.85) 70%);
            mask-image: radial-gradient(ellipse at center, transparent 28%, rgba(0,0,0,0.85) 70%);
    pointer-events: none;
}
/* Corner brackets — viewfinder style */
.store-soon-overlay-brackets {
    position: absolute;
    inset: 16px;
    pointer-events: none;
    background:
        linear-gradient(to right, rgba(240, 160, 66,0.55) 22px, transparent 22px) top left / 22px 2px no-repeat,
        linear-gradient(to bottom, rgba(240, 160, 66,0.55) 22px, transparent 22px) top left / 2px 22px no-repeat,
        linear-gradient(to left, rgba(240, 160, 66,0.55) 22px, transparent 22px) top right / 22px 2px no-repeat,
        linear-gradient(to bottom, rgba(240, 160, 66,0.55) 22px, transparent 22px) top right / 2px 22px no-repeat,
        linear-gradient(to right, rgba(240, 160, 66,0.55) 22px, transparent 22px) bottom left / 22px 2px no-repeat,
        linear-gradient(to top, rgba(240, 160, 66,0.55) 22px, transparent 22px) bottom left / 2px 22px no-repeat,
        linear-gradient(to left, rgba(240, 160, 66,0.55) 22px, transparent 22px) bottom right / 22px 2px no-repeat,
        linear-gradient(to top, rgba(240, 160, 66,0.55) 22px, transparent 22px) bottom right / 2px 22px no-repeat;
}
.store-soon-badge {
    pointer-events: auto;
    display: flex;
    align-items: center;
    gap: 1.25rem;
    padding: 1.4rem 1.8rem;
    max-width: 90%;
    background: rgba(12,12,18,0.92);
    border: 1px solid rgba(240, 160, 66,0.45);
    border-top: 2px solid rgba(240, 160, 66,0.9);
    border-radius: 8px;
    backdrop-filter: blur(16px);
    -webkit-backdrop-filter: blur(16px);
    box-shadow: 0 12px 50px rgba(0,0,0,0.6), 0 0 30px rgba(240, 160, 66,0.1);
}
.store-soon-icon {
    width: 56px;
    height: 56px;
    border-radius: 50%;
    background: rgba(240, 160, 66,0.12);
    border: 1px solid rgba(240, 160, 66,0.4);
    display: flex;
    align-items: center;
    justify-content: center;
    color: rgba(240, 160, 66,0.95);
    font-size: 1.4rem;
    flex-shrink: 0;
}
.store-soon-text {
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
}
.store-soon-eyebrow {
    font-family: var(--font-heading);
    font-size: 0.7rem;
    font-weight: 700;
    letter-spacing: 2.5px;
    text-transform: uppercase;
    color: rgba(240, 160, 66,0.95);
}
.store-soon-title {
    font-family: var(--font-heading);
    font-size: 1.2rem;
    font-weight: 700;
    letter-spacing: 1.5px;
    text-transform: uppercase;
    color: #fff;
    margin: 0;
}
.store-soon-sub {
    font-size: 0.82rem;
    color: rgba(255,255,255,0.55);
    margin: 0;
    max-width: 380px;
    line-height: 1.4;
}
@media (max-width: 600px) {
    .store-soon-badge {
        flex-direction: column;
        text-align: center;
        padding: 1.2rem 1.4rem;
    }
    .store-soon-sub { max-width: 100%; }
}

.store-carousel-track {
    display: flex;
    gap: 1.25rem;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    scroll-behavior: smooth;
    -webkit-overflow-scrolling: touch;
    padding-bottom: 0.5rem;
    scrollbar-width: none;
}

.store-carousel-track::-webkit-scrollbar {
    display: none;
}

.store-carousel-arrow {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    z-index: 10;
    width: 42px;
    height: 42px;
    border-radius: 50%;
    border: 1px solid rgba(255, 255, 255, 0.12);
    background: rgba(15, 18, 25, 0.92);
    backdrop-filter: blur(8px);
    color: rgba(255, 255, 255, 0.7);
    font-size: 0.9rem;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.25s ease;
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.4);
}

.store-carousel-arrow:hover {
    background: rgba(240, 160, 66, 0.2);
    border-color: rgba(240, 160, 66, 0.5);
    color: #fff;
    box-shadow: 0 4px 20px rgba(240, 160, 66, 0.25);
}

.store-carousel-arrow--left {
    left: -16px;
}

.store-carousel-arrow--right {
    right: -16px;
}

/* Product Card */
.store-card {
    flex: 0 0 280px;
    scroll-snap-align: start;
    background: var(--color-bg-card);
    border: 1px solid var(--color-bg-border);
    border-radius: 10px;
    overflow: hidden;
    transition: all 0.35s ease;
    text-decoration: none;
    color: inherit;
    display: flex;
    flex-direction: column;
    position: relative;
}

.store-card::before {
    content: '';
    position: absolute;
    inset: 0;
    border-radius: 10px;
    border: 1px solid transparent;
    transition: border-color 0.35s ease;
    pointer-events: none;
    z-index: 2;
}

.store-card:hover {
    transform: translateY(-6px);
    box-shadow: 0 16px 48px rgba(240, 160, 66, 0.15), 0 4px 16px rgba(0, 0, 0, 0.4);
    border-color: rgba(240, 160, 66, 0.35);
}

.store-card:hover::before {
    border-color: rgba(240, 160, 66, 0.2);
}

.store-card-img {
    position: relative;
    height: 160px;
    overflow: hidden;
}

.store-card-img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.5s ease;
}

.store-card:hover .store-card-img img {
    transform: scale(1.08);
}

.store-card-img::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    height: 50%;
    background: linear-gradient(transparent, rgba(21, 27, 35, 0.95));
    pointer-events: none;
}

.store-card-cat {
    position: absolute;
    top: 0.75rem;
    left: 0.75rem;
    z-index: 3;
    padding: 0.3rem 0.65rem;
    background: rgba(240, 160, 66, 0.88);
    backdrop-filter: blur(4px);
    font-family: var(--font-heading);
    font-size: 0.6rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 1.5px;
    color: #fff;
    border-radius: 4px;
}

.store-card-body {
    padding: 1.1rem 1.2rem 1.2rem;
    display: flex;
    flex-direction: column;
    flex: 1;
}

.store-card-name {
    font-family: var(--font-heading);
    font-size: 1rem;
    font-weight: 600;
    color: #fff;
    margin-bottom: 0.4rem;
    line-height: 1.3;
    letter-spacing: 0.5px;
}

.store-card-desc {
    font-size: 0.78rem;
    color: var(--color-text-muted);
    line-height: 1.55;
    margin-bottom: 0.9rem;
    flex: 1;
}

.store-card-footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    border-top: 1px solid rgba(255, 255, 255, 0.06);
    padding-top: 0.8rem;
}

.store-card-price {
    font-family: var(--font-heading);
    font-size: 1.15rem;
    font-weight: 700;
    color: #fff;
    letter-spacing: 0.5px;
}

.store-card-price-period {
    font-size: 0.7rem;
    font-weight: 400;
    color: var(--color-text-muted);
    letter-spacing: 0;
}

.store-card-link {
    font-family: var(--font-heading);
    font-size: 0.7rem;
    text-transform: uppercase;
    letter-spacing: 1.5px;
    color: var(--color-primary);
    display: flex;
    align-items: center;
    gap: 0.4rem;
    transition: gap 0.25s ease;
}

.store-card:hover .store-card-link {
    gap: 0.7rem;
}

/* ===========================
   GAME FEATURES — Contained Card Grid
   =========================== */
.game-features {
    padding: 4rem 0;
    background: var(--color-bg);
}

.features-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1.5rem;
    margin-top: 2rem;
}

.feature-card {
    position: relative;
    border-radius: var(--radius-lg);
    overflow: hidden;
    min-height: 300px;
    display: flex;
    align-items: flex-end;
    transition: transform 0.4s ease, box-shadow 0.4s ease;
    border: 1px solid rgba(255, 255, 255, 0.04);
}

.feature-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.5);
}

.feature-card-bg {
    position: absolute;
    inset: 0;
    background-size: cover;
    background-position: center;
    transition: transform 0.6s ease;
}

.feature-card:hover .feature-card-bg {
    transform: scale(1.06);
}

.feature-card-overlay {
    position: absolute;
    inset: 0;
    z-index: 1;
}

.feature-card-overlay--blue {
    background: linear-gradient(180deg, rgba(10, 20, 50, 0.5) 0%, rgba(10, 20, 50, 0.92) 100%);
}

.feature-card-overlay--green {
    background: linear-gradient(180deg, rgba(15, 35, 20, 0.5) 0%, rgba(15, 35, 20, 0.92) 100%);
}

.feature-card-overlay--gold {
    background: linear-gradient(180deg, rgba(50, 40, 10, 0.5) 0%, rgba(50, 40, 10, 0.92) 100%);
}

.feature-card-overlay--red {
    background: linear-gradient(180deg, rgba(50, 10, 12, 0.5) 0%, rgba(50, 10, 12, 0.92) 100%);
}

.feature-card-content {
    position: relative;
    z-index: 2;
    padding: 2rem;
    width: 100%;
}

.feature-card-icon {
    width: 48px;
    height: 48px;
    border-radius: 50%;
    background: rgba(240, 160, 66, 0.15);
    border: 1px solid rgba(240, 160, 66, 0.35);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.1rem;
    color: var(--color-primary);
    margin-bottom: 0.75rem;
}

.feature-card-title {
    font-size: clamp(1.2rem, 2vw, 1.6rem);
    font-weight: 600;
    letter-spacing: 2px;
    margin-bottom: 0.5rem;
    color: #fff;
}

.feature-card-desc {
    color: rgba(255, 255, 255, 0.7);
    font-size: 0.9rem;
    line-height: 1.7;
    margin-bottom: 0.75rem;
}

.feature-card-bullets {
    display: flex;
    flex-direction: column;
    gap: 0.4rem;
    list-style: none;
}

.feature-card-bullets li {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    color: rgba(255, 255, 255, 0.8);
    font-size: 0.85rem;
}

.feature-card-bullets li i {
    color: var(--color-accent-green);
    font-size: 0.8rem;
    flex-shrink: 0;
}

/* Carousel System (Features + FAQ) */
.features-carousel {
    position: relative;
}

.faq-carousel {
    position: relative;
}

.features-set,
.faq-set {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.6s ease;
}

.features-set.active,
.faq-set.active {
    position: relative;
    opacity: 1;
    pointer-events: auto;
}

.features-set.active .feature-card,
.faq-set.active .faq-card {
    animation: carouselCardIn 0.5s ease forwards;
}

@keyframes carouselCardIn {
    from {
        opacity: 0;
        transform: translateY(16px);
    }

    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.features-set.active .feature-card:nth-child(1),
.faq-set.active .faq-card:nth-child(1) {
    animation-delay: 0s;
}

.features-set.active .feature-card:nth-child(2),
.faq-set.active .faq-card:nth-child(2) {
    animation-delay: 0.08s;
}

.features-set.active .feature-card:nth-child(3),
.faq-set.active .faq-card:nth-child(3) {
    animation-delay: 0.16s;
}

.features-set.active .feature-card:nth-child(4) {
    animation-delay: 0.24s;
}

.carousel-controls {
    display: flex;
    align-items: center;
    gap: 1.25rem;
    margin-top: 1.75rem;
}

.carousel-progress {
    flex: 1;
    height: 3px;
    background: rgba(255, 255, 255, 0.08);
    border-radius: 2px;
    overflow: hidden;
}

.carousel-progress-fill {
    height: 100%;
    width: 0%;
    background: var(--color-primary);
    border-radius: 2px;
    transition: width 0.1s linear;
}

.carousel-dots {
    display: flex;
    gap: 0.4rem;
}

.carousel-dot {
    width: 28px;
    height: 28px;
    border-radius: 50%;
    border: 1px solid rgba(255, 255, 255, 0.15);
    background: transparent;
    color: var(--color-text-muted);
    font-family: var(--font-heading);
    font-size: 0.72rem;
    font-weight: 600;
    cursor: pointer;
    transition: all var(--transition-fast);
    display: flex;
    align-items: center;
    justify-content: center;
}

.carousel-dot.active {
    background: var(--color-primary);
    border-color: var(--color-primary);
    color: #fff;
}

.carousel-dot:hover:not(.active) {
    border-color: rgba(255, 255, 255, 0.4);
    color: #fff;
}

/* Store button in header */
.nav-cta--store {
    background: transparent;
    border: 1px solid rgba(255, 255, 255, 0.2);
    color: #fff;
}

.nav-cta--store:hover {
    background: rgba(255, 255, 255, 0.1);
    border-color: rgba(255, 255, 255, 0.4);
    color: #fff;
}

/* Hero Particles Canvas */
.hero-particles {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    z-index: 2;
    pointer-events: none;
}

/* ===========================
   GAME SHOWCASE — Cinematic features
   =========================== */
.game-showcase {
    padding: 0;
}

.showcase-feature {
    display: grid;
    grid-template-columns: 1fr 1fr;
    min-height: 500px;
}

.showcase-feature--reversed {
    direction: rtl;
}

.showcase-feature--reversed>* {
    direction: ltr;
}

.showcase-img-wrap {
    position: relative;
    overflow: hidden;
}

.showcase-img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.8s ease;
}

.showcase-feature:hover .showcase-img {
    transform: scale(1.03);
}

.showcase-text {
    display: flex;
    flex-direction: column;
    justify-content: center;
    padding: 4rem 5rem;
    background: var(--color-bg-section);
}

.showcase-feature:nth-child(even) .showcase-text {
    background: var(--color-bg);
}

.showcase-text p {
    color: var(--color-text);
    line-height: 1.8;
    margin-bottom: 1.5rem;
    font-size: 0.95rem;
}

.showcase-bullets {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
    margin-bottom: 1.5rem;
}

.showcase-bullets li {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    color: var(--color-text);
    font-size: 0.9rem;
}

.showcase-bullets li i {
    color: var(--color-primary);
    font-size: 0.85rem;
    width: 20px;
    text-align: center;
    flex-shrink: 0;
}

.showcase-dev-credit {
    font-size: 0.85rem !important;
    color: var(--color-text-muted) !important;
    border-top: 1px solid var(--color-bg-border);
    padding-top: 1.5rem;
    margin-top: 0.5rem;
}

.showcase-dev-credit strong {
    color: var(--color-text-bright);
}

/* ===========================
   HEXAGONAL FEATURE GRID
   =========================== */
.hex-features-section {
    padding: 6rem 0;
    background: var(--color-bg);
    position: relative;
    overflow: hidden;
}

.hex-features-section::before {
    content: '';
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 600px;
    height: 600px;
    background: radial-gradient(circle, rgba(240, 160, 66, 0.04) 0%, transparent 70%);
    pointer-events: none;
}

.hex-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 2rem;
    max-width: 900px;
    margin: 0 auto;
    position: relative;
}

.hex-card {
    position: relative;
    background: var(--color-bg-card);
    border: 1px solid var(--color-bg-border);
    border-radius: var(--radius-lg);
    padding: 2.5rem 2rem;
    overflow: hidden;
    transition: all 0.4s ease;
    cursor: default;
}

.hex-card::before {
    content: '';
    position: absolute;
    top: -2px;
    left: -2px;
    right: -2px;
    bottom: -2px;
    background: linear-gradient(135deg, var(--color-primary), transparent 50%);
    border-radius: var(--radius-lg);
    z-index: -1;
    opacity: 0;
    transition: opacity 0.4s ease;
}

.hex-card:hover::before {
    opacity: 0.3;
}

.hex-card:hover {
    transform: translateY(-6px);
    border-color: rgba(240, 160, 66, 0.4);
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.4), 0 0 30px rgba(240, 160, 66, 0.08);
}

.hex-shape {
    display: flex;
    align-items: center;
    gap: 1.25rem;
    margin-bottom: 1.5rem;
}

.hex-icon {
    width: 60px;
    height: 60px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(240, 160, 66, 0.1);
    border: 1px solid rgba(240, 160, 66, 0.25);
    clip-path: polygon(50% 0%, 100% 25%, 100% 75%, 50% 100%, 0% 75%, 0% 25%);
    font-size: 1.3rem;
    color: var(--color-primary);
    flex-shrink: 0;
    transition: all 0.4s ease;
}

.hex-card:hover .hex-icon {
    background: rgba(240, 160, 66, 0.2);
    transform: scale(1.1);
}

.hex-title {
    font-size: 1.3rem;
    font-weight: 600;
    letter-spacing: 1px;
}

.hex-detail {
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.5s ease, opacity 0.4s ease;
    opacity: 0;
}

.hex-card:hover .hex-detail {
    max-height: 300px;
    opacity: 1;
}

.hex-detail p {
    color: var(--color-text);
    font-size: 0.9rem;
    line-height: 1.7;
    margin-bottom: 1rem;
}

.hex-detail ul {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.hex-detail li {
    display: flex;
    align-items: center;
    gap: 0.6rem;
    font-size: 0.85rem;
    color: var(--color-text);
}

.hex-detail li i {
    color: var(--color-accent-green);
    font-size: 0.7rem;
    flex-shrink: 0;
}

/* Red connecting lines between hex cards */
.hex-connector-lines {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 2px;
    height: 60%;
    background: linear-gradient(to bottom, transparent, rgba(240, 160, 66, 0.2), transparent);
    pointer-events: none;
    display: none;
    /* hidden on mobile */
}

/* ===========================
   ANIMATED INFOGRAPHIC TIMELINE
   =========================== */
.infographic-section {
    padding: 6rem 0;
    background: var(--color-bg-section);
    position: relative;
}

.infographic-subtitle {
    color: var(--color-text-muted);
    font-size: 1rem;
    max-width: 500px;
    margin: -1rem auto 0;
}

.infographic-timeline {
    max-width: 900px;
    margin: 3rem auto 0;
    position: relative;
}

.infographic-node {
    display: grid;
    grid-template-columns: 1fr 80px 1fr;
    gap: 0;
    align-items: start;
    margin-bottom: 0;
}

.infographic-node--last {
    margin-bottom: 0;
}

.infographic-icon-wrap {
    display: flex;
    flex-direction: column;
    align-items: center;
    position: relative;
    z-index: 2;
}

.infographic-icon {
    width: 56px;
    height: 56px;
    border-radius: 50%;
    background: var(--color-bg-card);
    border: 2px solid var(--color-primary);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.2rem;
    color: var(--color-primary);
    flex-shrink: 0;
    box-shadow: 0 0 20px rgba(240, 160, 66, 0.15);
    transition: all var(--transition-base);
}

.infographic-node:hover .infographic-icon {
    background: var(--color-primary);
    color: #fff;
    transform: scale(1.1);
    box-shadow: 0 0 30px rgba(240, 160, 66, 0.35);
}

.infographic-icon--accent {
    background: var(--color-primary);
    color: #fff;
    border-color: var(--color-primary);
}

.infographic-line {
    width: 2px;
    height: 100px;
    background: linear-gradient(to bottom, var(--color-primary), rgba(240, 160, 66, 0.1));
    margin-top: 0;
}

.infographic-node--last .infographic-line {
    display: none;
}

.infographic-spacer {
    min-width: 0;
    /* Placeholder for grid layout spacing */
}

.infographic-content {
    background: var(--color-bg-card);
    border: 1px solid var(--color-bg-border);
    border-radius: var(--radius-lg);
    padding: 2rem;
    transition: all var(--transition-base);
    margin-top: 0.5rem;
}

.infographic-content--left {
    text-align: right;
    margin-right: 1rem;
}

.infographic-content--right {
    text-align: left;
    margin-left: 1rem;
}

.infographic-node:hover .infographic-content {
    border-color: rgba(240, 160, 66, 0.3);
    box-shadow: 0 8px 30px rgba(0, 0, 0, 0.3);
    transform: translateY(-3px);
}

.infographic-content h3 {
    font-size: 1.3rem;
    margin-bottom: 0.5rem;
    font-weight: 600;
}

.infographic-content p {
    color: var(--color-text);
    font-size: 0.9rem;
    line-height: 1.7;
    margin-bottom: 1rem;
}

.infographic-checks {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
}

.infographic-content--left .infographic-checks {
    justify-content: flex-end;
}

.infographic-checks span {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    font-family: var(--font-heading);
    font-size: 0.75rem;
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 1px;
    color: var(--color-text-muted);
    padding: 0.3rem 0.75rem;
    background: rgba(240, 160, 66, 0.06);
    border: 1px solid rgba(240, 160, 66, 0.12);
    border-radius: var(--radius-sm);
}

.infographic-checks span i {
    color: var(--color-primary);
    font-size: 0.65rem;
}

/* ===========================
   FAQ — Top 3 as Cards
   =========================== */
.faq-section {
    background: var(--color-bg-section);
    padding: 6rem 0;
}

.faq-cards-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.5rem;
    margin-bottom: 3rem;
}

.faq-card {
    background: var(--color-bg-card);
    border: 1px solid var(--color-bg-border);
    border-radius: var(--radius-lg);
    padding: 2.5rem 2rem;
    transition: all var(--transition-base);
}

.faq-card:hover {
    transform: translateY(-4px);
    border-color: rgba(240, 160, 66, 0.3);
    box-shadow: 0 12px 40px rgba(0, 0, 0, 0.4);
}

.faq-card-icon {
    width: 56px;
    height: 56px;
    border-radius: 50%;
    background: rgba(240, 160, 66, 0.1);
    border: 1px solid rgba(240, 160, 66, 0.2);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.3rem;
    color: var(--color-primary);
    margin-bottom: 1.5rem;
}

.faq-card h3 {
    font-size: 1.3rem;
    margin-bottom: 1rem;
    line-height: 1.2;
}

.faq-card p {
    color: var(--color-text-muted);
    font-size: 0.9rem;
    line-height: 1.7;
}

.faq-more {
    margin-top: 1rem;
}

/* ===========================
   MUSEUMS — Photo Carousel
   =========================== */
.museums-section {
    position: relative;
    padding: 7rem 0;
    overflow: hidden;
}

.museums-bg {
    position: absolute;
    inset: 0;
}

.museums-bg-img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.museums-overlay {
    position: absolute;
    inset: 0;
    background: rgba(10, 10, 14, 0.88);
}

.museums-content {
    position: relative;
    z-index: 2;
}

.museums-text {
    color: var(--color-text);
    font-size: 1rem;
    max-width: 700px;
    line-height: 1.8;
    margin-bottom: 3rem;
}

/* Carousel */
.museum-carousel {
    position: relative;
    overflow: hidden;
    border-radius: var(--radius-lg);
    margin-bottom: 3rem;
}

.museum-carousel-track {
    display: flex;
    gap: 1rem;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    scroll-behavior: smooth;
    -ms-overflow-style: none;
    scrollbar-width: none;
}

.museum-carousel-track::-webkit-scrollbar {
    display: none;
}

.museum-carousel-slide {
    flex: 0 0 340px;
    height: 240px;
    scroll-snap-align: start;
    border-radius: var(--radius-lg);
    overflow: hidden;
    position: relative;
}

.museum-carousel-slide img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform var(--transition-slow);
}

.museum-carousel-slide:hover img {
    transform: scale(1.05);
}

.museum-caption {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    padding: 0.75rem 1rem;
    background: linear-gradient(transparent, rgba(0, 0, 0, 0.85));
    font-family: var(--font-heading);
    font-size: 0.85rem;
    color: #fff;
    text-transform: uppercase;
    letter-spacing: 1.5px;
}

.museum-carousel-btn {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 42px;
    height: 42px;
    border-radius: 50%;
    border: none;
    background: rgba(0, 0, 0, 0.7);
    color: #fff;
    font-size: 1rem;
    cursor: pointer;
    z-index: 5;
    transition: all var(--transition-fast);
    display: flex;
    align-items: center;
    justify-content: center;
}

.museum-carousel-btn:hover {
    background: var(--color-primary);
}

.museum-carousel-btn--prev {
    left: 12px;
}

.museum-carousel-btn--next {
    right: 12px;
}

/* Partner logos */
.museum-partners {
    display: flex;
    align-items: center;
    gap: 2rem;
    flex-wrap: wrap;
}

.museum-partner-logo {
    height: 50px;
    width: auto;
    opacity: 0.85;
    transition: opacity var(--transition-base), filter var(--transition-base);
}

.museum-partner-logo:hover {
    opacity: 1;
}

/* ===========================
   MUSEUMS — Cinematic Split + Partners
   =========================== */
.museums-section {
    padding: 4rem 0;
    overflow: hidden;
}

.museums-split {
    display: grid;
    grid-template-columns: 1fr 1fr;
    min-height: 600px;
}

.museums-visual {
    position: relative;
    overflow: hidden;
}

.museums-hero-img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.8s ease;
}

.museums-section:hover .museums-hero-img {
    transform: scale(1.03);
}

.museums-visual-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(135deg, rgba(0, 0, 0, 0.3) 0%, rgba(0, 0, 0, 0.1) 50%, rgba(0, 0, 0, 0.4) 100%);
}

.museums-visual-badge {
    position: absolute;
    bottom: 1.5rem;
    left: 1.5rem;
    padding: 0.6rem 1.2rem;
    background: rgba(0, 0, 0, 0.75);
    backdrop-filter: blur(8px);
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: var(--radius-base);
    font-family: var(--font-heading);
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 2px;
    color: rgba(255, 255, 255, 0.85);
    display: flex;
    align-items: center;
    gap: 0.6rem;
}

.museums-visual-badge i {
    color: var(--color-primary);
}

.museums-info {
    background: var(--color-bg-section);
    padding: 4rem 3rem;
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.museums-desc {
    color: var(--color-text);
    font-size: 0.95rem;
    line-height: 1.8;
    margin-bottom: 2rem;
    max-width: 500px;
}

.museums-events {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
    margin-bottom: 2rem;
}

.museum-event-card {
    display: flex;
    align-items: center;
    gap: 1rem;
    padding: 0.75rem;
    background: var(--color-bg-card);
    border: 1px solid var(--color-bg-border);
    border-radius: var(--radius-base);
    transition: all var(--transition-base);
}

.museum-event-card:hover {
    border-color: rgba(240, 160, 66, 0.3);
    transform: translateX(4px);
}

.museum-event-img {
    width: 70px;
    height: 50px;
    object-fit: cover;
    border-radius: var(--radius-sm);
    flex-shrink: 0;
}

.museum-event-text h4 {
    font-size: 0.95rem;
    font-weight: 600;
    margin-bottom: 0.15rem;
}

.museum-event-text p {
    font-size: 0.8rem;
    color: var(--color-text-muted);
}

.museums-partners-row {
    border-top: 1px solid var(--color-bg-border);
    padding-top: 1.5rem;
}

.museums-partners-label {
    font-family: var(--font-heading);
    font-size: 0.7rem;
    text-transform: uppercase;
    letter-spacing: 2px;
    color: var(--color-text-muted);
    display: block;
    margin-bottom: 0.75rem;
}

/* Mobile: centre the Official Partners block + the Explore Museum Partners button */
@media (max-width: 768px) {
    .museums-partners-row {
        text-align: center;
    }
    .museum-partners {
        justify-content: center;
    }
    .museums-partners-row + div {
        text-align: center;
    }
}

/* ===========================
   SUPPORT — Tier Pricing Cards
   =========================== */
.support-section {
    padding: 6rem 0;
    background: var(--color-bg);
}

.support-subtitle {
    color: var(--color-text-muted);
    font-size: 1rem;
    max-width: 560px;
    margin: -1rem auto 0;
    line-height: 1.7;
}

.tier-cards {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.5rem;
    margin-top: 3rem;
    align-items: stretch;
}

.tier-card {
    background: var(--color-bg-card);
    border: 1px solid var(--color-bg-border);
    border-radius: var(--radius-lg);
    padding: 2.5rem 2rem;
    display: flex;
    flex-direction: column;
    transition: all var(--transition-base);
    position: relative;
}

.tier-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 12px 40px rgba(0, 0, 0, 0.4);
}

.tier-card--featured {
    border-color: var(--color-primary);
    box-shadow: 0 0 30px rgba(240, 160, 66, 0.1);
    transform: scale(1.03);
}

.tier-card--featured:hover {
    transform: scale(1.03) translateY(-4px);
}

.tier-badge {
    position: absolute;
    top: -12px;
    left: 50%;
    transform: translateX(-50%);
    background: var(--color-primary);
    color: #fff;
    font-family: var(--font-heading);
    font-size: 0.75rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 2px;
    padding: 0.25rem 1rem;
    border-radius: var(--radius-sm);
    white-space: nowrap;
}

.tier-header {
    text-align: center;
    margin-bottom: 2rem;
    padding-bottom: 2rem;
    border-bottom: 1px solid var(--color-bg-border);
}

.tier-rank {
    font-family: var(--font-heading);
    font-size: 0.8rem;
    text-transform: uppercase;
    letter-spacing: 3px;
    color: var(--color-primary);
}

.tier-name {
    font-size: 1.48rem;
    margin: 0.25rem 0 0.75rem;
}

.tier-price {
    font-family: var(--font-heading);
    font-size: 2.31rem;
    font-weight: 700;
    color: var(--color-text-bright);
    line-height: 1;
}

.tier-price span {
    font-size: 0.9rem;
    font-weight: 400;
    color: var(--color-text-muted);
    letter-spacing: 1px;
}

.tier-rewards {
    flex-grow: 1;
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
    margin-bottom: 2rem;
}

.tier-rewards li {
    display: flex;
    align-items: center;
    gap: 0.6rem;
    font-size: 0.9rem;
    color: var(--color-text);
}

.tier-rewards li i {
    color: var(--color-accent-green);
    font-size: 0.75rem;
    flex-shrink: 0;
}

.tier-cta {
    width: 100%;
    text-align: center;
    justify-content: center;
}

/* ===========================
   TECH PARTNERS — homepage trust strip
   =========================== */
.partners-section {
    padding: 4.5rem 0 5rem;
    background: #07080d;
    border-top: 1px solid rgba(255, 255, 255, 0.04);
    border-bottom: 1px solid rgba(255, 255, 255, 0.04);
    text-align: center;
    position: relative;
}
.partners-section::before {
    content: '';
    position: absolute;
    top: -1px;
    left: 50%;
    transform: translateX(-50%);
    width: 80px;
    height: 2px;
    background: var(--color-primary);
    opacity: 0.6;
}
.partners-container {
    max-width: 1100px;
    margin: 0 auto;
    padding: 0 1.5rem;
}
.partners-title {
    font-family: var(--font-heading);
    font-size: clamp(1.6rem, 3.4vw, 2.4rem);
    font-weight: 700;
    color: #fff;
    text-transform: uppercase;
    letter-spacing: 2px;
    margin: 0.7rem 0 0.7rem;
    line-height: 1.15;
}
.partners-sub {
    color: rgba(255, 255, 255, 0.45);
    font-size: 0.95rem;
    line-height: 1.6;
    max-width: 580px;
    margin: 0 auto 2.8rem;
}
.partners-grid {
    display: flex;
    justify-content: center;
    align-items: center;
    flex-wrap: wrap;
    gap: 3.5rem;
    padding: 1rem 0;
}
.partner-logo {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    height: 56px;
    text-decoration: none;
    transition: transform 0.32s cubic-bezier(0.34, 1.5, 0.64, 1);
}
.partner-logo:hover {
    transform: scale(1.18);
}
.partner-logo img {
    max-height: 100%;
    max-width: 200px;
    width: auto;
    height: auto;
    object-fit: contain;
    opacity: 0.85;
    transition: opacity 0.3s ease;
}
.partner-logo:hover img {
    opacity: 1;
}
/* Image-swap variant: cross-fade default ↔ hover */
.partner-logo--swap .partner-logo-hover {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.3s ease;
}
.partner-logo--swap:hover .partner-logo-default {
    opacity: 0;
}
.partner-logo--swap:hover .partner-logo-hover {
    opacity: 1;
}
/* ODIN: its SVG fills its viewBox more densely than Nakama / Hibiki, so
   at the same height it reads ~25% bigger. Scale it down to match. */
.partner-logo--odin img {
    max-height: 78%;
    max-width: 150px;
}
/* Hibiki: white silhouette, no hover effect — same fade-in opacity
   treatment as the other logos via .partner-logo:hover img. */
.partner-logo--hibiki .hibiki-silhouette {
    height: 100%;
    width: auto;
    max-width: none;
    filter: brightness(0) invert(1);
    opacity: 0.85;
}
.partner-logo--hibiki:hover .hibiki-silhouette {
    opacity: 1;
}
@media (max-width: 600px) {
    .partners-section { padding: 3rem 0 3.5rem; }
    .partners-grid { gap: 2.2rem; }
    .partner-logo { height: 42px; }
    .partner-logo img { max-width: 150px; }
}

/* ===========================
   JOIN CTA — Discord + Email signup strip above the footer
   =========================== */
.join-cta {
    position: relative;
    padding: clamp(3rem, 7vh, 5.5rem) 0 clamp(3rem, 7vh, 5.5rem);
    background:
        radial-gradient(ellipse at 20% 30%, rgba(240, 160, 66, 0.08), transparent 50%),
        radial-gradient(ellipse at 80% 70%, rgba(240, 160, 66, 0.06), transparent 55%),
        #08080c;
    border-top: 1px solid rgba(255, 255, 255, 0.04);
    border-bottom: 1px solid rgba(255, 255, 255, 0.04);
    text-align: center;
    overflow: hidden;
}
.join-cta::before {
    content: '';
    position: absolute;
    top: -1px;
    left: 50%;
    transform: translateX(-50%);
    width: 80px;
    height: 2px;
    background: var(--color-primary);
    opacity: 0.7;
}
.join-cta-inner {
    max-width: 880px;
    margin: 0 auto;
    padding: 0 1.5rem;
    position: relative;
    z-index: 1;
}

.join-cta-eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 0.55rem;
    font-family: 'Courier New', Consolas, monospace;
    font-size: 0.72rem;
    letter-spacing: 3px;
    text-transform: uppercase;
    color: rgba(255, 255, 255, 0.65);
    margin-bottom: 1.1rem;
    padding: 0.4rem 0.9rem;
    border: 1px solid rgba(255, 255, 255, 0.1);
    background: rgba(255, 255, 255, 0.03);
    border-radius: 2px;
}
.join-cta-dot {
    width: 7px;
    height: 7px;
    border-radius: 50%;
    background: #22c55e;
    box-shadow: 0 0 6px rgba(34, 197, 94, 0.6);
    animation: joinCtaPulse 2s ease-in-out infinite;
}
@keyframes joinCtaPulse {
    0%, 100% { opacity: 1; }
    50%      { opacity: 0.55; }
}

.join-cta-title {
    font-family: var(--font-heading);
    font-size: clamp(1.7rem, 4.4vw, 2.6rem);
    font-weight: 700;
    color: #fff;
    text-transform: uppercase;
    letter-spacing: 2px;
    margin: 0 0 0.7rem;
    line-height: 1.15;
}
.join-cta-title .text-primary {
    color: var(--color-primary);
}
.join-cta-sub {
    color: rgba(255, 255, 255, 0.55);
    font-size: clamp(0.95rem, 1.4vw, 1.05rem);
    line-height: 1.6;
    max-width: 560px;
    margin: 0 auto 2.25rem;
}

/* Action row */
.join-cta-actions {
    display: flex;
    gap: 0.85rem;
    justify-content: center;
    flex-wrap: wrap;
}

.join-cta-btn {
    display: inline-flex;
    align-items: center;
    gap: 0.85rem;
    padding: 0.95rem 1.6rem;
    text-decoration: none;
    border-radius: 4px;
    transition: transform 0.25s ease, background 0.25s ease, border-color 0.25s ease, box-shadow 0.25s ease;
    min-width: 270px;
    text-align: left;
}
.join-cta-btn i {
    font-size: 1.6rem;
    flex-shrink: 0;
    transition: transform 0.25s ease;
}
.join-cta-btn:hover {
    transform: translateY(-2px);
}
.join-cta-btn:hover i {
    transform: scale(1.1);
}
.join-cta-btn-label {
    display: flex;
    flex-direction: column;
    gap: 0.18rem;
    line-height: 1.1;
}
.join-cta-btn-line1 {
    font-family: var(--font-heading);
    font-size: 0.95rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 1.5px;
}
.join-cta-btn-line2 {
    font-size: 0.75rem;
    letter-spacing: 0.4px;
    opacity: 1;
    color: rgba(255, 255, 255, 0.92);
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    font-weight: 500;
}

/* Highlight the live online count number itself in bright green so the
   eye snaps to it. Sits on the red Discord button for contrast. */
.join-cta-btn--primary #joinDiscordCount {
    color: #4ade80;
    font-weight: 700;
    font-variant-numeric: tabular-nums;
    text-shadow: 0 0 8px rgba(74, 222, 128, 0.45);
}

/* Discord — primary accent */
.join-cta-btn--primary {
    background: var(--color-primary);
    color: #fff;
    border: 1px solid var(--color-primary);
    box-shadow: 0 8px 24px rgba(240, 160, 66, 0.25);
}
.join-cta-btn--primary:hover {
    background: var(--color-primary-dark);
    border-color: var(--color-primary-dark);
    box-shadow: 0 10px 30px rgba(240, 160, 66, 0.35);
}
.join-cta-btn--primary i {
    color: #fff;
}

/* Email — ghost button */
.join-cta-btn--ghost {
    background: rgba(255, 255, 255, 0.04);
    color: rgba(255, 255, 255, 0.9);
    border: 1px solid rgba(255, 255, 255, 0.18);
}
.join-cta-btn--ghost:hover {
    background: rgba(255, 255, 255, 0.08);
    border-color: rgba(255, 255, 255, 0.4);
    color: #fff;
}
.join-cta-btn--ghost i {
    color: rgba(255, 255, 255, 0.7);
}

/* Live online dot in the Discord button — visibly "ON-AIR" feeling.
   Bigger core, brighter green, soft outer halo, and a subtle expanding
   ring pulse so the eye picks it up from the side. */
.join-cta-livedot {
    position: relative;
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background: #4ade80;
    box-shadow:
        0 0 0 2px rgba(74, 222, 128, 0.22),
        0 0 12px rgba(74, 222, 128, 0.9);
    animation: joinCtaPulse 1.6s ease-in-out infinite;
    flex-shrink: 0;
}
.join-cta-livedot::before {
    content: '';
    position: absolute;
    inset: -3px;
    border-radius: 50%;
    border: 1.5px solid rgba(74, 222, 128, 0.55);
    animation: joinCtaLiveRing 1.6s ease-out infinite;
    pointer-events: none;
}
@keyframes joinCtaLiveRing {
    0%   { transform: scale(0.6); opacity: 1; }
    100% { transform: scale(2.0); opacity: 0; }
}

/* bp-zone (blueprint blue) overrides */
body.bp-zone .join-cta-btn--primary {
    background: var(--color-primary);
    border-color: var(--color-primary);
    box-shadow: 0 8px 24px rgba(74, 127, 255, 0.3);
}
body.bp-zone .join-cta-btn--primary:hover {
    background: var(--color-primary-dark);
    border-color: var(--color-primary-dark);
    box-shadow: 0 10px 30px rgba(74, 127, 255, 0.4);
}

@media (max-width: 600px) {
    .join-cta-btn {
        min-width: 0;
        width: 100%;
        max-width: 320px;
        justify-content: center;
    }
    .join-cta-actions {
        flex-direction: column;
        align-items: center;
    }
}

/* ===========================
   KICKSTARTER POP-UP MODAL
   =========================== */
.ks-modal-overlay {
    position: fixed;
    inset: 0;
    z-index: 9999;
    background: rgba(0, 0, 0, 0.85);
    backdrop-filter: blur(8px);
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.5s ease;
    padding: 2rem;
}

.ks-modal-overlay.active {
    opacity: 1;
    pointer-events: all;
}

.ks-modal {
    width: 100%;
    max-width: 560px;
    background: var(--color-bg-card);
    border: 1px solid var(--color-bg-border);
    border-radius: 12px;
    overflow: hidden;
    position: relative;
    transform: translateY(30px) scale(0.95);
    transition: transform 0.5s ease;
    box-shadow: 0 40px 100px rgba(0, 0, 0, 0.6);
}

.ks-modal-overlay.active .ks-modal {
    transform: translateY(0) scale(1);
}

.ks-modal-close {
    position: absolute;
    top: 1rem;
    right: 1rem;
    z-index: 10;
    width: 36px;
    height: 36px;
    border-radius: 50%;
    border: none;
    background: rgba(0, 0, 0, 0.6);
    color: #fff;
    font-size: 0.9rem;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all var(--transition-fast);
}

.ks-modal-close:hover {
    background: var(--color-primary);
}

.ks-modal-visual {
    position: relative;
    height: 200px;
    overflow: hidden;
}

.ks-modal-img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.ks-modal-visual-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(transparent 30%, rgba(21, 27, 35, 1) 100%);
}

.ks-modal-visual-content {
    position: absolute;
    bottom: 1rem;
    left: 50%;
    transform: translateX(-50%);
}

.ks-modal-logo {
    height: 32px;
    width: auto;
    opacity: 0.7;
}

.ks-modal-body {
    padding: 1.5rem 2rem 2rem;
    text-align: center;
}

.ks-modal-tag {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    font-family: var(--font-heading);
    font-size: 0.8rem;
    text-transform: uppercase;
    letter-spacing: 2px;
    color: var(--color-accent-green);
    margin-bottom: 1rem;
}

.ks-modal-tag i {
    font-size: 0.9rem;
}

.ks-modal-title {
    font-size: 1.8rem;
    margin-bottom: 0.75rem;
    line-height: 1.1;
}

.ks-modal-desc {
    color: var(--color-text-muted);
    font-size: 0.9rem;
    line-height: 1.7;
    margin-bottom: 1.5rem;
}

.ks-modal-progress {
    margin-bottom: 1.5rem;
}

.ks-modal-progress-bar {
    height: 8px;
    background: rgba(255, 255, 255, 0.08);
    border-radius: 4px;
    overflow: hidden;
    margin-bottom: 0.5rem;
}

.ks-modal-progress-fill {
    height: 100%;
    background: linear-gradient(90deg, var(--color-accent-green), #04b067);
    border-radius: 4px;
    transition: width 1.5s ease;
    position: relative;
}

.ks-modal-progress-fill::after {
    content: '';
    position: absolute;
    right: 0;
    top: 0;
    bottom: 0;
    width: 20px;
    background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.3));
    animation: progressShine 2s infinite;
}

@keyframes progressShine {

    0%,
    100% {
        opacity: 0;
    }

    50% {
        opacity: 1;
    }
}

.ks-modal-progress-stats {
    display: flex;
    justify-content: space-between;
    font-family: var(--font-heading);
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 1.5px;
    color: var(--color-text-muted);
}

.ks-modal-cta {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.6rem;
    width: 100%;
    padding: 0.85rem 2rem;
    background: var(--color-accent-green);
    color: #fff;
    font-family: var(--font-heading);
    font-size: 1.05rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 2px;
    border-radius: var(--radius-base);
    transition: all var(--transition-base);
    box-shadow: 0 6px 25px rgba(5, 206, 120, 0.3);
}

.ks-modal-cta:hover {
    background: var(--color-accent-green-hover);
    transform: translateY(-2px);
    box-shadow: 0 10px 35px rgba(5, 206, 120, 0.45);
    color: #fff;
}

.ks-modal-dismiss {
    display: block;
    margin: 1rem auto 0;
    background: none;
    border: none;
    color: var(--color-text-muted);
    font-family: var(--font-body);
    font-size: 0.85rem;
    cursor: pointer;
    transition: color var(--transition-fast);
    padding: 0.5rem;
}

.ks-modal-dismiss:hover {
    color: #fff;
}

/* ===========================
   VEHICLE CAROUSEL + TECH CARD
   =========================== */
/* ═══ Animated Tank Marquee Background ═══ */
.tank-marquee-bg {
    position: absolute;
    inset: 0;
    z-index: 0;
    pointer-events: none;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    overflow: hidden;
    opacity: 0.08;
}
.tank-row {
    display: flex;
    overflow: hidden;
    flex-shrink: 0;
}
.tank-row-inner {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    flex-shrink: 0;
    will-change: transform;
    animation-timing-function: linear;
    animation-iteration-count: infinite;
}
.tank-row-inner img {
    width: 90px;
    height: auto;
    flex-shrink: 0;
    filter: grayscale(1) brightness(2);
    user-select: none;
}

@keyframes tank-scroll-ltr {
    0%   { transform: translateX(0); }
    100% { transform: translateX(-50%); }
}
@keyframes tank-scroll-rtl {
    0%   { transform: translateX(-50%); }
    100% { transform: translateX(0); }
}

/* Ensure garage content sits above the tank bg */
.garage-explorer {
    position: relative;
    z-index: 1;
}

.hero-split-right {
    position: relative;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    background: radial-gradient(ellipse at center, #1a1e26 0%, #0a0a0e 100%);
    overflow: hidden;
    padding: 1.5rem 1rem;
    gap: 0;
}

.veh-carousel {
    position: relative;
    width: 100%;
    flex: 1;
    min-height: 0;
    max-height: 55vh;
}

.veh-slide {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    transform: scale(0.95);
    transition: opacity 0.6s ease, transform 0.6s ease;
    pointer-events: none;
}

.veh-slide.active {
    opacity: 1;
    transform: scale(1);
    pointer-events: all;
}

.veh-slide-img {
    max-width: 85%;
    max-height: 85%;
    object-fit: contain;
    filter: drop-shadow(0 15px 40px rgba(0, 0, 0, 0.6));
}

.model-360-container {
    position: relative;
    width: 100%;
    height: 100%;
    cursor: grab;
    user-select: none;
    display: flex;
    align-items: center;
    justify-content: center;
}

.model-360-container:active {
    cursor: grabbing;
}

#marderCanvas {
    width: 100%;
    height: 100%;
    object-fit: contain;
    display: block;
}

/* ===========================
   VTC — Military Dossier Stat Card
   =========================== */
.veh-tech-card {
    position: relative;
    width: 100%;
    background: linear-gradient(135deg, rgba(6, 8, 13, 0.97) 0%, rgba(10, 13, 20, 0.95) 100%);
    border: 1px solid rgba(240, 160, 66, 0.2);
    border-left: 3px solid var(--color-primary);
    border-radius: 4px 6px 6px 4px;
    padding: 0.65rem 1rem 0.6rem;
    flex-shrink: 0;
    backdrop-filter: blur(12px);
    box-shadow: 0 4px 30px rgba(0, 0, 0, 0.6), inset 0 0 60px rgba(240, 160, 66, 0.02);
    overflow: hidden;
}

/* Scanline overlay */
.veh-tech-card::before {
    content: '';
    position: absolute;
    inset: 0;
    background: repeating-linear-gradient(0deg,
            transparent,
            transparent 2px,
            rgba(255, 255, 255, 0.012) 2px,
            rgba(255, 255, 255, 0.012) 4px);
    pointer-events: none;
    z-index: 0;
}

/* Corner brackets */
.vtc-corner {
    position: absolute;
    width: 10px;
    height: 10px;
    border-color: rgba(240, 160, 66, 0.5);
    border-style: solid;
    z-index: 2;
}

.vtc-corner--tl {
    top: 4px;
    left: 6px;
    border-width: 1.5px 0 0 1.5px;
}

.vtc-corner--tr {
    top: 4px;
    right: 6px;
    border-width: 1.5px 1.5px 0 0;
}

.vtc-corner--bl {
    bottom: 4px;
    left: 6px;
    border-width: 0 0 1.5px 1.5px;
}

.vtc-corner--br {
    bottom: 4px;
    right: 6px;
    border-width: 0 1.5px 1.5px 0;
}

/* ── Header ── */
.vtc-header {
    position: relative;
    z-index: 1;
    display: flex;
    align-items: center;
    gap: 0.6rem;
    margin-bottom: 0.35rem;
}

.vtc-flag {
    width: 44px;
    height: 30px;
    border-radius: 2px;
    overflow: hidden;
    flex-shrink: 0;
    background-size: 100% 100%, 43% 54%;
    background-repeat: no-repeat;
    background-position: 0 0, 0 0;
    box-shadow: 0 1px 4px rgba(0, 0, 0, 0.5);
}

.vtc-identity {
    flex: 1;
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 0.2rem;
}

.vtc-name {
    font-family: var(--font-heading);
    font-size: 1.25rem;
    font-weight: 700;
    color: #fff;
    text-transform: uppercase;
    letter-spacing: 2.5px;
    line-height: 1;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.vtc-meta {
    display: flex;
    align-items: center;
    gap: 0.4rem;
}

.vtc-class-badge {
    font-family: var(--font-heading);
    font-size: 0.78rem;
    text-transform: uppercase;
    letter-spacing: 1.5px;
    color: rgba(255, 255, 255, 0.55);
    background: rgba(255, 255, 255, 0.05);
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 2px;
    padding: 0.1rem 0.4rem;
}

.vtc-rank-badge {
    font-family: var(--font-heading);
    font-size: 0.78rem;
    text-transform: uppercase;
    letter-spacing: 1.5px;
    color: var(--color-primary);
    background: rgba(240, 160, 66, 0.08);
    border: 1px solid rgba(240, 160, 66, 0.25);
    border-radius: 2px;
    padding: 0.1rem 0.4rem;
}

.vtc-br-wrap {
    display: flex;
    flex-direction: column;
    align-items: center;
    flex-shrink: 0;
    background: rgba(240, 160, 66, 0.08);
    border: 1px solid rgba(240, 160, 66, 0.3);
    border-radius: 4px;
    padding: 0.2rem 0.55rem;
}

.vtc-br-label {
    font-family: var(--font-heading);
    font-size: 0.65rem;
    text-transform: uppercase;
    letter-spacing: 2px;
    color: var(--color-primary);
    opacity: 0.7;
    line-height: 1;
}

.vtc-br-val {
    font-family: var(--font-heading);
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--color-primary);
    line-height: 1;
}

/* ── Classification strip ── */
.vtc-strip {
    position: relative;
    z-index: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.6rem;
    font-family: var(--font-heading);
    font-size: 0.72rem;
    letter-spacing: 3px;
    text-transform: uppercase;
    color: rgba(240, 160, 66, 0.6);
    background: rgba(240, 160, 66, 0.06);
    border-top: 1px solid rgba(240, 160, 66, 0.1);
    border-bottom: 1px solid rgba(240, 160, 66, 0.1);
    padding: 0.15rem 0;
    margin-bottom: 0.4rem;
}

.vtc-strip i {
    font-size: 0.5rem;
    opacity: 0.7;
}

/* ── Stat Groups ── */
.vtc-groups {
    position: relative;
    z-index: 1;
    display: flex;
    flex-direction: column;
    gap: 0;
    margin-bottom: 0.4rem;
}

.vtc-group {
    padding: 0.18rem 0;
}

.vtc-group-label {
    font-family: var(--font-heading);
    font-size: 0.6rem;
    text-transform: uppercase;
    letter-spacing: 2px;
    color: rgba(255, 255, 255, 0.35);
    margin-bottom: 0.15rem;
    display: flex;
    align-items: center;
    gap: 0.35rem;
}

.vtc-group-label i {
    color: var(--color-primary);
    opacity: 0.7;
    font-size: 0.55rem;
}

.vtc-group-rows {
    display: flex;
    flex-direction: column;
    gap: 0.2rem;
}

.vtc-row {
    display: flex;
    align-items: baseline;
    gap: 0.3rem;
    font-family: var(--font-heading);
}

.vtc-key {
    font-size: 0.6rem;
    text-transform: uppercase;
    letter-spacing: 1px;
    color: rgba(255, 255, 255, 0.35);
    white-space: nowrap;
    flex-shrink: 0;
}

.vtc-key--ml {
    margin-left: 0.5rem;
}

.vtc-val {
    font-size: 0.82rem;
    font-weight: 600;
    color: #e8e8e8;
    letter-spacing: 0.5px;
    white-space: nowrap;
    flex-shrink: 0;
}

.vtc-val--accent {
    color: var(--color-primary);
}

.vtc-sep {
    height: 1px;
    background: linear-gradient(90deg, rgba(240, 160, 66, 0.15), transparent);
    margin: 0.1rem 0;
}

/* ── Stat Bars ── */
.vtc-bars {
    position: relative;
    z-index: 1;
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
    margin-bottom: 0.4rem;
    padding: 0.35rem 0.6rem;
    background: rgba(0, 0, 0, 0.25);
    border-radius: 3px;
    border: 1px solid rgba(255, 255, 255, 0.04);
}

.vtc-bar-row {
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.vtc-bar-label {
    font-family: var(--font-heading);
    font-size: 0.58rem;
    text-transform: uppercase;
    letter-spacing: 1px;
    color: rgba(255, 255, 255, 0.4);
    width: 52px;
    flex-shrink: 0;
}

.vtc-bar-track {
    flex: 1;
    height: 5px;
    background: rgba(255, 255, 255, 0.06);
    border-radius: 3px;
    overflow: hidden;
}

.vtc-bar-fill {
    height: 100%;
    border-radius: 3px;
    transition: width 0.9s cubic-bezier(0.25, 1, 0.5, 1);
}

.vtc-bar-fill--fire {
    background: linear-gradient(90deg, #c0392b, #e74c3c);
    box-shadow: 0 0 6px rgba(240, 160, 66, 0.5);
}

.vtc-bar-fill--arm {
    background: linear-gradient(90deg, #2c5364, #4a8fa8);
    box-shadow: 0 0 6px rgba(74, 143, 168, 0.4);
}

.vtc-bar-fill--spd {
    background: linear-gradient(90deg, #1a6b3c, #2ecc71);
    box-shadow: 0 0 6px rgba(46, 204, 113, 0.4);
}

.vtc-bar-pct {
    font-family: var(--font-heading);
    font-size: 0.62rem;
    font-weight: 700;
    color: rgba(255, 255, 255, 0.4);
    width: 22px;
    text-align: right;
    flex-shrink: 0;
}

/* ── Difficulty row ── */
.vtc-difficulty-row {
    position: relative;
    z-index: 1;
    display: flex;
    align-items: center;
    gap: 0.5rem;
    padding-top: 0.3rem;
    border-top: 1px solid rgba(255, 255, 255, 0.05);
}

.vtc-diff-label {
    font-family: var(--font-heading);
    font-size: 0.58rem;
    text-transform: uppercase;
    letter-spacing: 1.5px;
    color: rgba(255, 255, 255, 0.35);
    flex-shrink: 0;
}

.vtc-diff-pips {
    display: flex;
    gap: 3px;
    align-items: center;
}

.diff-pip {
    width: 16px;
    height: 4px;
    border-radius: 2px;
    background: rgba(255, 255, 255, 0.08);
    flex-shrink: 0;
    transition: background 0.3s ease, box-shadow 0.3s ease;
}

.diff-pip--on {
    background: var(--color-primary);
    box-shadow: 0 0 6px rgba(240, 160, 66, 0.6);
}

.vtc-diff-text {
    font-family: var(--font-heading);
    font-size: 0.62rem;
    text-transform: uppercase;
    letter-spacing: 1.5px;
    color: var(--color-primary);
    margin-left: auto;
}

/* ── Legacy classes kept for bar IDs (no visual role) ── */
.veh-tech-card .veh-spec,
.veh-tech-card .veh-tech-divider,
.veh-tech-card .veh-tech-header,
.veh-tech-card .veh-tech-specs,
.veh-tech-card .veh-tech-bars,
.veh-tech-card .vtc-groups,
.veh-tech-card .vtc-bars,
.veh-tech-card .vtc-difficulty-row {
    display: none;
}

/* ── Flat stat grid ── */
.vtc-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 0.15rem 0.4rem;
    margin-bottom: 0.4rem;
}

.vtc-cell {
    display: flex;
    flex-direction: column;
    background: rgba(255, 255, 255, 0.03);
    border: 1px solid rgba(255, 255, 255, 0.05);
    border-radius: 3px;
    padding: 0.2rem 0.4rem;
    gap: 0.05rem;
}

.vtc-cell--wide {
    grid-column: 1 / -1;
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
}

.vtc-cell--span2 {
    grid-column: span 2;
}

.vtc-sk {
    font-family: var(--font-heading);
    font-size: 0.72rem;
    text-transform: uppercase;
    letter-spacing: 1px;
    color: rgba(255, 255, 255, 0.35);
    white-space: nowrap;
}

.vtc-sk i {
    color: var(--color-primary);
    opacity: 0.6;
    font-size: 0.5rem;
}

.vtc-sv {
    font-family: var(--font-heading);
    font-size: 1.04rem;
    font-weight: 600;
    color: #e0e0e0;
    letter-spacing: 0.5px;
    white-space: nowrap;
}

.vtc-sv--hi {
    color: var(--color-primary);
}

/* ── Bottom row: bars + difficulty ── */
.vtc-bottom {
    display: flex;
    gap: 0.7rem;
    align-items: center;
    padding-top: 0.35rem;
    border-top: 1px solid rgba(255, 255, 255, 0.05);
}

.vtc-bar-col {
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: 0.22rem;
}

.vtc-diff-col {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.3rem;
    flex-shrink: 0;
    padding-left: 0.5rem;
    border-left: 1px solid rgba(255, 255, 255, 0.06);
}

/* =============================================
   VEHICLE GARAGE EXPLORER — REDESIGNED
   ============================================= */

/* Explorer wrapper fills the right panel */
.garage-explorer {
    position: relative;
    width: 100%;
    max-height: 85vh;
    display: flex;
    flex-direction: column;
    overflow: hidden;
}

/* State visibility machine */
.garage-state {
    display: none;
    flex-direction: column;
    width: 100%;
    min-height: 0;
    padding: 1.5rem;
    animation: garageStateIn 0.35s cubic-bezier(0.25, 1, 0.5, 1) both;
}

.garage-state.active {
    display: flex;
}

@keyframes garageStateIn {
    from {
        opacity: 0;
        transform: translateX(18px);
    }

    to {
        opacity: 1;
        transform: translateX(0);
    }
}

/* ── State 0: Intro ── */
.garage-state--intro {
    justify-content: center;
    align-items: center;
}

.garage-intro-header {
    margin-bottom: 1.6rem;
    text-align: center;
    width: 100%;
}

.garage-intro-line {
    width: 36px;
    height: 2px;
    background: var(--color-primary);
    margin: 0 auto 0.7rem;
    border-radius: 2px;
}

.garage-intro-eyebrow {
    font-family: var(--font-heading);
    font-size: 1rem;
    letter-spacing: 3px;
    text-transform: uppercase;
    color: rgba(240, 160, 66, 0.7);
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.4rem;
    margin-bottom: 0.5rem;
}

.garage-intro-title {
    font-family: var(--font-heading);
    font-size: clamp(1.85rem, 3.5vw, 2.77rem);
    font-weight: 700;
    color: #fff;
    line-height: 1.05;
    letter-spacing: 2px;
    text-transform: uppercase;
    margin-bottom: 0.6rem;
}

.garage-intro-title span {
    color: var(--color-primary);
    position: relative;
    display: inline-block;
}

.garage-intro-title span::after {
    content: '';
    position: absolute;
    bottom: -2px;
    left: 0;
    right: 0;
    height: 2px;
    background: var(--color-primary);
    border-radius: 2px;
    animation: shimmer 2s ease infinite;
}

.garage-intro-sub {
    font-family: var(--font-body);
    font-size: 0.82rem;
    color: rgba(255, 255, 255, 0.45);
    line-height: 1.5;
}

/* ── Nation Grid (State 0) ── */
.garage-nation-grid {
    display: flex;
    flex-direction: column;
    gap: 0.85rem;
    width: 100%;
    align-items: center;
}

/* ── Keyframes for nation cards ── */
@keyframes gnc-scanline {
    0% {
        transform: translateX(-100%);
    }

    100% {
        transform: translateX(400%);
    }
}

@keyframes gnc-pulse {

    0%,
    100% {
        opacity: 0.06;
    }

    50% {
        opacity: 0.15;
    }
}

@keyframes gnc-border-glow {

    0%,
    100% {
        opacity: 0.3;
    }

    50% {
        opacity: 0.7;
    }
}

.garage-nation-card {
    display: flex;
    align-items: center;
    width: 100%;
    min-height: 120px;
    background: linear-gradient(135deg,
            rgba(var(--nation-accent-rgb), 0.03) 0%,
            rgba(10, 12, 18, 0.95) 40%,
            rgba(10, 12, 18, 0.98) 100%);
    border: 1px solid rgba(var(--nation-accent-rgb), 0.12);
    border-radius: 10px;
    padding: 0;
    cursor: pointer;
    text-align: left;
    transition: all 0.35s cubic-bezier(0.4, 0, 0.2, 1);
    position: relative;
    overflow: hidden;
}

/* Animated scan line */
.garage-nation-card::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 30%;
    height: 100%;
    background: linear-gradient(90deg,
            transparent 0%,
            rgba(var(--nation-accent-rgb), 0.06) 40%,
            rgba(var(--nation-accent-rgb), 0.12) 50%,
            rgba(var(--nation-accent-rgb), 0.06) 60%,
            transparent 100%);
    animation: gnc-scanline 4s ease-in-out infinite;
    pointer-events: none;
    z-index: 1;
}

/* Top accent border line */
.garage-nation-card::after {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 1px;
    background: linear-gradient(90deg,
            transparent 0%,
            rgba(var(--nation-accent-rgb), 0.5) 30%,
            rgba(var(--nation-accent-rgb), 0.8) 50%,
            rgba(var(--nation-accent-rgb), 0.5) 70%,
            transparent 100%);
    opacity: 0;
    transition: opacity 0.3s;
    z-index: 3;
}

.garage-nation-card:hover::after {
    opacity: 1;
}

.garage-nation-card:hover {
    transform: translateY(-4px) scale(1.01);
    border-color: rgba(var(--nation-accent-rgb), 0.45);
    background: linear-gradient(135deg,
            rgba(var(--nation-accent-rgb), 0.08) 0%,
            rgba(10, 12, 18, 0.92) 40%,
            rgba(10, 12, 18, 0.95) 100%);
    box-shadow:
        0 12px 40px rgba(0, 0, 0, 0.6),
        0 0 30px rgba(var(--nation-accent-rgb), 0.1),
        0 0 60px rgba(var(--nation-accent-rgb), 0.05),
        inset 0 1px 0 rgba(var(--nation-accent-rgb), 0.15);
}

.garage-nation-card:active {
    transform: translateY(-2px) scale(1.005);
    transition-duration: 0.1s;
}

/* Map silhouette container */
.gnc-map {
    width: 140px;
    height: 100%;
    min-height: 120px;
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
    overflow: hidden;
    padding: 1.2rem;
}

/* Pulsing radial glow behind map */
.gnc-map::before {
    content: '';
    position: absolute;
    width: 100%;
    height: 100%;
    background: radial-gradient(circle at center,
            rgba(var(--nation-accent-rgb), 0.12) 0%,
            rgba(var(--nation-accent-rgb), 0.04) 40%,
            transparent 70%);
    animation: gnc-pulse 3s ease-in-out infinite;
    z-index: 0;
}

/* Tactical grid dots */
.gnc-map::after {
    content: '';
    position: absolute;
    inset: 0;
    background-image: radial-gradient(circle,
            rgba(var(--nation-accent-rgb), 0.08) 1px,
            transparent 1px);
    background-size: 12px 12px;
    opacity: 0.4;
    z-index: 1;
    transition: opacity 0.3s;
}

.garage-nation-card:hover .gnc-map::after {
    opacity: 0.7;
}

.gnc-map img {
    width: 100%;
    height: 100%;
    object-fit: contain;
    opacity: 0.2;
    filter: brightness(3) saturate(0);
    transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
    position: relative;
    z-index: 2;
}

.garage-nation-card:hover .gnc-map img {
    opacity: 0.85;
    filter: brightness(1.2) saturate(0) drop-shadow(0 0 12px rgba(var(--nation-accent-rgb), 0.6)) drop-shadow(0 0 24px rgba(var(--nation-accent-rgb), 0.3));
    transform: scale(1.1);
}

/* Content area */
.gnc-content {
    position: relative;
    z-index: 2;
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
    padding: 1rem 0.5rem;
    flex: 1;
}

.gnc-name {
    font-family: var(--font-heading);
    font-size: 1.6rem;
    font-weight: 700;
    color: #f0f0f0;
    letter-spacing: 3px;
    text-transform: uppercase;
    line-height: 1;
    transition: color 0.3s, text-shadow 0.3s;
}

.garage-nation-card:hover .gnc-name {
    color: #fff;
    text-shadow: 0 0 20px rgba(var(--nation-accent-rgb), 0.4);
}

.gnc-count {
    font-family: var(--font-heading);
    font-size: 0.8rem;
    color: rgba(var(--nation-accent-rgb), 0.8);
    text-transform: uppercase;
    letter-spacing: 2px;
    font-weight: 600;
    transition: color 0.3s;
}

.garage-nation-card:hover .gnc-count {
    color: rgba(var(--nation-accent-rgb), 1);
}

/* Status indicator dot */
.gnc-status {
    display: flex;
    align-items: center;
    gap: 0.4rem;
    margin-top: 0.15rem;
}

.gnc-status-dot {
    width: 5px;
    height: 5px;
    border-radius: 50%;
    background: rgba(var(--nation-accent-rgb), 0.5);
    animation: gnc-border-glow 2s ease-in-out infinite;
}

.gnc-status-text {
    font-family: var(--font-body);
    font-size: 0.65rem;
    color: rgba(255, 255, 255, 0.65);
    text-transform: uppercase;
    letter-spacing: 1.5px;
}

.garage-nation-card:hover .gnc-status-text {
    color: rgba(255, 255, 255, 0.8);
}

/* Arrow */
.gnc-arrow {
    position: relative;
    z-index: 2;
    font-size: 0.9rem;
    color: rgba(var(--nation-accent-rgb), 0.2);
    margin-right: 1.5rem;
    flex-shrink: 0;
    transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1), color 0.3s;
}

.garage-nation-card:hover .gnc-arrow {
    transform: translateX(6px);
    color: var(--nation-accent);
    filter: drop-shadow(0 0 8px rgba(var(--nation-accent-rgb), 0.4));
}

/* ── State 1: Vehicle Type Selector ── */
.garage-type-header {
    text-align: center;
    margin-bottom: 0.6rem;
}

.garage-type-title {
    font-family: var(--font-heading);
    font-size: 0.75rem;
    letter-spacing: 2px;
    text-transform: uppercase;
    color: rgba(255, 255, 255, 0.35);
}

.garage-type-grid {
    display: flex;
    flex-direction: column;
    gap: 0.55rem;
    width: 100%;
    align-items: center;
    overflow-y: auto;
    flex: 1;
    padding-top: 4px;
}

.garage-type-card {
    display: flex;
    align-items: center;
    width: min(420px, 95%);
    height: 72px;
    background: rgba(255, 255, 255, 0.03);
    border: 1px solid rgba(255, 255, 255, 0.07);
    border-radius: 8px;
    padding: 0;
    cursor: pointer;
    text-align: left;
    transition: border-color 0.25s, transform 0.2s, box-shadow 0.25s, background 0.25s;
    position: relative;
    overflow: hidden;
}

.garage-type-card:hover {
    background: rgba(240, 160, 66, 0.06);
    border-color: rgba(240, 160, 66, 0.35);
    transform: translateY(-2px);
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.4);
}

.garage-type-card:active {
    transform: translateY(-1px);
}

.gte-preview {
    width: 90px;
    height: 100%;
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
    background: radial-gradient(ellipse at center, rgba(30, 34, 42, 0.6) 0%, transparent 100%);
    padding: 0.25rem;
}

.gte-preview img {
    width: 100%;
    height: 100%;
    object-fit: contain;
    filter: brightness(0.85) contrast(1.05);
    transition: transform 0.3s;
}

.garage-type-card:hover .gte-preview img {
    transform: scale(1.08);
    filter: brightness(1) contrast(1.1);
}

.gte-info {
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: 0.15rem;
    padding: 0 0.8rem;
}

.gte-era {
    font-family: var(--font-heading);
    font-size: 0.5rem;
    letter-spacing: 1.5px;
    text-transform: uppercase;
    padding: 0.05rem 0.35rem;
    border-radius: 2px;
    display: inline-block;
    width: fit-content;
}

.gte-era--ww2 {
    color: rgba(255, 193, 7, 0.8);
    background: rgba(255, 193, 7, 0.1);
    border: 1px solid rgba(255, 193, 7, 0.2);
}

.gte-era--modern {
    color: rgba(96, 165, 250, 0.8);
    background: rgba(96, 165, 250, 0.1);
    border: 1px solid rgba(96, 165, 250, 0.2);
}

.gte-label {
    font-family: var(--font-heading);
    font-size: 1.1rem;
    font-weight: 700;
    color: #f0f0f0;
    letter-spacing: 2px;
    text-transform: uppercase;
    line-height: 1;
}

.gte-count {
    font-family: var(--font-body);
    font-size: 0.6rem;
    color: rgba(255, 255, 255, 0.35);
    text-transform: uppercase;
    letter-spacing: 1px;
}

.gte-arrow {
    font-size: 0.7rem;
    color: rgba(255, 255, 255, 0.15);
    margin-right: 1rem;
    flex-shrink: 0;
    transition: transform 0.2s, color 0.2s;
}

.garage-type-card:hover .gte-arrow {
    transform: translateX(3px);
    color: var(--color-primary);
}

/* ── Pagination ── */
.garage-veh-pagination {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.35rem;
    padding: 0.6rem 0 0;
    flex-shrink: 0;
}

.garage-page-btn {
    width: 28px;
    height: 28px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(240, 160, 66, 0.08);
    border: 1px solid rgba(240, 160, 66, 0.3);
    border-radius: 4px;
    color: #e0e0e0;
    font-size: 0.6rem;
    cursor: pointer;
    transition: background 0.2s, border-color 0.2s, color 0.2s;
}

.garage-page-btn:hover {
    background: rgba(240, 160, 66, 0.15);
    border-color: rgba(240, 160, 66, 0.5);
    color: #fff;
}

.garage-page-dot {
    width: 28px;
    height: 28px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: transparent;
    border: 1px solid rgba(255, 255, 255, 0.12);
    border-radius: 4px;
    color: rgba(255, 255, 255, 0.4);
    font-family: var(--font-heading);
    font-size: 0.65rem;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.2s;
}

.garage-page-dot:hover {
    border-color: rgba(255, 255, 255, 0.3);
    color: #fff;
}

.garage-page-dot.active {
    background: var(--color-primary);
    border-color: var(--color-primary);
    color: #fff;
    box-shadow: 0 0 8px rgba(240, 160, 66, 0.3);
}

/* ── State Header (shared) ── */
.garage-state-header {
    display: flex;
    align-items: center;
    gap: 0.8rem;
    margin-top: 0.8rem;
    margin-bottom: 1rem;
    padding-bottom: 0.7rem;
    border-bottom: 1px solid rgba(255, 255, 255, 0.07);
}

.garage-back-btn {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    background: rgba(240, 160, 66, 0.08);
    border: 1px solid rgba(240, 160, 66, 0.35);
    color: #e8e8e8;
    font-family: var(--font-heading);
    font-size: 0.85rem;
    text-transform: uppercase;
    letter-spacing: 1.5px;
    cursor: pointer;
    padding: 0.45rem 0.9rem;
    border-radius: 5px;
    transition: color 0.2s, background 0.2s, border-color 0.2s;
}

.garage-back-btn i {
    color: var(--color-primary);
    font-size: 0.7rem;
}

.garage-back-btn:hover {
    color: #fff;
    background: rgba(240, 160, 66, 0.15);
    border-color: rgba(240, 160, 66, 0.6);
}

/* Nation badge in vehicle grid header */
.garage-nation-badge {
    display: flex;
    align-items: center;
    gap: 0.6rem;
    margin-left: auto;
}

.garage-nation-badge-icon {
    width: 40px;
    height: 28px;
    object-fit: cover;
    border-radius: 3px;
    border: 1px solid rgba(255, 255, 255, 0.1);
}

.garage-nation-badge-info {
    display: flex;
    flex-direction: column;
    gap: 0.1rem;
}

.garage-nation-badge-name {
    font-family: var(--font-heading);
    font-size: 0.9rem;
    color: #c0c0c0;
    letter-spacing: 2px;
    text-transform: uppercase;
    line-height: 1;
}

.garage-nation-badge-count {
    font-family: var(--font-body);
    font-size: 0.6rem;
    color: rgba(255, 255, 255, 0.3);
    text-transform: uppercase;
    letter-spacing: 1px;
}

/* ── State 1: Vehicle Grid ── */
.garage-veh-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 0.5rem;
    flex: 1;
    overflow-y: auto;
    padding-right: 0.2rem;
    padding-top: 4px;
    align-content: start;
}

.garage-veh-grid::-webkit-scrollbar {
    width: 3px;
}

.garage-veh-grid::-webkit-scrollbar-thumb {
    background: rgba(240, 160, 66, 0.3);
    border-radius: 3px;
}

.garage-veh-card {
    display: flex;
    flex-direction: column;
    background: rgba(255, 255, 255, 0.03);
    border: 1px solid rgba(255, 255, 255, 0.07);
    border-radius: 6px;
    padding: 0;
    cursor: pointer;
    text-align: center;
    transition: background 0.2s, border-color 0.2s, transform 0.15s, box-shadow 0.2s;
    position: relative;
    overflow: hidden;
}

.garage-veh-card:hover {
    background: rgba(240, 160, 66, 0.08);
    border-color: rgba(240, 160, 66, 0.4);
    transform: translateY(-2px);
    box-shadow: 0 4px 16px rgba(240, 160, 66, 0.15);
}

.garage-veh-card--collector {
    border-color: rgba(255, 193, 7, 0.25);
}

.garage-veh-card--collector:hover {
    border-color: rgba(255, 193, 7, 0.5);
    box-shadow: 0 4px 16px rgba(255, 193, 7, 0.15);
}

.gvc-thumb {
    width: 100%;
    aspect-ratio: 4/3;
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
    background: radial-gradient(ellipse at center, rgba(30, 34, 42, 0.8) 0%, transparent 100%);
    padding: 0.2rem;
}

.gvc-thumb img {
    width: 100%;
    height: 100%;
    object-fit: contain;
    filter: brightness(0.9) contrast(1.05);
    transition: transform 0.25s;
}

.garage-veh-card:hover .gvc-thumb img {
    transform: scale(1.08);
    filter: brightness(1) contrast(1.1);
}

.gvc-info {
    display: flex;
    flex-direction: column;
    gap: 0.05rem;
    padding: 0.3rem 0.35rem 0.4rem;
}

.gvc-rank {
    font-family: var(--font-heading);
    font-size: 0.48rem;
    font-weight: 700;
    color: var(--color-primary);
    letter-spacing: 1.5px;
    opacity: 0.7;
}

.gvc-name {
    font-family: var(--font-heading);
    font-size: 0.65rem;
    font-weight: 600;
    color: #e0e0e0;
    letter-spacing: 0.5px;
    text-transform: uppercase;
    line-height: 1.15;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.gvc-class {
    font-family: var(--font-body);
    font-size: 0.45rem;
    color: rgba(255, 255, 255, 0.3);
    text-transform: uppercase;
    letter-spacing: 0.8px;
}

.gvc-collector {
    position: absolute;
    top: 4px;
    right: 4px;
    font-size: 0.55rem;
    color: #FFC107;
    filter: drop-shadow(0 0 4px rgba(255, 193, 7, 0.5));
}

.gvc-thumb--missing {
    background: rgba(255, 255, 255, 0.03);
    position: relative;
}

.gvc-thumb--missing::after {
    content: '\f135';
    font-family: 'Font Awesome 5 Free';
    font-weight: 900;
    font-size: 2rem;
    color: rgba(255, 255, 255, 0.08);
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
}

/* ── State 2: Vehicle Detail ── */
.garage-detail-layout {
    display: flex;
    flex-direction: column;
    flex: 1;
    gap: 0.6rem;
    min-height: 0;
}

/* Preview area */
.garage-detail-preview {
    position: relative;
    flex: 1;
    min-height: 270px;
    border-radius: 8px;
    overflow: hidden;
    background: radial-gradient(ellipse at center, #1a1e26 0%, #0a0a0e 100%);
    display: flex;
    align-items: center;
    justify-content: center;
}

/* Corner overlays on preview area */
.gdp-overlay {
    position: absolute;
    z-index: 2;
    pointer-events: none;
}

.gdp-overlay--tl {
    top: 0.6rem;
    left: 0.6rem;
}

.gdp-overlay--bl {
    bottom: 0.8rem;
    left: 0.6rem;
}

.gdp-overlay--br {
    bottom: 0.8rem;
    right: 0.6rem;
}

.gdp-overlay--tr {
    top: 0.6rem;
    right: 0.6rem;
    text-align: right;
}

.garage-detail-preview-img {
    max-width: 90%;
    max-height: 90%;
    object-fit: contain;
    filter: drop-shadow(0 8px 24px rgba(0, 0, 0, 0.5));
    transition: transform 0.3s;
}

.garage-detail-preview:hover .garage-detail-preview-img:not([style*="display:none"]) {
    transform: scale(1.02);
}

/* Turntable */
.garage-turntable {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: grab;
    user-select: none;
}

.garage-turntable:active {
    cursor: grabbing;
}

.garage-turntable-img {
    max-width: 90%;
    max-height: 90%;
    object-fit: contain;
    filter: drop-shadow(0 8px 24px rgba(0, 0, 0, 0.5));
    pointer-events: none;
}

.garage-turntable-hint {
    position: absolute;
    bottom: 10px;
    left: 50%;
    transform: translateX(-50%);
    display: flex;
    align-items: center;
    gap: 0.4rem;
    font-family: var(--font-heading);
    font-size: 0.72rem;
    letter-spacing: 2px;
    text-transform: uppercase;
    color: rgba(255, 255, 255, 0.35);
    background: rgba(0, 0, 0, 0.5);
    padding: 0.35rem 0.8rem;
    border-radius: 4px;
    border: 1px solid rgba(255, 255, 255, 0.08);
    pointer-events: none;
    transition: opacity 0.4s;
}

.garage-turntable:active .garage-turntable-hint {
    opacity: 0;
}

.garage-turntable-hint i {
    font-size: 0.84rem;
    animation: ttHintBounce 2s ease-in-out infinite;
}

@keyframes ttHintBounce {

    0%,
    100% {
        transform: translateX(0);
    }

    30% {
        transform: translateX(-4px);
    }

    70% {
        transform: translateX(4px);
    }
}

/* Loading spinner for turntable probe */
.garage-preview-spinner {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 5;
}

.garage-preview-spinner::after {
    content: '';
    width: 32px;
    height: 32px;
    border: 3px solid rgba(255, 255, 255, 0.08);
    border-top-color: var(--color-primary);
    border-radius: 50%;
    animation: garageSpinnerRotate 0.8s linear infinite;
}

@keyframes garageSpinnerRotate {
    to {
        transform: rotate(360deg);
    }
}

/* Collector badge in header */
.detail-collector-badge {
    margin-left: auto;
    display: flex;
    align-items: center;
    gap: 0.4rem;
    font-family: var(--font-heading);
    font-size: 0.84rem;
    letter-spacing: 1.5px;
    text-transform: uppercase;
    color: #FFC107;
    background: rgba(255, 193, 7, 0.1);
    border: 1px solid rgba(255, 193, 7, 0.3);
    border-radius: 4px;
    padding: 0.25rem 0.6rem;
}

.detail-collector-badge i {
    font-size: 0.66rem;
}

/* ── Stat Card (gds = garage detail stats) ── */
.garage-detail-stats {
    background: rgba(10, 10, 14, 0.7);
    border: 1px solid rgba(255, 255, 255, 0.06);
    border-radius: 8px;
    padding: 0.6rem;
    backdrop-filter: blur(8px);
}

.gds-header {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    margin-bottom: 0.2rem;
}

.gds-nation-icon {
    width: 36px;
    height: 25px;
    object-fit: cover;
    border-radius: 3px;
    border: 1px solid rgba(255, 255, 255, 0.1);
    flex-shrink: 0;
}

.gds-identity {
    flex: 1;
    min-width: 0;
}

.gds-name {
    font-family: var(--font-heading);
    font-size: 1.35rem;
    font-weight: 600;
    color: #fff;
    text-transform: uppercase;
    letter-spacing: 2px;
    line-height: 1.1;
    display: block;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.gds-tags {
    display: flex;
    gap: 0.4rem;
    margin-top: 0.2rem;
}

.gds-tag {
    font-family: var(--font-heading);
    font-size: 0.78rem;
    letter-spacing: 1px;
    text-transform: uppercase;
    padding: 0.15rem 0.5rem;
    border-radius: 3px;
}

.gds-tag--class {
    color: rgba(255, 255, 255, 0.65);
    background: rgba(255, 255, 255, 0.06);
    border: 1px solid rgba(255, 255, 255, 0.08);
}

.gds-tag--rank {
    color: var(--color-primary);
    background: rgba(240, 160, 66, 0.1);
    border: 1px solid rgba(240, 160, 66, 0.25);
}

.gds-divider {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    font-family: var(--font-heading);
    font-size: 0.84rem;
    letter-spacing: 2px;
    text-transform: uppercase;
    color: rgba(255, 255, 255, 0.55);
    padding: 0.25rem 0;
    margin-bottom: 0.25rem;
    border-top: 1px solid rgba(255, 255, 255, 0.05);
    border-bottom: 1px solid rgba(255, 255, 255, 0.05);
}

.gds-divider i {
    font-size: 0.48rem;
    color: var(--color-primary);
    opacity: 0.8;
}

/* Spec Grid */
.gds-spec-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 0.15rem 0.4rem;
    margin-bottom: 0.5rem;
}

.gds-spec {
    display: flex;
    flex-direction: column;
    background: rgba(255, 255, 255, 0.03);
    border: 1px solid rgba(255, 255, 255, 0.04);
    border-radius: 3px;
    padding: 0.2rem 0.4rem;
    gap: 0.05rem;
}

.gds-spec--wide {
    grid-column: 1 / -1;
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
}

.gds-spec-key {
    font-family: var(--font-heading);
    font-size: 0.9rem;
    text-transform: uppercase;
    letter-spacing: 1px;
    color: rgba(255, 255, 255, 0.7);
    white-space: nowrap;
}

.gds-spec-key i {
    color: var(--color-primary);
    opacity: 0.5;
    font-size: 0.54rem;
    margin-right: 0.2rem;
}

.gds-spec-val {
    font-family: var(--font-heading);
    /* Fluid: scales with viewport width so long values like "90 / 90 / 60 mm"
       still fit on narrow screens without overflowing the cell. */
    font-size: clamp(0.95rem, 3.6vw, 1.35rem);
    font-weight: 600;
    color: #fff;
    letter-spacing: 0.5px;
    white-space: nowrap;
}

/* ── Name Row with Class Icon ── */
.gds-name-row {
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.gds-class-icon {
    width: 28px;
    height: 28px;
    object-fit: contain;
    filter: brightness(0.9);
    flex-shrink: 0;
}

.gds-tag--collector {
    color: #ffd700;
    background: rgba(255, 215, 0, 0.1);
    border: 1px solid rgba(255, 215, 0, 0.25);
    display: inline-flex;
    align-items: center;
    gap: 0.2rem;
}

/* ── Role & Difficulty Row ── */
.gds-role-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0.25rem 0;
    margin-bottom: 0.1rem;
}

.gds-role {
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.gds-role-icon {
    width: 32px;
    height: 32px;
    object-fit: contain;
    filter: drop-shadow(0 0 4px rgba(240, 160, 66, 0.3));
}

.gds-role-label {
    font-family: var(--font-heading);
    font-size: 1rem;
    letter-spacing: 1.5px;
    text-transform: uppercase;
    color: rgba(255, 255, 255, 0.85);
    font-weight: 600;
}

.gds-difficulty {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 0.15rem;
}

.gds-difficulty-label {
    font-family: var(--font-heading);
    font-size: 0.6rem;
    letter-spacing: 1.5px;
    text-transform: uppercase;
    color: rgba(255, 255, 255, 0.55);
}

.gds-difficulty-stars {
    display: flex;
    gap: 0.15rem;
}

.gds-star {
    font-size: 0.72rem;
    color: rgba(255, 255, 255, 0.2);
    transition: color 0.2s;
}

.gds-star--active {
    color: #ffd700;
    filter: drop-shadow(0 0 3px rgba(255, 215, 0, 0.4));
}

/* ── Gun Names Section ── */
.gds-gun-section {
    margin-bottom: 0.25rem;
}

.gds-section-label {
    display: block;
    font-family: var(--font-heading);
    font-size: 0.9rem;
    letter-spacing: 1.5px;
    text-transform: uppercase;
    color: rgba(255, 255, 255, 0.7);
    margin-bottom: 0.3rem;
}

.gds-section-label i {
    color: var(--color-primary);
    opacity: 0.8;
    font-size: 0.54rem;
    margin-right: 0.2rem;
}

.gds-gun-list {
    display: flex;
    flex-direction: column;
    gap: 0.2rem;
}

.gds-gun-item {
    display: flex;
    align-items: center;
    gap: 0.4rem;
    font-family: var(--font-heading);
    font-size: 1.08rem;
    color: #fff;
    letter-spacing: 0.5px;
}

.gds-gun-cal {
    font-size: 0.78rem;
    color: var(--color-primary);
    background: rgba(240, 160, 66, 0.12);
    border: 1px solid rgba(240, 160, 66, 0.25);
    padding: 0.05rem 0.3rem;
    border-radius: 3px;
    font-weight: 600;
    letter-spacing: 0.5px;
    flex-shrink: 0;
}

/* ── Skill Matrix (2×2 grid) ── */
.gds-skill-matrix {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0.3rem;
    margin-bottom: 0.4rem;
}

.gds-skill-cell {
    background: rgba(255, 255, 255, 0.03);
    border: 1px solid rgba(255, 255, 255, 0.05);
    border-radius: 4px;
    padding: 0.3rem 0.4rem;
}

.gds-skill-head {
    display: flex;
    align-items: center;
    gap: 0.3rem;
    margin-bottom: 0.2rem;
}

.gds-skill-ico {
    font-size: 0.6rem;
    opacity: 0.7;
}
.gds-skill-ico--fp { color: #ff6b6b; }
.gds-skill-ico--sv { color: #60a5fa; }
.gds-skill-ico--mb { color: #4ade80; }
.gds-skill-ico--ut { color: #fbbf24; }

.gds-skill-label {
    font-family: var(--font-heading);
    font-size: 0.84rem;
    letter-spacing: 1px;
    text-transform: uppercase;
    color: rgba(255, 255, 255, 0.75);
    flex: 1;
}

.gds-skill-track {
    height: 4px;
    background: rgba(255, 255, 255, 0.06);
    border-radius: 2px;
    overflow: hidden;
}

.gds-skill-fill {
    height: 100%;
    width: 0;
    border-radius: 2px;
    transition: width 0.8s cubic-bezier(0.4, 0, 0.2, 1);
}

.gds-skill--firepower {
    background: linear-gradient(90deg, #F0A042, #ff6b6b);
}

.gds-skill--survivability {
    background: linear-gradient(90deg, #3b82f6, #60a5fa);
}

.gds-skill--mobility {
    background: linear-gradient(90deg, #22c55e, #4ade80);
}

.gds-skill--utility {
    background: linear-gradient(90deg, #f59e0b, #fbbf24);
}

.gds-skill-val {
    font-family: var(--font-heading);
    font-size: 1rem;
    font-weight: 700;
    color: #fff;
    margin-left: auto;
}

/* ── Gameplay Features ── */
.gds-features-section {
    margin-bottom: 0.5rem;
}

.gds-feature-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 0.3rem;
    margin-top: 0.2rem;
}

.gds-feature-tag {
    font-family: var(--font-heading);
    font-size: 0.84rem;
    letter-spacing: 0.5px;
    text-transform: uppercase;
    padding: 0.2rem 0.6rem;
    border-radius: 12px;
    color: rgba(255, 255, 255, 0.9);
    background: rgba(255, 255, 255, 0.08);
    border: 1px solid rgba(255, 255, 255, 0.15);
    white-space: nowrap;
}

/* ── Store Button ── */
.gds-store-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    width: 100%;
    padding: 0.5rem 1rem;
    font-family: var(--font-heading);
    font-size: 0.95rem;
    letter-spacing: 2px;
    text-transform: uppercase;
    color: #fff;
    background: linear-gradient(135deg, var(--color-primary), #c0151b);
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 5px;
    text-decoration: none;
    transition: transform 0.2s, box-shadow 0.2s, background 0.2s;
    cursor: pointer;
}

.gds-store-btn:hover {
    transform: translateY(-1px);
    box-shadow: 0 4px 15px rgba(240, 160, 66, 0.3);
    background: linear-gradient(135deg, #ff3339, var(--color-primary));
}


.news-magazine-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    grid-template-rows: 300px 300px;
    gap: 1rem;
}

.news-mag-card {
    position: relative;
    border-radius: var(--radius-lg);
    overflow: hidden;
    transition: transform var(--transition-base), box-shadow var(--transition-base);
}

.news-mag-card:hover {
    transform: translateY(-3px);
    box-shadow: 0 12px 40px rgba(0, 0, 0, 0.5);
}

.news-mag-card--hero {
    grid-row: 1 / -1;
}

.news-mag-card a {
    display: block;
    width: 100%;
    height: 100%;
    position: relative;
}

.news-mag-img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
    position: absolute;
    inset: 0;
    transition: transform var(--transition-slow);
}

.news-mag-card a {
    display: block;
    width: 100%;
    height: 100%;
    position: relative;
    overflow: hidden;
}

.news-mag-card:hover .news-mag-img {
    transform: scale(1.04);
}

.news-mag-overlay {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    padding: 1.5rem;
    background: linear-gradient(transparent 0%, rgba(0, 0, 0, 0.92) 100%);
    z-index: 2;
}

.news-mag-title {
    font-family: var(--font-heading);
    font-size: 1.1rem;
    color: #fff;
    margin-top: 0.4rem;
    line-height: 1.2;
}

.news-mag-card--hero .news-mag-title {
    font-size: 1.8rem;
}

.news-mag-excerpt {
    color: var(--color-text-muted);
    font-size: 0.85rem;
    margin-top: 0.5rem;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.news-mag-date {
    font-family: var(--font-heading);
    font-size: 0.75rem;
    color: var(--color-text-muted);
    text-transform: uppercase;
    letter-spacing: 1px;
    display: flex;
    align-items: center;
    gap: 0.4rem;
    margin-top: 0.5rem;
}

/* ── Vehicle detail — mobile layout ──
   On phones the 4-column spec grid is too narrow and long values like
   "90 / 90 / 60 mm" overflow. Reflow to 2 columns. The drag-to-rotate
   hint sits bottom-centre and collides with the bottom-left role badge,
   so we hide it on touch screens. Corner overlays are also tightened
   so the four corners stop crowding the tank image. */
@media (max-width: 768px) {
    .gds-spec-grid {
        grid-template-columns: repeat(2, 1fr);
        gap: 0.4rem;
    }
    .gds-spec {
        min-width: 0;
    }

    .garage-turntable-hint {
        display: none;
    }

    .gdp-overlay--tl { top: 0.4rem; left: 0.4rem; }
    .gdp-overlay--tr { top: 0.4rem; right: 0.4rem; }
    .gdp-overlay--bl { bottom: 0.5rem; left: 0.4rem; }
    .gdp-overlay--br { bottom: 0.5rem; right: 0.4rem; }

    .gds-role-icon {
        width: 26px;
        height: 26px;
    }
    .gds-role-label {
        font-size: 0.85rem;
        letter-spacing: 1.2px;
    }

    .gds-class-icon {
        width: 22px;
        height: 22px;
    }

    /* Tag chips (FIRE SUPPORT, RANK 10) wrap instead of forcing the
       overlay wider than the screen. */
    .gds-tags {
        flex-wrap: wrap;
        gap: 0.25rem;
    }
}

/* ===========================
   _blueprint.css — RETIRED
   The hex blueprint tech-tree was replaced by the phase ops board
   in _roadmap.css. This file is kept only so the @import in styles.css
   doesn't 404 — its contents are intentionally empty.
   =========================== */

/* ===========================
   ROADMAP — Tabbed Dossier Folder
   Phase tabs at the top, cream-paper folder beneath,
   memos expand on click.
   =========================== */

.roadmap-section {
    position: relative;
    padding: 5rem 0 4.5rem;
    overflow: hidden;
    /* background is set by the homepage alternation block (lighter shade) */
}
.roadmap-section::before {
    content: '';
    position: absolute;
    inset: 0;
    background: radial-gradient(ellipse at top, rgba(240, 160, 66, 0.04) 0%, transparent 55%);
    pointer-events: none;
}

/* ── Header ─────────────────────────────── */
.rdm-header {
    max-width: 820px;
    margin: 0 0 2.25rem;
    position: relative;
    z-index: 2;
}
.rdm-header .section-title {
    margin: 0.5rem 0 1.1rem;
}
.rdm-header .section-title span {
    color: var(--color-primary);
}
.rdm-lead {
    font-family: var(--font-body);
    color: rgba(255, 255, 255, 0.7);
    font-size: 1rem;
    line-height: 1.65;
    margin: 0 0 1.75rem;
    max-width: 640px;
}

.rdm-stats {
    display: flex;
    flex-wrap: wrap;
    border-top: 1px solid rgba(255, 255, 255, 0.06);
    border-bottom: 1px solid rgba(255, 255, 255, 0.06);
}
.rdm-stat {
    flex: 1 1 0;
    min-width: 110px;
    padding: 1rem 1.25rem;
    border-right: 1px solid rgba(255, 255, 255, 0.06);
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
}
.rdm-stat:last-child { border-right: 0; }
.rdm-stat strong {
    font-family: var(--font-heading);
    font-size: 2.1rem;
    color: var(--color-primary);
    line-height: 1;
    font-weight: 400;
}
.rdm-stat em {
    font-family: var(--font-mono);
    font-size: 0.62rem;
    letter-spacing: 0.22em;
    color: rgba(255, 255, 255, 0.5);
    text-transform: uppercase;
    font-style: normal;
}
.rdm-stat--shipped  strong { color: #4ade80; }
.rdm-stat--building strong { color: var(--color-primary); }
.rdm-stat--queued   strong { color: #fbbf68; }
.rdm-stat--planned  strong { color: rgba(255, 255, 255, 0.7); }
.rdm-stat--horizon  strong { color: rgba(255, 255, 255, 0.4); }

/* ── Phase tabs ─────────────────────────── */
.rdm-tabs {
    display: flex;
    gap: 0.4rem;
    border-bottom: 2px solid rgba(255, 255, 255, 0.08);
    flex-wrap: wrap;
}
.rdm-tab {
    background: rgba(255, 255, 255, 0.03);
    border: 1px solid rgba(255, 255, 255, 0.12);
    border-bottom: 0;
    padding: 0.75rem 1.25rem 0.95rem;
    color: rgba(255, 255, 255, 0.6);
    cursor: pointer;
    display: flex;
    align-items: center;
    gap: 0.65rem;
    transition: all 0.15s ease;
    min-width: 150px;
    position: relative;
    top: 2px;
    font-family: inherit;
}
.rdm-tab:hover {
    background: rgba(240, 160, 66, 0.06);
    color: #fff;
}
.rdm-tab.is-on {
    background: #f5ecd9;
    border-color: var(--color-primary);
    color: #1a1410;
    top: 0;
}
.rdm-tab--shipped.is-on  { background: #e4f5d9; border-color: #4ade80; }
.rdm-tab--building.is-on { background: #f5ecd9; border-color: var(--color-primary); }
.rdm-tab--queued.is-on   { background: #fbf3d9; border-color: #fbbf68; }
.rdm-tab--planned.is-on  { background: #ecedef; border-color: rgba(255, 255, 255, 0.55); }
.rdm-tab--horizon.is-on  { background: #d8dadd; border-color: rgba(255, 255, 255, 0.4); }
.rdm-tab strong {
    font-family: var(--font-heading);
    font-size: 1rem;
    text-transform: uppercase;
    letter-spacing: 1px;
    font-weight: 400;
}
.rdm-tab em {
    font-style: normal;
    font-family: var(--font-mono);
    font-size: 0.65rem;
    letter-spacing: 0.15em;
    padding: 0.15rem 0.45rem;
    background: rgba(0, 0, 0, 0.15);
}
.rdm-tab.is-on em {
    background: rgba(240, 160, 66, 0.25);
    color: #1a1410;
}

/* ── Folder paper ───────────────────────── */
.rdm-paper {
    background: #f5ecd9;
    color: #1a1410;
    background-image: repeating-linear-gradient(0deg, transparent 0 26px, rgba(120, 90, 50, 0.06) 26px 27px);
    box-shadow: 0 8px 30px rgba(0, 0, 0, 0.4);
    padding: 1.75rem 2rem;
    min-height: 320px;
}
.rdm-paper-head {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    gap: 0.65rem;
    flex-wrap: wrap;
    border-bottom: 2px solid rgba(26, 20, 16, 0.4);
    padding-bottom: 0.7rem;
    margin-bottom: 1rem;
}
.rdm-paper-head h3 {
    font-family: 'Georgia', 'Times New Roman', serif;
    font-size: 1.4rem;
    color: #1a1410;
    margin: 0;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 1px;
}
.rdm-stamp {
    font-family: var(--font-heading);
    font-size: 0.9rem;
    letter-spacing: 2px;
    padding: 0.35rem 0.85rem;
    border: 3px double currentColor;
    text-transform: uppercase;
    font-weight: 400;
    transform: rotate(-3deg);
}
.rdm-stamp--shipped  { color: #2f7a3f; }
.rdm-stamp--building { color: #b85020; }
.rdm-stamp--queued   { color: #8a6020; }
.rdm-stamp--planned  { color: #4a4a4a; }
.rdm-stamp--horizon  { color: #3a3a3a; }

/* ── Memos ──────────────────────────────── */
.rdm-memos {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 0.4rem;
}
.rdm-memo {
    display: grid;
    grid-template-columns: 1.4rem 1fr;
    gap: 0.6rem;
    padding: 0.6rem 0.5rem;
    cursor: pointer;
    transition: background 0.15s ease;
    border-bottom: 1px dashed rgba(26, 20, 16, 0.15);
    align-items: start;
}
.rdm-memo:last-child { border-bottom: 0; }
.rdm-memo:hover { background: rgba(26, 20, 16, 0.04); }
.rdm-memo.is-open { background: rgba(184, 80, 32, 0.06); }
.rdm-memo-bullet {
    font-family: 'Courier New', monospace;
    color: rgba(180, 60, 60, 0.7);
    font-size: 1rem;
    line-height: 1.5;
}
.rdm-memo-body {
    font-family: 'Courier New', 'JetBrains Mono', monospace;
    color: #2a2018;
    font-size: 0.95rem;
    line-height: 1.55;
}
.rdm-memo-name {
    font-family: 'Georgia', 'Times New Roman', serif;
    font-weight: 700;
    color: #1a1410;
    font-size: 1rem;
}
.rdm-memo-cat {
    color: rgba(26, 20, 16, 0.55);
}
.rdm-memo-detail {
    display: none;
    margin-top: 0.55rem;
    padding-top: 0.5rem;
    border-top: 1px dotted rgba(26, 20, 16, 0.25);
}
.rdm-memo.is-open .rdm-memo-detail { display: block; }
.rdm-memo-detail p {
    margin: 0 0 0.5rem;
    font-size: 0.92rem;
    line-height: 1.6;
}
.rdm-memo-meta {
    display: flex;
    gap: 1rem;
    flex-wrap: wrap;
    font-family: var(--font-mono);
    font-size: 0.62rem;
    letter-spacing: 0.18em;
    color: rgba(26, 20, 16, 0.55);
    text-transform: uppercase;
}
.rdm-memo-meta strong {
    color: #b85020;
    font-weight: 700;
    margin-right: 0.3rem;
}

/* ── Footer ─────────────────────────────── */
.rdm-foot {
    margin-top: 1.5rem;
    padding-top: 1.25rem;
    border-top: 1px solid rgba(255, 255, 255, 0.06);
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
    gap: 0.5rem;
}
.rdm-foot-note {
    font-family: var(--font-mono);
    font-size: 0.72rem;
    letter-spacing: 0.18em;
    color: rgba(255, 255, 255, 0.4);
    text-transform: uppercase;
}
.rdm-foot-link {
    font-family: var(--font-mono);
    font-size: 0.78rem;
    letter-spacing: 0.18em;
    color: var(--color-primary);
    text-transform: uppercase;
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    transition: gap 0.15s ease;
}
.rdm-foot-link:hover { gap: 0.7rem; }
.rdm-foot-link i { font-size: 0.7rem; }

/* ── Responsive ─────────────────────────── */
@media (max-width: 720px) {
    .rdm-stats { flex-wrap: wrap; }
    .rdm-stat { flex: 1 1 33%; min-width: 90px; border-bottom: 1px solid rgba(255,255,255,0.06); }
    .rdm-stat:nth-child(3) { border-right: 0; }
    .rdm-tab { min-width: 0; flex: 1; padding: 0.55rem 0.6rem; }
    .rdm-tab em { display: none; }
    .rdm-paper { padding: 1.25rem 1.25rem; }
    .rdm-paper-head h3 { font-size: 1.15rem; }
}

/* ===========================
   AUTH PAGES — Login / Register
   Split layout: form panel + cinematic visual
   =========================== */

.auth-page {
    min-height: calc(100vh - 116px);
    display: flex;
    background: var(--color-bg);
}

.auth-page-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    width: 100%;
}

/* ── Form side ── */
.auth-page-form-side {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 3rem 1.5rem;
}
.auth-page-card {
    width: 100%;
    max-width: 420px;
}
.auth-page-logo {
    display: inline-block;
    margin-bottom: 2rem;
}
.auth-page-logo img {
    height: 38px;
    width: auto;
}
.auth-page-card .section-tag {
    margin-bottom: 0.75rem;
}
.auth-page-title {
    font-family: var(--font-heading);
    font-size: clamp(2rem, 4vw, 2.8rem);
    color: var(--color-text-bright);
    text-transform: uppercase;
    letter-spacing: 2px;
    line-height: 1;
    margin: 0 0 0.75rem;
}
.auth-page-sub {
    font-family: var(--font-body);
    color: rgba(255, 255, 255, 0.6);
    font-size: 0.95rem;
    line-height: 1.6;
    margin: 0 0 2rem;
}

/* ── Form ── */
.auth-page-form {
    display: flex;
    flex-direction: column;
    gap: 1.1rem;
}
.auth-page-field label {
    display: block;
    font-family: var(--font-mono);
    font-size: 0.68rem;
    letter-spacing: 0.2em;
    text-transform: uppercase;
    color: var(--color-primary);
    margin-bottom: 0.45rem;
}
.auth-page-field input {
    width: 100%;
    padding: 0.85rem 1rem;
    background: rgba(0, 0, 0, 0.25);
    border: 1px solid rgba(255, 255, 255, 0.12);
    color: #fff;
    font-family: var(--font-body);
    font-size: 1rem;
    transition: border-color 0.15s ease;
}
.auth-page-field input:focus {
    outline: none;
    border-color: var(--color-primary);
}
.auth-page-field input::placeholder {
    color: rgba(255, 255, 255, 0.3);
}

.auth-page-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 1rem;
    flex-wrap: wrap;
    margin-top: -0.2rem;
}
.auth-page-check {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    font-family: var(--font-body);
    font-size: 0.88rem;
    color: rgba(255, 255, 255, 0.65);
    cursor: pointer;
}
.auth-page-check input {
    width: 16px;
    height: 16px;
    accent-color: var(--color-primary);
}
.auth-page-link {
    font-family: var(--font-mono);
    font-size: 0.72rem;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--color-primary);
    text-decoration: none;
    transition: color 0.15s ease;
}
.auth-page-link:hover { color: #fff; }

.auth-page-submit {
    width: 100%;
    margin-top: 0.6rem;
    justify-content: center;
}

/* ── Divider ── */
.auth-page-divider {
    display: flex;
    align-items: center;
    gap: 1rem;
    margin: 1.6rem 0;
    font-family: var(--font-mono);
    font-size: 0.66rem;
    letter-spacing: 0.2em;
    text-transform: uppercase;
    color: rgba(255, 255, 255, 0.35);
}
.auth-page-divider::before,
.auth-page-divider::after {
    content: '';
    flex: 1;
    height: 1px;
    background: rgba(255, 255, 255, 0.1);
}

/* ── Social ── */
.auth-page-social {
    display: flex;
    gap: 0.75rem;
}
.auth-page-social-btn {
    flex: 1;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.55rem;
    padding: 0.8rem;
    border: 1px solid rgba(255, 255, 255, 0.12);
    background: rgba(255, 255, 255, 0.03);
    color: rgba(255, 255, 255, 0.8);
    font-family: var(--font-mono);
    font-size: 0.72rem;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    text-decoration: none;
    transition: all 0.15s ease;
}
.auth-page-social-btn:hover {
    border-color: var(--color-primary);
    color: #fff;
}
.auth-page-social-btn i { font-size: 1rem; }
.auth-page-social-btn--discord:hover { border-color: #5865F2; }
.auth-page-social-btn--discord i { color: #5865F2; }
.auth-page-social-btn--steam:hover { border-color: #66c0f4; }
.auth-page-social-btn--steam i { color: #66c0f4; }

/* ── Switch line ── */
.auth-page-switch {
    margin: 1.75rem 0 0;
    text-align: center;
    font-family: var(--font-body);
    font-size: 0.92rem;
    color: rgba(255, 255, 255, 0.55);
}
.auth-page-switch a {
    color: var(--color-primary);
    text-decoration: none;
    font-weight: 600;
    transition: color 0.15s ease;
}
.auth-page-switch a:hover { color: #fff; text-decoration: underline; }

.auth-page-fineprint {
    margin: 1.25rem 0 0;
    font-family: var(--font-body);
    font-size: 0.78rem;
    line-height: 1.5;
    color: rgba(255, 255, 255, 0.4);
    text-align: center;
}
.auth-page-fineprint a {
    color: rgba(255, 255, 255, 0.65);
    text-decoration: underline;
}
.auth-page-fineprint a:hover { color: var(--color-primary); }

/* ── Visual side ── */
.auth-page-visual {
    position: relative;
    background-size: cover;
    background-position: center;
    border-left: 2px solid var(--color-primary);
    min-height: 100%;
}
.auth-page-visual--left {
    border-left: 0;
    border-right: 2px solid var(--color-primary);
}
.auth-page-visual::after {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(135deg,
        rgba(8, 10, 14, 0.85) 0%,
        rgba(8, 10, 14, 0.45) 45%,
        rgba(8, 10, 14, 0.75) 100%);
}
.auth-page-visual-inner {
    position: absolute;
    inset: 0;
    z-index: 1;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    padding: 3rem;
}
.auth-page-visual-tag {
    font-family: var(--font-mono);
    font-size: 0.72rem;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    color: var(--color-primary);
    margin-bottom: 0.85rem;
}
.auth-page-visual h2 {
    font-family: var(--font-heading);
    font-size: clamp(1.8rem, 3vw, 2.6rem);
    color: #fff;
    text-transform: uppercase;
    letter-spacing: 1px;
    line-height: 1.05;
    margin: 0 0 0.85rem;
    font-weight: 400;
}
.auth-page-visual p {
    font-family: var(--font-body);
    color: rgba(255, 255, 255, 0.78);
    font-size: 1rem;
    line-height: 1.6;
    margin: 0;
    max-width: 440px;
}

/* ── Responsive ── */
@media (max-width: 900px) {
    .auth-page-grid { grid-template-columns: 1fr; }
    .auth-page-visual {
        display: none;       /* drop the image panel on small screens */
    }
    .auth-page { min-height: calc(100vh - 116px); }

    /* Centre the header block so it matches the centred header logo above.
       Form fields stay left-aligned for legibility. */
    .auth-page-form-side { padding: 2.5rem 1.5rem; }
    .auth-page-card { text-align: center; }
    .auth-page-logo { margin-left: auto; margin-right: auto; }
    .auth-page-card .section-tag { margin-left: auto; margin-right: auto; }
    .auth-page-form,
    .auth-page-field,
    .auth-page-field label,
    .auth-page-row { text-align: left; }
    .auth-page-check { justify-content: flex-start; }
}

/* ===========================
   GENERIC PAGE STYLES
   =========================== */
.page-header {
    padding: 8rem 0 3rem;
}

.page-title {
    font-size: 2.77rem;
    margin-bottom: 0.75rem;
}

.page-subtitle {
    font-size: 1.05rem;
    color: var(--color-text-muted);
    max-width: 550px;
    margin: 0 auto;
}

.rich-text-content {
    max-width: 850px;
    margin: 0 auto;
    padding: 2.5rem;
    background: var(--color-bg-card);
    border: 1px solid var(--color-bg-border);
    border-radius: var(--radius-base);
}

.rich-text-content h1,
.rich-text-content h2,
.rich-text-content h3 {
    margin: 2rem 0 1rem;
}

.rich-text-content p {
    margin-bottom: 1rem;
    color: var(--color-text);
}

.rich-text-content ul,
.rich-text-content ol {
    margin: 1rem 0;
    padding-left: 2rem;
    list-style: disc;
}

.rich-text-content li {
    margin-bottom: 0.5rem;
    color: var(--color-text);
}

.rich-text-content a {
    color: var(--color-primary);
}

.rich-text-content a:hover {
    text-decoration: underline;
}

.news-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(340px, 1fr));
    gap: 1.25rem;
}

.read-more {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    font-weight: 600;
    color: #fff;
}

.read-more:hover {
    color: var(--color-primary);
}

/* ===========================
   RESPONSIVE
   =========================== */
@media (max-width: 1100px) {

    .nav-topstrip {
        display: none;
    }

    .nav-left,
    .nav-right,
    .nav-divider-v {
        display: none;
    }

    .nav-container {
        padding: 0 1rem;
        justify-content: space-between;
    }

    .mobile-toggle {
        display: flex;
        align-items: center;
        justify-content: center;
        z-index: 10002;
        width: 44px;
        height: 44px;
        border-radius: 8px;
        background: rgba(255, 255, 255, 0.04);
        border: 1px solid rgba(255, 255, 255, 0.08);
        transition: all 0.25s;
    }

    .mobile-toggle:hover {
        background: rgba(240, 160, 66, 0.1);
        border-color: rgba(240, 160, 66, 0.3);
    }

    /* ── Premium Mobile Menu ── */
    .nav-mobile {
        display: none;
    }

    .nav-mobile.active {
        display: flex;
        position: fixed;
        top: 0;
        left: 0;
        width: 100vw;
        height: 100vh;
        height: 100dvh;
        z-index: 99998;
        background: rgba(7, 8, 13, 0.97);
        backdrop-filter: blur(24px) saturate(1.2);
        -webkit-backdrop-filter: blur(24px) saturate(1.2);
        flex-direction: column;
        /* No vertical centering — items flow top→bottom and fit the viewport.
           Internal scroll is disabled so nothing can hide under the close
           button. All sizing below uses clamp(min, vh, max) so the menu
           tightens on iPhone SE and breathes on iPhone Pro Max. */
        padding: clamp(0.7rem, 1.5vh, 1.25rem) 1.25rem clamp(0.85rem, 1.8vh, 1.5rem);
        overflow: hidden;
        animation: mobileMenuFadeIn 0.3s ease;
    }

    @keyframes mobileMenuFadeIn {
        from {
            opacity: 0;
            transform: scale(0.97);
        }

        to {
            opacity: 1;
            transform: scale(1);
        }
    }

    .nav-mobile.active::before {
        content: '';
        position: absolute;
        top: 0;
        left: 0;
        right: 0;
        height: 1px;
        background: linear-gradient(90deg, transparent, rgba(240, 160, 66, 0.4), transparent);
    }

    /* Close button — sits in flow at top-right of the menu, never overlaps
       with nav items. Scales with viewport. */
    .mobile-menu-close {
        position: relative;
        align-self: flex-end;
        flex-shrink: 0;
        width: clamp(40px, 5.5vh, 48px);
        height: clamp(40px, 5.5vh, 48px);
        border-radius: 10px;
        background: rgba(255, 255, 255, 0.04);
        border: 1px solid rgba(255, 255, 255, 0.1);
        color: #fff;
        font-size: clamp(1.05rem, 1.7vh, 1.3rem);
        cursor: pointer;
        display: flex;
        align-items: center;
        justify-content: center;
        transition: all 0.2s;
        z-index: 1;
    }

    .mobile-menu-close:hover {
        background: rgba(240, 160, 66, 0.12);
        border-color: rgba(240, 160, 66, 0.4);
        color: var(--color-primary);
    }

    .nav-mobile.active ul {
        display: flex;
        flex-direction: column;
        align-items: stretch;
        justify-content: center;
        gap: clamp(0.3rem, 0.7vh, 0.55rem);
        width: 100%;
        max-width: 360px;
        list-style: none;
        padding: 0;
        margin: clamp(0.4rem, 1vh, 0.85rem) auto 0;
        flex: 1;
        min-height: 0;
    }

    .nav-mobile.active li {
        list-style: none;
    }

    .nav-mobile.active a {
        display: flex;
        align-items: center;
        gap: clamp(0.6rem, 1.5vh, 0.95rem);
        font-family: var(--font-heading);
        font-size: clamp(0.9rem, 1.7vh, 1.15rem);
        color: rgba(255, 255, 255, 0.8);
        text-transform: uppercase;
        letter-spacing: 2px;
        text-decoration: none;
        padding: clamp(0.5rem, 1.4vh, 1rem) clamp(0.75rem, 1.5vh, 1.15rem);
        border-radius: 10px;
        background: rgba(255, 255, 255, 0.025);
        border: 1px solid rgba(255, 255, 255, 0.06);
        transition: all 0.2s;
        position: relative;
        overflow: hidden;
    }

    .nav-mobile.active a::before {
        content: '';
        position: absolute;
        left: 0;
        top: 0;
        bottom: 0;
        width: 3px;
        background: var(--color-primary);
        border-radius: 0 2px 2px 0;
        opacity: 0;
        transition: opacity 0.2s;
    }

    .nav-mobile.active a:hover,
    .nav-mobile.active a:active {
        background: rgba(240, 160, 66, 0.06);
        border-color: rgba(240, 160, 66, 0.2);
        color: #fff;
    }

    .nav-mobile.active a:hover::before,
    .nav-mobile.active a:active::before {
        opacity: 1;
    }

    /* Icon squares in mobile nav */
    .nav-mobile.active a i {
        width: clamp(28px, 4.2vh, 36px);
        height: clamp(28px, 4.2vh, 36px);
        border-radius: 7px;
        background: rgba(240, 160, 66, 0.1);
        border: 1px solid rgba(240, 160, 66, 0.2);
        display: flex;
        align-items: center;
        justify-content: center;
        font-size: clamp(0.7rem, 1.1vh, 0.9rem);
        color: var(--color-primary);
        flex-shrink: 0;
    }

    /* Download CTA inside mobile menu */
    .nav-mobile.active .mobile-nav-cta {
        background: var(--color-primary);
        border-color: var(--color-primary);
        color: #fff;
        justify-content: center;
        margin-top: 0.5rem;
    }

    .nav-mobile.active .mobile-nav-cta:hover {
        background: #c71a22;
    }

    .nav-mobile.active .mobile-nav-cta i {
        background: rgba(255, 255, 255, 0.15);
        border-color: rgba(255, 255, 255, 0.15);
        color: #fff;
    }

    /* Outline variant for Store CTA */
    .nav-mobile.active .mobile-nav-cta--outline {
        background: transparent;
        border-color: rgba(255, 255, 255, 0.15);
        color: rgba(255, 255, 255, 0.8);
    }

    .nav-mobile.active .mobile-nav-cta--outline:hover {
        background: rgba(255, 255, 255, 0.05);
        border-color: rgba(255, 255, 255, 0.3);
        color: #fff;
    }

    .nav-mobile.active .mobile-nav-cta--outline i {
        background: rgba(240, 160, 66, 0.1);
        border-color: rgba(240, 160, 66, 0.2);
        color: var(--color-primary);
    }

    /* Action buttons container */
    .mobile-nav-actions {
        display: flex;
        flex-direction: column;
        gap: 0.5rem;
        width: 100%;
        max-width: 340px;
        margin-top: 1rem;
    }

    /* Auth buttons in mobile menu */
    .mobile-nav-auth {
        align-self: center;
        flex-shrink: 0;
        margin-top: clamp(0.5rem, 1.2vh, 0.85rem);
        display: flex;
        gap: clamp(0.5rem, 1vh, 0.75rem);
        width: 100%;
        max-width: 360px;
        margin-top: 1rem;
    }

    .mobile-auth-btn {
        flex: 1;
        font-family: var(--font-heading);
        font-size: clamp(0.78rem, 1.3vh, 0.95rem);
        font-weight: 600;
        text-transform: uppercase;
        letter-spacing: 1.5px;
        padding: clamp(0.55rem, 1.1vh, 0.85rem) 1rem;
        border-radius: 8px;
        cursor: pointer;
        transition: all 0.2s;
        text-align: center;
        text-decoration: none;
        /* Override: nav-mobile a sets display:flex with no justify-content,
           which left-aligns text. Center the auth-button labels. */
        justify-content: center;
    }

    .mobile-auth-btn--login {
        background: transparent;
        color: rgba(255, 255, 255, 0.8);
        border: 1px solid rgba(255, 255, 255, 0.15);
    }

    .mobile-auth-btn--login:hover {
        color: #fff;
        border-color: rgba(255, 255, 255, 0.35);
        background: rgba(255, 255, 255, 0.04);
    }

    .mobile-auth-btn--register {
        background: #F0A042;
        color: #fff;
        border: 1px solid #F0A042;
    }

    .mobile-auth-btn--register:hover {
        background: #D88A2C;
        border-color: #D88A2C;
    }

    /* ── Mobile auth coming-soon popup ──
       Appears at the top of the mobile menu (to the left of the close
       button) when LOG IN or REGISTER is tapped. Auto-dismisses after a
       short timeout. Mirrors the desktop .nav-auth-popup design. */
    .mobile-auth-popup {
        position: absolute;
        top: clamp(0.7rem, 1.5vh, 1.25rem);
        left: 1.25rem;
        right: calc(1.25rem + clamp(40px, 5.5vh, 48px) + 0.6rem);
        background: rgba(12, 12, 18, 0.97);
        border: 1px solid rgba(240, 160, 66, 0.5);
        border-top: 2px solid rgba(240, 160, 66, 0.9);
        border-radius: 6px;
        padding: 0.65rem 0.9rem;
        display: flex;
        align-items: center;
        gap: 0.7rem;
        z-index: 10;
        backdrop-filter: blur(16px);
        -webkit-backdrop-filter: blur(16px);
        box-shadow: 0 12px 40px rgba(0, 0, 0, 0.6), 0 0 20px rgba(240, 160, 66, 0.08);
        opacity: 0;
        transform: translateY(-6px);
        transition: opacity 0.25s ease, transform 0.25s ease;
        pointer-events: none;
    }
    .mobile-auth-popup.show {
        opacity: 1;
        transform: translateY(0);
        pointer-events: all;
    }
    .map-icon {
        width: clamp(28px, 4vh, 34px);
        height: clamp(28px, 4vh, 34px);
        border-radius: 50%;
        background: rgba(240, 160, 66, 0.12);
        border: 1px solid rgba(240, 160, 66, 0.35);
        display: flex;
        align-items: center;
        justify-content: center;
        color: rgba(240, 160, 66, 0.9);
        font-size: 0.8rem;
        flex-shrink: 0;
    }
    .map-content {
        display: flex;
        flex-direction: column;
        gap: 0.15rem;
        min-width: 0;
    }
    .map-title {
        font-family: var(--font-heading);
        font-size: 0.7rem;
        font-weight: 700;
        letter-spacing: 1.4px;
        text-transform: uppercase;
        color: #fff;
        line-height: 1.1;
    }
    .map-sub {
        font-size: 0.62rem;
        color: rgba(255, 255, 255, 0.55);
        letter-spacing: 0.3px;
        line-height: 1.3;
    }

    /* Compact the lang switcher when it lives inside the open mobile menu —
       it always sits at the bottom and gets a subtle separator above it. */
    .nav-mobile.active .mobile-lang-switcher {
        align-self: center;
        flex-shrink: 0;
        width: 100%;
        max-width: 360px;
        justify-content: center;
        margin: clamp(0.45rem, 1vh, 0.75rem) 0 0;
        padding: clamp(0.5rem, 1vh, 0.75rem) 0 0;
        border-top: 1px solid rgba(255, 255, 255, 0.06);
    }

    .mobile-nav-socials {
        display: flex;
        gap: 0.75rem;
        margin-top: 2rem;
    }

    .mobile-nav-socials a {
        width: 42px !important;
        height: 42px !important;
        padding: 0 !important;
        border-radius: 50% !important;
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        background: rgba(255, 255, 255, 0.03) !important;
        border: 1px solid rgba(255, 255, 255, 0.08) !important;
        font-size: 1rem !important;
        letter-spacing: 0 !important;
        gap: 0 !important;
    }

    .mobile-nav-socials a::before {
        display: none !important;
    }

    .mobile-nav-socials a i {
        width: auto !important;
        height: auto !important;
        background: none !important;
        border: none !important;
        color: rgba(255, 255, 255, 0.5) !important;
    }

    .mobile-nav-socials a:hover {
        border-color: rgba(240, 160, 66, 0.4) !important;
        background: rgba(240, 160, 66, 0.08) !important;
    }

    .mobile-nav-socials a:hover i {
        color: var(--color-primary) !important;
    }

    /* ── Layout adjustments ── */
    .hero-split {
        grid-template-columns: 1fr;
        height: auto;
        min-height: auto;
    }

    .hero-split-left {
        height: 100vh !important;
        min-height: 100vh !important;
        padding: 4rem 1.5rem 2rem;
        align-items: center;
        justify-content: center;
    }

    /* Let the poster image be more visible on mobile */
    .hero-left-overlay {
        background: linear-gradient(180deg,
            rgba(8, 10, 14, 0.85) 0%,
            rgba(10, 12, 18, 0.7) 40%,
            rgba(8, 10, 14, 0.9) 100%);
    }

    .hero-split-content {
        align-items: center !important;
        text-align: center !important;
        max-width: 100% !important;
    }

    .hero-accent-line {
        margin: 0 auto 1rem !important;
    }

    .hero-headline {
        font-size: clamp(2.03rem, 8vw, 2.77rem) !important;
        text-align: center !important;
        margin-bottom: 1rem !important;
    }

    .hero-subtitle {
        font-size: 0.95rem !important;
        color: rgba(255, 255, 255, 0.85) !important;
        text-align: center !important;
        line-height: 1.7 !important;
        margin-bottom: 1.25rem !important;
        max-width: 100% !important;
    }

    .hero-badge {
        margin-bottom: 1.5rem !important;
        font-size: 0.6rem !important;
        letter-spacing: 2.5px !important;
    }

    .hero-actions {
        flex-direction: column !important;
        width: 100% !important;
        gap: 0.75rem !important;
    }

    .hero-actions .btn {
        width: 100% !important;
        justify-content: center !important;
        text-align: center !important;
    }

    .hero-live-count {
        margin-top: 1.5rem !important;
        justify-content: center !important;
    }

    .hero-split-right {
        min-height: 400px;
    }

    /* Hide video, show poster on mobile */
    .hero-left-bg {
        display: none;
    }
    .hero-left-poster {
        display: block;
    }

    /* Disable heavy effects on mobile for performance */
    .hero-particles,
    .hero-scanlines {
        display: none !important;
    }

    /* ── Global section tightening for mobile ── */
    .game-features,
    section {
        padding-top: 3rem !important;
        padding-bottom: 3rem !important;
    }

    .section-title {
        font-size: clamp(1.29rem, 5vw, 1.85rem) !important;
    }

    .section-tag {
        font-size: 0.65rem !important;
        letter-spacing: 2px !important;
    }

    .container {
        padding-left: 1rem !important;
        padding-right: 1rem !important;
    }

    /* Tighten cine panels */
    .cine-panel {
        min-height: 350px !important;
    }

    .cine-panel-inner {
        padding: 1.5rem 1rem !important;
    }

    .cine-panel-inner--right {
        justify-content: flex-start;
    }

    .museums-split {
        grid-template-columns: 1fr;
    }

    .museums-visual {
        height: 300px;
    }
    /* ── Store carousel mobile ── */
    .store-carousel-arrow {
        display: none !important;
    }

    .store-card {
        flex: 0 0 220px !important;
    }

    .store-carousel-track {
        gap: 0.75rem !important;
        padding-bottom: 0.75rem !important;
        scrollbar-width: thin !important;
        scrollbar-color: var(--color-primary) rgba(255,255,255,0.05) !important;
    }

    .store-carousel-track::-webkit-scrollbar {
        display: block !important;
        height: 4px !important;
    }

    .store-carousel-track::-webkit-scrollbar-track {
        background: rgba(255,255,255,0.05) !important;
        border-radius: 2px !important;
    }

    .store-carousel-track::-webkit-scrollbar-thumb {
        background: var(--color-primary) !important;
        border-radius: 2px !important;
    }

    .store-carousel {
        position: relative !important;
    }

    /* Gradient fade hint on right edge */
    .store-carousel::after {
        content: '' !important;
        position: absolute !important;
        top: 0 !important;
        right: 0 !important;
        bottom: 0 !important;
        width: 40px !important;
        background: linear-gradient(to left, var(--color-bg, #0a0a0e), transparent) !important;
        pointer-events: none !important;
        z-index: 5 !important;
    }
}

@media (max-width: 1024px) {
    .faq-cards-grid {
        grid-template-columns: 1fr;
        max-width: 500px;
        margin: 0 auto 3rem;
    }

    .tier-cards {
        grid-template-columns: 1fr;
        max-width: 420px;
        margin: 3rem auto 0;
    }

    .tier-card--featured {
        transform: none;
    }

    .tier-card--featured:hover {
        transform: translateY(-4px);
    }

    .footer-grid {
        grid-template-columns: 1fr 1fr;
        gap: 2.5rem 2rem;
    }

    .footer-brand {
        grid-column: span 2;
        text-align: center;
    }

    .footer-brand .footer-desc {
        max-width: 100%;
        margin-left: auto;
        margin-right: auto;
    }

    .footer-brand .footer-logo {
        margin-left: auto;
        margin-right: auto;
        display: block;
    }
}

@media (max-width: 768px) {
    section {
        padding: 4rem 0;
    }

    .store-showcase-header {
        flex-direction: column;
        align-items: flex-start;
        gap: 1rem;
    }

    .store-carousel-arrow {
        display: none;
    }

    .store-card {
        flex: 0 0 250px;
    }

    .footer {
        padding: 2.5rem 0 0;
    }

    .footer-grid {
        grid-template-columns: 1fr;
        text-align: center;
        gap: 2rem;
    }

    .footer-brand {
        grid-column: span 1;
    }

    .footer-brand .footer-desc {
        max-width: 100%;
        margin-left: auto;
        margin-right: auto;
    }

    .footer-brand .footer-logo {
        margin-left: auto;
        margin-right: auto;
        display: block;
    }

    .footer-col .footer-heading {
        display: block;
        border-bottom: 2px solid #F0A042;
        padding-bottom: 0.75rem;
    }

    .footer-col ul {
        align-items: center;
    }

    .footer-bottom {
        flex-direction: column;
        gap: 1rem;
        text-align: center;
    }

    .footer-partner-logos,
    .footer-partner-logos--small {
        height: 40px;
    }

    .news-magazine-grid {
        grid-template-columns: 1fr;
        grid-template-rows: auto;
    }

    .news-mag-card--hero {
        grid-row: auto;
        min-height: 280px;
    }

    .news-mag-card:not(.news-mag-card--hero) {
        min-height: 200px;
    }

    .stats-bridge-strip {
        flex-direction: column;
        gap: 1rem;
    }

    .stats-bridge-divider {
        width: 40px;
        height: 1px;
    }

    .hero-actions {
        flex-direction: column;
    }

    .cine-panel {
        min-height: 400px;
    }

    .cine-panel-inner {
        padding: 2rem 1.5rem;
    }

    .ks-modal {
        max-width: 100%;
    }

    .ks-modal-visual {
        height: 150px;
    }

    .museums-info {
        padding: 2.5rem 1.5rem;
    }
}

/* ═══════════════════════════════════════════
   BRAND DISTINCT — Aces & Armour overrides
   Tactical visual differentiation (loaded last)
   ═══════════════════════════════════════════ */

/* ─── Sharp corners on all interactive surfaces ─── */
.btn,
.pillar-card,
.arsenal-card,
.team-card,
.nl-card,
.home-news .news-card,
.feature-figure img,
.home-about-figure img,
.home-roadmap-figure img,
.arsenal-card img,
.showcase-tile,
.stat,
.article-figure img,
.news-card-img,
.home-video-frame,
input[type="text"],
input[type="email"],
input[type="search"],
input[type="number"],
input[type="password"],
textarea,
select,
.nl-search input,
.cb-banner-inner,
.cc-card,
.pk-fact,
.pk-asset,
.pk-shot,
.pk-color,
.contact-card,
.bu-benefit,
.ec-link-card,
.legal-toc {
    border-radius: 0 !important;
}

/* ─── Type system: Futura (non-bold / Medium 500) ───
   Per studio feedback: CF Game Of Chaos works only in the logo, not standalone;
   and Futura Bold reads too heavy. So everything is Futura MEDIUM (500).
   No squash/faux-bold hacks needed. !important beats the scattered
   `font-weight:400` declarations left over from single-weight Black Ops One. */
h1, h2, h3, h4, h5, h6,
.section-title,
.home-hero-title,
.about-hero-title,
.contact-hero-title,
.pk-hero-title,
.bu-hero-title,
.ec-hero-title,
.err-title,
.nl-hero-title,
.legal-hero-title,
.news-hero-title,
.pillar-card h3,
.arsenal-card figcaption strong,
.contact-card h3,
.bu-benefit h3,
.bu-direct-card h3,
.ec-link-card h3,
.err-route strong,
.pk-fact strong,
.faq-q,
.legal-article h2,
.prose h2,
.news-article h2,
.news-article h3,
.nl-card-title,
.news-card-title,
.faq-cat-tag,
.section-tag,
.home-hero-eyebrow,
.bu-direct-action,
.contact-card-link,
.ec-link-cta,
.nav-auth-btn,
.mobile-auth-btn,
.btn,
.nav-link,
.lang-current,
.lang-soon-label,
.footer-heading,
.lang-option-code,
.bu-direct-status,
.nav-topstrip-link {
    font-weight: 500 !important;
    letter-spacing: 1px;
}

/* Big display titles → Futura Medium (non-bold) */
.home-hero-title,
.hs-title,
.section-title,
.about-hero-title,
.contact-hero-title,
.pk-hero-title,
.bu-hero-title,
.ec-hero-title,
.err-title,
.err-code,
.nl-hero-title,
.legal-hero-title,
.news-hero-title {
    font-family: var(--font-display) !important;
    font-weight: 500 !important;
    letter-spacing: 0.5px;
}

/* Rajdhani is variable — body weights look right at 400/500, bold at 600/700 */
strong, b {
    font-weight: 600;
}

/* ─── Section tag: tactical left-bar + tighter ─── */
.section-tag {
    border-bottom: none !important;
    border-left: 2px solid var(--color-primary);
    padding: 0.2rem 0 0.2rem 0.7rem !important;
    margin-bottom: 1rem;
    display: inline-block;
}

/* ─── Buttons ─── */
.btn-outline { border-width: 1px; }
.btn-primary {
    border: 1px solid var(--color-primary);
}
.btn-primary:hover {
    background: var(--color-primary-dark);
    border-color: var(--color-primary-dark);
}

/* ─── Cards: corner-bracket hover indicator ─── */
.pillar-card,
.arsenal-card,
.nl-card,
.home-news .news-card,
.contact-card,
.bu-benefit,
.ec-link-card {
    position: relative;
}
.pillar-card::before,
.pillar-card::after,
.arsenal-card::before,
.arsenal-card::after,
.nl-card::before,
.nl-card::after,
.home-news .news-card::before,
.home-news .news-card::after,
.contact-card::before,
.contact-card::after,
.bu-benefit::before,
.bu-benefit::after,
.ec-link-card::before,
.ec-link-card::after {
    content: '';
    position: absolute;
    width: 12px;
    height: 12px;
    pointer-events: none;
    opacity: 0;
    transition: opacity var(--transition-fast);
    z-index: 2;
}
.pillar-card::before,
.arsenal-card::before,
.nl-card::before,
.home-news .news-card::before,
.contact-card::before,
.bu-benefit::before,
.ec-link-card::before {
    top: -1px; left: -1px;
    border-top: 2px solid var(--color-primary);
    border-left: 2px solid var(--color-primary);
}
.pillar-card::after,
.arsenal-card::after,
.nl-card::after,
.home-news .news-card::after,
.contact-card::after,
.bu-benefit::after,
.ec-link-card::after {
    bottom: -1px; right: -1px;
    border-bottom: 2px solid var(--color-primary);
    border-right: 2px solid var(--color-primary);
}
.pillar-card:hover::before,
.pillar-card:hover::after,
.arsenal-card:hover::before,
.arsenal-card:hover::after,
.nl-card:hover::before,
.nl-card:hover::after,
.home-news .news-card:hover::before,
.home-news .news-card:hover::after,
.contact-card:hover::before,
.contact-card:hover::after,
.bu-benefit:hover::before,
.bu-benefit:hover::after,
.ec-link-card:hover::before,
.ec-link-card:hover::after {
    opacity: 1;
}

/* ─── Stat cards: top accent line ─── */
.stat {
    border-top: 3px solid var(--color-primary);
}

/* ─── Footer ─── */
.footer {
    border-top: 1px solid var(--color-bg-border);
    position: relative;
}
.footer::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    width: 100%;
    height: 3px;
    background: var(--color-primary);
}
.footer-heading {
    position: relative;
    padding-left: 0.7rem !important;
    border-left: 2px solid var(--color-primary);
}

/* ─── Hero bottom accent ─── */
.home-hero,
.about-hero,
.nl-hero,
.pk-hero,
.contact-hero,
.bu-hero,
.ec-hero,
.err-hero,
.legal-hero {
    position: relative;
}
.home-hero::after,
.about-hero::after,
.nl-hero::after,
.pk-hero::after,
.contact-hero::after,
.bu-hero::after,
.ec-hero::after,
.err-hero::after,
.legal-hero::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 50%;
    transform: translateX(-50%);
    width: 80px;
    height: 4px;
    background: var(--color-primary);
    z-index: 3;
}

/* ─── Top strip: accent link for highlighted item (Survey) ─── */
.nav-topstrip-link--accent {
    color: var(--color-primary) !important;
    font-weight: 600;
}
.nav-topstrip-link--accent i {
    margin-right: 0.3rem;
    font-size: 0.9em;
}
.nav-topstrip-link--accent:hover {
    color: var(--color-text-bright) !important;
}

/* ─── Auth buttons in main nav ─── */
.nav-auth-btn i {
    font-size: 0.85em;
}
.nav-auth-btn--login {
    border-color: var(--color-bg-border) !important;
}
.nav-auth-btn--login:hover {
    color: var(--color-primary) !important;
    border-color: var(--color-primary) !important;
    background: transparent !important;
}

/* ─── Mobile auth buttons ─── */
.mobile-nav-auth {
    display: flex;
    gap: 0.5rem;
    padding: 1rem 1.25rem 0;
    margin-top: 0.5rem;
    border-top: 1px solid var(--color-bg-border);
    padding-top: 1.25rem;
}
.mobile-auth-btn {
    flex: 1;
    font-family: var(--font-heading);
    font-size: 0.85rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 1.5px;
    padding: 0.75rem 1rem;
    text-align: center;
    text-decoration: none;
    border: 1px solid var(--color-bg-border);
    color: var(--color-text-bright);
    transition: background var(--transition-fast), color var(--transition-fast), border-color var(--transition-fast);
}
.mobile-auth-btn--login:hover {
    color: var(--color-primary);
    border-color: var(--color-primary);
}
.mobile-auth-btn--register {
    background: var(--color-primary);
    border-color: var(--color-primary);
    color: #fff;
}
.mobile-auth-btn--register:hover {
    background: var(--color-primary-dark);
    border-color: var(--color-primary-dark);
}

/* ─── Language switcher dropdown ─── */
.lang-switcher {
    position: relative;
}
.lang-current {
    -webkit-appearance: none;
    appearance: none;
    border-radius: var(--radius-base);   /* curved corners — match across button + hover bg + border */
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    padding: 0.3rem 0.6rem;
    background: transparent;
    border: 1px solid transparent;
    color: rgba(255, 255, 255, 0.7);
    font-family: var(--font-heading);
    font-size: 0.85rem;
    line-height: 1;
    letter-spacing: 1.5px;
    cursor: pointer;
    transition: background var(--transition-fast), color var(--transition-fast), border-color var(--transition-fast);
}
.lang-current i {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    line-height: 1;
}
.lang-current .lang-current-label {
    display: inline-flex;
    align-items: center;
    line-height: 1;
}
.lang-current:hover,
.lang-current[aria-expanded="true"] {
    color: var(--color-primary);
    border-color: var(--color-bg-border);
    background: var(--color-bg-card);
}
.lang-current-flag {
    width: 18px;
    height: 12px;
    border: 1px solid rgba(255, 255, 255, 0.15);
}
.lang-chevron {
    font-size: 0.6rem;
    transition: transform var(--transition-base);
    margin-left: 0.1rem;
}
.lang-current[aria-expanded="true"] .lang-chevron {
    transform: rotate(180deg);
}

.lang-dropdown {
    position: absolute;
    top: calc(100% + 6px);
    right: 0;
    min-width: 260px;
    background: var(--color-bg-card);
    border: 1px solid var(--color-bg-border);
    box-shadow: 0 16px 40px rgba(0, 0, 0, 0.55);
    opacity: 0;
    pointer-events: none;
    transform: translateY(-8px);
    transition: opacity 0.2s ease, transform 0.2s ease;
    z-index: 1000;
    max-height: 70vh;
    overflow-y: auto;
    padding: 0.4rem 0;
}
.lang-dropdown::before {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0;
    height: 2px;
    background: var(--color-primary);
}
.lang-switcher--open .lang-dropdown {
    opacity: 1;
    pointer-events: auto;
    transform: translateY(0);
}

.lang-option {
    display: flex;
    align-items: center;
    gap: 0.7rem;
    width: 100%;
    padding: 0.65rem 1rem;
    background: transparent;
    border: 0;
    color: var(--color-text);
    font-family: var(--font-body);
    font-size: 0.92rem;
    text-align: left;
    cursor: pointer;
    transition: background var(--transition-fast), color var(--transition-fast);
    position: relative;
}
.lang-option:hover {
    background: var(--color-bg-hover);
    color: var(--color-text-bright);
}
.lang-option--active {
    color: var(--color-primary);
    background: rgba(240, 160, 66, 0.06);
}
.lang-option-name { flex: 1; }
.lang-option-code {
    font-family: var(--font-mono, 'JetBrains Mono', monospace);
    font-size: 0.72rem;
    color: var(--color-text-muted);
    letter-spacing: 1px;
}
.lang-option--active .lang-option-code { color: var(--color-primary); }
.lang-option-check {
    color: var(--color-primary);
    font-size: 0.8rem;
    margin-left: 0.25rem;
    opacity: 0;
}
.lang-option--active .lang-option-check { opacity: 1; }

.lang-flag-icon {
    width: 22px;
    height: 14px;
    border: 1px solid rgba(255, 255, 255, 0.1);
    flex-shrink: 0;
}
.lang-flag-text {
    width: 22px;
    height: 14px;
    background: var(--color-bg-section);
    border: 1px solid var(--color-bg-border);
    color: var(--color-text-muted);
    font-family: var(--font-mono, 'JetBrains Mono', monospace);
    font-size: 0.55rem;
    font-weight: 700;
    letter-spacing: 0.5px;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.lang-divider {
    height: 1px;
    background: var(--color-bg-border);
    margin: 0.4rem 0;
}
.lang-soon-label {
    padding: 0.4rem 1rem 0.3rem;
    font-family: var(--font-heading);
    font-size: 0.7rem;
    color: var(--color-text-muted);
    text-transform: uppercase;
    letter-spacing: 2.5px;
}

.lang-option--soon {
    color: var(--color-text-muted);
    cursor: not-allowed;
    opacity: 0.55;
}
.lang-option--soon:hover {
    background: transparent;
    color: var(--color-text-muted);
}

/* Smaller flag icons on mobile lang switcher (kept inline buttons there) */
.mobile-lang-switcher .flag-icon {
    width: 26px;
    height: 16px;
}

/* ─── Custom scrollbar ─── */
::-webkit-scrollbar {
    width: 10px;
    height: 10px;
}
::-webkit-scrollbar-track {
    background: var(--color-bg);
}
::-webkit-scrollbar-thumb {
    background: var(--color-bg-border);
    border-right: 2px solid var(--color-primary);
}
::-webkit-scrollbar-thumb:hover {
    background: var(--color-bg-hover);
}

/* ─── Navbar accents ─── */
.navbar {
    border-bottom: 1px solid var(--color-bg-border);
}
.nav-link--active {
    color: var(--color-primary) !important;
    position: relative;
}
/* Underline rule lives in _includes/header.html (.nav-main .nav-link--active::after) */

/* ─── Subtle tactical grid on dark sections ─── */
.home-pillars,
.home-showcase,
.home-team,
.about-arsenal,
.about-team,
.pk-fact-sheet,
.pk-screenshots,
.pk-palette,
.bu-benefits {
    position: relative;
}
.home-pillars::before,
.home-showcase::before,
.home-team::before,
.about-arsenal::before,
.about-team::before,
.pk-fact-sheet::before,
.pk-screenshots::before,
.pk-palette::before,
.bu-benefits::before {
    content: '';
    position: absolute;
    inset: 0;
    background-image:
        linear-gradient(rgba(240, 160, 66, 0.03) 1px, transparent 1px),
        linear-gradient(90deg, rgba(240, 160, 66, 0.03) 1px, transparent 1px);
    background-size: 60px 60px;
    pointer-events: none;
    z-index: 0;
}
.home-pillars > *,
.home-showcase > *,
.home-team > *,
.about-arsenal > *,
.about-team > *,
.pk-fact-sheet > *,
.pk-screenshots > *,
.pk-palette > *,
.bu-benefits > * {
    position: relative;
    z-index: 1;
}

/* ─── Show "BUILD //" mark in the hero corner for a tactical feel ─── */
.home-hero-inner,
.about-hero-inner {
    position: relative;
}

/* ─── Article body links ─── */
.news-article a {
    color: var(--color-primary);
    text-decoration: underline;
    text-decoration-thickness: 1px;
    text-underline-offset: 3px;
}
.news-article a:hover {
    color: var(--color-primary-dark);
}

/* ─── Form inputs ─── */
input[type="text"],
input[type="email"],
input[type="search"],
input[type="number"],
input[type="password"],
textarea,
select {
    background: var(--color-bg-card);
    border: 1px solid var(--color-bg-border);
    color: var(--color-text);
    padding: 0.7rem 1rem;
    font-family: var(--font-body);
    font-size: 0.95rem;
    transition: border-color var(--transition-fast);
}
input[type="text"]:focus,
input[type="email"]:focus,
input[type="search"]:focus,
input[type="number"]:focus,
input[type="password"]:focus,
textarea:focus,
select:focus {
    outline: none;
    border-color: var(--color-primary);
}

