/* ============================================================ BASE ============================================================ */ *, *::before, *::after { box-sizing: border-box; } html, body { margin: 0; padding: 0; } body { background: #000; color: #e5e7eb; font-family: "Inter", system-ui, sans-serif; } a { color: inherit; text-decoration: none; } img { display: block; max-width: 100%; } .container { width: 100%; max-width: 1120px; margin: 0 auto; padding: 0 1.25rem; } /* ============================================================ HEADER ============================================================ */ .site-header { position: sticky; top: 0; background: rgba(0, 0, 0, 0.9); border-bottom: 1px solid rgba(255, 0, 0, 0.35); backdrop-filter: blur(8px); z-index: 999; } .header-inner { display: flex; align-items: center; justify-content: space-between; padding: 0.75rem 0; } .logo-image { height: 56px; } .main-nav { display: flex; gap: 0.65rem; font-family: "Rajdhani", system-ui, sans-serif; } .nav-link { font-size: 0.78rem; text-transform: uppercase; letter-spacing: 0.22em; padding-bottom: 0.2rem; border-bottom: 1px solid transparent; color: #888; } .nav-link:hover { color: #ff3f3f; border-bottom-color: #ff3f3f; } .nav-active { color: #ff6b6b; border-bottom-color: #ff6b6b; } .nav-dot { color: #444; font-size: 0.6rem; } /* ============================================================ HERO SECTION ============================================================ */ .hero { position: relative; padding: 3rem 0 2rem; background: #000; } .hero-bg-glow { position: absolute; inset: -40%; background: radial-gradient(circle at 30% 0%, rgba(255, 0, 0, 0.25), transparent 60%), radial-gradient(circle at 80% 120%, rgba(150, 0, 0, 0.2), transparent 70%); pointer-events: none; } .hero-scanlines { position: absolute; inset: 0; opacity: 0.18; background-image: repeating-linear-gradient( to bottom, rgba(255, 0, 0, 0.12), rgba(255, 0, 0, 0.12) 1px, transparent 1px, transparent 3px ); mix-blend-mode: soft-light; } .hero-inner { position: relative; display: grid; grid-template-columns: minmax(0, 2fr) minmax(0, 1fr); gap: 2rem; align-items: center; } .hero-label { font-family: "Rajdhani"; font-size: 0.75rem; color: #ff4a4a; letter-spacing: 0.25em; margin-bottom: 0.8rem; text-transform: uppercase; } .hero-title { font-family: "Rajdhani"; font-size: 2.6rem; text-transform: uppercase; margin: 0; color: #eee; } .hero-title span { color: #ff2f2f; } .hero-sub { margin-top: 1rem; font-size: 1rem; color: #ccc; } .hero-tags { display: flex; gap: 0.5rem; margin-top: 1rem; } .hero-tag { padding: 0.3rem 0.6rem; border-radius: 999px; border: 1px solid rgba(255, 0, 0, 0.35); background: rgba(255, 0, 0, 0.08); text-transform: uppercase; letter-spacing: 0.15em; font-size: 0.68rem; color: #ffb3b3; } .hero-actions { margin-top: 1.5rem; display: flex; gap: 1rem; } .btn { display: inline-flex; justify-content: center; align-items: center; border-radius: 999px; padding: 0.6rem 1.4rem; font-size: 0.75rem; letter-spacing: 0.2em; text-transform: uppercase; } .btn-primary { background: #8b0000; border: 1px solid #ff3a3a; color: #ffdada; box-shadow: 0 0 18px rgba(255, 0, 0, 0.4); } .btn-primary:hover { background: #ff1a1a; } .btn-ghost { border: 1px solid rgba(255, 100, 100, 0.7); color: #ffbaba; } .btn-ghost:hover { background: rgba(255, 0, 0, 0.1); } /* ============================================================ TIER STACK ============================================================ */ .hero-right { display: flex; justify-content: flex-end; } .tower { background: rgba(20, 0, 0, 0.65); border: 1px solid rgba(255, 0, 0, 0.25); border-radius: 0.5rem; padding: 1rem; max-width: 320px; } .tower-header { display: flex; justify-content: space-between; color: #ff4e4e; font-family: "Rajdhani"; font-size: 0.72rem; letter-spacing: 0.22em; margin-bottom: 0.6rem; text-transform: uppercase; } .tower-row { display: flex; justify-content: space-between; background: rgba(0,0,0,0.45); padding: 0.6rem; margin-top: 0.5rem; border: 1px solid rgba(255,0,0,0.25); border-radius: 0.4rem; } .tower-name { color: #fff; font-family: "Rajdhani"; letter-spacing: 0.08em; text-transform: uppercase; } .tower-meta { font-size: 0.7rem; color: #bbb; } .tower-tier-tag { font-size: 0.6rem; padding: 0.25rem 0.5rem; border-radius: 999px; border: 1px solid rgba(255,0,0,0.3); color: #ffc6c6; letter-spacing: 0.15em; text-transform: uppercase; } .tower-tier-flagship { border-color: #ff3f3f; color: #ffdddd; } /* ============================================================ DOCTRINE SECTION ============================================================ */ .section { padding: 3rem 0; background: #000; } .section-kicker { font-family: "Rajdhani"; font-size: 0.72rem; color: #ff4a4a; letter-spacing: 0.22em; text-transform: uppercase; } .section-header h2 { font-family: "Rajdhani"; text-transform: uppercase; margin-top: 0.4rem; font-size: 1.5rem; } .doctrine-grid { margin-top: 1rem; display: grid; gap: 1rem; grid-template-columns: repeat(3,1fr); } .doctrine-card { background: rgba(10,0,0,0.55); border: 1px solid rgba(255,0,0,0.25); padding: 1rem; border-radius: 0.5rem; } .doctrine-card h3 { margin-bottom: 0.4rem; font-family: "Rajdhani"; color: #ff6b6b; } /* ============================================================ TIER CARDS ============================================================ */ .tier-section { background: #000; } .tier-grid { margin-top: 1.5rem; display: grid; grid-template-columns: repeat(4,1fr); gap: 1rem; } .tier-card { background: rgba(20,0,0,0.6); border: 1px solid rgba(255,0,0,0.22); padding: 1rem; border-radius: 0.5rem; } .tier-label { font-family: "Rajdhani"; font-size: 0.72rem; color: #ff4a4a; margin-bottom: 0.5rem; letter-spacing: 0.22em; text-transform: uppercase; } .tier-card h3 { font-family: "Rajdhani"; color: #fff; letter-spacing: 0.08em; text-transform: uppercase; margin: 0; } .tier-card p { margin: 0.6rem 0 1rem; color: #ccc; } .tier-card ul { list-style: none; padding: 0; margin: 0 0 1rem; color: #aaa; } .tier-card li { margin-bottom: 0.2rem; } .tier-link { font-size: 0.75rem; color: #ffcccc; letter-spacing: 0.18em; text-transform: uppercase; } .tier-link:hover { color: #fff; } /* ============================================================ FOOTER ============================================================ */ .site-footer { padding: 1.5rem 0; border-top: 1px solid rgba(255,0,0,0.15); text-align: center; background: #000; } .footer-inner p { font-size: 0.72rem; color: #777; } /* ============================================================ INTRO OVERLAY ============================================================ */ .reaper-intro { position: fixed; inset: 0; background: #000; display: flex; justify-content: center; align-items: center; z-index: 9999; overflow: hidden; transition: opacity 0.6s ease-out; } .reaper-intro-hide { opacity: 0; pointer-events: none; } .reaper-intro-fire { position: absolute; inset: -10%; background: radial-gradient(circle at 50% 120%, rgba(255,0,0,0.25), transparent 60%), radial-gradient(circle at 0% 100%, rgba(255,0,0,0.15), transparent 60%), radial-gradient(circle at 100% 100%, rgba(255,0,0,0.1), transparent 60%); animation: introFire 2s infinite alternate; } @keyframes introFire { 0% { transform: scale(1); opacity: 0.6; } 100% { transform: scale(1.05) translateY(-4px); opacity: 1; } } .reaper-intro-noise { position: absolute; inset: 0; opacity: 0.22; background-image: repeating-linear-gradient( to bottom, rgba(255,0,0,0.15), rgba(255,0,0,0.15) 1px, transparent 1px, transparent 4px ); } .reaper-intro-inner { position: relative; text-align: center; z-index: 10; } .reaper-intro-text { font-family: "Rajdhani"; font-size: 1rem; color: #ff4a4a; letter-spacing: 0.22em; text-transform: uppercase; margin-bottom: 1rem; white-space: pre-line; } /* bigger skull, no animation, just show */ .reaper-intro-image { width: 60vw; max-width: 900px; opacity: 1; } /* ============================================================ RESPONSIVE ============================================================ */ @media (max-width: 960px) { .hero-inner { grid-template-columns: 1fr; } .tier-grid { grid-template-columns: repeat(2,1fr); } } @media (max-width: 640px) { .tier-grid { grid-template-columns: 1fr; } .logo-image { height: 48px; } .reaper-intro-image { width: 80vw; } }