@import url('https://fonts.googleapis.com/css2?family=Cinzel:wght@600;800;900&family=Space+Grotesk:wght@400;600;700&display=swap');

/* Default Fallbacks in case index.php fails to supply logic */
:root {
    --theme-bg-dark: #1a0505;
    --theme-page-bg: #2b0808;
    
    --c-orange: #f97316;
    --c-amber: #f59e0b;
    --c-yellow: #eab308;
    --c-red: #ef4444;
    --c-rose: #f43f5e;
    
    --text-dark: #450a0a;
    --text-muted: #7f1d1d;
    
    --card-front-top: #fffdf8;
    --card-front-bot: #feecce;
    
    --card-back-top: #ffedd5;
    --card-back-bot: #fed7aa;
}

body, html {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
    font-family: 'Space Grotesk', sans-serif;
    background-color: var(--theme-bg-dark);
    color: #fff;
    overflow-x: hidden;
    -webkit-tap-highlight-color: transparent;
}

*, *::before, *::after { box-sizing: inherit; }

.nr-font-cinzel { font-family: 'Cinzel', serif; }
.nr-font-space { font-family: 'Space Grotesk', sans-serif; }

.text-spike { color: var(--text-muted); font-weight: 800; }
.text-phase { color: var(--c-orange); }
.text-normal { color: var(--text-dark); }

/* Dynamic Map Gradients */
.from-orange-500.to-amber-500 { background: linear-gradient(to bottom right, var(--c-orange), var(--c-amber)); }
.from-red-500.to-rose-500 { background: linear-gradient(to bottom right, var(--c-red), var(--c-rose)); }
.from-amber-500.to-yellow-500 { background: linear-gradient(to bottom right, var(--c-amber), var(--c-yellow)); }
.from-red-500.to-orange-500 { background: linear-gradient(to right, var(--c-red), var(--c-orange)); }
.from-orange-400.to-amber-400 { background: linear-gradient(to right, var(--c-orange), var(--c-amber)); }

@keyframes entrance {
    from { opacity: 0; transform: translateY(20px); }
    to { opacity: 1; transform: translateY(0); }
}

.nr-animate-entrance { animation: entrance 0.8s cubic-bezier(0.23, 1, 0.32, 1) forwards; opacity: 0; }

.nr-noise {
    position: fixed; inset: 0; z-index: 1; pointer-events: none; opacity: 0.05;
    background-image: url('data:image/svg+xml;utf8,%3Csvg viewBox="0 0 200 200" xmlns="http://www.w3.org/2000/svg"%3E%3Cfilter id="noiseFilter"%3E%3CfeTurbulence type="fractalNoise" baseFrequency="0.65" numOctaves="3" stitchTiles="stitch"/%3E%3C/filter%3E%3Crect width="100%25" height="100%25" filter="url(%23noiseFilter)"/%3E%3C/svg%3E');
}

.nr-blob-container { position: fixed; inset: 0; z-index: 0; overflow: hidden; pointer-events: none; }
.nr-blob { position: absolute; filter: blur(100px); border-radius: 50%; opacity: 0.4; transition: transform 0.1s ease-out; }
.nr-blob-1 { width: 50vw; height: 50vw; background: var(--text-muted); top: -10vw; left: -10vw; }
.nr-blob-2 { width: 40vw; height: 40vw; background: var(--c-orange); bottom: -10vw; right: -10vw; }
.nr-blob-3 { width: 30vw; height: 30vw; background: var(--c-red); top: 40%; left: 30%; }

.nr-particle-container {
    position: fixed; inset: 0; z-index: 2; pointer-events: none; overflow: hidden;
    mix-blend-mode: screen; opacity: 0.8;
}
.nr-particle {
    position: absolute; top: -10%;
    animation-name: fall; animation-timing-function: linear; animation-iteration-count: infinite;
    animation-duration: var(--nr-duration); animation-delay: var(--nr-delay);
    box-shadow: var(--nr-shadow);
}
@keyframes fall {
    0% { transform: translateY(0) translateX(0) rotate(0deg); opacity: 0; }
    10% { opacity: 1; }
    90% { opacity: 1; }
    100% { transform: translateY(110vh) translateX(var(--nr-drift)) rotate(var(--nr-rot)); opacity: 0; }
}
.nr-ember { border-radius: 50%; }
.particle-svg { width: 100%; height: 100%; }

.main-container {
    position: relative; z-index: 10; max-width: 1152px; margin: 0 auto;
    display: flex; flex-direction: column; min-height: 100vh;
    padding: env(safe-area-inset-top) env(safe-area-inset-right) env(safe-area-inset-bottom) env(safe-area-inset-left);
}
.content-wrapper { flex: 1; display: flex; flex-direction: column; gap: 1.25rem; padding: 0.5rem 0; }

.navbar { display: flex; justify-content: space-between; align-items: center; padding: 1.25rem 1.5rem; animation-delay: 0.05s; }
.nav-logo { height: 2.75rem; width: auto; filter: brightness(0) invert(1); opacity: 0.9; transition: transform 0.3s, filter 0.3s; }
.nav-logo-link:hover .nav-logo { transform: scale(1.05); filter: brightness(0) invert(1) drop-shadow(0 0 8px rgba(255,255,255,0.5)); }
.back-btn { background: rgba(255,255,255,0.1); border-radius: 9999px; padding: 0.5rem 1.25rem; font-size: 0.75rem; font-weight: 700; color: #fff; text-decoration: none; transition: background 0.3s; }
.back-btn:hover { background: rgba(255,255,255,0.2); }

.nr-hero-container { border-radius: 1rem; overflow: hidden; box-shadow: 0 25px 50px -12px var(--theme-bg-dark); margin: 0 1.5rem; border: 1px solid rgba(255, 255, 255, 0.1); animation-delay: 0.15s; }
.hero-inner { position: relative; height: 240px; background: var(--theme-page-bg); overflow: hidden; }
#hero-img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; transition: transform 0.1s ease-out; }

.kpi-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 0.5rem; padding: 0 1rem; animation-delay: 0.3s; }
@media(min-width: 640px) { .kpi-grid { gap: 1rem; padding: 0 1.5rem; } }

.nr-kpi-card { background: linear-gradient(135deg, var(--card-front-top) 0%, var(--card-front-bot) 100%); border-radius: 0.75rem; padding: 0.75rem; display: flex; flex-direction: column; justify-content: space-between; box-shadow: inset 0 0 20px rgba(0,0,0,0.05), 0 4px 6px rgba(0,0,0,0.1); border: 1px solid rgba(0, 0, 0, 0.1); color: var(--text-dark); }
@media(min-width: 640px) { .nr-kpi-card { padding: 1.5rem; border-radius: 1rem; } }

.kpi-header { display: flex; align-items: center; gap: 0.6rem; margin-bottom: 0.5rem; }
.kpi-icon-wrapper { width: 1.5rem; height: 1.5rem; border-radius: 0.4rem; display: flex; align-items: center; justify-content: center; box-shadow: 0 4px 6px rgba(0,0,0,0.1); border: 1px solid rgba(255,255,255,0.3); }
@media(min-width: 640px) { .kpi-icon-wrapper { width: 2.25rem; height: 2.25rem; border-radius: 0.75rem; } }

.kpi-svg { width: 1.25rem; height: 1.25rem; color: #fff; }
.kpi-label { font-size: 0.55rem; font-weight: 800; text-transform: uppercase; letter-spacing: 0.1em; color: var(--text-muted); opacity: 0.8; margin: 0; }
@media(min-width: 640px) { .kpi-label { font-size: 0.65rem; letter-spacing: 0.15em; } }

.kpi-value-container { display: flex; align-items: baseline; gap: 0.5rem; margin-top: 0.5rem; }
.nr-counter { font-size: 1.25rem; line-height: 1; font-weight: 900; font-family: 'Cinzel', serif; color: var(--text-dark); }
@media(min-width: 640px) { .nr-counter { font-size: 2.5rem; } }

.kpi-progress { margin-top: 1.25rem; }
.progress-info { display: flex; align-items: flex-end; justify-content: space-between; margin-bottom: 0.5rem; }
.progress-label { font-size: 0.65rem; color: var(--text-muted); opacity: 0.8; font-weight: 700; text-transform: uppercase; letter-spacing: 0.05em; }
.progress-values { font-size: 0.65rem; color: var(--text-muted); font-weight: 700; }
.progress-total { color: var(--text-dark); opacity: 0.5; }
.progress-bar-bg { position: relative; width: 100%; height: 8px; background: rgba(0,0,0,0.05); border-radius: 9999px; overflow: hidden; box-shadow: inset 0 2px 4px rgba(0,0,0,0.05); }
.progress-bar-fill { position: absolute; top: 0; left: 0; height: 100%; border-radius: 9999px; transition: width 1s cubic-bezier(0.23, 1, 0.32, 1); width: 0%; }

.timeline-section { position: relative; animation-delay: 0.45s; }
.timeline-header { display: flex; align-items: center; gap: 1rem; margin-bottom: 0.75rem; padding: 0 1.5rem; }
.line-divider { height: 1px; flex: 1; background: linear-gradient(to right, transparent, var(--c-orange), transparent); opacity: 0.5; }
.timeline-header h2 { font-size: 0.625rem; font-weight: 700; color: var(--c-amber); opacity: 0.7; text-transform: uppercase; letter-spacing: 0.2em; margin: 0; text-align: center; }

.timeline-navigation { position: absolute; inset: 0; pointer-events: none; z-index: 20; height: 480px; top: 2rem; }
.nav-arrow { position: absolute; top: 50%; transform: translateY(-50%); pointer-events: auto; background: transparent; border: none; padding: 0.75rem; color: var(--c-amber); cursor: pointer; border-radius: 9999px; transition: color 0.3s; opacity: 0.5; }
.nav-arrow:hover { color: var(--c-orange); opacity: 1; }
#prev-btn { left: 0.5rem; }
#next-btn { right: 0.5rem; }

.dots-container { position: absolute; bottom: -2rem; left: 0; right: 0; display: flex; justify-content: center; gap: 0.375rem; flex-wrap: wrap; padding: 0 1rem; pointer-events: auto; }
.nr-dot { width: 0.5rem; height: 0.5rem; border-radius: 50%; background: var(--c-amber); opacity: 0.3; border: none; cursor: pointer; transition: all 0.3s; padding: 0; }
.nr-dot:hover { opacity: 0.8; }
.nr-dot-active { background: var(--c-orange); transform: scale(1.5); opacity: 1; }
.nr-dot-special { box-shadow: 0 0 8px var(--c-red); background: var(--c-red); opacity: 0.5; }
.nr-dot-special.nr-dot-active { opacity: 1; }

.nr-card-strip { display: flex; align-items: center; gap: 1rem; width: 100%; height: 480px; overflow-x: auto; overflow-y: hidden; padding: 2rem 0; scroll-snap-type: x mandatory; scrollbar-width: none; }
.nr-card-strip::-webkit-scrollbar { display: none; }
@media(min-width: 640px) { .nr-card-strip { gap: 2rem; } }

.nr-card-wrapper { scroll-snap-align: center; padding: 1rem 1.5rem; flex-shrink: 0; perspective: 1000px; transition: opacity 0.3s, transform 0.3s; opacity: 0.5; transform: scale(0.9); }
.nr-card-wrapper.nr-centered { opacity: 1; transform: scale(1); z-index: 10; }

.nr-card-tilt { width: 75vw; max-width: 290px; height: 410px; border-radius: 1.5rem; transition: transform 0.1s ease-out; transform-style: preserve-3d; }
@media(min-width: 640px) { .nr-card-tilt { width: 320px; max-width: 100%; } }

.nr-glow-red { box-shadow: 0 0 30px rgba(239, 68, 68, 0.3); } /* Still statically glowing red on spike */
.nr-glow-orange { box-shadow: 0 0 30px rgba(249, 115, 22, 0.3); }

.nr-card-flip-container { position: relative; width: 100%; height: 100%; border-radius: inherit; perspective: 1000px; }
.nr-card-flip-inner { position: absolute; width: 100%; height: 100%; border-radius: inherit; transition: transform 0.6s cubic-bezier(0.4, 0, 0.2, 1); transform-style: preserve-3d; cursor: pointer; }
.nr-card-flip-inner.nr-flipped { transform: rotateY(180deg); }

.nr-card-front, .nr-card-back { position: absolute; width: 100%; height: 100%; backface-visibility: hidden; border-radius: inherit; display: flex; flex-direction: column; overflow: hidden; }

/* Themes & Parchment */
.nr-parchment { background: linear-gradient(to bottom, var(--card-front-top), var(--card-front-bot)); border: 2px solid rgba(0,0,0,0.1); color: var(--text-dark); }
.nr-parchment-strong { background: linear-gradient(to bottom, var(--card-back-top), var(--card-back-bot)); border: 2px solid rgba(0,0,0,0.15); color: var(--text-dark); }

.card-header { padding: 1.25rem 1.25rem 0.75rem; display: flex; justify-content: space-between; align-items: center; position: relative; z-index: 2; }
.card-date { font-size: 1.25rem; font-weight: 900; }
.card-badge { font-family: 'Space Grotesk', sans-serif; font-size: 0.5625rem; text-transform: uppercase; letter-spacing: 0.1em; padding: 0.25rem 0.625rem; border-radius: 0.5rem; font-weight: 700; background: rgba(0,0,0,0.05); color: var(--text-muted); }

.nr-badge-spike { background: var(--c-red); color: white; box-shadow: 0 0 10px rgba(239, 68, 68, 0.5); }

.card-divider { margin: 0 1.25rem; height: 1px; background: linear-gradient(to right, transparent, rgba(0,0,0,0.1), transparent); }

.card-body { padding: 1.25rem; flex: 1; display: flex; flex-direction: column; gap: 0.875rem; z-index: 2; overflow-y: auto; }
.pills-container { display: flex; flex-wrap: wrap; gap: 0.375rem; }
.nr-pill { padding: 0.375rem 0.75rem; border-radius: 0.5rem; font-size: 0.6875rem; font-weight: 700; letter-spacing: 0.05em; font-family: 'Space Grotesk', sans-serif; }
.nr-pill-recharge { background: rgba(0,0,0,0.05); color: var(--text-dark); border: 1px solid rgba(0,0,0,0.1); }
.nr-pill-spend { background: var(--c-red); color: white; opacity: 0.9; }
.nr-pill-draws { background: var(--c-orange); color: white; opacity: 0.9; }

.bullets-list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 0.75rem; }
.bullet-item { display: flex; align-items: flex-start; gap: 0.625rem; font-size: 0.8125rem; font-weight: 600; line-height: 1.5; letter-spacing: 0.025em; }
@media(min-width: 640px) { .bullet-item { font-size: 0.875rem; } }
.bullet-dot { margin-top: 0.4375rem; width: 0.5rem; height: 0.5rem; border-radius: 50%; border: 1px solid rgba(0,0,0,0.1); flex-shrink: 0; }
.bullet-bold { font-weight: 800; }
.bullet-text { opacity: 0.9; }

.key-day-tag { margin-top: auto; padding-top: 0.5rem; display: flex; justify-content: flex-end; align-items: center; gap: 0.375rem; font-size: 0.625rem; color: var(--c-red); font-weight: 700; text-transform: uppercase; letter-spacing: 0.1em; background: rgba(255,255,255,0.8); border: 1px solid var(--c-red); padding: 0.375rem 0.75rem; border-radius: 0.5rem; align-self: flex-end; box-shadow: 0 2px 4px rgba(0,0,0,0.05); }
.pulse-dot { width: 0.375rem; height: 0.375rem; border-radius: 50%; background: var(--c-red); animation: pulse 2s cubic-bezier(0.4, 0, 0.6, 1) infinite; }
@keyframes pulse { 0%, 100% { opacity: 1; } 50% { opacity: .5; } }

.card-glow-bg { position: absolute; bottom: -1.5rem; right: -1.5rem; width: 6rem; height: 6rem; border-radius: 50%; filter: blur(20px); pointer-events: none; opacity: 0.15; }
.card-glow-bg.bg-red { background: linear-gradient(to top left, var(--c-red), transparent); }
.card-glow-bg.bg-orange { background: linear-gradient(to top left, var(--c-orange), transparent); }
.card-glow-bg.bg-amber { background: linear-gradient(to top left, var(--c-amber), transparent); }

.nr-flip-hint { position: absolute; bottom: 0.75rem; left: 0; right: 0; display: flex; justify-content: center; z-index: 2; pointer-events: none; }
.hint-text { font-family: 'Space Grotesk', sans-serif; font-size: 0.5625rem; color: var(--text-muted); font-weight: 700; display: flex; align-items: center; gap: 0.25rem; }

.nr-card-back { transform: rotateY(180deg); align-items: center; justify-content: center; }
.back-top-bar { position: absolute; top: 0; left: 0; right: 0; height: 0.5rem; }
.card-back-content { padding: 1.25rem 1.5rem; display: flex; flex-direction: column; align-items: center; justify-content: center; flex: 1; gap: 1rem; width: 100%; position: relative; z-index: 2; }
.nr-protip-icon { font-size: 2.25rem; line-height: 1; filter: drop-shadow(0 4px 6px rgba(0,0,0,0.1)); filter: grayscale(1); }
.protip-label { font-family: 'Space Grotesk', sans-serif; font-size: 0.625rem; text-transform: uppercase; letter-spacing: 0.15em; font-weight: 700; background-clip: text; -webkit-background-clip: text; color: transparent; background-color: var(--c-orange); }
.protip-text { font-size: 0.875rem; font-weight: 700; line-height: 1.6; text-align: center; max-width: 240px; margin: 0; }
@media(min-width: 640px) { .protip-text { font-size: 0.9375rem; } }

.card-glow-bg-back { position: absolute; bottom: -1.5rem; left: -1.5rem; width: 6rem; height: 6rem; border-radius: 50%; filter: blur(20px); pointer-events: none; opacity: 0.15; }
.card-glow-bg-back.bg-red { background: linear-gradient(to top right, var(--c-red), transparent); }
.card-glow-bg-back.bg-orange { background: linear-gradient(to top right, var(--c-orange), transparent); }
.card-glow-bg-back.bg-amber { background: linear-gradient(to top right, var(--c-amber), transparent); }

.mt-auto { margin-top: auto; }

.page-footer { margin-top: auto; padding: 1.5rem 1.5rem; animation-delay: 0.6s; z-index: 10; position: relative; }
.footer-inner { border-radius: 1rem; padding: 1rem 1.5rem; display: flex; flex-direction: column; gap: 0.75rem; align-items: center; justify-content: space-between; box-shadow: 0 4px 6px -1px rgba(0,0,0,0.1); border-color: rgba(255, 255, 255, 0.05); }
@media(min-width: 640px) { .footer-inner { flex-direction: row; } }

.footer-brand { display: flex; align-items: center; gap: 0.75rem; }
.footer-logo { height: 2rem; width: auto; opacity: 0.9; }
.footer-title { font-family: 'Space Grotesk', sans-serif; font-size: 0.625rem; color: var(--text-muted); font-weight: 800; letter-spacing: 0.05em; text-transform: uppercase; }

.footer-legal { text-align: center; }
@media(min-width: 640px) { .footer-legal { text-align: right; } }
.copyright { font-size: 0.625rem; color: var(--text-muted); font-weight: 600; margin: 0; }
.trademark { font-size: 0.59375rem; color: var(--text-dark); opacity: 0.6; font-weight: 500; margin: 0.25rem 0 0 0; }
