:root {
  --bg: #040711;
  --bg-2: #08131d;
  --panel: rgba(9, 22, 34, 0.72);
  --panel-strong: rgba(7, 18, 30, 0.92);
  --text: #f6fbff;
  --muted: #a6b9c6;
  --cyan: #22f0ef;
  --cyan-2: #51c9ff;
  --cyan-soft: rgba(34, 240, 239, 0.22);
  --gold: #eaff34;
  --gold-2: #ffef61;
  --gold-soft: rgba(234, 255, 52, 0.20);
  --line: rgba(255, 255, 255, 0.13);
  --line-cyan: rgba(34, 240, 239, 0.28);
  --shadow: 0 30px 90px rgba(0, 0, 0, 0.48);
  --radius: 28px;
  --radius-sm: 16px;
  --max: 1180px;
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; background: var(--bg); color: var(--text); font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif; overflow-x: hidden; }
body.is-gate-ready { overflow: hidden; }
body.site-entered { overflow: auto; }
a { color: inherit; }
img { max-width: 100%; display: block; }
.background-system { position: fixed; inset: 0; z-index: -4; overflow: hidden; background: radial-gradient(circle at 22% 12%, rgba(34, 240, 239, 0.18), transparent 32%), radial-gradient(circle at 82% 22%, rgba(234, 255, 52, 0.14), transparent 28%), linear-gradient(135deg, #02050b 0%, #07101c 46%, #05070d 100%); }
.background-system::before { content: ""; position: absolute; inset: -10%; background-image: linear-gradient(rgba(255,255,255,0.035) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,0.035) 1px, transparent 1px); background-size: 52px 52px; mask-image: radial-gradient(circle at center, black, transparent 70%); opacity: .38; }
.starfield { position: absolute; inset: 0; background-image: radial-gradient(circle, rgba(255,255,255,.42) 1px, transparent 1px), radial-gradient(circle, rgba(34,240,239,.35) 1px, transparent 1px); background-size: 120px 120px, 170px 170px; background-position: 0 0, 38px 62px; opacity: .18; animation: stars 34s linear infinite; }
.orb { position: absolute; width: 36rem; height: 36rem; border-radius: 999px; filter: blur(90px); opacity: .42; animation: drift 16s ease-in-out infinite alternate; }
.orb-cyan { left: -10rem; top: 10rem; background: var(--cyan); }
.orb-gold { right: -16rem; top: 4rem; background: var(--gold); animation-delay: -5s; }
.grid-floor { position: absolute; left: -10%; right: -10%; bottom: -18%; height: 42%; background: linear-gradient(rgba(34,240,239,.12) 1px, transparent 1px), linear-gradient(90deg, rgba(34,240,239,.1) 1px, transparent 1px); background-size: 44px 44px; transform: perspective(520px) rotateX(62deg); transform-origin: center bottom; opacity: .25; }
.scanline { position: absolute; inset: 0; pointer-events: none; background: repeating-linear-gradient(to bottom, rgba(255,255,255,.024), rgba(255,255,255,.024) 1px, transparent 1px, transparent 5px); opacity: .32; }
@keyframes drift { from { transform: translate3d(0,0,0) scale(1); } to { transform: translate3d(7%, -4%, 0) scale(1.12); } }
@keyframes stars { from { transform: translateY(0); } to { transform: translateY(-120px); } }
.welcome-gate {
  position: fixed;
  inset: 0;
  z-index: 50;
  min-height: 100svh;
  display: grid;
  place-items: center;
  padding: 24px;
  overflow: hidden;
  isolation: isolate;
  background: #02050b;
  transform: translateY(0);
  opacity: 1;
  visibility: visible;
  transition: transform .95s cubic-bezier(.76,0,.24,1), visibility .95s step-end;
}
.welcome-gate::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 2;
  pointer-events: none;
  background:
    radial-gradient(circle at 50% 34%, rgba(34,240,239,.17), transparent 38%),
    radial-gradient(circle at 82% 78%, rgba(234,255,52,.12), transparent 28%),
    linear-gradient(180deg, rgba(2,5,10,.24), rgba(2,5,10,.90));
}
.welcome-gate.is-entering {
  transform: translateY(110vh);
  opacity: 1;
  visibility: hidden;
  pointer-events: none;
}
.gate-video-bg {
  position: absolute;
  inset: -34px;
  z-index: 1;
  width: calc(100% + 68px);
  height: calc(100% + 68px);
  object-fit: cover;
  filter: blur(14px) brightness(.46) saturate(1.12);
  transform: scale(1.055);
  pointer-events: none;
}
.gate-video-fallback {
  position: absolute;
  inset: -34px;
  z-index: 0;
  background:
    linear-gradient(180deg, rgba(2,5,10,.16), rgba(2,5,10,.80)),
    url('../assets/images/iwrc-intro-poster.jpg') center/cover no-repeat,
    url('../assets/images/iwrc-dashboard-banner.jpg') center/cover no-repeat;
  filter: blur(12px) brightness(.48) saturate(1.15);
  transform: scale(1.055);
}
.gate-noise {
  position: absolute;
  inset: 0;
  z-index: 3;
  pointer-events: none;
  background:
    radial-gradient(circle at 20% 20%, var(--cyan-soft), transparent 34%),
    radial-gradient(circle at 80% 80%, var(--gold-soft), transparent 28%),
    repeating-linear-gradient(to bottom, rgba(255,255,255,.03), rgba(255,255,255,.03) 1px, transparent 1px, transparent 5px);
  mix-blend-mode: screen;
  opacity: .68;
}
.gate-ring { position: absolute; z-index: 4; width: min(72vw, 680px); aspect-ratio: 1; border: 1px solid rgba(34,240,239,.25); border-radius: 50%; box-shadow: inset 0 0 60px rgba(34,240,239,.10), 0 0 80px rgba(234,255,52,.08); animation: rotateRing 16s linear infinite; }
.gate-ring::before, .gate-ring::after { content:""; position:absolute; inset: 12%; border: 1px dashed rgba(234,255,52,.20); border-radius: 50%; }
.gate-ring::after { inset: -7%; border-color: rgba(34,240,239,.14); }
@keyframes rotateRing { to { transform: rotate(360deg); } }
.gate-panel { width: min(900px, 100%); position: relative; z-index: 5; display: grid; justify-items: center; text-align: center; padding: clamp(28px, 6vw, 64px); border-radius: 34px; border: 1px solid rgba(255,255,255,.16); background: linear-gradient(145deg, rgba(4, 10, 17, .82), rgba(13, 28, 41, .58)); box-shadow: var(--shadow), 0 0 80px rgba(34,240,239,.12); backdrop-filter: blur(18px); overflow: hidden; }
.gate-panel::before { content: ""; position: absolute; inset: 0; background: linear-gradient(90deg, transparent, rgba(34,240,239,.14), transparent); transform: translateX(-120%); animation: sheen 4.8s ease-in-out infinite; }
.gate-logo { width: min(330px, 70vw); margin-bottom: 20px; filter: drop-shadow(0 0 26px rgba(34,240,239,.38)); }
.eyebrow { margin: 0 0 12px; color: var(--gold); text-transform: uppercase; letter-spacing: .16em; font-size: .78rem; font-weight: 900; }
.gate-panel h1 { max-width: 760px; margin: 0; font-size: clamp(2.3rem, 7vw, 5.7rem); line-height: .95; letter-spacing: -0.06em; }
.gate-copy { max-width: 690px; margin: 22px auto 28px; color: var(--muted); font-size: clamp(1rem, 2vw, 1.2rem); line-height: 1.7; }
.enter-button { cursor: pointer; border: 0; color: #041014; background: linear-gradient(135deg, var(--cyan), var(--gold)); padding: 15px 34px; border-radius: 999px; font-weight: 950; text-transform: uppercase; letter-spacing: .14em; box-shadow: 0 0 28px rgba(34,240,239,.34); transition: transform .2s ease, box-shadow .2s ease; }
.enter-button:hover { transform: translateY(-3px); box-shadow: 0 0 42px rgba(234,255,52,.32), 0 0 28px rgba(34,240,239,.30); }
.gate-panel small { color: rgba(246,251,255,.55); margin-top: 18px; }
@keyframes sheen { 0%, 45% { transform: translateX(-130%); } 70%, 100% { transform: translateX(130%); } }
.site-shell { position: relative; z-index: 2; width: min(var(--max), calc(100% - 32px)); margin: 0 auto; }
.dashboard-shell { opacity: 1; transform: none; transition: opacity .75s ease .25s, transform .75s ease .25s; }
body.is-gate-ready:not(.site-entered) .dashboard-shell { opacity: 1; transform: none; }
body.site-entered .dashboard-shell, body.no-gate .site-shell { opacity: 1; transform: none; }
.page-shell { min-height: 100vh; padding-top: 18px; }
.site-header { position: sticky; top: 14px; z-index: 30; display: flex; align-items: center; justify-content: space-between; gap: 18px; margin: 18px 0 28px; padding: 10px 12px; border: 1px solid rgba(34,240,239,.18); border-radius: 999px; background: rgba(5, 11, 18, .74); backdrop-filter: blur(18px); box-shadow: 0 18px 70px rgba(0,0,0,.26), inset 0 0 0 1px rgba(255,255,255,.03); }
.site-header.scrolled { background: rgba(5, 11, 18, .92); box-shadow: 0 16px 60px rgba(0,0,0,.34), 0 0 30px rgba(34,240,239,.06); }
.brand { display: flex; align-items: center; gap: 10px; text-decoration: none; min-width: max-content; }
.brand-orbit { width: 46px; height: 46px; display: grid; place-items:center; border-radius: 50%; background: radial-gradient(circle, rgba(34,240,239,.18), rgba(234,255,52,.08) 55%, transparent 56%); box-shadow: 0 0 24px rgba(34,240,239,.18); }
.brand-mark { width: 42px; height: 42px; object-fit: contain; filter: drop-shadow(0 0 10px rgba(34,240,239,.32)); }
.brand-copy { display: grid; line-height: 1; }
.brand-copy strong { letter-spacing: .1em; }
.brand-copy small { color: var(--muted); font-size: .68rem; margin-top: 4px; }
.site-nav { display: flex; align-items: center; gap: 4px; }
.nav-link, .nav-cta { text-decoration: none; color: var(--muted); padding: 10px 12px; border-radius: 999px; font-size: .9rem; transition: background .2s ease, color .2s ease, box-shadow .2s ease, transform .2s ease; }
.nav-link:hover, .nav-link.active { color: var(--text); background: rgba(255,255,255,.08); box-shadow: inset 0 0 0 1px rgba(34,240,239,.12); }
.nav-cta { color: #041014; background: linear-gradient(135deg, var(--cyan), var(--gold)); font-weight: 950; margin-left: 4px; }
.nav-cta:hover { transform: translateY(-2px); box-shadow: 0 0 26px rgba(34,240,239,.22); }
.nav-toggle { display: none; width: 44px; height: 44px; background: rgba(255,255,255,.08); border: 1px solid var(--line); border-radius: 50%; }
.nav-toggle span { display: block; width: 18px; height: 2px; background: var(--text); margin: 4px auto; }
.hero-section { position: relative; min-height: 680px; display: grid; align-items: end; grid-template-columns: 1fr minmax(240px, 360px); gap: 24px; padding: clamp(28px, 6vw, 68px); border: 1px solid var(--line); border-radius: 36px; overflow: hidden; box-shadow: var(--shadow); background: var(--panel-strong); }
.hero-section::after { content:""; position:absolute; inset:0; pointer-events:none; background: linear-gradient(90deg, rgba(34,240,239,.34), transparent 22%, transparent 78%, rgba(234,255,52,.24)); mix-blend-mode: screen; opacity:.35; }
.hero-art { position: absolute; inset: 0; z-index: -1; background: linear-gradient(90deg, rgba(4,8,14,.96) 0%, rgba(4,8,14,.52) 46%, rgba(4,8,14,.88) 100%), url('../assets/images/iwrc-hero-1920.jpg') center/cover no-repeat; transform: scale(1.02); }
.hero-section h1, .page-hero h1 { max-width: 850px; margin: 0; font-size: clamp(3rem, 8vw, 7.4rem); line-height: .88; letter-spacing: -0.075em; }
.hero-copy, .page-hero p { max-width: 720px; color: var(--muted); font-size: clamp(1.03rem, 2vw, 1.25rem); line-height: 1.7; }
.button-row { display: flex; flex-wrap: wrap; align-items: center; gap: 12px; margin-top: 28px; }
.button-row.center { justify-content: center; }
.button { display: inline-flex; align-items: center; justify-content: center; min-height: 48px; padding: 13px 20px; border-radius: 999px; text-decoration: none; font-weight: 950; border: 1px solid transparent; transition: transform .2s ease, box-shadow .2s ease, background .2s ease; }
.button.primary { color: #041014; background: linear-gradient(135deg, var(--cyan), var(--gold)); box-shadow: 0 0 30px rgba(34,240,239,.22); }
.button.ghost { color: var(--text); border-color: var(--line); background: rgba(255,255,255,.06); }
.button.large { padding: 16px 26px; font-size: 1.02rem; }
.button:hover { transform: translateY(-3px); }
.hero-status-card { align-self: end; padding: 22px; border-radius: 24px; border: 1px solid rgba(34,240,239,.18); background: rgba(0,0,0,.42); backdrop-filter: blur(14px); box-shadow: 0 0 42px rgba(34,240,239,.08); }
.status-badge { width: 88px; height: 88px; object-fit: contain; margin-bottom: 16px; border-radius: 20px; box-shadow: 0 0 34px rgba(34,240,239,.16); }
.status-dot { display: inline-block; width: 11px; height: 11px; margin-right: 8px; border-radius: 50%; background: var(--gold); box-shadow: 0 0 20px var(--gold); }
.hero-status-card p { color: var(--muted); line-height: 1.6; margin-bottom: 0; }
.section { margin: 28px 0; }
.block-section, .bot-section, .join-panel, .panel, .feature-card, .page-hero, .brand-strip { border: 1px solid var(--line); border-radius: var(--radius); background: linear-gradient(145deg, rgba(255,255,255,.072), rgba(255,255,255,.032)); box-shadow: 0 22px 70px rgba(0,0,0,.22); backdrop-filter: blur(14px); }
.brand-strip { display: grid; grid-template-columns: .78fr 1fr; gap: 24px; align-items: center; overflow: hidden; padding: 16px; background: linear-gradient(135deg, rgba(34,240,239,.10), rgba(234,255,52,.06)); }
.brand-strip img { width: 100%; height: 190px; object-fit: cover; border-radius: 20px; border: 1px solid rgba(255,255,255,.11); }
.brand-strip h2 { margin: 0; font-size: clamp(1.8rem,4vw,3.2rem); line-height: 1; letter-spacing: -.05em; }
.block-section { padding: clamp(24px, 5vw, 42px); }
.section-heading { display: grid; gap: 8px; margin-bottom: 24px; }
.section-heading h2, .bot-copy h2, .join-panel h2, .panel h2 { margin: 0; font-size: clamp(2rem, 4vw, 3.8rem); line-height: 1; letter-spacing: -0.05em; }
.section-heading p, .bot-copy p, .join-panel p, .panel p, .feature-card p, .mode-card p { color: var(--muted); line-height: 1.7; }
.card-grid { display: grid; gap: 16px; }
.card-grid.four { grid-template-columns: repeat(4, 1fr); }
.card-grid.three { grid-template-columns: repeat(3, 1fr); }
.feature-card { padding: 22px; position: relative; overflow: hidden; }
.feature-card::before { content:""; position:absolute; inset:0; border-radius:inherit; background: linear-gradient(135deg, rgba(34,240,239,.10), transparent 38%, rgba(234,255,52,.08)); opacity:0; transition: opacity .25s ease; }
.feature-card::after { content: ""; position: absolute; inset: auto -20% -50% -20%; height: 90px; background: radial-gradient(circle, var(--cyan-soft), transparent 62%); opacity: 0; transition: opacity .25s ease; }
.feature-card:hover::before, .feature-card:hover::after { opacity: 1; }
.feature-card span { color: var(--gold); font-weight: 950; font-size: .78rem; letter-spacing: .12em; text-transform: uppercase; position:relative; }
.feature-card h3 { margin: 14px 0 8px; font-size: 1.25rem; position:relative; }
.feature-card p { position:relative; }
.mode-showcase { display: grid; grid-template-columns: 1.15fr .85fr; gap: 16px; }
.mode-card { min-height: 300px; padding: 26px; border-radius: var(--radius); border: 1px solid var(--line); overflow: hidden; position: relative; background: linear-gradient(145deg, rgba(255,255,255,.08), rgba(255,255,255,.03)); }
.mode-card:first-child { grid-row: span 2; }
.mode-card::before { content: ""; position: absolute; inset: 0; z-index: -1; opacity: .46; background: linear-gradient(180deg, rgba(4,8,14,.44), rgba(4,8,14,.92)), url('../assets/images/iwrc-panel-art.jpg') center/cover no-repeat; }
.mode-card:nth-child(2)::before { background-image: radial-gradient(circle at 20% 0%, rgba(34,240,239,.42), transparent 40%), radial-gradient(circle at 90% 80%, rgba(234,255,52,.34), transparent 40%); }
.mode-card:nth-child(3)::before { background-image: linear-gradient(180deg, rgba(4,8,14,.30), rgba(4,8,14,.86)), url('../assets/images/iwrc-welcome-strip.jpg'); }
.mode-card h2 { margin: 0; font-size: clamp(1.8rem, 4vw, 3.4rem); line-height: .98; letter-spacing: -0.05em; }
.mode-card a { display: inline-flex; margin-top: 14px; color: var(--gold); text-decoration: none; font-weight: 950; }
.bot-section { display: grid; grid-template-columns: .9fr 1.1fr; gap: 22px; padding: clamp(24px, 5vw, 42px); align-items: center; }
.bot-list { display: flex; flex-wrap: wrap; gap: 10px; }
.bot-list span { padding: 12px 14px; border-radius: 999px; border: 1px solid rgba(34,240,239,.22); background: rgba(34,240,239,.08); color: #d9ffff; font-weight: 850; }
.join-panel { display: flex; align-items: center; justify-content: space-between; gap: 24px; padding: clamp(24px, 5vw, 42px); background: linear-gradient(135deg, rgba(34,240,239,.13), rgba(234,255,52,.12)); }
.page-hero { margin: 28px 0; min-height: 430px; display: grid; place-items: center; text-align: center; padding: clamp(34px, 7vw, 78px); position: relative; overflow: hidden; }
.page-hero::before { content: ""; position: absolute; inset: 0; z-index: -1; background: linear-gradient(180deg, rgba(5,8,15,.62), rgba(5,8,15,.96)), url('../assets/images/iwrc-dashboard-banner.jpg') center/cover no-repeat; opacity: .94; }
.page-hero::after { content:""; position:absolute; inset:0; z-index:-1; background: radial-gradient(circle at 20% 10%, rgba(34,240,239,.28), transparent 30%), radial-gradient(circle at 88% 85%, rgba(234,255,52,.18), transparent 28%); }
.page-hero.compact { min-height: 390px; }
.join-hero::before { background-image: linear-gradient(180deg, rgba(5,8,15,.58), rgba(5,8,15,.96)), url('../assets/images/iwrc-hero-1920.jpg'); }
.server-hero::before { background-image: linear-gradient(180deg, rgba(5,8,15,.60), rgba(5,8,15,.96)), url('../assets/images/iwrc-welcome-strip.jpg'); }
.zombies-hero::before, .multiplayer-hero::before { background-image: linear-gradient(180deg, rgba(5,8,15,.60), rgba(5,8,15,.96)), url('../assets/images/iwrc-panel-art.jpg'); }
.contact-hero::before { background-image: linear-gradient(180deg, rgba(5,8,15,.60), rgba(5,8,15,.96)), url('../assets/images/iwrc-dashboard-banner.jpg'); }
.two-column { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.panel { padding: clamp(22px, 4vw, 34px); }
.panel.highlight { border-color: rgba(234,255,52,.25); background: linear-gradient(145deg, rgba(234,255,52,.12), rgba(255,255,255,.035)); }
.site-footer { position: relative; margin: 36px 0 22px; padding: 30px; border: 1px solid var(--line); border-radius: var(--radius); background: rgba(3, 8, 13, .84); overflow:hidden; }
.footer-glow { position:absolute; inset:auto -10% -50% -10%; height: 130px; background: radial-gradient(circle, rgba(34,240,239,.16), transparent 60%); pointer-events:none; }
.footer-grid { display: grid; grid-template-columns: 1.2fr .6fr .6fr; gap: 24px; position:relative; }
.footer-brand { display: flex; align-items: center; gap: 10px; font-weight: 950; letter-spacing: .1em; }
.footer-brand img { width: 34px; height: 34px; object-fit:contain; }
.site-footer p, .site-footer a { color: var(--muted); line-height: 1.6; }
.site-footer h3 { margin: 0 0 12px; }
.site-footer a { display: block; text-decoration: none; margin: 7px 0; }
.site-footer a:hover { color: var(--text); }
.legal { margin: 24px 0 0; padding-top: 18px; border-top: 1px solid var(--line); font-size: .78rem; color: rgba(246,251,255,.54) !important; position:relative; }
.reveal { opacity: 0; transform: translateY(22px); transition: opacity .65s ease, transform .65s ease; }
.reveal.visible { opacity: 1; transform: none; }
@media (max-width: 980px) { .site-header { border-radius: 24px; align-items: flex-start; } .nav-toggle { display: block; flex: 0 0 auto; } .site-nav { position: absolute; left: 12px; right: 12px; top: calc(100% + 8px); flex-direction: column; align-items: stretch; padding: 10px; border-radius: 22px; border: 1px solid var(--line); background: rgba(5, 11, 18, .96); transform: translateY(-8px); opacity: 0; pointer-events: none; transition: opacity .2s ease, transform .2s ease; } .site-nav.open { opacity: 1; transform: none; pointer-events: auto; } .nav-link, .nav-cta { width: 100%; } .hero-section, .bot-section, .two-column, .footer-grid, .brand-strip { grid-template-columns: 1fr; } .mode-showcase { grid-template-columns: 1fr; } .mode-card:first-child { grid-row: auto; } .card-grid.four, .card-grid.three { grid-template-columns: 1fr 1fr; } .join-panel { flex-direction: column; align-items: flex-start; } }
@media (max-width: 640px) { .site-shell { width: min(100% - 22px, var(--max)); } .brand-copy small { display: none; } .hero-section { min-height: 620px; padding: 24px; grid-template-columns: 1fr; } .hero-section h1, .page-hero h1 { font-size: clamp(2.8rem, 17vw, 4.4rem); } .card-grid.four, .card-grid.three { grid-template-columns: 1fr; } .gate-panel { border-radius: 24px; } .gate-logo { width: min(260px, 75vw); } .button-row { flex-direction: column; align-items: stretch; } .button { width: 100%; } .brand-strip img { height: 150px; } }
@media (prefers-reduced-motion: reduce) { *, *::before, *::after { animation: none !important; transition: none !important; scroll-behavior: auto !important; } body.is-gate-ready { overflow: auto; } .gate-video-bg { display: none; } .welcome-gate.is-entering { display: none; } }


/* Update 3 content-page expansion */
.dashboard-metrics { display:grid; grid-template-columns:repeat(4,1fr); gap:14px; }
.dashboard-metrics article, .step-card, .contact-card, .status-tiles article, .platform-cards article, .rules-grid article { border:1px solid var(--line); background:linear-gradient(145deg, rgba(255,255,255,.08), rgba(255,255,255,.025)); border-radius:22px; padding:20px; position:relative; overflow:hidden; }
.dashboard-metrics article::before, .step-card::before, .contact-card::before, .platform-cards article::before { content:""; position:absolute; inset:0; background:radial-gradient(circle at 16% 0%, rgba(34,240,239,.18), transparent 36%); opacity:.7; pointer-events:none; }
.dashboard-metrics span, .step-card span, .contact-card span, .status-tiles span { display:inline-flex; color:var(--gold); font-size:.74rem; font-weight:950; letter-spacing:.12em; text-transform:uppercase; margin-bottom:10px; position:relative; }
.dashboard-metrics strong, .status-tiles strong, .platform-cards strong, .rules-grid strong { display:block; font-size:1.12rem; position:relative; }
.dashboard-metrics p, .step-card p, .contact-card p, .status-tiles p, .platform-cards span, .rules-grid span { color:var(--muted); line-height:1.6; position:relative; }
.content-split { display:grid; grid-template-columns:1.2fr .8fr; gap:18px; align-items:stretch; }
.panel.jumbo { padding:clamp(26px,5vw,48px); }
.panel.jumbo p { font-size:1.02rem; }
.identity-panel h3 { margin-top:0; font-size:1.5rem; }
.styled-list { list-style:none; padding:0; margin:18px 0 0; display:grid; gap:12px; }
.styled-list li { color:var(--muted); line-height:1.55; padding-left:30px; position:relative; }
.styled-list li::before { content:""; position:absolute; left:0; top:.42em; width:12px; height:12px; border-radius:50%; background:linear-gradient(135deg, var(--cyan), var(--gold)); box-shadow:0 0 18px rgba(34,240,239,.45); }
.timeline-section { padding:clamp(24px,5vw,42px); }
.timeline { display:grid; grid-template-columns:repeat(4,1fr); gap:14px; margin-top:22px; }
.timeline article { border-left:2px solid rgba(34,240,239,.32); padding:10px 16px 16px; background:rgba(255,255,255,.035); border-radius:0 18px 18px 0; }
.timeline span { color:var(--gold); font-weight:950; font-size:.8rem; letter-spacing:.14em; text-transform:uppercase; }
.timeline h3 { margin:10px 0 8px; }
.timeline p { color:var(--muted); line-height:1.65; }
.join-flow { padding:clamp(24px,5vw,42px); }
.step-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:14px; margin-top:22px; }
.server-rules { display:grid; grid-template-columns:.9fr 1.1fr; gap:18px; align-items:stretch; }
.rules-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:14px; }
.status-board { display:grid; grid-template-columns:1fr .8fr; gap:18px; align-items:stretch; }
.status-panel { border:1px solid rgba(34,240,239,.2); border-radius:var(--radius); padding:clamp(24px,5vw,44px); background:linear-gradient(135deg, rgba(34,240,239,.12), rgba(255,255,255,.035)); }
.status-panel h2 { font-size:clamp(2rem,4vw,3.6rem); line-height:1; letter-spacing:-.05em; margin:0 0 12px; }
.status-panel p { color:var(--muted); line-height:1.7; }
.status-tiles { display:grid; gap:14px; }
.checklist-section { padding:clamp(24px,5vw,42px); }
.checklist { display:grid; grid-template-columns:repeat(5,1fr); gap:12px; margin-top:20px; }
.checklist label { border:1px solid var(--line); border-radius:18px; padding:16px; color:var(--muted); background:rgba(255,255,255,.04); display:flex; gap:10px; align-items:flex-start; }
.checklist input { accent-color:var(--cyan); margin-top:2px; }
.mode-dashboard { display:grid; grid-template-columns:1fr .7fr; gap:18px; align-items:stretch; }
.mode-actions { display:grid; gap:12px; }
.mode-actions a { display:flex; align-items:center; justify-content:space-between; min-height:64px; padding:16px 18px; border-radius:18px; border:1px solid rgba(34,240,239,.18); background:rgba(34,240,239,.065); color:var(--text); text-decoration:none; font-weight:900; }
.mode-actions a::after { content:"→"; color:var(--gold); }
.platform-grid { padding:clamp(24px,5vw,42px); }
.platform-cards { display:grid; grid-template-columns:repeat(4,1fr); gap:14px; margin-top:22px; }
.contact-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:16px; }
.contact-card { min-height:260px; display:flex; flex-direction:column; }
.contact-card h2 { margin:4px 0 10px; font-size:1.65rem; position:relative; }
.contact-card a { margin-top:auto; color:var(--gold); text-decoration:none; font-weight:950; position:relative; }
.footer-socials { display:flex; flex-wrap:wrap; gap:8px; margin-top:12px; }
.footer-socials a { margin:0; padding:8px 10px; border:1px solid rgba(34,240,239,.15); border-radius:999px; background:rgba(34,240,239,.055); }
@media (max-width: 980px) { .dashboard-metrics, .timeline, .step-grid, .platform-cards, .checklist { grid-template-columns:1fr 1fr; } .content-split, .server-rules, .status-board, .mode-dashboard, .contact-grid { grid-template-columns:1fr; } }
@media (max-width: 640px) { .dashboard-metrics, .timeline, .step-grid, .platform-cards, .rules-grid, .checklist { grid-template-columns:1fr; } .contact-card { min-height:auto; } }


/* Update 4 — polish, motion, accessibility, and responsive refinement */
html { scroll-behavior: smooth; }
::selection { background: rgba(234, 255, 52, .28); color: #ffffff; }
:focus-visible { outline: 2px solid var(--gold); outline-offset: 4px; border-radius: 12px; }
.skip-link { position: fixed; left: 18px; top: 12px; z-index: 10000; padding: 10px 14px; border-radius: 999px; color: #06111d; background: var(--gold); font-weight: 950; text-decoration: none; transform: translateY(-140%); transition: transform .2s ease; }
.skip-link:focus { transform: translateY(0); }
.scroll-progress { position: fixed; left: 0; top: 0; width: 100%; height: 4px; z-index: 9999; background: rgba(255,255,255,.05); }
.scroll-progress span { display: block; width: 0%; height: 100%; background: linear-gradient(90deg, var(--cyan), var(--gold)); box-shadow: 0 0 22px rgba(34,240,239,.7); transition: width .08s linear; }
.pointer-spotlight { position: fixed; inset: 0; z-index: -1; pointer-events: none; background: radial-gradient(520px circle at var(--mouse-x, 50%) var(--mouse-y, 20%), rgba(34,240,239,.12), transparent 42%); mix-blend-mode: screen; opacity: .9; transition: opacity .25s ease; }
body:not(.has-pointer) .pointer-spotlight { opacity: .4; }
.background-system::after { content:""; position:absolute; inset:0; background: radial-gradient(circle at var(--mouse-x, 50%) var(--mouse-y, 25%), rgba(234,255,52,.09), transparent 32%); pointer-events:none; opacity:.72; }
.site-header { backdrop-filter: blur(18px) saturate(145%); }
.site-header::after { content:""; position:absolute; left:22px; right:22px; bottom:-1px; height:1px; background:linear-gradient(90deg, transparent, rgba(34,240,239,.65), rgba(234,255,52,.45), transparent); opacity:.6; }
.nav-link { position: relative; overflow: hidden; }
.nav-link::after { content:""; position:absolute; left:14px; right:14px; bottom:8px; height:2px; border-radius:999px; background:linear-gradient(90deg, var(--cyan), var(--gold)); transform:scaleX(0); transform-origin:left; transition: transform .24s ease; }
.nav-link:hover::after, .nav-link.active::after { transform:scaleX(1); }
.nav-toggle.is-open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.nav-toggle.is-open span:nth-child(2) { opacity: 0; }
.nav-toggle.is-open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }
.button, .nav-cta, .enter-button, .mode-actions a { position: relative; overflow: hidden; isolation: isolate; }
.button::before, .nav-cta::before, .enter-button::before, .mode-actions a::before { content:""; position:absolute; inset:0; background:linear-gradient(120deg, transparent 0%, rgba(255,255,255,.18) 42%, transparent 64%); transform: translateX(-120%); transition: transform .65s ease; z-index:-1; }
.button:hover::before, .nav-cta:hover::before, .enter-button:hover::before, .mode-actions a:hover::before { transform: translateX(120%); }
.button:hover, .enter-button:hover, .nav-cta:hover { transform: translateY(-2px); box-shadow: 0 18px 50px rgba(34,240,239,.2), 0 0 24px rgba(234,255,52,.12); }
.feature-card, .mode-card, .panel, .dashboard-metrics article, .step-card, .contact-card, .status-tiles article, .platform-cards article, .rules-grid article { transform-style: preserve-3d; transition: transform .22s ease, border-color .22s ease, box-shadow .22s ease, background .22s ease; will-change: transform; }
.feature-card:hover, .mode-card:hover, .panel:hover, .dashboard-metrics article:hover, .step-card:hover, .contact-card:hover, .status-tiles article:hover, .platform-cards article:hover, .rules-grid article:hover { border-color: rgba(34,240,239,.42); box-shadow: 0 24px 80px rgba(0,0,0,.34), 0 0 28px rgba(34,240,239,.08); }
.feature-card::after, .mode-card::after, .panel::after, .dashboard-metrics article::after, .step-card::after, .contact-card::after { content:""; position:absolute; inset:0; border-radius:inherit; pointer-events:none; background: radial-gradient(360px circle at var(--card-x, 50%) var(--card-y, 0%), rgba(255,255,255,.13), transparent 42%); opacity:0; transition: opacity .22s ease; }
.feature-card:hover::after, .mode-card:hover::after, .panel:hover::after, .dashboard-metrics article:hover::after, .step-card:hover::after, .contact-card:hover::after { opacity:1; }
.hero-section::before, .page-hero::before { transform: scale(1.03); transition: transform 1.2s ease; }
.hero-section:hover::before, .page-hero:hover::before { transform: scale(1.06); }
.gate-panel { animation: gateFloat 7s ease-in-out infinite; }
.gate-ring { animation: gateSpin 18s linear infinite; }
.enter-button { box-shadow: 0 0 0 0 rgba(234,255,52,.38); animation: enterPulse 2.2s ease-in-out infinite; }
body.site-entered .hero-content { animation: dashboardRise .85s ease both; }
body.site-entered .hero-status-card { animation: dashboardRise .85s .09s ease both; }
.reveal { transition-duration: .72s; transition-delay: var(--reveal-delay, 0ms); }
.reveal.visible { animation: revealGlow .9s ease both; }
.copy-note { position: fixed; left: 50%; bottom: 26px; transform: translateX(-50%) translateY(20px); z-index: 9999; padding: 12px 16px; border-radius: 999px; background: rgba(5,11,18,.9); color: var(--text); border: 1px solid rgba(34,240,239,.24); box-shadow: var(--shadow); opacity: 0; pointer-events: none; transition: opacity .2s ease, transform .2s ease; }
.copy-note.show { opacity:1; transform: translateX(-50%) translateY(0); }
.back-to-top { position: fixed; right: 22px; bottom: 22px; z-index: 5000; width: 46px; height: 46px; border: 1px solid rgba(34,240,239,.28); border-radius: 16px; color: var(--text); background: rgba(5,11,18,.82); box-shadow: 0 18px 42px rgba(0,0,0,.4); cursor: pointer; font-weight: 950; opacity: 0; transform: translateY(18px) scale(.92); pointer-events: none; transition: opacity .22s ease, transform .22s ease, border-color .22s ease; backdrop-filter: blur(14px); }
.back-to-top.visible { opacity: 1; transform: translateY(0) scale(1); pointer-events: auto; }
.back-to-top:hover { border-color: rgba(234,255,52,.5); transform: translateY(-2px) scale(1.02); }
@keyframes gateFloat { 0%,100% { transform: translateY(0); } 50% { transform: translateY(-9px); } }
@keyframes gateSpin { to { transform: rotate(360deg); } }
@keyframes enterPulse { 0%,100% { box-shadow: 0 0 0 0 rgba(234,255,52,.22); } 50% { box-shadow: 0 0 0 10px rgba(234,255,52,0); } }
@keyframes dashboardRise { from { opacity:0; transform: translateY(24px); } to { opacity:1; transform:none; } }
@keyframes revealGlow { 0% { filter: drop-shadow(0 0 0 rgba(34,240,239,0)); } 45% { filter: drop-shadow(0 0 12px rgba(34,240,239,.16)); } 100% { filter: none; } }
@media (max-width: 980px) { .site-nav.open { box-shadow: 0 24px 80px rgba(0,0,0,.48); } .pointer-spotlight { display:none; } }
@media (max-width: 640px) { .back-to-top { right: 14px; bottom: 14px; width: 42px; height: 42px; border-radius: 14px; } .scroll-progress { height: 3px; } }
@media (prefers-reduced-motion: reduce) { html { scroll-behavior: auto; } .gate-panel, .gate-ring, .enter-button, body.site-entered .hero-content, body.site-entered .hero-status-card, .reveal.visible { animation: none !important; } .feature-card, .mode-card, .panel, .dashboard-metrics article, .step-card, .contact-card { transform: none !important; } }


/* Update 5 — public command center, status hub, bot systems, and data-ready frontend */
.nav-link { padding-inline: 10px; }
.command-center, .live-data-split, .bot-command-console, .status-page-grid { position: relative; }
.command-center-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; align-items: stretch; }
.command-center-grid.wide { grid-template-columns: 1.15fr .85fr; }
.live-console, .bot-preview-card, .server-detail-card, .status-list-panel, .announcement-panel { min-height: 260px; }
.live-console h3, .bot-preview-card h3, .server-detail-card h3 { margin: 14px 0 10px; font-size: clamp(2rem, 4vw, 3.6rem); line-height: .96; letter-spacing: -.055em; }
.live-console a, .bot-preview-card a, .status-list-panel a, .announcement-panel a, .panel > a { color: var(--gold); font-weight: 950; text-decoration: none; }
.status-pill { display: inline-flex; align-items: center; gap: 8px; width: max-content; padding: 8px 12px; border-radius: 999px; font-size: .72rem; letter-spacing: .12em; text-transform: uppercase; font-weight: 950; border: 1px solid rgba(255,255,255,.14); background: rgba(255,255,255,.06); color: var(--muted); }
.status-pill::before { content:""; width: 9px; height: 9px; border-radius: 50%; background: currentColor; box-shadow: 0 0 18px currentColor; }
.status-pill.operational { color: #8cffdf; background: rgba(46, 255, 185, .08); border-color: rgba(46, 255, 185, .28); }
.status-pill.monitoring { color: var(--gold); background: rgba(234,255,52,.08); border-color: rgba(234,255,52,.28); }
.status-pill.degraded { color: #ffb86b; background: rgba(255,184,107,.08); border-color: rgba(255,184,107,.28); }
.status-pill.offline { color: #ff7070; background: rgba(255,112,112,.08); border-color: rgba(255,112,112,.28); }
.status-pill.unknown { color: #a8c8d6; }
.live-data-split, .status-page-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; }
.health-grid { display: grid; gap: 12px; margin-top: 18px; }
.health-grid.compact { gap: 10px; }
.health-item { display: grid; grid-template-columns: auto 1fr auto; gap: 12px; align-items: start; padding: 14px; border-radius: 18px; border: 1px solid rgba(255,255,255,.1); background: rgba(255,255,255,.045); position: relative; overflow: hidden; }
.health-item::after { content:""; position:absolute; inset:0; background: linear-gradient(90deg, rgba(34,240,239,.09), transparent 45%, rgba(234,255,52,.05)); opacity:.65; pointer-events:none; }
.health-dot { width: 12px; height: 12px; margin-top: 5px; border-radius: 50%; background: #a8c8d6; box-shadow: 0 0 18px currentColor; position: relative; z-index:1; }
.health-dot.operational { background: #8cffdf; color: #8cffdf; }
.health-dot.monitoring { background: var(--gold); color: var(--gold); }
.health-dot.degraded { background: #ffb86b; color: #ffb86b; }
.health-dot.offline { background: #ff7070; color: #ff7070; }
.health-copy, .health-state { position: relative; z-index:1; }
.health-copy strong { display: block; margin-bottom: 3px; }
.health-copy span { color: var(--muted); font-size: .94rem; line-height: 1.45; }
.health-state { color: var(--gold); font-size: .72rem; text-transform: uppercase; letter-spacing: .11em; font-weight: 950; }
.announcement-list, .schedule-list { display: grid; gap: 12px; margin-top: 18px; }
.announcement-item, .schedule-item { padding: 14px; border: 1px solid rgba(34,240,239,.16); border-radius: 18px; background: linear-gradient(135deg, rgba(34,240,239,.07), rgba(255,255,255,.035)); }
.announcement-meta, .schedule-meta { display:flex; gap:10px; flex-wrap:wrap; align-items:center; color: var(--gold); font-size: .74rem; text-transform: uppercase; letter-spacing:.1em; font-weight:950; }
.announcement-item h3, .schedule-item h3 { margin: 8px 0 6px; font-size: 1.12rem; }
.announcement-item p, .schedule-item p { margin: 0; color: var(--muted); line-height:1.55; }
.module-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; }
.module-grid article { min-height: 220px; padding: 20px; border-radius: 24px; border: 1px solid var(--line); background: linear-gradient(145deg, rgba(255,255,255,.072), rgba(255,255,255,.032)); box-shadow: 0 18px 50px rgba(0,0,0,.18); position:relative; overflow:hidden; }
.module-grid article::before { content:""; position:absolute; inset:auto -20% -45% -20%; height:120px; background:radial-gradient(circle, rgba(34,240,239,.16), transparent 62%); opacity:.9; }
.module-grid span { color: var(--gold); font-size:.75rem; font-weight:950; letter-spacing:.12em; text-transform:uppercase; position:relative; }
.module-grid h3 { margin: 14px 0 8px; font-size:1.45rem; position:relative; }
.module-grid p { color: var(--muted); line-height:1.6; position:relative; }
.bridge-list { display:flex; flex-wrap:wrap; gap:10px; margin-top:18px; }
.bridge-list span { padding: 10px 12px; border: 1px solid rgba(234,255,52,.22); border-radius:999px; background: rgba(234,255,52,.07); color:#f7ffd0; font-weight:850; }
.status-page-grid { grid-template-columns: 1.1fr .9fr; }
.mono-value { font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace; padding: 14px; border: 1px solid rgba(34,240,239,.18); border-radius: 16px; background: rgba(0,0,0,.22); color: #dfffff !important; word-break: break-word; }
.copy-button { cursor:pointer; border: 1px solid rgba(34,240,239,.25); background: rgba(34,240,239,.09); color: var(--text); padding: 12px 14px; border-radius: 14px; font-weight: 950; }
.copy-button:hover { border-color: rgba(234,255,52,.42); box-shadow: 0 0 24px rgba(34,240,239,.12); }
.bot-hero::before { background-image: linear-gradient(180deg, rgba(5,8,15,.52), rgba(5,8,15,.96)), url('../assets/images/iwrc-hero-banner.jpg'); }
.status-hero::before { background-image: linear-gradient(180deg, rgba(5,8,15,.52), rgba(5,8,15,.96)), url('../assets/images/iwrc-dashboard-banner.jpg'); }
code { color: #dfffff; background: rgba(34,240,239,.08); border: 1px solid rgba(34,240,239,.13); padding: .08em .38em; border-radius: 7px; }
@media (max-width: 1100px) { .site-nav { gap: 2px; } .nav-link, .nav-cta { font-size: .82rem; padding-inline: 8px; } }
@media (max-width: 980px) { .command-center-grid, .command-center-grid.wide, .live-data-split, .status-page-grid, .module-grid { grid-template-columns: 1fr; } }
@media (max-width: 640px) { .health-item { grid-template-columns: auto 1fr; } .health-state { grid-column: 2; } }


/* Update 8 — video welcome gate, fixed dashboard reveal, and drop-in gameplay media support */
.noscript-banner {
  position: fixed;
  left: 50%;
  top: 16px;
  z-index: 9999;
  transform: translateX(-50%);
  padding: 10px 14px;
  border-radius: 999px;
  border: 1px solid rgba(34,240,239,.28);
  background: rgba(5,11,18,.92);
  color: var(--text);
  box-shadow: var(--shadow);
  font-size: .9rem;
}
body.gate-fallback .dashboard-shell {
  opacity: 1 !important;
  transform: none !important;
}
body.gate-fallback .welcome-gate {
  display: none !important;
}
.welcome-gate.gate-mounted .gate-panel {
  animation: gatePanelIn .42s ease both;
}
@keyframes gatePanelIn {
  from { opacity: 0; transform: translateY(18px) scale(.985); }
  to { opacity: 1; transform: none; }
}


/* Update 9 — keep intro media isolated to the welcome screen and restore page stacking */
body:not(.home-theme) .welcome-gate,
body:not(.home-theme) .gate-video-bg,
body:not(.home-theme) .gate-video-fallback,
body:not(.home-theme) .gate-noise,
body:not(.home-theme) .gate-ring {
  display: none !important;
}
.background-system {
  z-index: -4;
}
.site-shell,
.back-to-top {
  position: relative;
}
.site-shell {
  z-index: 2;
}
.welcome-gate {
  z-index: 9000;
}
body.site-entered .welcome-gate.is-entering {
  pointer-events: none;
}
