@font-face {
    font-family: "N1F Montserrat";
    src:
        url("../fonts/Montserrat-ExtraBold.ttf.woff") format("woff"),
        url("../fonts/Montserrat Extra Bold.otf") format("opentype");
    font-weight: 800;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: "N1F Orbitron";
    src: url("../fonts/orbitron-bold.otf") format("opentype");
    font-weight: 700;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: "N1F Bebas";
    src:
        url("../fonts/BebasNeue-Regular.woff2") format("woff2"),
        url("../fonts/BebasNeue-Regular.woff") format("woff"),
        url("../fonts/BebasNeue-Regular.otf") format("opentype");
    font-weight: 400;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: "N1F Marker";
    src: url("../fonts/PermanentMarker-Regular.ttf") format("truetype");
    font-weight: 400;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: "N1F Cinzel";
    src: url("../fonts/Cinzel-Bold.otf") format("opentype");
    font-weight: 700;
    font-style: normal;
    font-display: swap;
}

:root {

    /* ========= CORE ========= */

    --n1f-bg: #050505;

    --n1f-text: #f5f5f5;

    --n1f-soft-text: rgba(255,255,255,0.72);

    --n1f-border: rgba(255,255,255,0.08);

    --n1f-border-soft: rgba(255,255,255,0.04);
    
    --n1f-panel-radius: 18px;

    --n1f-glow-white:
        0 0 10px rgba(255,255,255,0.10),
        0 0 26px rgba(255,255,255,0.04);

    --n1f-shadow-soft:
        0 12px 32px rgba(0,0,0,0.32);

    --n1f-transition:
        220ms cubic-bezier(.2,.8,.2,1);

    /* ========= GENRES ========= */

    --electronic: #8f5cff;

    --electronic-glow:
        0 0 18px rgba(143,92,255,0.34);

    --rock: #ff4747;

    --rock-glow:
        0 0 18px rgba(255,71,71,0.30);

    --urban: #58e8ff;

    --urban-glow:
        0 0 18px rgba(88,232,255,0.28);

    --voice: #f1c878;

    --voice-glow:
        0 0 18px rgba(241,200,120,0.30);
}

body[data-world="neutral"] {
    --world-accent: rgba(255,255,255,0.82);
    --world-accent-soft: rgba(255,255,255,0.22);
    --world-accent-glow: rgba(255,255,255,0.14);
    --world-accent-rgb: 255,255,255;
}

body[data-world="electronic"] {
    --world-accent: var(--electronic);
    --world-accent-soft: rgba(143,92,255,0.24);
    --world-accent-glow: rgba(143,92,255,0.18);
    --world-accent-rgb: 143,92,255;
}

body[data-world="rock"] {
    --world-accent: var(--rock);
    --world-accent-soft: rgba(255,71,71,0.24);
    --world-accent-glow: rgba(255,71,71,0.18);
    --world-accent-rgb: 255,71,71;
}

body[data-world="urban"] {
    --world-accent: var(--urban);
    --world-accent-soft: rgba(88,232,255,0.24);
    --world-accent-glow: rgba(88,232,255,0.18);
    --world-accent-rgb: 88,232,255;
}

body[data-world="voice"] {
    --world-accent: var(--voice);
    --world-accent-soft: rgba(241,200,120,0.24);
    --world-accent-glow: rgba(241,200,120,0.18);
    --world-accent-rgb: 241,200,120;
}

*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; }
html,
body {
    margin: 0;
    padding: 0;
    min-height: 100%;
    overflow-x: hidden;

    background:
        radial-gradient(
            circle at 48% 0%,
            var(--world-accent-glow),
            transparent 42%
        ),
        #050507;

    color: var(--n1f-text);

    font-family:
        Inter,
        "Segoe UI",
        sans-serif;
}
a { color: inherit; text-decoration: none; }
img { display: block; max-width: 100%; }

.n1f-entry {
    width: 100%;
    min-height: 100vh;
    padding: 14px 24px 12px;
    display: grid;
    grid-template-rows: auto auto minmax(0, 1fr) auto;
    gap: 9px;
}

.n1f-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 24px;

    overflow: visible;

    background:
        linear-gradient(
            90deg,
            rgba(255,255,255,0.035) 0%,
            rgba(255,255,255,0.018) 18%,
            rgba(255,255,255,0.006) 42%,
            transparent 72%
        );
}

.n1f-brand {
    display: flex;
    align-items: center;
    gap: clamp(18px, 2vw, 32px);
    min-width: 0;
    position: relative;
    overflow: visible;
}

.n1f-brand::before {
    content: "";

    position: absolute;

    left: -90px;
    top: -70px;

    width: 420px;
    height: 280px;

    pointer-events: none;

    background:
        radial-gradient(
            ellipse at 18% 44%,
            rgba(255,255,255,0.070) 0%,
            rgba(210,215,235,0.045) 18%,
            rgba(150,140,190,0.030) 36%,
            rgba(80,60,120,0.018) 58%,
            transparent 82%
        );

    filter: blur(30px);

    opacity: 0.58;

    z-index: 0;
}

.n1f-brand-logo {
    position: relative;
    z-index: 2;
    width: clamp(92px, 7vw, 150px);
    height: auto;
    filter: 
		drop-shadow(0 0 5px var(--n1f-border))
        drop-shadow(0 0 14px rgba(220,225,235,0.08));
}

.n1f-brand-text {
    display: flex;
    flex-direction: column;
    gap: 1px;
    min-width: 0;
    font-family: "N1F Montserrat", sans-serif;
}

.n1f-wordmark-img {
    display: block;

    width: clamp(240px, 16vw, 400px);
    height: auto;

    opacity: 0.98;

    filter:
        drop-shadow(0 0 10px rgba(255,255,255,0.06))
        drop-shadow(0 0 18px var(--world-accent-glow));
}

.n1f-tagline-img {
    display: block;

    width: clamp(220px, 15.5vw, 360px);
    height: auto;

    opacity: 0.18;

    margin-top: -10px;

    filter:
        drop-shadow(0 0 10px var(--world-accent-glow))
        drop-shadow(0 0 18px var(--world-accent-glow));
}

.n1f-brand-logo,
.n1f-wordmark-img,
.n1f-tagline-img {
    transition:
        filter 420ms ease,
        opacity 420ms ease,
        transform 420ms ease;
}

body:not([data-world="neutral"]) .n1f-brand-logo,
body:not([data-world="neutral"]) .n1f-wordmark-img,
body:not([data-world="neutral"]) .n1f-tagline-img {
    filter:
        drop-shadow(0 0 4px var(--world-accent-soft))
        drop-shadow(0 0 10px var(--world-accent-glow));
}

.n1f-nav {
    display: flex;
    align-items: center;

    gap: clamp(22px, 2.2vw, 54px);

    margin-right: clamp(10px, 1.2vw, 28px);

    font-family: "N1F Montserrat", sans-serif;
}

.n1f-nav a {
    position: relative;

    padding: 8px 0 10px;

    color: var(--world-accent);

    text-transform: uppercase;
    letter-spacing: 0.24em;

    font-size: clamp(10px, 0.72vw, 13px);
    font-weight: 800;

    transition:
        color 220ms ease,
        text-shadow 220ms ease,
        transform 220ms ease;
}

.n1f-nav a::after {
    content: "";

    position: absolute;
    left: 0;
    bottom: 8px;

    width: 100%;
    height: 1px;

    background:
        linear-gradient(
            90deg,
            transparent,
            var(--world-accent),
            transparent
        );

    opacity: 0;

    transform:
        scaleX(0.35)
        translateY(2px);

    transform-origin: center;

    transition:
        opacity 620ms ease,
        transform 1020ms cubic-bezier(0.19, 1, 0.22, 1);
}

.n1f-nav a:hover {
    color: var(--world-accent);

    transform: translateY(-1px);

    text-shadow:
        0 0 8px var(--world-accent-glow);
}

.n1f-nav a:hover::after {
    opacity: 1;

    transform:
        scaleX(1)
        translateY(0);
}

.n1f-intro {
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
}

.n1f-intro h1 {
    margin: 0;
    color: rgba(255,255,255,0.72);
    font-family: "N1F Montserrat", sans-serif;
    text-transform: uppercase;
    letter-spacing: 0.32em;
    font-size: clamp(12px, 0.9vw, 18px);
    font-weight: 800;
}

.n1f-footer {
    display: grid;
    grid-template-columns: 1fr auto 1fr;
    align-items: center;
    gap: 16px;

    color: rgba(255,255,255,0.48);

    text-transform: uppercase;
    letter-spacing: 0.18em;
    font-size: clamp(9px, 0.65vw, 11px);
}

.n1f-footer > span:first-child {
    text-align: left;
}

.n1f-footer > span:last-child {
    text-align: right;
}

.n1f-footer-center {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 14px;

    color: rgba(255,255,255,0.8);
}

.n1f-footer a {
    color: rgba(255,255,255,0.62);

    text-decoration: none;

    transition:
        color 220ms ease,
        text-shadow 220ms ease,
        opacity 220ms ease;
}

.n1f-footer a:hover {
    color: var(--world-accent);

    text-shadow:
        0 0 10px var(--world-accent-glow);
}

.n1f-page-content {
    width: min(980px, 100%);
    margin:
        clamp(120px, 10vw, 180px)
        auto
        clamp(80px, 6vw, 120px);
    padding: clamp(24px, 4vw, 56px);
    border: 1px solid rgba(255,255,255,0.12);
    border-radius: 18px;
    background: rgba(0,0,0,0.34);
}

..n1f-subpage {
    position: relative;
    min-height: 100vh;
    overflow: hidden;
}

.n1f-page-content {
    position: relative;
    z-index: 2;

    width: min(1100px, 100%);
    margin: 0 auto;

    padding:
        clamp(36px, 4vw, 72px);

    border-radius: 28px;

    background:
        linear-gradient(
            180deg,
            rgba(8,8,14,0.82),
            rgba(4,4,8,0.88)
        );

    border:
        1px solid rgba(255,255,255,0.06);

    backdrop-filter:
        blur(12px);

    box-shadow:
        0 20px 80px rgba(0,0,0,0.42);
}

.n1f-page-content h1 {
    margin: 0 0 28px;

    font-size: clamp(48px, 6vw, 120px);
    line-height: 0.9;
    letter-spacing: 0.08em;
    text-transform: uppercase;

    color: var(--world-accent);

    text-shadow:
        0 0 18px var(--world-accent-glow);
}

.n1f-page-content p {
    max-width: 760px;

    color: rgba(255,255,255,0.72);

    line-height: 1.8;

    font-size: clamp(15px, 1vw, 18px);
}

/* =========================================================
   WORLD TEMPLATE
========================================================= */

.n1f-world-page {
    position: relative;
    min-height: 100vh;
    overflow: hidden;
}

.n1f-world-hero {
    position: relative;
    z-index: 2;

    min-height: 100vh;

    display: flex;
    align-items: center;
    justify-content: center;

    padding:
        clamp(120px, 10vw, 180px)
        clamp(28px, 4vw, 72px)
        clamp(100px, 8vw, 140px);
}

.n1f-world-hero-inner {
    position: relative;

    width: min(1200px, 100%);

    padding:
        clamp(42px, 5vw, 88px);

    border-radius: 34px;

    background:
        linear-gradient(
            180deg,
            rgba(8,8,14,0.72),
            rgba(4,4,8,0.86)
        );

    border:
        1px solid var(--world-accent-soft);

    backdrop-filter:
        blur(18px);

    box-shadow:
        0 0 0 1px rgba(255,255,255,0.025),
        0 0 46px var(--world-accent-glow),
        0 24px 80px rgba(0,0,0,0.46);
}

.n1f-world-kicker {
    margin: 0 0 18px;

    color: rgba(255,255,255,0.42);

    text-transform: uppercase;
    letter-spacing: 0.22em;

    font-size: 12px;
}

.n1f-world-hero h1 {
    margin: 0;

    font-size: clamp(56px, 8vw, 132px);
    line-height: 0.88;

    letter-spacing: 0.06em;
    text-transform: uppercase;

    color: var(--world-accent);

    text-shadow:
        0 0 18px var(--world-accent-glow);
    max-width: 100%;
    overflow-wrap: normal;
    white-space: nowrap;
}

.n1f-world-claim {
    margin-top: 22px;

    font-size: clamp(18px, 1.4vw, 28px);
    line-height: 1.5;

    color: rgba(255,255,255,0.76);

    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.n1f-world-body {
    margin-top: 54px;

    max-width: 760px;

    color: rgba(255,255,255,0.72);

    line-height: 1.9;

    font-size: clamp(15px, 1vw, 18px);
}

/* =========================================================
   WORLD PAGE ATMOSPHERE
========================================================= */

.n1f-world-page::before {
    content: "";
    position: absolute;
    inset: 0;
    z-index: 0;

    background:
        radial-gradient(
            circle at 50% 28%,
            var(--world-accent-soft),
            rgba(0,0,0,0) 34%
        ),
        radial-gradient(
            circle at 50% 72%,
            var(--world-accent-glow),
            rgba(0,0,0,0) 42%
        );

    opacity: 0.72;
    pointer-events: none;
}

.n1f-world-page::after {
    content: "";
    position: absolute;
    inset: 0;
    z-index: 1;

    background:
        linear-gradient(
            180deg,
            rgba(0,0,0,0.12),
            rgba(0,0,0,0.72)
        );

    pointer-events: none;
}

.n1f-world-hero,
.n1f-header,
.n1f-footer {
    position: relative;
    z-index: 2;
}

/* =========================================================
   WORLD PAGE IMAGE ATMOSPHERE
========================================================= */

.n1f-world-stage-bg {
    position: absolute;
    inset: 0;
    z-index: 0;

    overflow: hidden;
    pointer-events: none;

    opacity: 0.44;
}

.n1f-world-stage-bg img {
    width: 100%;
    height: 100%;

    object-fit: cover;

    filter:
        blur(2px)
        brightness(0.36)
        saturate(1.25);

    transform: scale(1.12);
}

/* =========================================================
   WORLD BACKGROUND MOTION
========================================================= */

/* ELECTRONIC */

.n1f-world-electronic .n1f-world-stage-bg img {
    animation:
        n1f-bg-electronic
        34s
        ease-in-out
        infinite;
}

/* ROCK */

.n1f-world-rock .n1f-world-stage-bg img {
    animation:
        n1f-bg-rock
        11s
        cubic-bezier(.18,.72,.22,1)
        infinite;

    filter:
        blur(18px)
        brightness(0.32)
        saturate(1.3)
        contrast(1.08);
}

/* URBAN */

.n1f-world-urban .n1f-world-stage-bg img {
    animation:
        n1f-bg-urban
        6s
        cubic-bezier(.22,.78,.22,1)
        infinite;

    filter:
        blur(2px)
        brightness(0.94)
        saturate(1.22);
}

/* VOICE */

.n1f-world-voice .n1f-world-stage-bg img {
    animation:
        n1f-bg-voice
        42s
        ease-in-out
        infinite;

    filter:
        blur(18px)
        brightness(0.48)
        saturate(1.08);
}

/* =========================================================
   KEYFRAMES
========================================================= */

@keyframes n1f-bg-electronic {

    0%, 100% {
        transform:
            scale(1.12)
            translate3d(-1%, 0, 0);
    }

    50% {
        transform:
            scale(1.18)
            translate3d(1.2%, -1%, 0);
    }
}

@keyframes n1f-bg-rock {

    0%, 100% {
        transform:
            scale(1.14)
            translate3d(0,0,0);
    }

    46% {
        transform:
            scale(1.17)
            translate3d(-0.4%,0.2%,0);
    }

    48% {
        transform:
            scale(1.175)
            translate3d(0.5%,-0.2%,0);
    }

    52% {
        transform:
            scale(1.18)
            translate3d(0,0.3%,0);
    }
}

@keyframes n1f-bg-urban {

    0%, 100% {
        transform:
            scale(1.12);
    }

    40% {
        transform:
            scale(1.16);
    }

    55% {
        transform:
            scale(1.135);
    }

    72% {
        transform:
            scale(1.18);
    }
}

@keyframes n1f-bg-voice {

    0%, 100% {
        transform:
            scale(1.10)
            translate3d(0,0,0);
    }

    50% {
        transform:
            scale(1.15)
            translate3d(0,-0.8%,0);
    }
}

@keyframes n1f-world-bg-drift {
    0%, 100% {
        transform: scale(1.12) translate3d(-1.2%, 0, 0);
    }

    50% {
        transform: scale(1.18) translate3d(1.2%, -0.8%, 0);
    }
}

.n1f-world-signal {
    margin:
        clamp(18px, 2vw, 30px)
        0
        0;

    max-width: 1080px;

    color: rgba(255,255,255,0.52);

    font-size: clamp(13px, 0.85vw, 16px);
    line-height: 1.8;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

.n1f-world-signal::before {
    content: "";
    display: block;

    width: 72px;
    height: 1px;

    margin-bottom: 18px;

    background: var(--world-accent);

    box-shadow:
        0 0 12px var(--world-accent-glow);
}

/* =========================================================
   WORLD NAV TYPOGRAPHY — FINAL OVERRIDE
========================================================= */

body[data-world="electronic"] header.n1f-header nav.n1f-nav a {
    font-family: "N1F Orbitron", sans-serif;
    letter-spacing: 0.16em;
}

body[data-world="rock"] header.n1f-header nav.n1f-nav a {
    font-family: "N1F Bebas", "Arial Black", sans-serif;
    letter-spacing: 0.20em;
}

body[data-world="urban"] header.n1f-header nav.n1f-nav a {
    font-family: "N1F Marker", "Comic Sans MS", cursive;
    letter-spacing: 0.15em;
}

body[data-world="voice"] header.n1f-header nav.n1f-nav a {
    font-family: "N1F Cinzel", Georgia, serif;
    letter-spacing: 0.18em;
}

/* =========================================================
   WORLD NAV HOVER MOTION
========================================================= */

body:not([data-world="neutral"]) header.n1f-header nav.n1f-nav a {
    position: relative;
    display: inline-block;
    overflow: hidden;
}

/* ELECTRONIC — electric jitter */
body[data-world="electronic"] header.n1f-header nav.n1f-nav a:hover {
    color: #d9c7ff;

    text-shadow:
        0 0 2px rgba(255,255,255,0.95),
        0 0 8px rgba(180,135,255,0.88),
        0 0 18px rgba(143,92,255,0.58),
        0 0 32px rgba(143,92,255,0.28);

    filter:
        drop-shadow(0 0 4px rgba(180,135,255,0.55));
}

@keyframes n1f-nav-electric {
    0%, 100% {
        transform: translate3d(0,0,0);
    }

    18% {
        transform: translate3d(-1px,0,0);
    }

    32% {
        transform: translate3d(1px,-1px,0);
    }

    46% {
        transform: translate3d(-1px,1px,0);
    }

    62% {
        transform: translate3d(1px,0,0);
    }
}

/* ROCK — one brutal shake */
body[data-world="rock"] header.n1f-header nav.n1f-nav a:hover {
    animation:
        n1f-nav-rock-hit
        420ms
        cubic-bezier(.18,.72,.22,1)
        1;

    text-shadow:
        0 0 8px rgba(255,92,58,0.64),
        0 0 18px rgba(255,44,32,0.34);
}

@keyframes n1f-nav-rock-hit {
    0%, 100% {
        transform: translate3d(0,0,0) rotate(0);
    }

    22% {
        transform: translate3d(-2px,1px,0) rotate(-0.8deg);
    }

    38% {
        transform: translate3d(2px,-1px,0) rotate(0.7deg);
    }

    54% {
        transform: translate3d(-1px,0,0) rotate(-0.4deg);
    }

    72% {
        transform: translate3d(1px,0,0) rotate(0.25deg);
    }
}

/* URBAN — bass pump */
body[data-world="urban"] header.n1f-header nav.n1f-nav a:hover {
    animation:
        n1f-nav-urban-pump
        900ms
        cubic-bezier(.22,.78,.22,1)
        infinite;

    text-shadow:
        0 0 8px rgba(120,245,255,0.62),
        0 0 18px rgba(88,232,255,0.32);
}

@keyframes n1f-nav-urban-pump {
    0%, 100% {
        transform: scale(1);
    }

    42% {
        transform: scale(1.055);
    }

    68% {
        transform: scale(1.025);
    }
}

/* VOICE — elegant shimmer */
body[data-world="voice"] header.n1f-header nav.n1f-nav a:hover {
    color: #fff3cc;

    background:
        linear-gradient(
            90deg,
            #716115 0%,
            #ffe157 38%,
            #c8ad31 50%,
            #f6e180 62%,
            #bea100 100%
        );

    background-size: 220% 100%;
    background-position: 100% 50%;

    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;

    animation:
        n1f-nav-voice-text-shine
        3900ms
        ease-out
        1;

    text-shadow:
        0 0 10px rgba(255,226,150,0.12);
}

@keyframes n1f-nav-voice-text-shine {
    from {
        background-position: 0% 50%;
    }

    to {
        background-position: 100% 50%;
    }
}

/* =========================================================
   WORLD NAV — REMOVE ENTRY UNDERLINE ON SUBPAGES
========================================================= */

body:not([data-world="neutral"]) header.n1f-header nav.n1f-nav a::after {
    display: none;
}

/* =========================================================
   WORLD NAV
========================================================= */

.n1f-world-nav {
    position: relative;
    z-index: 2;

    display: flex;
    justify-content: center;
    align-items: center;
    gap: clamp(18px, 3vw, 46px);

    margin:
        clamp(-72px, -5vw, -42px)
        auto
        clamp(54px, 5vw, 92px);

    padding: 0 clamp(24px, 4vw, 72px);

    text-transform: uppercase;
}

.n1f-world-nav a {
    position: relative;

    color: rgba(255,255,255,0.42);
    text-decoration: none;

    font-size: clamp(11px, 0.9vw, 15px);
    letter-spacing: 0.16em;

    transition:
        color 260ms ease,
        text-shadow 260ms ease,
        transform 260ms ease;
}

.n1f-world-nav a:hover {
    color: var(--world-accent);

    text-shadow:
        0 0 10px var(--world-accent-glow);
}

body[data-world="electronic"] .n1f-world-nav a[data-world-link="electronic"],
body[data-world="rock"] .n1f-world-nav a[data-world-link="rock"],
body[data-world="urban"] .n1f-world-nav a[data-world-link="urban"],
body[data-world="voice"] .n1f-world-nav a[data-world-link="voice"] {
    color: var(--world-accent);

    text-shadow:
        0 0 10px var(--world-accent-glow);
}

/* =========================================================
   WORLD NAV IDENTITIES
========================================================= */

/* ELECTRONIC */

.n1f-world-nav a[data-world-link="electronic"] {
    font-family:
        "N1F Orbitron",
        sans-serif;

    letter-spacing: 0.16em;
}

/* ROCK */

.n1f-world-nav a[data-world-link="rock"] {
    font-family:
        "N1F Bebas",
        "Arial Black",
        sans-serif;

    letter-spacing: 0.20em;
}

/* URBAN */

.n1f-world-nav a[data-world-link="urban"] {
    font-family:
        "N1F Marker",
        "Comic Sans MS",
        cursive;

    letter-spacing: 0.05em;
}

/* VOICE */

.n1f-world-nav a[data-world-link="voice"] {
    font-family:
        "N1F Cinzel",
        Georgia,
        serif;

    letter-spacing: 0.18em;
}

.n1f-world-nav a[data-world-link="rock"] {
    font-family:
        "N1F Bebas",
        "Arial Black",
        sans-serif;

    letter-spacing: 0.06em;

    font-size: 1.20em;

    transform:
        translateY(1px);
}

body[data-world="rock"] .n1f-world-nav a[data-world-link="rock"] {
    text-shadow:
        0 0 12px rgba(255,60,40,0.34);
}

/* =========================================================
   WORLD NAV LINK HOVER COLORS
========================================================= */

.n1f-world-nav a[data-world-link="electronic"]:hover {
    color: var(--electronic);
    text-shadow: 0 0 12px rgba(143,92,255,0.38);
}

.n1f-world-nav a[data-world-link="rock"]:hover {
    color: var(--rock);
    text-shadow: 0 0 12px rgba(255,71,71,0.36);
}

.n1f-world-nav a[data-world-link="urban"]:hover {
    color: var(--urban);
    text-shadow: 0 0 12px rgba(88,232,255,0.34);
}

.n1f-world-nav a[data-world-link="voice"]:hover {
    color: var(--voice);
    text-shadow: 0 0 12px rgba(241,200,120,0.34);
}

/* =========================================================
   WORLD AMBIENT
========================================================= */

.n1f-world-ambient {
    inset: 0;

    pointer-events: none;

    z-index: 0;

    overflow: hidden;
    mix-blend-mode: screen;
}

.n1f-world-hero,
.n1f-world-music,
.n1f-world-footer,
.n1f-world-nav {
    position: relative;
    z-index: 2;
}

.n1f-header,
.n1f-world-hero,
.n1f-world-nav,
.n1f-footer {
    position: relative;
    z-index: 2;
}

body[data-world="electronic"] .n1f-world-ambient::after {
    content: "";

    position: absolute;
    inset: -30%;

    background:
        radial-gradient(
            circle at center,
            transparent 52%,
            rgba(180,135,255,0.08) 54%,
            transparent 16%
        ),
        radial-gradient(
            circle at center,
            transparent 68%,
            rgba(143,92,255,0.06) 70%,
            transparent 32%
        );

    filter: blur(12px);
    opacity: 1.02;

    animation:
        n1f-electronic-arcs
        46s
        linear
        infinite;
}

@keyframes n1f-electronic-arcs {
    from {
        transform:
            rotate(0deg)
            scale(1.04);
    }

    to {
        transform:
            rotate(-360deg)
            scale(1.10);
    }
}

/* =========================================================
   ELECTRONIC AMBIENT — DEBUG VISIBLE
========================================================= */

body[data-world="electronic"] .n1f-world-ambient::after {
    content: "";

    position: absolute;
    inset: -30%;

    background:
        radial-gradient(
            ellipse at center,
            transparent 46%,
            rgba(210,185,255,0.32) 48%,
            rgba(143,92,255,0.12) 50%,
            transparent 53%
        ),
        radial-gradient(
            ellipse at center,
            transparent 62%,
            rgba(180,135,255,0.24) 64%,
            rgba(143,92,255,0.10) 66%,
            transparent 69%
        );

    filter: blur(50px);
    opacity: 0.75;

    animation:
        n1f-electronic-arcs
        76s
        linear
        infinite;
}

body[data-world="electronic"] .n1f-world-ambient {
    isolation: isolate;
}

body[data-world="electronic"] .n1f-world-ambient span {
    position: absolute;
    inset: -20%;

    border-radius: 50%;

    pointer-events: none;

    mix-blend-mode: screen;
}

@keyframes n1f-electronic-ambient {
    from {
        transform: rotate(0deg) scale(1.15);
    }

    to {
        transform: rotate(360deg) scale(1.15);
    }
}

/* =========================================================
   ELECTRONIC DEPTH
========================================================= */

.n1f-electronic-depth-1 {
    background:
        radial-gradient(
            circle at center,
            rgba(160,120,255,0.12),
            transparent 62%
        );

    filter:
        blur(90px);

    opacity: 0.34;

    animation:
        n1f-electronic-depth-1
        56s
        ease-in-out
        infinite;
}

.n1f-electronic-depth-2 {
    background:
        radial-gradient(
            circle at center,
            rgba(120,80,255,0.10),
            transparent 68%
        );

    filter:
        blur(140px);

    opacity: 0.22;

    animation:
        n1f-electronic-depth-2
        84s
        ease-in-out
        infinite;
}

@keyframes n1f-electronic-depth-1 {

    0%, 100% {
        transform:
            translate3d(-4%, -2%, 0)
            scale(1);
    }

    50% {
        transform:
            translate3d(3%, 2%, 0)
            scale(1.12);
    }
}

@keyframes n1f-electronic-depth-2 {

    0%, 100% {
        transform:
            translate3d(2%, 1%, 0)
            scale(1.08);
    }

    50% {
        transform:
            translate3d(-3%, -2%, 0)
            scale(1.18);
    }
}

/* =========================================================
   ROCK AMBIENT
========================================================= */

body[data-world="rock"] .n1f-world-ambient {
    isolation: isolate;
}

body[data-world="rock"] .n1f-world-ambient span {
    position: absolute;
    inset: -20%;

    pointer-events: none;

    mix-blend-mode: screen;
}

.n1f-rock-heat-1 {
    background:
        radial-gradient(
            ellipse at 52% 42%,
            rgba(255,80,42,0.26),
            rgba(120,18,12,0.18) 34%,
            transparent 66%
        );

    filter: blur(60px);

    opacity: 0.52;

    animation:
        n1f-rock-heat-pressure-1
        18s
        cubic-bezier(.28,.78,.22,1)
        infinite;
}

.n1f-rock-heat-2 {
    background:
        conic-gradient(
            from 0deg,
            transparent 0deg,
            rgba(255,70,32,0.00) 62deg,
            rgba(255,96,52,0.22) 82deg,
            rgba(120,18,12,0.16) 110deg,
            transparent 138deg,
            transparent 220deg,
            rgba(255,70,32,0.10) 252deg,
            transparent 292deg,
            transparent 360deg
        );

    filter: blur(38px);

    opacity: 0.60;

    animation:
        n1f-rock-heat-pressure-2
        26s
        ease-in-out
        infinite;
}

@keyframes n1f-rock-heat-pressure-1 {
    0%, 100% {
        transform:
            translate3d(0, 0, 0)
            scale(1.02);
        opacity: 0.40;
    }

    44% {
        transform:
            translate3d(-1.2%, 0.8%, 0)
            scale(1.10);
        opacity: 0.62;
    }

    58% {
        transform:
            translate3d(0.8%, -0.4%, 0)
            scale(1.06);
        opacity: 0.48;
    }
}

@keyframes n1f-rock-heat-pressure-2 {
    0%, 100% {
        transform:
            rotate(0deg)
            scale(1.04);
        opacity: 0.40;
    }

    50% {
        transform:
            rotate(7deg)
            scale(1.14);
        opacity: 0.68;
    }
}

/* =========================================================
   URBAN AMBIENT
========================================================= */

body[data-world="urban"] .n1f-world-ambient {
    isolation: isolate;
}

body[data-world="urban"] .n1f-world-ambient span {
    position: absolute;
    inset: -20%;

    pointer-events: none;

    mix-blend-mode: screen;
}

.n1f-urban-haze-1 {
    background:
        radial-gradient(
            ellipse at 40% 70%,
            rgba(88,232,255,0.22),
            rgba(20,60,90,0.15) 36%,
            transparent 68%
        );

    filter:
        blur(120px);

    opacity: 0.42;

    animation:
        n1f-urban-haze-1
        22s
        ease-in-out
        infinite;
}

.n1f-urban-haze-2 {
    background:
        linear-gradient(
            120deg,
            transparent 0%,
            rgba(120,245,255,0.15) 32%,
            rgba(88,232,255,0.20) 48%,
            transparent 72%
        );

    filter:
        blur(90px);

    opacity: 0.36;

    animation:
        n1f-urban-haze-2
        14s
        cubic-bezier(.22,.78,.22,1)
        infinite;
}

@keyframes n1f-urban-haze-1 {

    0%, 100% {
        transform:
            translate3d(-2%, 0, 0)
            scale(1.02);
    }

    50% {
        transform:
            translate3d(2%, -1%, 0)
            scale(1.10);
    }
}

@keyframes n1f-urban-haze-2 {

    0%, 100% {
        transform:
            translate3d(0, 0, 0)
            scale(1);
        opacity: 0.28;
    }

    50% {
        transform:
            translate3d(1%, 0, 0)
            scale(1.06);
        opacity: 0.44;
    }
}

/* =========================================================
   VOICE AMBIENT
========================================================= */

body[data-world="voice"] .n1f-world-ambient {
    isolation: isolate;
}

body[data-world="voice"] .n1f-world-ambient span {
    position: absolute;
    inset: -20%;

    pointer-events: none;

    mix-blend-mode: screen;
}

.n1f-voice-air-1 {
    background:
        radial-gradient(
            ellipse at 50% 85%,
            rgba(255,226,150,0.44),
            rgba(241,200,120,0.10) 34%,
            transparent 68%
        );

    filter: blur(120px);

    opacity: 0.56;

    animation:
        n1f-voice-air-breath-1
        68s
        ease-in-out
        infinite;
}

.n1f-voice-air-2 {
    background:
        radial-gradient(
            ellipse at 48% 62%,
            rgba(255,245,210,0.30),
            rgba(241,200,120,0.10) 32%,
            transparent 72%
        );

    filter: blur(160px);

    opacity: 0.56;

    animation:
        n1f-voice-air-breath-2
        92s
        ease-in-out
        infinite;
}

@keyframes n1f-voice-air-breath-1 {
    0%, 100% {
        transform:
            translate3d(0, 0, 0)
            scale(1.00);
        opacity: 0.24;
    }

    50% {
        transform:
            translate3d(0, -1.2%, 0)
            scale(1.10);
        opacity: 0.72;
    }
}

@keyframes n1f-voice-air-breath-2 {
    0%, 100% {
        transform:
            translate3d(0, 1%, 0)
            scale(1.04);
        opacity: 0.38;
    }

    50% {
        transform:
            translate3d(0, -1.6%, 0)
            scale(1.16);
        opacity: 0.72;
    }
}

/* =========================================================
   WORLD BODY HEADLINE TYPOGRAPHY
========================================================= */

body[data-world="electronic"] .n1f-world-body h1,
body[data-world="electronic"] .n1f-world-body h2,
body[data-world="electronic"] .n1f-world-body h3 {
    font-family: "N1F Orbitron", sans-serif;
    letter-spacing: 0.08em;
}

body[data-world="rock"] .n1f-world-body h1,
body[data-world="rock"] .n1f-world-body h2,
body[data-world="rock"] .n1f-world-body h3 {
    font-family: "N1F Bebas", "Arial Black", sans-serif;
    letter-spacing: 0.04em;
}

body[data-world="urban"] .n1f-world-body h1,
body[data-world="urban"] .n1f-world-body h2,
body[data-world="urban"] .n1f-world-body h3 {
    font-family: "N1F Marker", cursive;
    letter-spacing: 0.03em;
}

body[data-world="voice"] .n1f-world-body h1,
body[data-world="voice"] .n1f-world-body h2,
body[data-world="voice"] .n1f-world-body h3 {
    font-family: "N1F Cinzel", serif;
    letter-spacing: 0.12em;
}

/* =========================================================
   WORLD TITLE TYPOGRAPHY
========================================================= */

body[data-world="electronic"] .n1f-world-hero-inner > h1 {
    font-family: "N1F Orbitron", sans-serif;
    letter-spacing: 0.04em;
}

body[data-world="rock"] .n1f-world-hero-inner > h1 {
    font-family: "N1F Bebas", "Arial Black", sans-serif;
    letter-spacing: 0.04em;
}

body[data-world="urban"] .n1f-world-hero-inner > h1 {
    font-family: "N1F Marker", "Comic Sans MS", cursive;
    letter-spacing: 0.03em;
}

body[data-world="voice"] .n1f-world-hero-inner > h1 {
    font-family: "N1F Cinzel", Georgia, serif;
    letter-spacing: 0.14em;
}

/* =========================================================
   FEATURED RELEASE
========================================================= */

.n1f-featured-release {

    position: relative;
    z-index: 2;

    width: min(1400px, 92vw);

    margin:
        80px auto 0;

    display: grid;

    grid-template-columns:
        420px
        1fr;

    gap: 48px;

    align-items: center;
}

.n1f-featured-release-cover {

    position: relative;

    border-radius: 28px;

    overflow: hidden;

    border:
        1px solid
        rgba(255,255,255,0.08);

    background:
        rgba(8,8,14,0.72);

    box-shadow:
        0 0 40px rgba(0,0,0,0.42);
}

.n1f-featured-release-cover img {

    width: 100%;
    display: block;

    aspect-ratio: 1 / 1;

    object-fit: cover;
}

.n1f-featured-release-content {

    display: flex;
    flex-direction: column;

    gap: 20px;
}

.n1f-release-type {

    text-transform: uppercase;

    letter-spacing: 0.24em;

    font-size: 11px;

    opacity: 0.58;
}

.n1f-featured-release h2 {

    font-size:
        clamp(48px, 6vw, 96px);

    line-height: 0.92;

    margin: 0;
}

.n1f-release-description {

    max-width: 640px;

    font-size: 18px;

    line-height: 1.8;

    opacity: 0.78;
}

.n1f-release-link {

    width: fit-content;

    padding:
        16px 28px;

    border-radius: 999px;

    text-decoration: none;

    text-transform: uppercase;

    letter-spacing: 0.18em;

    font-size: 12px;

    border:
        1px solid
        rgba(255,255,255,0.12);

    transition:
        transform 220ms ease,
        border-color 220ms ease,
        box-shadow 220ms ease;
}

.n1f-release-link:hover {

    transform:
        translateY(-2px);

    box-shadow:
        0 0 24px rgba(143,92,255,0.22);
}
/* =========================================================
   n1F MUSIC SYSTEM
========================================================= */

.n1f-world-music-system,
.n1f-world-manifest,
.n1f-detail-shell {
    position: relative;
    z-index: 2;
    width: min(1200px, 92vw);
    margin: clamp(64px, 6vw, 110px) auto;
    padding: clamp(28px, 4vw, 56px);
    border-radius: 30px;
    background:
        linear-gradient(180deg, rgba(8,8,14,0.72), rgba(4,4,8,0.88));
    border: 1px solid var(--world-accent-soft);
    backdrop-filter: blur(18px);
    box-shadow:
        0 0 0 1px rgba(255,255,255,0.025),
        0 0 46px var(--world-accent-glow),
        0 24px 80px rgba(0,0,0,0.46);
}

.n1f-system-head h2,
.n1f-detail-shell h1,
.n1f-world-manifest h2 {
    margin: 0 0 28px;
    color: var(--world-accent);
    text-transform: uppercase;
    letter-spacing: 0.08em;
    font-size: clamp(38px, 5vw, 92px);
    line-height: 0.95;
    text-shadow: 0 0 18px var(--world-accent-glow);
}

.n1f-section-kicker {
    margin: 0 0 14px;
    color: rgba(255,255,255,0.46);
    text-transform: uppercase;
    letter-spacing: 0.24em;
    font-size: 11px;
}

.n1f-music-filter {
    margin: 32px 0 42px;
}

.n1f-filter-row {
    display: grid;
    grid-template-columns: 1fr auto auto;
    gap: 16px;
    align-items: end;
}

.n1f-filter-row label {
    display: grid;
    gap: 8px;
    color: rgba(255,255,255,0.48);
    text-transform: uppercase;
    letter-spacing: 0.16em;
    font-size: 10px;
}

.n1f-filter-row input,
.n1f-filter-row select {
    min-height: 44px;
    border-radius: 999px;
    border: 1px solid rgba(255,255,255,0.10);
    background: rgba(0,0,0,0.34);
    color: rgba(255,255,255,0.84);
    padding: 0 18px;
    outline: none;
}

.n1f-filter-search input {
    width: 100%;
}

.n1f-filter-row input:focus,
.n1f-filter-row select:focus {
    border-color: var(--world-accent-soft);
    box-shadow: 0 0 18px var(--world-accent-glow);
}

.n1f-release-grid,
.n1f-track-list {
    display: grid;
    gap: 22px;
}

.n1f-release-card,
.n1f-track-card {
    display: grid;
    grid-template-columns: 148px 1fr;
    gap: 22px;
    align-items: stretch;
    border-radius: 24px;
    padding: 16px;
    border: 1px solid rgba(255,255,255,0.07);
    background: rgba(0,0,0,0.26);
    box-shadow: 0 16px 48px rgba(0,0,0,0.24);
}

.n1f-release-card--secondary,
.n1f-track-card--secondary {
    opacity: 0.78;
    border-style: dashed;
}

.n1f-release-cover,
.n1f-track-cover {
    display: block;
    border-radius: 18px;
    overflow: hidden;
    background: rgba(255,255,255,0.04);
}

.n1f-release-cover img,
.n1f-track-cover img {
    width: 100%;
    height: 100%;
    aspect-ratio: 1 / 1;
    object-fit: cover;
    display: block;
    transform: scale(1.01);
}

.n1f-release-main,
.n1f-track-main {
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 12px;
    min-width: 0;
}

.n1f-release-kicker,
.n1f-track-meta-line {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    align-items: center;
    color: rgba(255,255,255,0.48);
    text-transform: uppercase;
    letter-spacing: 0.16em;
    font-size: 10px;
}

.n1f-track-meta-line em,
.n1f-crossworlds {
    color: var(--world-accent);
    font-style: normal;
    opacity: 0.78;
}

.n1f-release-card h3,
.n1f-track-card h3 {
    margin: 0;
    font-size: clamp(24px, 2.8vw, 46px);
    line-height: 1;
    text-transform: uppercase;
}

.n1f-release-card h3 a,
.n1f-track-card h3 a,
.n1f-detail-meta a {
    color: inherit;
    text-decoration: none;
}

.n1f-release-card h3 a:hover,
.n1f-track-card h3 a:hover,
.n1f-detail-meta a:hover {
    color: var(--world-accent);
    text-shadow: 0 0 14px var(--world-accent-glow);
}

.n1f-release-main p,
.n1f-track-tags,
.n1f-detail-meta,
.n1f-persona-profile p {
    margin: 0;
    color: rgba(255,255,255,0.68);
    line-height: 1.7;
}

.n1f-track-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    font-size: 12px;
    text-transform: uppercase;
    letter-spacing: 0.12em;
}

.n1f-track-tags span {
    border: 1px solid rgba(255,255,255,0.08);
    border-radius: 999px;
    padding: 4px 10px;
    background: rgba(255,255,255,0.03);
}

.n1f-stream-links {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-top: 4px;
}

.n1f-stream-links a,
.n1f-release-link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 34px;
    padding: 0 14px;
    border-radius: 999px;
    border: 1px solid rgba(255,255,255,0.10);
    color: rgba(255,255,255,0.72);
    text-decoration: none;
    text-transform: uppercase;
    letter-spacing: 0.13em;
    font-size: 10px;
    transition: border-color 220ms ease, color 220ms ease, box-shadow 220ms ease, transform 220ms ease;
}

.n1f-stream-links a:hover,
.n1f-release-link:hover {
    color: var(--world-accent);
    border-color: var(--world-accent-soft);
    box-shadow: 0 0 18px var(--world-accent-glow);
    transform: translateY(-1px);
}

.n1f-audio {
    width: 100%;
    max-width: 560px;
    margin: 4px 0;
    opacity: 0.86;
}

.n1f-lyrics-toggle {
    margin-top: 8px;
    border-top: 1px solid rgba(255,255,255,0.06);
    padding-top: 12px;
}

.n1f-lyrics-toggle summary {
    cursor: pointer;
    color: rgba(255,255,255,0.68);
    text-transform: uppercase;
    letter-spacing: 0.14em;
    font-size: 11px;
}

.n1f-lyrics-text {
    margin-top: 16px;
    color: rgba(255,255,255,0.74);
    line-height: 1.9;
    white-space: normal;
}

.n1f-world-featured {
    margin-top: clamp(34px, 4vw, 60px);
    padding-top: clamp(24px, 3vw, 42px);
    border-top: 1px solid rgba(255,255,255,0.06);
}

.n1f-empty-state {
    color: rgba(255,255,255,0.46);
    text-transform: uppercase;
    letter-spacing: 0.16em;
    font-size: 12px;
}

.n1f-persona-profile {
    display: grid;
    grid-template-columns: 220px 1fr;
    gap: 30px;
    align-items: start;
    margin: 30px 0 56px;
}

.n1f-persona-profile img {
    width: 100%;
    aspect-ratio: 1 / 1;
    object-fit: cover;
    border-radius: 24px;
    border: 1px solid rgba(255,255,255,0.08);
}

body[data-world="electronic"] .n1f-world-music-system h2,
body[data-world="electronic"] .n1f-detail-shell h1,
body[data-world="electronic"] .n1f-release-card h3,
body[data-world="electronic"] .n1f-track-card h3 {
    font-family: "N1F Orbitron", sans-serif;
}

body[data-world="rock"] .n1f-world-music-system h2,
body[data-world="rock"] .n1f-detail-shell h1,
body[data-world="rock"] .n1f-release-card h3,
body[data-world="rock"] .n1f-track-card h3 {
    font-family: "N1F Bebas", "Arial Black", sans-serif;
    letter-spacing: 0.04em;
}

body[data-world="urban"] .n1f-world-music-system h2,
body[data-world="urban"] .n1f-detail-shell h1,
body[data-world="urban"] .n1f-release-card h3,
body[data-world="urban"] .n1f-track-card h3 {
    font-family: "N1F Marker", "Comic Sans MS", cursive;
    letter-spacing: 0.03em;
}

body[data-world="voice"] .n1f-world-music-system h2,
body[data-world="voice"] .n1f-detail-shell h1,
body[data-world="voice"] .n1f-release-card h3,
body[data-world="voice"] .n1f-track-card h3 {
    font-family: "N1F Cinzel", Georgia, serif;
    letter-spacing: 0.10em;
}

@media (max-width: 820px) {
    .n1f-filter-row,
    .n1f-release-card,
    .n1f-track-card,
    .n1f-persona-profile {
        grid-template-columns: 1fr;
    }

    .n1f-release-cover,
    .n1f-track-cover {
        max-width: 260px;
    }
}

/* =========================================================
   WORLD TRACK ARCHIVE
========================================================= */

.n1f-world-music {
    position: relative;
    width: min(1200px, 92vw);
    margin:
        clamp(8px, 2vw, 28px)
        auto
        clamp(80px, 7vw, 120px);
}

.n1f-world-music-head {
    margin-bottom: 28px;
}

.n1f-world-music-head h2 {
    margin: 0;

    font-size: clamp(34px, 4vw, 72px);
    line-height: 0.95;

    color: var(--world-accent);

    text-transform: uppercase;
    letter-spacing: 0.08em;

    text-shadow:
        0 0 18px var(--world-accent-glow);
}

.n1f-track-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 18px;
}

.n1f-track-card {
    display: grid;
    grid-template-columns: 76px 1fr auto;
    align-items: center;
    gap: 18px;

    padding: 14px 18px;

    border-radius: 18px;

    background:
        linear-gradient(
            90deg,
            rgba(8,8,14,0.62),
            rgba(4,4,8,0.76)
        );

    border: 1px solid rgba(255,255,255,0.045);

    box-shadow:
        0 8px 26px rgba(0,0,0,0.28);

    overflow: hidden;
}

.n1f-track-art {
    width: 76px;
    aspect-ratio: 1 / 1;

    border-radius: 12px;
    overflow: hidden;

    border: 1px solid rgba(255,255,255,0.08);

    box-shadow:
        0 8px 18px rgba(0,0,0,0.38);
}

.n1f-track-art img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    box-shadow:
        0 0 30px rgba(255,40,40,0.16),
        0 12px 34px rgba(0,0,0,0.48);
}

.n1f-track-main {
    min-width: 0;
}

.n1f-track-main h3 {
    margin: 0 0 18px;
}

.n1f-track-main h3 {
    margin: 0 0 8px;

    font-size: clamp(24px, 2vw, 38px);
    line-height: 0.95;
}

.n1f-track-main audio {
    width: min(440px, 100%);
    height: 34px;

    margin: 8px 0 6px;

    opacity: 0.78;

    filter:
        invert(1)
        hue-rotate(180deg)
        saturate(0.5)
        brightness(0.68);
}

.n1f-track-lyrics {
    margin-top: 4px;
    font-size: 11px;
}

.n1f-track-lyrics summary {
    cursor: pointer;
    color: var(--world-accent);
}

.n1f-track-lyrics div {
    margin-top: 14px;

    max-width: 720px;

    color: rgba(255,255,255,0.76);

    line-height: 1.8;
    letter-spacing: 0.02em;
    text-transform: none;
}

/* =========================================================
   WORLD LAYER STACK — FINAL
========================================================= */

.n1f-world-page {
    position: relative;
    isolation: isolate;
}

.n1f-world-stage-bg {
    position: fixed;
    inset: 0;
    z-index: 0;
}

.n1f-world-ambient {
    position: fixed;
    inset: 0;
    z-index: 1;
    pointer-events: none;
}

.n1f-header,
.n1f-world-hero,
.n1f-world-music,
.n1f-world-nav,
.n1f-footer {
    position: relative;
    z-index: 3;
}

/* =========================================================
   MUSIC CONTROLS
========================================================= */

.n1f-music-controls {
    display: grid;
    grid-template-columns: 1fr auto auto;
    gap: 16px;
    align-items: end;

    margin: 0 0 24px;

    padding: 18px;

    border-radius: 22px;

    background:
        linear-gradient(
            180deg,
            rgba(8,8,14,0.58),
            rgba(4,4,8,0.74)
        );

    border: 1px solid rgba(255,255,255,0.055);

    backdrop-filter:
        blur(12px)
        saturate(1.12);

    box-shadow:
        0 14px 44px rgba(0,0,0,0.28);
}

.n1f-music-controls label {
    display: grid;
    gap: 8px;
}

.n1f-music-controls span {
    color: rgba(255,255,255,0.42);

    font-size: 10px;
    letter-spacing: 0.18em;
    text-transform: uppercase;
}

.n1f-music-controls input,
.n1f-music-controls select {
    appearance: none;
    -webkit-appearance: none;

    min-width: 150px;

    padding:
        0
        42px
        0
        18px;

    border:
        1px solid var(--world-accent-soft);

    background:
        linear-gradient(
            180deg,
            rgba(10,10,16,0.82),
            rgba(4,4,8,0.94)
        );

    color: rgba(255,255,255,0.86);

    box-shadow:
        inset 0 0 18px rgba(255,255,255,0.025),
        0 0 18px var(--world-accent-glow);
}

.n1f-music-select {
    position: relative;
}

.n1f-music-select::after {
    content: "⌄";

    position: absolute;
    right: 17px;
    bottom: 11px;

    color: var(--world-accent);

    font-size: 14px;
    line-height: 1;

    pointer-events: none;

    text-shadow:
        0 0 10px var(--world-accent-glow);
}

.n1f-music-controls select:hover {
    border-color: var(--world-accent);

    box-shadow:
        inset 0 0 20px rgba(255,255,255,0.035),
        0 0 24px var(--world-accent-glow);
}

.n1f-music-controls option {
    background: #050508;
    color: rgba(255,255,255,0.86);
}

.n1f-music-controls input:focus,
.n1f-music-controls select:focus {
    border-color: var(--world-accent);

    box-shadow:
        0 0 18px var(--world-accent-glow);
}

@media (max-width: 760px) {
    .n1f-music-controls {
        grid-template-columns: 1fr;
    }
}

/* =========================================================
   ALBUM STRUCTURE GROUPS
========================================================= */

.n1f-album-group {
    display: grid;
    gap: 14px;

    margin-bottom: 18px;
}

.n1f-album-group-title {
    margin:
        10px
        0
        0;

    color: rgba(255,255,255,0.54);

    font-size: clamp(18px, 1.6vw, 28px);
    line-height: 1;

    letter-spacing: 0.12em;
    text-transform: uppercase;
}

.n1f-album-track-list {
    display: grid;
    gap: 14px;
}

.n1f-album-group-title::before {
    content: "Release // ";
    color: var(--world-accent);
}

.n1f-track-release-card {
    display: inline-grid;
    grid-template-columns: 72px 1fr;
    align-items: center;
    gap: 16px;

    margin-top: 22px;
    padding: 12px 16px 12px 12px;

    max-width: 420px;

    border-radius: 18px;
    border: 1px solid rgba(255,255,255,0.07);

    background:
        linear-gradient(
            90deg,
            rgba(255,255,255,0.045),
            rgba(255,255,255,0.018)
        );

    color: inherit;
    text-decoration: none;

    transition:
        transform 220ms ease,
        border-color 220ms ease,
        box-shadow 220ms ease;
}

.n1f-track-release-card:hover {
    transform: translateY(-2px);

    border-color: var(--world-accent);

    box-shadow:
        0 0 24px var(--world-accent-glow),
        0 16px 36px rgba(0,0,0,0.36);
}

.n1f-track-release-cover {
    width: 72px;
    aspect-ratio: 1 / 1;

    border-radius: 12px;
    overflow: hidden;

    background: rgba(0,0,0,0.3);
}

.n1f-track-release-cover img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.n1f-track-release-info {
    display: grid;
    gap: 4px;
}

.n1f-track-release-label {
    color: rgba(255,255,255,0.42);

    font-size: 9px;
    letter-spacing: 0.18em;
    text-transform: uppercase;
}

.n1f-track-release-info strong {
    color: var(--world-accent);

    font-size: 18px;
    line-height: 1;
    text-transform: uppercase;

    text-shadow:
        0 0 10px var(--world-accent-glow);
}

.n1f-track-release-info small {
    color: rgba(255,255,255,0.50);

    font-size: 10px;
    letter-spacing: 0.14em;
    text-transform: uppercase;
}

.n1f-track-persona {
    color: rgba(255,255,255,0.7);

    text-decoration: none;

    transition:
        color 180ms ease,
        text-shadow 180ms ease;
}

.n1f-track-persona:hover {
    color: var(--world-accent);

    text-shadow:
        0 0 10px var(--world-accent-glow);
}

.n1f-persona-quote {
    margin-top: 28px;

    color: rgba(255,255,255,0.72);

    font-size: 22px;
    line-height: 1.4;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.n1f-release-grid {
    display: grid;

    grid-template-columns:
        repeat(auto-fill, minmax(220px, 1fr));

    gap: 28px;
}

.n1f-release-card {
    display: grid;
    gap: 14px;

    text-decoration: none;
    color: inherit;
}

.n1f-release-card img {
    width: 100%;
    aspect-ratio: 1 / 1;

    object-fit: cover;

    border-radius: 22px;
}

.n1f-persona-tracks {
    width: min(1120px, calc(100vw - 80px));
    margin: 0 auto 140px;
}

.n1f-persona-layout {
    width: min(1180px, calc(100vw - 80px));
    margin: 120px auto 80px;

    display: grid;
    grid-template-columns: 1fr 280px;
    gap: 28px;
    align-items: stretch;
}

.n1f-persona-layout .n1f-persona-hero {
    margin: 0;
    width: auto;
}

.n1f-persona-featured-release {
    padding: 24px;

    border-radius: 28px;

    background:
        linear-gradient(
            180deg,
            rgba(5,5,10,0.88),
            rgba(2,2,6,0.96)
        );

    border: 1px solid rgba(var(--world-accent-rgb),0.14);

    box-shadow:
        0 0 34px rgba(var(--world-accent-rgb),0.08);
}

.n1f-persona-featured-release a {
    display: grid;
    gap: 14px;

    color: inherit;
    text-decoration: none;
}

.n1f-persona-featured-release img {
    width: 100%;
    aspect-ratio: 1 / 1;

    object-fit: cover;

    border-radius: 18px;
}

.n1f-persona-featured-release strong {
    color: var(--world-accent);

    font-size: 1.4rem;
    text-transform: uppercase;
}

.n1f-persona-featured-release span {
    color: rgba(255,255,255,0.52);

    font-size: 0.72rem;
    letter-spacing: 0.16em;
    text-transform: uppercase;
}

.n1f-persona-track-list {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
}

.n1f-persona-track-row {
    display: grid;
    grid-template-columns: 64px 1fr;
    gap: 14px;
    align-items: center;

    padding: 14px 16px;

    border-radius: 14px;

    background: rgba(255,255,255,0.035);
    border: 1px solid rgba(255,255,255,0.055);

    color: inherit;
    text-decoration: none;
}

.n1f-persona-track-row span {
    color: rgba(255,255,255,0.38);

    font-size: 0.72rem;
}

.n1f-persona-track-row strong {
    color: rgba(255,255,255,0.84);

    text-transform: uppercase;
}

.n1f-persona-track-row:hover {
    border-color: var(--world-accent);

    box-shadow:
        0 0 18px rgba(var(--world-accent-rgb),0.10);
}

@media (max-width: 900px) {
    .n1f-persona-layout {
        grid-template-columns: 1fr;
    }

    .n1f-persona-track-list {
        grid-template-columns: 1fr;
    }
}

.n1f-persona-showroom {
    width: min(1180px, calc(100vw - 80px));
    margin: 0 auto 90px;
}

.n1f-release-rail {
    display: flex;
    gap: 18px;

    overflow-x: auto;
    overflow-y: visible;

    padding: 10px 4px 28px;

    scroll-snap-type: x mandatory;
}

.n1f-release-showcase-card {
    position: relative;

    flex: 0 0 220px;
    aspect-ratio: 1 / 1;

    border-radius: 22px;
    overflow: hidden;

    scroll-snap-align: start;

    border: 1px solid rgba(var(--world-accent-rgb), 0.14);

    background: rgba(0,0,0,0.46);

    text-decoration: none;
    color: inherit;

    box-shadow:
        0 18px 44px rgba(0,0,0,0.36);

    transition:
        transform 240ms ease,
        border-color 240ms ease,
        box-shadow 240ms ease;
}

.n1f-release-showcase-card:hover {
    transform: translateY(-5px);

    border-color: var(--world-accent);

    box-shadow:
        0 0 28px rgba(var(--world-accent-rgb), 0.16),
        0 22px 52px rgba(0,0,0,0.48);
}

.n1f-release-showcase-card img {
    width: 100%;
    height: 100%;
    object-fit: cover;

    filter:
        brightness(0.82)
        contrast(1.08);
}

.n1f-release-showcase-info {
    position: absolute;
    inset: auto 0 0;

    display: grid;
    gap: 5px;

    padding: 18px;

    background:
        linear-gradient(
            180deg,
            transparent,
            rgba(0,0,0,0.82)
        );

    opacity: 0;
    transform: translateY(10px);

    transition:
        opacity 220ms ease,
        transform 220ms ease;
}

.n1f-release-showcase-card:hover .n1f-release-showcase-info {
    opacity: 1;
    transform: translateY(0);
}

.n1f-release-showcase-info small,
.n1f-release-showcase-info span {
    color: rgba(255,255,255,0.62);

    font-size: 10px;
    letter-spacing: 0.14em;
    text-transform: uppercase;
}

.n1f-release-showcase-info strong {
    color: var(--world-accent);

    font-size: 22px;
    line-height: 1;
    text-transform: uppercase;

    text-shadow:
        0 0 10px var(--world-accent-glow);
}