/* rcr.css */
/* =========================
   Core theme variables
   ========================= */
:root {
    --rcr-red: #e50914;
    --rcr-red-hover: #ff1a24;
    --rcr-red-active: #800000;

    --bg: #0b0b0b;
    --fg: #eaeaea;
    --card: #141414;
    --line: #222;
}

/* =========================
   Base
   ========================= */
html,
body {
    height: 100%;
}

body {
    font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
    background: var(--bg);
    color: var(--fg);
    -webkit-font-smoothing: antialiased;
    text-rendering: optimizeLegibility;
}

a {
    text-decoration: none;
}

/* =========================
   Hero header
   ========================= */
.hero {
    position: relative;
    background:
        linear-gradient(180deg, rgba(0, 0, 0, .25) 0%, rgba(0, 0, 0, .7) 70%, rgba(0, 0, 0, .85) 100%);
    background-color: #0e0e0e;
    height: 36vh;
    min-height: 240px;
}

/* Page-specific hero art (override per page) */
.hero--listen {
    background-image: linear-gradient(180deg, rgba(0, 0, 0, .25) 0%, rgba(0, 0, 0, .7) 70%, rgba(0, 0, 0, .85) 100%), url('listenHeader.png');
    background-size: cover;
    background-position: top center;
}

.hero--speak {
    background-image: linear-gradient(180deg, rgba(0, 0, 0, .25) 0%, rgba(0, 0, 0, .7) 70%, rgba(0, 0, 0, .85) 100%), url('speakHeader.png');
    background-size: cover;
    background-position: top center;
}

.hero--ripple {
    background-image: linear-gradient(180deg, rgba(0, 0, 0, .25) 0%, rgba(0, 0, 0, .7) 70%, rgba(0, 0, 0, .85) 100%), url('rippleHeader.png?v=2');
    background-size: cover;
    background-position: bottom center;
}

/* swap when you have rippleHeader.png */
.hero--understand {
    background-image: linear-gradient(180deg, rgba(0, 0, 0, .25) 0%, rgba(0, 0, 0, .7) 70%, rgba(0, 0, 0, .85) 100%), url('understandHeader.png');
    background-size: cover;
    background-position: top center;
}

/* swap when you have understandHeader.png */

/* =========================
   Iconbar (music/social row)
   ========================= */
.iconbar {
    font-size: 1.5rem;
}

@media (max-width: 576px) {
    .iconbar {
        font-size: 1.25rem;
    }
}

.iconbar a {
    color: #fff;
    opacity: .85;
}

@media (prefers-reduced-motion:no-preference) {
    .iconbar a {
        transition: color .2s ease, opacity .2s ease, transform .02s ease;
    }
}

.iconbar a:hover,
.iconbar a:focus-visible {
    color: var(--rcr-red);
    opacity: 1;
    outline: none;
}

.iconbar a:active {
    color: var(--rcr-red-active);
    transform: translateY(1px);
}

.iconbar .vr {
    height: 1.2em;
    opacity: .25;
}

/* =========================
   Primary nav (right side)
   ========================= */
.site-nav-inline .nav-link {
    color: var(--fg) !important;
    opacity: .9;
    font-weight: 600;
}

.site-nav-inline .nav-link:hover,
.site-nav-inline .nav-link:focus-visible {
    color: var(--rcr-red) !important;
    opacity: 1;
    outline: none;
}

.site-nav-inline .nav-link.active {
    color: var(--rcr-red) !important;
}

.site-nav-inline .sep {
    color: #888;
    opacity: .5;
    user-select: none;
}

@media (max-width: 767.98px) {
    .site-nav-inline {
        display: none !important;
    }
}

/* =========================
   Mobile nav
   ========================= */
.nav-toggle {
    background: transparent;
    border: 1px solid rgba(255, 255, 255, .35);
    color: #fff;
    line-height: 1;
}

.nav-toggle:focus {
    box-shadow: 0 0 0 .2rem rgba(229, 9, 20, .25);
}

.nav-toggle i {
    font-size: 1.25rem;
}

.mobile-nav a {
    color: var(--fg);
    display: block;
    padding: .6rem 0;
}

.mobile-nav a:hover,
.mobile-nav a:focus-visible {
    color: var(--rcr-red);
    outline: none;
}

/* =========================
   Cards / content blocks
   ========================= */
.card-block {
    background: var(--card);
    border: 1px solid var(--line);
    border-radius: 16px;
    overflow: hidden;
}

/* =========================
   Forms
   ========================= */
label {
    font-weight: 600;
    margin-top: 1rem;
}

.form-control,
.form-select {
    background: #1a1a1a;
    border: 1px solid #333;
    color: #fff;
}

.form-control:focus,
.form-select:focus {
    background: #1a1a1a;
    border-color: #444;
    color: #fff;
    box-shadow: none;
}

/* Placeholders */
.form-control::placeholder,
.form-select::placeholder {
    color: var(--rcr-red);
    opacity: .9;
}

/* =========================
   Tooltips (Bootstrap)
   ========================= */
.tooltip .tooltip-inner {
    background-color: #111;
    color: #fff;
    border: 1px solid #333;
}

.tooltip.bs-tooltip-auto[data-popper-placement^=top] .tooltip-arrow::before,
.tooltip.bs-tooltip-top .tooltip-arrow::before {
    border-top-color: #111;
}

.tooltip.bs-tooltip-auto[data-popper-placement^=bottom] .tooltip-arrow::before,
.tooltip.bs-tooltip-bottom .tooltip-arrow::before {
    border-bottom-color: #111;
}

.tooltip.bs-tooltip-auto[data-popper-placement^=start] .tooltip-arrow::before,
.tooltip.bs-tooltip-start .tooltip-arrow::before {
    border-left-color: #111;
}

.tooltip.bs-tooltip-auto[data-popper-placement^=end] .tooltip-arrow::before,
.tooltip.bs-tooltip-end .tooltip-arrow::before {
    border-right-color: #111;
}
  /* Cards */
  .album-card {
      background: #141414;
      border: 1px solid #222;
      border-radius: 16px;
      overflow: hidden;
  }

  .album-cover {
      width: 100%;
      border-radius: 12px;
  }
        /* Buttons */
        .btn-rcr {
            background: var(--rcr-red);
            color: #fff;
            border: none;
            transition: background .2s ease, filter .2s ease, transform .02s ease;
        }
    
        .btn-rcr:hover {
            background: var(--rcr-red-hover);
            color: #fff;
        }
    
        .btn-rcr:active {
            background: var(--rcr-red-active) !important;
            color: #fff;
            transform: translateY(1px);
        }
    
        .badge-sm {
            font-size: .65rem;
            padding: .25rem .5rem;
        }
    
        .track-row {
            border-top: 1px dashed #2a2a2a;
            padding-top: .5rem;
            margin-top: .5rem;
        }
                /* Default nav link styling (you already have this) */
                .site-nav-inline .nav-link {
                    color: var(--fg) !important;
                    opacity: .9;
                    font-weight: 600;
                    transition: none;
                    /* turn off smooth fade so glitch feels abrupt */
                }
        
                /* Glitch animation */
                @keyframes nav-glitch {
                    0% {
                        opacity: .9;
                        letter-spacing: normal;
                        transform: none;
                    }
        
                    10% {
                        opacity: .4;
                        letter-spacing: 2px;
                        transform: translateX(-1px);
                    }
        
                    20% {
                        opacity: 1;
                        letter-spacing: -1px;
                        transform: translateX(1px);
                    }
        
                    30% {
                        opacity: .6;
                        transform: translateY(-1px);
                    }
        
                    40% {
                        opacity: 1;
                        transform: translateY(1px);
                    }
        
                    50% {
                        opacity: .8;
                        letter-spacing: 1px;
                    }
        
                    60% {
                        opacity: 1;
                        letter-spacing: normal;
                        transform: none;
                    }
        
                    100% {
                        opacity: 1;
                        letter-spacing: normal;
                        transform: none;
                    }
                }
        
                /* Apply on hover */
                .site-nav-inline .nav-link:hover {
                    color: var(--rcr-red) !important;
                    animation: nav-glitch .35s steps(2, jump-none);
                }
                