/* ===================================
   FOX HOUND — style.css
   Dark sci-fi military · Orange/Black
   =================================== */

@import url('https://fonts.googleapis.com/css2?family=Orbitron:wght@400;600;700;900&family=Rajdhani:wght@300;400;500;600&display=swap');

:root {
  --bg:         #070809;
  --bg2:        #0c0e10;
  --bg3:        #111416;
  --bg4:        #161a1d;
  --orange:     #f97316;
  --orange-dim: #c2410c;
  --orange-glow:rgba(249,115,22,0.15);
  --orange-soft:rgba(249,115,22,0.08);
  --red:        #ef4444;
  --amber:      #f59e0b;
  --text:       #e8e6e3;
  --text-dim:   #7a7875;
  --border:     rgba(249,115,22,0.12);
  --border-hot: rgba(249,115,22,0.35);
  --green:      #22c55e;
  --radius:     6px;
  --font-head:  'Orbitron', monospace;
  --font-body:  'Rajdhani', sans-serif;
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }

body {
  background: var(--bg);
  color: var(--text);
  font-family: var(--font-body);
  font-size: 16px;
  font-weight: 400;
  line-height: 1.6;
  min-height: 100vh;
  overflow-x: hidden;
  letter-spacing: 0.01em;
}

/* ---- SCANLINES ---- */
.scanlines {
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 9999;
  background: repeating-linear-gradient(
    to bottom,
    transparent,
    transparent 2px,
    rgba(0,0,0,0.04) 2px,
    rgba(0,0,0,0.04) 4px
  );
}

/* ---- CURSOR GLOW ---- */
.cursor-glow {
  position: fixed;
  width: 300px; height: 300px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(249,115,22,0.06) 0%, transparent 70%);
  pointer-events: none;
  transform: translate(-50%, -50%);
  z-index: 0;
  transition: left 0.08s, top 0.08s;
}

/* ---- TYPOGRAPHY ---- */
h1,h2,h3 { font-family: var(--font-head); line-height: 1.1; }
h1 { font-size: clamp(2.5rem, 6vw, 5rem); font-weight: 900; letter-spacing: 0.05em; }
h2 { font-size: clamp(1.6rem, 3vw, 2.4rem); font-weight: 700; letter-spacing: 0.04em; }
h3 { font-size: 1.1rem; font-weight: 600; letter-spacing: 0.03em; }

.accent { color: var(--orange); }

.section-label {
  font-family: var(--font-head);
  font-size: 0.65rem;
  letter-spacing: 0.2em;
  color: var(--orange);
  margin-bottom: 1rem;
  opacity: 0.8;
}

/* ---- NAVBAR ---- */
.navbar {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 100;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0.9rem 5vw;
  background: rgba(7,8,9,0.9);
  backdrop-filter: blur(20px);
  border-bottom: 1px solid var(--border);
}
.navbar::after {
  content: '';
  position: absolute;
  bottom: 0; left: 5%; right: 5%;
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--orange), transparent);
  opacity: 0.3;
}

.nav-logo { display: flex; align-items: center; gap: 0.6rem; }
.nav-logo-img { height: 36px; width: 36px; object-fit: contain; }
.nav-logo-label {
  font-family: var(--font-head);
  font-size: 0.85rem;
  font-weight: 900;
  color: var(--orange);
  letter-spacing: 0.15em;
}
.nav-logo-text {
  font-family: var(--font-head);
  font-size: 0.85rem;
  font-weight: 900;
  color: var(--orange);
  letter-spacing: 0.15em;
}

.nav-links { display: flex; gap: 2.5rem; list-style: none; align-items: center; }
.nav-links a {
  font-family: var(--font-head);
  font-size: 0.7rem;
  letter-spacing: 0.12em;
  color: var(--text-dim);
  text-decoration: none;
  text-transform: uppercase;
  transition: color 0.2s;
}
.nav-links a:hover, .nav-links a.active { color: var(--text); }
.nav-links a.nav-cta {
  color: var(--orange);
  border: 1px solid var(--border-hot);
  padding: 0.4rem 1rem;
  border-radius: var(--radius);
  background: var(--orange-soft);
  transition: background 0.2s;
}
.nav-links a.nav-cta:hover { background: var(--orange-glow); }

.burger { display: none; background: none; border: none; color: var(--text); font-size: 1.4rem; cursor: pointer; }

@media (max-width: 700px) {
  .burger { display: block; }
  .nav-links {
    display: none; flex-direction: column;
    position: absolute; top: 60px; left: 0; right: 0;
    background: var(--bg2); padding: 1.5rem 2rem;
    border-bottom: 1px solid var(--border); gap: 1.5rem;
  }
  .nav-links.open { display: flex; }
}

/* ---- BUTTONS ---- */
.btn-primary {
  display: inline-block;
  background: linear-gradient(135deg, var(--orange), var(--orange-dim));
  color: #fff;
  font-family: var(--font-head);
  font-size: 0.7rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  padding: 0.85rem 2rem;
  border-radius: var(--radius);
  text-decoration: none;
  border: none;
  cursor: pointer;
  transition: opacity 0.2s, transform 0.2s, box-shadow 0.2s;
  box-shadow: 0 0 25px rgba(249,115,22,0.3);
}
.btn-primary:hover { opacity: 0.85; transform: translateY(-2px); box-shadow: 0 0 40px rgba(249,115,22,0.4); }

.btn-ghost {
  display: inline-block;
  background: transparent;
  color: var(--text);
  font-family: var(--font-head);
  font-size: 0.7rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  padding: 0.85rem 2rem;
  border-radius: var(--radius);
  text-decoration: none;
  border: 1px solid var(--border-hot);
  cursor: pointer;
  transition: background 0.2s, transform 0.2s;
}
.btn-ghost:hover { background: var(--orange-glow); transform: translateY(-2px); }

/* ---- HERO ---- */
.hero {
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  text-align: center;
  position: relative;
  overflow: hidden;
  padding: 6rem 5vw 4rem;
}

.hero-bg {
  position: absolute;
  inset: 0;
  z-index: 0;
}

.star-field { position: absolute; inset: 0; }
.star {
  position: absolute;
  background: #fff;
  border-radius: 50%;
  animation: twinkle linear infinite;
}
@keyframes twinkle {
  0%,100% { opacity: 0.1; }
  50%      { opacity: 0.9; }
}

.hero-glow-orb {
  position: absolute;
  top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  width: 70vw; height: 70vw;
  background: radial-gradient(circle, rgba(249,115,22,0.07) 0%, transparent 60%);
  pointer-events: none;
}

.hero-content { position: relative; z-index: 2; }

.hero-tag {
  font-family: var(--font-head);
  font-size: 0.6rem;
  letter-spacing: 0.25em;
  color: var(--orange);
  margin-bottom: 1.5rem;
  opacity: 0.8;
  animation: fadeUp 0.6s ease both;
}

.hero-title {
  display: flex;
  flex-direction: column;
  gap: 0;
  line-height: 0.95;
  animation: fadeUp 0.7s 0.1s ease both;
}
.title-line { display: block; }
.title-line.accent { color: var(--orange); text-shadow: 0 0 40px rgba(249,115,22,0.5); }

.hero-separator {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 1rem;
  margin: 1.5rem 0;
  animation: fadeUp 0.7s 0.2s ease both;
}
.hero-separator span { display: block; height: 1px; width: 60px; background: var(--border-hot); }
.sep-diamond { color: var(--orange); font-size: 0.7rem; }

.hero-sub {
  font-family: var(--font-body);
  font-size: 1.1rem;
  font-weight: 300;
  color: var(--text-dim);
  letter-spacing: 0.05em;
  margin-bottom: 2.5rem;
  animation: fadeUp 0.7s 0.3s ease both;
}

.hero-btns {
  display: flex;
  gap: 1rem;
  justify-content: center;
  flex-wrap: wrap;
  animation: fadeUp 0.7s 0.4s ease both;
}

@keyframes fadeUp {
  from { opacity: 0; transform: translateY(20px); }
  to   { opacity: 1; transform: translateY(0); }
}

.hero-scroll-hint {
  position: absolute;
  bottom: 2rem;
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.5rem;
  z-index: 2;
}
.hero-scroll-hint span {
  font-family: var(--font-head);
  font-size: 0.5rem;
  letter-spacing: 0.2em;
  color: var(--text-dim);
}
.scroll-line {
  width: 1px;
  height: 40px;
  background: linear-gradient(to bottom, var(--orange), transparent);
  animation: scrollPulse 2s ease infinite;
}
@keyframes scrollPulse {
  0%,100% { opacity: 0.3; transform: scaleY(1); }
  50%      { opacity: 1; transform: scaleY(1.2); }
}

/* ---- STATS BAR ---- */
.stats-bar {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  gap: 0;
  background: var(--bg2);
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
  padding: 1.5rem 5vw;
  position: relative;
  z-index: 2;
}
.stat-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 0 3vw;
}
.stat-val {
  font-family: var(--font-head);
  font-size: 2.2rem;
  font-weight: 900;
  color: var(--orange);
  line-height: 1;
}
.stat-label {
  font-size: 0.7rem;
  letter-spacing: 0.08em;
  color: var(--text-dim);
  text-transform: uppercase;
  margin-top: 0.3rem;
}
.stat-divider { color: var(--border-hot); font-size: 1.5rem; padding: 0 1rem; }

/* ---- MISSION ---- */
.mission-section {
  padding: 6rem 6vw;
  text-align: center;
}
.mission-section .section-title { margin-bottom: 3rem; }

.mission-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 1px;
  background: var(--border);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  overflow: hidden;
  max-width: 960px;
  margin: 0 auto;
}
.mission-card {
  background: var(--bg2);
  padding: 2.5rem 2rem;
  text-align: left;
  position: relative;
  transition: background 0.3s;
}
.mission-card:hover { background: var(--bg3); }
.mission-card.featured { background: var(--bg3); border: none; }
.mission-card.featured::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  background: linear-gradient(90deg, transparent, var(--orange), transparent);
}
.card-glow {
  position: absolute;
  top: 50%; left: 50%;
  transform: translate(-50%,-50%);
  width: 200px; height: 200px;
  background: radial-gradient(circle, rgba(249,115,22,0.07) 0%, transparent 70%);
  pointer-events: none;
}
.mission-icon { font-size: 2rem; margin-bottom: 1.2rem; }
.mission-card h3 { margin-bottom: 0.8rem; color: var(--orange); }
.mission-card p { color: var(--text-dim); font-size: 0.95rem; line-height: 1.7; }

/* ---- OPS SECTION ---- */
.ops-section {
  padding: 5rem 6vw;
  background: var(--bg2);
}
.ops-header {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  margin-bottom: 2.5rem;
}
.see-all-btn {
  font-family: var(--font-head);
  font-size: 0.65rem;
  letter-spacing: 0.12em;
  color: var(--orange);
  text-decoration: none;
  transition: opacity 0.2s;
}
.see-all-btn:hover { opacity: 0.6; }

.ops-grid, .news-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  gap: 1.5rem;
}

/* ---- NEWS CARD ---- */
.news-card {
  background: var(--bg3);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  overflow: hidden;
  cursor: pointer;
  transition: border-color 0.25s, transform 0.25s, box-shadow 0.25s;
}
.news-card:hover {
  border-color: var(--border-hot);
  transform: translateY(-3px);
  box-shadow: 0 8px 40px rgba(249,115,22,0.12);
}
.news-card-media { position: relative; }
.news-card-img {
  width: 100%;
  aspect-ratio: 16/9;
  object-fit: cover;
  display: block;
}
.news-card-img-placeholder {
  width: 100%;
  aspect-ratio: 16/9;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 2.5rem;
}
.cat-bg-op  { background: linear-gradient(135deg, #1a0a00, #2d1000); }
.cat-bg-nw  { background: linear-gradient(135deg, #0a0d1a, #0d1530); }
.cat-bg-ex  { background: linear-gradient(135deg, #1a1500, #2d2500); }
.cat-bg-pv  { background: linear-gradient(135deg, #001a0a, #002d15); }

.cat-badge {
  position: absolute;
  top: 0.6rem;
  left: 0.6rem;
  font-family: var(--font-head);
  font-size: 0.55rem;
  letter-spacing: 0.1em;
  padding: 0.3rem 0.7rem;
  border-radius: 3px;
  text-transform: uppercase;
}
/* Non-absolute version for admin list */
.admin-item-info .cat-badge {
  position: static;
  display: inline-block;
}
.modal-article-body .cat-badge {
  position: static;
  display: inline-block;
  margin-bottom: 1rem;
}

.cat-operation { background: rgba(249,115,22,0.15); color: var(--orange); border: 1px solid rgba(249,115,22,0.3); }
.cat-news      { background: rgba(59,130,246,0.15);  color: #60a5fa;      border: 1px solid rgba(59,130,246,0.3); }
.cat-exploit   { background: rgba(234,179,8,0.15);   color: var(--amber); border: 1px solid rgba(234,179,8,0.3); }
.cat-pve       { background: rgba(34,197,94,0.15);   color: #4ade80;      border: 1px solid rgba(34,197,94,0.3); }

.news-card-body { padding: 1.2rem 1.4rem 1.4rem; }
.news-card-body h3 {
  font-size: 1rem;
  margin-bottom: 0.6rem;
  line-height: 1.3;
}
.news-card-body p { color: var(--text-dim); font-size: 0.9rem; margin-bottom: 1rem; }
.news-card-footer { display: flex; justify-content: space-between; align-items: center; }
.news-card-footer span { font-size: 0.75rem; color: var(--text-dim); }
.read-more { color: var(--orange) !important; font-family: var(--font-head); font-size: 0.6rem !important; letter-spacing: 0.1em; }

/* ---- GAMES ---- */
.games-section {
  padding: 5rem 6vw;
  text-align: center;
}
.games-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
  justify-content: center;
  margin-top: 2.5rem;
}
.game-tag {
  background: var(--bg3);
  border: 1px solid var(--border);
  padding: 0.8rem 1.8rem;
  border-radius: var(--radius);
  font-family: var(--font-head);
  font-size: 0.7rem;
  letter-spacing: 0.1em;
  color: var(--text-dim);
  transition: border-color 0.2s, color 0.2s;
}
.game-tag:hover { border-color: var(--border-hot); color: var(--text); }

/* ---- CTA BANNER ---- */
.cta-banner {
  position: relative;
  background: var(--bg2);
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
  padding: 6rem 5vw;
  text-align: center;
  overflow: hidden;
}
.cta-bg-glow {
  position: absolute;
  top: 50%; left: 50%;
  transform: translate(-50%,-50%);
  width: 80vw; height: 80vw;
  background: radial-gradient(circle, rgba(249,115,22,0.07) 0%, transparent 60%);
  pointer-events: none;
}
.cta-content { position: relative; z-index: 1; }
.cta-content p { color: var(--text-dim); margin: 1rem 0 2rem; font-size: 1rem; }

/* ---- PAGE HERO ---- */
.page-hero {
  padding: 8rem 6vw 5rem;
  text-align: center;
  position: relative;
  overflow: hidden;
}
.page-hero-bg {
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse at 50% 0%, rgba(249,115,22,0.06) 0%, transparent 60%);
  pointer-events: none;
}
.page-hero::after {
  content: '';
  position: absolute;
  bottom: 0; left: 10%; right: 10%;
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--border-hot), transparent);
}
.page-title {
  margin: 0.5rem 0 1rem;
  position: relative;
}
.page-hero p { color: var(--text-dim); font-size: 1.05rem; }

/* ---- FILTERS ---- */
.filters {
  display: flex;
  gap: 0.6rem;
  justify-content: center;
  flex-wrap: wrap;
  margin-top: 2rem;
  position: relative;
}
.filter-btn {
  background: var(--bg3);
  border: 1px solid var(--border);
  color: var(--text-dim);
  padding: 0.5rem 1.2rem;
  border-radius: var(--radius);
  font-family: var(--font-head);
  font-size: 0.62rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  cursor: pointer;
  transition: all 0.2s;
}
.filter-btn.active, .filter-btn:hover {
  border-color: var(--border-hot);
  color: var(--orange);
  background: var(--orange-soft);
}

/* ---- NEWS SECTION ---- */
.news-section { padding: 4rem 6vw 6rem; }

/* ---- MANIFESTO ---- */
.manifesto-section {
  padding: 5rem 6vw;
  display: flex;
  justify-content: center;
}
.manifesto-card {
  background: var(--bg2);
  border: 1px solid var(--border);
  border-left: 3px solid var(--orange);
  border-radius: var(--radius);
  padding: 3rem;
  max-width: 700px;
  text-align: center;
}
.manifesto-card blockquote {
  font-family: var(--font-head);
  font-size: clamp(0.85rem, 1.5vw, 1.05rem);
  line-height: 2;
  color: var(--text-dim);
  letter-spacing: 0.05em;
}

/* ---- ABOUT BLOCKS ---- */
.about-blocks {
  padding: 3rem 6vw 5rem;
  max-width: 900px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: 4rem;
}
.about-block { }
.about-block-label {
  font-family: var(--font-head);
  font-size: 0.6rem;
  letter-spacing: 0.2em;
  color: var(--orange);
  margin-bottom: 0.8rem;
  opacity: 0.7;
}
.about-block h2 { margin-bottom: 1.2rem; }
.about-block p { color: var(--text-dim); font-size: 1rem; line-height: 1.8; margin-bottom: 0.8rem; }

.threat-bar { margin-top: 1.5rem; }
.threat-label {
  font-family: var(--font-head);
  font-size: 0.62rem;
  letter-spacing: 0.1em;
  color: var(--orange);
  margin-bottom: 0.5rem;
  display: block;
}
.progress-bar {
  background: var(--bg3);
  border: 1px solid var(--border);
  border-radius: 3px;
  height: 28px;
  overflow: hidden;
}
.progress-fill {
  height: 100%;
  background: linear-gradient(90deg, var(--orange-dim), var(--orange));
  display: flex;
  align-items: center;
  justify-content: flex-end;
  padding-right: 0.8rem;
  font-family: var(--font-head);
  font-size: 0.7rem;
  color: #fff;
  width: 0;
  transition: width 1.5s ease;
}
.progress-fill.animated { width: 87%; }

.games-inline {
  display: flex;
  gap: 0.8rem;
  flex-wrap: wrap;
  margin-top: 1.2rem;
}
.games-inline span {
  background: var(--bg3);
  border: 1px solid var(--border);
  padding: 0.4rem 1rem;
  border-radius: var(--radius);
  font-size: 0.85rem;
  color: var(--text-dim);
}

/* ---- RANKS ---- */
.ranks-section {
  padding: 5rem 6vw;
  background: var(--bg2);
  text-align: center;
}
.section-title { margin: 0.5rem 0 3rem; }
.ranks-list {
  display: flex;
  flex-direction: column;
  gap: 1px;
  max-width: 700px;
  margin: 0 auto;
  background: var(--border);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  overflow: hidden;
}
.rank-item {
  display: flex;
  align-items: center;
  gap: 1.5rem;
  padding: 1.5rem 2rem;
  background: var(--bg2);
  text-align: left;
  transition: background 0.2s;
}
.rank-item:hover { background: var(--bg3); }
.rank-badge {
  font-family: var(--font-head);
  font-size: 0.7rem;
  letter-spacing: 0.1em;
  min-width: 60px;
  text-align: center;
}
.r1 { color: var(--orange); }
.r2 { color: var(--amber); }
.r3 { color: var(--text-dim); }
.r4 { color: #444; }
.rank-info h3 { font-size: 0.95rem; margin-bottom: 0.3rem; }
.rank-info p { color: var(--text-dim); font-size: 0.85rem; }

/* ---- JOIN ---- */
.join-section {
  padding: 6rem 6vw;
  text-align: center;
  max-width: 900px;
  margin: 0 auto;
}
.join-section p { color: var(--text-dim); margin: 1rem 0 2.5rem; }
.join-steps {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  flex-wrap: wrap;
  margin-bottom: 1rem;
}
.join-step {
  background: var(--bg3);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 1.2rem 1.5rem;
  text-align: center;
  flex: 1;
  min-width: 140px;
}
.step-num {
  display: block;
  font-family: var(--font-head);
  font-size: 1.2rem;
  color: var(--orange);
  margin-bottom: 0.5rem;
}
.join-step p { font-size: 0.85rem; color: var(--text-dim); margin: 0; }
.step-arrow { color: var(--border-hot); font-size: 1.2rem; flex-shrink: 0; }

/* ---- LOGIN ---- */
.login-screen {
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 2rem;
  background: var(--bg);
  position: relative;
}
.login-screen::before {
  content: '';
  position: absolute;
  top: 50%; left: 50%;
  transform: translate(-50%,-50%);
  width: 60vw; height: 60vw;
  background: radial-gradient(circle, rgba(249,115,22,0.06) 0%, transparent 60%);
}
.login-card {
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 3rem 2.5rem;
  text-align: center;
  max-width: 400px;
  width: 100%;
  position: relative;
  z-index: 1;
}
.login-card::before {
  content: '';
  position: absolute;
  top: 0; left: 10%; right: 10%;
  height: 2px;
  background: linear-gradient(90deg, transparent, var(--orange), transparent);
}
.login-badge {
  font-family: var(--font-head);
  font-size: 0.7rem;
  letter-spacing: 0.2em;
  color: var(--orange);
  margin-bottom: 1.5rem;
}
.login-card h2 { margin-bottom: 0.5rem; }
.login-card p { color: var(--text-dim); margin-bottom: 2rem; font-size: 0.9rem; }
.login-form { display: flex; flex-direction: column; gap: 0.8rem; }
.login-form input {
  background: var(--bg3);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  color: var(--text);
  padding: 0.85rem 1.2rem;
  font-family: var(--font-head);
  font-size: 0.75rem;
  letter-spacing: 0.1em;
  text-align: center;
  outline: none;
  transition: border-color 0.2s;
}
.login-form input:focus { border-color: var(--border-hot); }
.login-form .btn-primary { width: 100%; text-align: center; }
.login-error {
  color: var(--red);
  font-family: var(--font-head);
  font-size: 0.65rem;
  letter-spacing: 0.1em;
  margin-top: 1rem;
}

/* ---- ADMIN ---- */
.admin-section {
  padding: 3rem 6vw 6rem;
  max-width: 1000px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: 2rem;
}
.admin-card {
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 2rem;
}
.form-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.2rem;
  margin-top: 1.5rem;
}
.form-grid .full { grid-column: 1 / -1; }
.field-group { display: flex; flex-direction: column; gap: 0.4rem; }
.field-group label {
  font-family: var(--font-head);
  font-size: 0.58rem;
  letter-spacing: 0.15em;
  color: var(--orange);
  text-transform: uppercase;
}
.field-group input,
.field-group textarea,
.field-group select {
  background: var(--bg3);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  color: var(--text);
  padding: 0.75rem 1rem;
  font-family: var(--font-body);
  font-size: 0.95rem;
  outline: none;
  transition: border-color 0.2s;
}
.field-group input:focus,
.field-group textarea:focus,
.field-group select:focus { border-color: var(--border-hot); }
.field-group textarea { resize: vertical; min-height: 120px; }
.field-group select option { background: var(--bg3); }
.form-btns { display: flex; gap: 1rem; margin-top: 1.5rem; }
.form-success { color: var(--green); font-family: var(--font-head); font-size: 0.65rem; letter-spacing: 0.1em; margin-top: 0.7rem; }

.admin-list { display: flex; flex-direction: column; gap: 0.8rem; margin-top: 1rem; }
.admin-item {
  display: flex; align-items: center; justify-content: space-between;
  background: var(--bg3); border: 1px solid var(--border);
  border-radius: var(--radius); padding: 1rem 1.2rem; gap: 1rem; flex-wrap: wrap;
}
.admin-item-info { display: flex; align-items: center; gap: 0.8rem; flex-wrap: wrap; }
.admin-item-info strong { font-family: var(--font-head); font-size: 0.85rem; }
.admin-item-info small { color: var(--text-dim); font-size: 0.78rem; }
.admin-item-btns { display: flex; gap: 0.6rem; }
.btn-edit, .btn-delete {
  padding: 0.4rem 0.9rem;
  border-radius: var(--radius);
  font-family: var(--font-head);
  font-size: 0.6rem;
  letter-spacing: 0.08em;
  cursor: pointer;
  border: none;
  transition: opacity 0.2s;
}
.btn-edit   { background: var(--orange-soft); color: var(--orange); border: 1px solid var(--border); }
.btn-delete { background: rgba(239,68,68,0.1); color: var(--red); border: 1px solid rgba(239,68,68,0.2); }
.btn-edit:hover, .btn-delete:hover { opacity: 0.7; }

/* ---- MODAL ---- */
.modal-overlay {
  position: fixed; inset: 0;
  background: rgba(7,8,9,0.92);
  backdrop-filter: blur(12px);
  z-index: 200;
  display: flex; align-items: center; justify-content: center;
  padding: 1.5rem;
}
.modal-article {
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  max-width: 680px; width: 100%;
  max-height: 90vh; overflow-y: auto;
  position: relative;
}
.modal-article::before {
  content: '';
  position: sticky;
  display: block;
  top: 0;
  height: 2px;
  background: linear-gradient(90deg, transparent, var(--orange), transparent);
}
.modal-close {
  position: sticky;
  top: 0.8rem;
  left: calc(100% - 3rem);
  float: right;
  margin: 0.8rem 0.8rem 0 0;
  background: var(--bg3);
  border: 1px solid var(--border);
  color: var(--text-dim);
  border-radius: var(--radius);
  width: 32px; height: 32px;
  cursor: pointer;
  font-size: 0.85rem;
  transition: color 0.2s;
  font-family: var(--font-body);
}
.modal-close:hover { color: var(--orange); }
.modal-hero-img { width: 100%; aspect-ratio: 16/9; object-fit: cover; display: block; }
.modal-article-body { padding: 2rem; }
.modal-article-body h2 { margin: 0.8rem 0 0.5rem; font-size: 1.4rem; }
.modal-meta { color: var(--text-dim); font-size: 0.8rem; margin-bottom: 1.5rem; font-family: var(--font-head); letter-spacing: 0.05em; }
.modal-text { color: var(--text-dim); font-size: 1rem; line-height: 1.85; }
.modal-text b { color: var(--text); }

/* ---- FOOTER ---- */
footer {
  background: var(--bg2);
  border-top: 1px solid var(--border);
  padding: 3rem 5vw;
  text-align: center;
}
.footer-inner {}
.footer-logo {
  font-family: var(--font-head);
  font-size: 1.2rem;
  font-weight: 900;
  letter-spacing: 0.15em;
  margin-bottom: 0.5rem;
}
.footer-sub { color: var(--text-dim); font-size: 0.8rem; margin-bottom: 1.5rem; }
.footer-nav { display: flex; justify-content: center; gap: 2rem; margin-bottom: 1.5rem; }
.footer-nav a {
  font-family: var(--font-head);
  font-size: 0.62rem;
  letter-spacing: 0.12em;
  color: var(--text-dim);
  text-decoration: none;
  transition: color 0.2s;
}
.footer-nav a:hover { color: var(--orange); }
.footer-copy { color: #333; font-size: 0.75rem; }

/* ---- UTILITIES ---- */
.hidden { display: none !important; }
.no-content {
  color: var(--text-dim);
  text-align: center;
  padding: 3rem;
  grid-column: 1/-1;
  font-family: var(--font-head);
  font-size: 0.75rem;
  letter-spacing: 0.1em;
}

/* ---- RESPONSIVE ---- */
@media (max-width: 900px) {
  .ops-header { flex-direction: column; align-items: flex-start; gap: 1rem; }
  .form-grid { grid-template-columns: 1fr; }
  .form-grid .full { grid-column: 1; }
  .about-blocks { padding: 2rem 5vw 4rem; }
}
@media (max-width: 600px) {
  .stats-bar { flex-direction: column; gap: 1.5rem; }
  .stat-divider { display: none; }
  .mission-section, .ops-section, .games-section, .cta-banner { padding: 3rem 5vw; }
  .hero-title { font-size: 3.5rem; }
  .join-steps { flex-direction: column; }
  .step-arrow { transform: rotate(90deg); }
}

/* ══════════════════════════════════════
   ADMIN v2 — Tabs, Roles, Perms, Fleet
   ══════════════════════════════════════ */

/* CMD TABS */
.cmd-tabs {
  display: flex;
  gap: 0;
  background: var(--bg2);
  border-bottom: 1px solid var(--border);
  overflow-x: auto;
  padding: 0 6vw;
}
.cmd-tab {
  background: none;
  border: none;
  color: var(--text-dim);
  font-family: var(--font-head);
  font-size: 0.62rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  padding: 1rem 1.4rem;
  cursor: pointer;
  border-bottom: 2px solid transparent;
  transition: color 0.2s, border-color 0.2s;
  white-space: nowrap;
}
.cmd-tab:hover   { color: var(--text); }
.cmd-tab.active  { color: var(--orange); border-bottom-color: var(--orange); }

.admin-workspace {
  padding: 2.5rem 6vw 6rem;
  max-width: 1000px;
  margin: 0 auto;
}
.tab-content { display: flex; flex-direction: column; gap: 2rem; }
.tab-content.hidden { display: none; }

/* SESSION INFO */
.session-info { margin-top: 0.8rem; }

/* PERMISSIONS GRID */
.perms-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
  gap: 0.6rem;
  margin-top: 0.5rem;
}
.perm-item {
  display: flex;
  align-items: center;
  gap: 0.7rem;
  background: var(--bg3);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 0.65rem 1rem;
  cursor: pointer;
  transition: border-color 0.2s;
  font-size: 0.88rem;
  color: var(--text-dim);
}
.perm-item:hover { border-color: var(--border-hot); color: var(--text); }
.perm-check { accent-color: var(--orange); width: 15px; height: 15px; cursor: pointer; }

/* ROLE PILL */
.role-pill {
  display: inline-block;
  font-family: var(--font-head);
  font-size: 0.6rem;
  letter-spacing: 0.08em;
  padding: 0.25rem 0.7rem;
  border-radius: 4px;
}
.you-badge {
  background: var(--orange-soft);
  color: var(--orange);
  border: 1px solid var(--border-hot);
  font-family: var(--font-head);
  font-size: 0.55rem;
  letter-spacing: 0.1em;
  padding: 0.2rem 0.5rem;
  border-radius: 3px;
}

/* HIERARCHY EDITOR */
.hier-row { margin-bottom: 1rem; }
.hier-sep { height: 1px; background: var(--border); margin-top: 1rem; }

/* FLEET PAGE */
.fleet-links {
  display: flex;
  gap: 0.8rem;
  justify-content: center;
  flex-wrap: wrap;
  margin-top: 1.5rem;
}
.fleet-link-btn {
  font-family: var(--font-head);
  font-size: 0.65rem;
  letter-spacing: 0.1em;
  padding: 0.6rem 1.4rem;
  border: 1px solid var(--border-hot);
  border-radius: var(--radius);
  color: var(--text-dim);
  text-decoration: none;
  background: var(--bg3);
  transition: all 0.2s;
}
.fleet-link-btn:hover  { background: var(--orange-glow); color: var(--text); }
.fleet-link-btn.accent-btn { background: var(--orange-glow); color: var(--orange); }

.fleet-section {
  padding: 3rem 6vw 6rem;
  min-height: 500px;
}
.fleet-embed-wrap { width: 100%; }
.fleet-frame-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  background: var(--bg2);
  border: 1px solid var(--border);
  border-bottom: none;
  border-radius: var(--radius) var(--radius) 0 0;
  padding: 0.8rem 1.2rem;
}
.fleet-iframe {
  width: 100%;
  height: 700px;
  border: 1px solid var(--border);
  border-radius: 0 0 var(--radius) var(--radius);
  background: var(--bg2);
}
.fleet-fallback {
  padding: 3rem;
  text-align: center;
  color: var(--text-dim);
  background: var(--bg2);
  border: 1px solid var(--border);
}
.fleet-placeholder { display: flex; align-items: center; justify-content: center; min-height: 400px; }
.fleet-placeholder-inner {
  text-align: center;
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 4rem 3rem;
  max-width: 480px;
}
.fleet-icon { font-size: 3rem; margin-bottom: 1.5rem; }
.fleet-placeholder-inner h2 { margin-bottom: 1rem; }
.fleet-placeholder-inner p  { color: var(--text-dim); line-height: 1.8; }

/* SOCIAL IN HERO */
.hero-social {
  display: flex;
  gap: 0.8rem;
  justify-content: center;
  margin-top: 1.5rem;
  flex-wrap: wrap;
}
.social-btn {
  font-family: var(--font-head);
  font-size: 0.62rem;
  letter-spacing: 0.12em;
  padding: 0.5rem 1.2rem;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  color: var(--text-dim);
  text-decoration: none;
  background: var(--bg3);
  transition: all 0.2s;
}
.social-btn:hover { border-color: var(--border-hot); color: var(--orange); }

/* ── Search bars ── */
.search-bar-wrap { position: relative; margin-bottom: 1.2rem; }
.search-input-bar {
  width: 100%;
  background: var(--bg3);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  color: var(--text);
  padding: .7rem 1rem;
  font-family: var(--font-body);
  font-size: .9rem;
  outline: none;
  transition: border-color .2s;
}
.search-input-bar:focus { border-color: var(--border-hot); }

/* ── Member filters bar ── */
.member-filters {
  display: flex;
  gap: .8rem;
  margin-bottom: 1.2rem;
  flex-wrap: wrap;
  align-items: center;
}
.filter-select {
  background: var(--bg3);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  color: var(--text-dim);
  padding: .6rem .9rem;
  font-family: var(--font-head);
  font-size: .62rem;
  letter-spacing: .08em;
  outline: none;
  cursor: pointer;
  transition: border-color .2s;
}
.filter-select:focus { border-color: var(--border-hot); }
.filter-select option { background: var(--bg2); }

/* ── Pagination ── */
.pagination {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: .8rem;
  margin-top: 1rem;
  padding-top: 1rem;
  border-top: 1px solid var(--border);
}
.page-btn {
  background: var(--bg3);
  border: 1px solid var(--border);
  color: var(--text-dim);
  padding: .4rem .9rem;
  border-radius: var(--radius);
  font-family: var(--font-head);
  font-size: .65rem;
  cursor: pointer;
  transition: all .2s;
}
.page-btn:hover { border-color: var(--border-hot); color: var(--orange); }
.page-info { font-family: var(--font-head); font-size: .62rem; color: var(--text-dim); letter-spacing: .08em; }
.page-info small { color: #333; }

/* ══════════════════════════════════════
   FoxHound v3 — New styles
   ══════════════════════════════════════ */

/* Toast */
.fh-toast{position:fixed;bottom:2rem;right:2rem;z-index:9999;background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:.85rem 1.4rem;font-family:var(--font-head);font-size:.72rem;letter-spacing:.08em;color:var(--text);box-shadow:0 8px 32px rgba(0,0,0,.5);opacity:0;transform:translateY(8px);transition:all .3s;pointer-events:none;max-width:300px}
.fh-toast.show{opacity:1;transform:translateY(0)}
.fh-toast-success{border-color:rgba(34,197,94,.4);color:#22c55e}
.fh-toast-error{border-color:rgba(239,68,68,.4);color:#ef4444}

/* Tags */
.tag-pill{display:inline-block;font-size:.6rem;font-family:var(--font-head);letter-spacing:.07em;padding:.18rem .55rem;border-radius:4px;border:1px solid;margin-right:.3rem}
.card-tags{display:flex;flex-wrap:wrap;gap:.3rem;margin-bottom:.6rem}

/* Op cards */
.op-card-header{display:flex;align-items:center;gap:.6rem;margin-bottom:.6rem}
.op-status{font-family:var(--font-head);font-size:.62rem;letter-spacing:.07em;color:var(--text-dim)}
.enrolled-badge{font-family:var(--font-head);font-size:.6rem;letter-spacing:.07em;padding:.2rem .55rem;background:rgba(34,197,94,.1);color:#22c55e;border:1px solid rgba(34,197,94,.3);border-radius:4px}

/* Enroll section in modal */
.enroll-section{margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid var(--border)}
.btn-enrolled{background:rgba(239,68,68,.1)!important;border:1px solid rgba(239,68,68,.3)!important;color:#ef4444!important}
.login-prompt{margin-top:1.5rem;padding:1rem;background:rgba(249,115,22,.05);border:1px solid rgba(249,115,22,.15);border-radius:var(--radius);font-size:.88rem;color:var(--text-dim)}

/* Rich text editor toolbar */
.editor-toolbar{display:flex;flex-wrap:wrap;gap:.4rem;margin-bottom:.5rem}
.editor-btn{background:var(--bg3);border:1px solid var(--border);color:var(--text-dim);padding:.35rem .7rem;border-radius:4px;cursor:pointer;font-size:.75rem;font-family:var(--font-head);transition:all .2s}
.editor-btn:hover{border-color:var(--border-hot);color:var(--orange)}
.editor-btn-redact{background:rgba(239,68,68,.1);border-color:rgba(239,68,68,.3);color:#ef4444}
.editor-btn-redact:hover{background:rgba(239,68,68,.2)}
.rich-editor{background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);padding:.85rem 1rem;min-height:140px;outline:none;font-family:var(--font-body);font-size:.95rem;line-height:1.7;transition:border-color .2s}
.rich-editor:focus{border-color:var(--border-hot)}
/* .rich-editor .redacted — see canonical block below */
.redacted-notice{background:rgba(249,115,22,.05);border:1px solid rgba(249,115,22,.15);border-radius:var(--radius);padding:1.5rem;text-align:center;color:var(--text-dim);font-size:.9rem}

/* Custom stats grid */
.custom-stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:1.2rem;margin:1.5rem 0}
.custom-stat-item{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:1.2rem;text-align:center;transition:border-color .2s}
.custom-stat-item:hover{border-color:var(--border-hot)}
.custom-stat-icon{font-size:1.5rem;margin-bottom:.5rem}
.custom-stat-val{font-family:var(--font-head);font-size:1.8rem;font-weight:900;color:var(--orange);letter-spacing:.05em}
.custom-stat-label{font-size:.75rem;color:var(--text-dim);letter-spacing:.08em;margin-top:.3rem}

/* Uptime counter */
.uptime-counter{font-family:var(--font-head);font-size:1.1rem;color:var(--orange);letter-spacing:.1em;margin-top:.5rem}

/* Allies page */
.allies-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem;padding:2rem var(--px)}
.ally-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:1.5rem;display:flex;flex-direction:column;gap:1rem;transition:border-color .2s,transform .2s}
.ally-card:hover{border-color:var(--border-hot);transform:translateY(-2px)}
.ally-logo{width:64px;height:64px;object-fit:contain;border-radius:8px;background:var(--bg3);padding:4px}
.ally-logo-placeholder{width:64px;height:64px;background:var(--bg3);border:1px solid var(--border);border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:1.5rem}
.ally-name{font-family:var(--font-head);font-size:1.1rem;font-weight:700;letter-spacing:.08em;color:var(--text)}
.ally-desc{font-size:.88rem;color:var(--text-dim);line-height:1.6}
.ally-rsi{display:inline-block;margin-top:.5rem;font-family:var(--font-head);font-size:.65rem;letter-spacing:.08em;color:var(--orange);border:1px solid rgba(249,115,22,.3);padding:.3rem .7rem;border-radius:4px;text-decoration:none;transition:background .2s}
.ally-rsi:hover{background:rgba(249,115,22,.1)}

/* Discord sync button */
.discord-btn{display:inline-flex;align-items:center;gap:.6rem;background:#5865f2;border:none;color:#fff;padding:.75rem 1.5rem;border-radius:var(--radius);font-family:var(--font-head);font-size:.72rem;letter-spacing:.08em;cursor:pointer;transition:background .2s;text-decoration:none}
.discord-btn:hover{background:#4752c4}
.discord-linked{background:rgba(88,101,242,.1);border:1px solid rgba(88,101,242,.3);color:#7289da;border-radius:var(--radius);padding:.6rem 1rem;font-size:.82rem;display:flex;align-items:center;gap:.6rem}

/* Form error */
.form-error{color:#ef4444;font-size:.82rem;margin-top:.5rem;padding:.5rem .8rem;background:rgba(239,68,68,.08);border:1px solid rgba(239,68,68,.2);border-radius:var(--radius)}
.accent-link{color:var(--orange);text-decoration:none}
.accent-link:hover{text-decoration:underline}

/* Status badges */
.status-badge{display:inline-block;font-family:var(--font-head);font-size:.55rem;letter-spacing:.07em;padding:.18rem .5rem;border-radius:4px;border:1px solid}
.badge-green{background:rgba(34,197,94,.1);color:#22c55e;border-color:rgba(34,197,94,.3)}
.badge-yellow{background:rgba(234,179,8,.1);color:#eab308;border-color:rgba(234,179,8,.3)}
.badge-red{background:rgba(239,68,68,.12);color:#ef4444;border-color:rgba(239,68,68,.3)}
.badge-orange{background:rgba(249,115,22,.1);color:var(--orange);border-color:rgba(249,115,22,.3)}
.badge-discord{background:rgba(88,101,242,.1);color:#7289da;border-color:rgba(88,101,242,.3)}

/* Btn variants */
.btn-icon{background:var(--bg3);border:1px solid var(--border);color:var(--text-dim);padding:.38rem .6rem;border-radius:var(--radius);cursor:pointer;font-size:.82rem;transition:all .2s;line-height:1}
.btn-icon:hover{border-color:var(--border-hot);color:var(--orange)}
.btn-icon-red:hover{border-color:rgba(239,68,68,.4)!important;color:#ef4444!important}
.btn-xs{font-size:.65rem;padding:.3rem .65rem}
.full-select{width:100%;background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);padding:.72rem 1rem;font-family:var(--font-body);font-size:.92rem;outline:none;cursor:pointer}
.full-select option{background:var(--bg2)}

/* Session pill */
.session-pill{display:inline-block;margin-top:.5rem;font-family:var(--font-head);font-size:.68rem;letter-spacing:.1em;padding:.32rem .9rem;border:1px solid;border-radius:40px}

/* Pagination */
.pagination{display:flex;align-items:center;justify-content:center;gap:.8rem;margin-top:1.2rem;padding-top:1rem;border-top:1px solid var(--border)}
.page-btn{background:var(--bg3);border:1px solid var(--border);color:var(--text-dim);padding:.38rem .85rem;border-radius:var(--radius);font-family:var(--font-head);font-size:.65rem;cursor:pointer;transition:all .2s}
.page-btn:hover{border-color:var(--border-hot);color:var(--orange)}
.page-info{font-family:var(--font-head);font-size:.62rem;color:var(--text-dim);letter-spacing:.07em}

/* Search */
.search-input-inline{background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);padding:.48rem .9rem;font-family:var(--font-body);font-size:.85rem;outline:none;transition:border-color .2s;min-width:170px}
.search-input-inline:focus{border-color:var(--border-hot)}
.filter-select{background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius);color:var(--text-dim);padding:.48rem .8rem;font-family:var(--font-head);font-size:.62rem;letter-spacing:.07em;outline:none;cursor:pointer}
.filter-select option{background:var(--bg2)}

/* Admin card header */
.admin-card-header{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1.2rem;flex-wrap:wrap}
.header-filters{display:flex;gap:.6rem;flex-wrap:wrap;align-items:center}

/* Hier rows */
.hier-row{margin-bottom:.5rem}
.hier-sep{height:1px;background:var(--border);margin:1rem 0}
.hier-actions{display:flex;gap:.5rem;flex-wrap:wrap;grid-column:1/-1;padding-top:.2rem}
.modal-inner{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:2rem;position:relative;width:100%;max-height:90vh;overflow-y:auto}

/* Ops restricted */
.ops-gate{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;text-align:center;gap:1rem}
.ops-gate .gate-icon{font-size:3rem}
.ops-gate h2{font-family:var(--font-head);font-size:1.5rem;letter-spacing:.1em}
.ops-gate p{color:var(--text-dim);max-width:400px;line-height:1.7}

/* ══════════════════════════════════════
   FoxHound v3.1 — Recruitment timeline
   + Discord sync + general polish
   ══════════════════════════════════════ */

/* ── Recruitment Timeline (about.html) ── */
.recruit-full-section {
  padding: 5rem var(--px);
  background: linear-gradient(180deg, var(--bg1) 0%, rgba(249,115,22,.03) 50%, var(--bg1) 100%);
  border-top: 1px solid var(--border);
}
.recruit-full-inner { max-width: 780px; margin: 0 auto; }
.recruit-full-header { text-align: center; margin-bottom: 4rem; }
.recruit-intro { color: var(--text-dim); font-size: 1rem; max-width: 560px; margin: 1rem auto 0; line-height: 1.75; }

.recruit-timeline { display: flex; flex-direction: column; gap: 0; }

.timeline-item {
  display: flex;
  gap: 2rem;
  position: relative;
}
.timeline-last .timeline-body { padding-bottom: 0; }

.timeline-left {
  display: flex;
  flex-direction: column;
  align-items: center;
  flex-shrink: 0;
  width: 56px;
}
.timeline-num {
  width: 56px;
  height: 56px;
  border-radius: 50%;
  background: var(--bg2);
  border: 2px solid var(--border);
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-head);
  font-size: .85rem;
  font-weight: 700;
  color: var(--text-dim);
  letter-spacing: .08em;
  flex-shrink: 0;
  transition: border-color .3s, color .3s;
  position: relative;
  z-index: 1;
}
.timeline-item:hover .timeline-num {
  border-color: var(--orange);
  color: var(--orange);
}
.accent-num {
  border-color: var(--orange) !important;
  color: var(--orange) !important;
  background: rgba(249,115,22,.08) !important;
  box-shadow: 0 0 20px rgba(249,115,22,.2);
}
.timeline-vline {
  flex: 1;
  width: 2px;
  background: var(--border);
  margin: 4px 0;
  min-height: 40px;
}

.timeline-body {
  flex: 1;
  padding-bottom: 3.5rem;
  display: flex;
  gap: 1.2rem;
  align-items: flex-start;
}
.timeline-icon {
  font-size: 1.6rem;
  flex-shrink: 0;
  margin-top: .6rem;
  line-height: 1;
}
.timeline-content { flex: 1; }
.timeline-content h3 {
  font-family: var(--font-head);
  font-size: 1.05rem;
  letter-spacing: .06em;
  color: var(--text);
  margin-bottom: .6rem;
}
.timeline-content p {
  color: var(--text-dim);
  line-height: 1.75;
  font-size: .95rem;
  margin-bottom: .8rem;
}
.optional-label { color: var(--text-dim); font-weight: 400; font-size: .85em; }
.channel {
  background: rgba(88,101,242,.12);
  color: #7289da;
  border: 1px solid rgba(88,101,242,.25);
  border-radius: 4px;
  padding: .05rem .4rem;
  font-family: 'Courier New', monospace;
  font-size: .88em;
}
.timeline-cta {
  display: inline-block;
  font-family: var(--font-head);
  font-size: .7rem;
  letter-spacing: .1em;
  color: var(--orange);
  border: 1px solid rgba(249,115,22,.3);
  padding: .45rem 1rem;
  border-radius: var(--radius);
  text-decoration: none;
  transition: background .2s, border-color .2s;
  margin-top: .2rem;
}
.timeline-cta:hover { background: rgba(249,115,22,.08); border-color: var(--orange); }

/* ── Discord sync (admin.html session area) ── */
.discord-btn {
  display: inline-flex;
  align-items: center;
  gap: .6rem;
  background: #5865f2;
  border: none;
  color: #fff;
  padding: .7rem 1.5rem;
  border-radius: var(--radius);
  font-family: var(--font-head);
  font-size: .7rem;
  letter-spacing: .09em;
  cursor: pointer;
  transition: background .2s, transform .15s;
  text-decoration: none;
}
.discord-btn:hover { background: #4752c4; transform: translateY(-1px); }

.discord-linked {
  display: inline-flex;
  align-items: center;
  gap: .8rem;
  background: rgba(88,101,242,.1);
  border: 1px solid rgba(88,101,242,.3);
  color: #8b9cf4;
  border-radius: var(--radius);
  padding: .55rem 1.1rem;
  font-size: .82rem;
}

/* ── Custom stat items – polish ── */
.custom-stats-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
  gap: 1.2rem;
  padding: 0 var(--px);
  max-width: 1100px;
  margin: 0 auto;
}
.custom-stat-item {
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 1.5rem 1rem;
  text-align: center;
  transition: border-color .25s, transform .2s;
  position: relative;
  overflow: hidden;
}
.custom-stat-item::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  background: linear-gradient(90deg, transparent, rgba(249,115,22,.4), transparent);
  opacity: 0;
  transition: opacity .3s;
}
.custom-stat-item:hover { border-color: rgba(249,115,22,.3); transform: translateY(-2px); }
.custom-stat-item:hover::before { opacity: 1; }
.custom-stat-icon { font-size: 1.6rem; margin-bottom: .6rem; }
.custom-stat-val {
  font-family: var(--font-head);
  font-size: 1.9rem;
  font-weight: 900;
  color: var(--orange);
  letter-spacing: .04em;
  line-height: 1;
  margin-bottom: .4rem;
}
.custom-stat-label {
  font-size: .72rem;
  color: var(--text-dim);
  letter-spacing: .1em;
  text-transform: uppercase;
}

/* ── Stats section on index.html ── */
.stats-section {
  padding: 4rem var(--px);
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
  background: linear-gradient(180deg, rgba(249,115,22,.02) 0%, transparent 100%);
}

/* ── card-summary clamp ── */
.card-summary {
  overflow: hidden;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  color: var(--text-dim);
  font-size: .88rem;
  line-height: 1.6;
  margin-bottom: .8rem;
}

/* ── Admin stat row ── */
#customStatsList .field-group { margin: 0; }
#customStatsList label { font-size: .65rem !important; }
#customStatsList input[type="text"],
#customStatsList input[type="date"] {
  font-size: .85rem;
  padding: .5rem .75rem;
}

/* ── Fleet iframe ── */
.fleet-iframe {
  width: 100%;
  height: 600px;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  background: var(--bg2);
}
.fleet-placeholder {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 4rem;
  text-align: center;
  gap: .8rem;
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: var(--radius);
}
.fleet-placeholder-icon { font-size: 3rem; opacity: .4; }

/* ── Badge discord ── */
.badge-discord { background: rgba(88,101,242,.1); color: #7289da; border-color: rgba(88,101,242,.3); }

/* ── About page rank-item animation ── */
.rank-item {
  animation: fadeSlideIn .4s ease both;
  animation-delay: var(--delay, 0s);
}
@keyframes fadeSlideIn {
  from { opacity: 0; transform: translateY(12px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* ── Responsive timeline ── */
@media (max-width: 600px) {
  .timeline-body { flex-direction: column; gap: .6rem; }
  .timeline-icon { margin-top: 0; }
  .timeline-left { width: 40px; }
  .timeline-num  { width: 40px; height: 40px; font-size: .72rem; }
}

/* ══════════════════════════════════════
   FoxHound — Opérations v2 + Redacted system
   ══════════════════════════════════════ */

/* ── Filtres ── */
.ops-filters{display:flex;flex-wrap:wrap;gap:.8rem;align-items:center;padding:1.2rem var(--px);border-bottom:1px solid var(--border);background:var(--bg1);position:sticky;top:60px;z-index:10}
.ops-filter-tabs{display:flex;gap:.4rem;flex-wrap:wrap}
.op-tab-btn{background:var(--bg3);border:1px solid var(--border);color:var(--text-dim);font-family:var(--font-head);font-size:.65rem;letter-spacing:.08em;padding:.4rem .9rem;border-radius:20px;cursor:pointer;transition:all .2s}
.op-tab-btn:hover{border-color:var(--border-hot);color:var(--text)}
.op-tab-btn.active{border-color:var(--orange);color:var(--orange);background:rgba(249,115,22,.08)}

/* ── 3 colonnes ── */
.ops-columns{display:grid;grid-template-columns:repeat(3,1fr);gap:0;min-height:60vh;border-top:none}
.ops-col{border-right:1px solid var(--border);min-height:400px}
.ops-col:last-child{border-right:none}
.ops-col-header{font-family:var(--font-head);font-size:.65rem;letter-spacing:.12em;padding:.9rem 1.2rem;border-bottom:2px solid;position:sticky;top:112px;z-index:5;backdrop-filter:blur(8px)}
.upcoming-header{border-color:#3b82f6;color:#3b82f6;background:rgba(59,130,246,.06)}
.ongoing-header{border-color:#22c55e;color:#22c55e;background:rgba(34,197,94,.06)}
.ended-header{border-color:#4b5563;color:#9ca3af;background:rgba(75,85,99,.06)}
.ops-col-body{padding:.8rem;display:flex;flex-direction:column;gap:.7rem}
.no-content-col{color:var(--text-dim);font-size:.82rem;text-align:center;padding:2.5rem 1rem;opacity:.6}

/* ── Op card v2 ── */
.op-card-v2{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:1.1rem;cursor:pointer;transition:border-color .2s,transform .15s,box-shadow .2s;position:relative;overflow:hidden}
.op-card-v2::before{content:'';position:absolute;top:0;left:0;width:3px;height:100%;transition:opacity .2s;opacity:0}
.op-card-v2.status-upcoming::before{background:#3b82f6}
.op-card-v2.status-ongoing::before{background:#22c55e}
.op-card-v2.status-ended::before{background:#4b5563}
.op-card-v2:hover{border-color:var(--border-hot);transform:translateX(2px);box-shadow:0 4px 20px rgba(0,0,0,.3)}
.op-card-v2:hover::before{opacity:1}
.op-card-v2-top{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;margin-bottom:.5rem}
.op-card-v2-title{font-family:var(--font-head);font-size:.9rem;font-weight:700;letter-spacing:.05em;color:var(--text);margin-bottom:.4rem;line-height:1.35}
.op-card-v2-summary{font-size:.82rem;color:var(--text-dim);line-height:1.55;margin-bottom:.7rem;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}
.op-card-v2-footer{display:flex;flex-direction:column;gap:.35rem}
.op-card-meta{font-size:.72rem;color:var(--text-dim)}

/* ── Status badges ── */
.op-status-badge{display:inline-block;font-family:var(--font-head);font-size:.58rem;letter-spacing:.08em;padding:.18rem .55rem;border-radius:20px;border:1px solid}
.status-upcoming{background:rgba(59,130,246,.1);color:#3b82f6;border-color:rgba(59,130,246,.3)}
.status-ongoing{background:rgba(34,197,94,.1);color:#22c55e;border-color:rgba(34,197,94,.3)}
.status-ended{background:rgba(75,85,99,.1);color:#9ca3af;border-color:rgba(75,85,99,.3)}
.slots-badge{display:inline-block;font-family:var(--font-head);font-size:.58rem;letter-spacing:.07em;padding:.15rem .5rem;border-radius:20px;background:rgba(249,115,22,.1);color:var(--orange);border:1px solid rgba(249,115,22,.3)}
.slots-full{background:rgba(239,68,68,.1)!important;color:#ef4444!important;border-color:rgba(239,68,68,.3)!important}
.grade-badge{display:inline-block;font-family:var(--font-head);font-size:.58rem;letter-spacing:.07em;padding:.15rem .5rem;border-radius:20px;background:rgba(250,204,21,.08);color:#fbbf24;border:1px solid rgba(250,204,21,.2)}
.lock-badge{display:inline-block;font-family:var(--font-head);font-size:.58rem;letter-spacing:.07em;padding:.15rem .5rem;border-radius:20px;background:rgba(148,163,184,.08);color:#94a3b8;border:1px solid rgba(148,163,184,.2)}

/* ── Op modal ── */
.op-modal-inner{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);width:100%;max-width:780px;max-height:90vh;overflow-y:auto;position:relative}
.op-modal-header{padding:2rem 2rem 1.2rem;border-bottom:1px solid var(--border);position:sticky;top:0;background:var(--bg2);z-index:2}
.op-modal-badges{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:.8rem}
.op-modal-title{font-family:var(--font-head);font-size:1.5rem;font-weight:900;letter-spacing:.08em;color:var(--text);margin-bottom:.7rem}
.op-modal-meta-row{display:flex;flex-wrap:wrap;gap:.8rem 1.5rem;font-size:.82rem;color:var(--text-dim);margin-top:.7rem}
.op-modal-meta-row strong{color:var(--text)}
.op-modal-body{padding:1.8rem 2rem}
.op-modal-summary{color:var(--text-dim);font-size:.95rem;line-height:1.7;margin-bottom:1.5rem;padding-bottom:1.5rem;border-bottom:1px solid var(--border)}
.op-modal-content{font-size:.95rem;line-height:1.8;color:var(--text)}
.op-modal-content p{margin-bottom:.8rem}

/* ── Op modal image ── */
.op-modal-img-wrap{width:100%;max-height:280px;overflow:hidden;border-radius:var(--radius) var(--radius) 0 0;background:var(--bg3);border-bottom:1px solid var(--border)}
.op-modal-img{width:100%;height:280px;object-fit:cover;display:block}

/* ════════════════════════════════════════
   REDACTED SYSTEM — single source of truth
   ════════════════════════════════════════
   1. Admin editor:   .rich-editor .redacted → orange text, editable
   2. Modal masked:   .op-modal-content.redacted-masked .redacted → black bar
   3. Modal revealed: .op-modal-content (no .redacted-masked) .redacted → orange
   4. Not enrolled:   .redacted-locked → red tag, no reveal
*/

/* 1. Admin rich editor */
.rich-editor .redacted {
  color: #ef4444;
  background: rgba(239,68,68,.12);
  border: 1px solid rgba(239,68,68,.3);
  border-radius: 3px;
  padding: .05em .35em;
  font-family: var(--font-head);
  font-size: .85em;
  cursor: text;
  user-select: text;
  display: inline;
}

/* 2. Modal — default masked state (black bar) */
.op-modal-content .redacted {
  color: transparent;
  background: rgba(20, 20, 20, 0.97);
  border: 1px solid rgba(239,68,68,.3);
  border-radius: 3px;
  padding: .05em .4em;
  display: inline;
  position: relative;
  user-select: none;
  cursor: pointer;
  transition: color .2s, background .2s, border-color .2s;
  min-width: 3em;
}
.op-modal-content.redacted-masked .redacted::after {
  content: "\2588\2588\2588";
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%,-50%);
  color: rgba(239,68,68,.5);
  font-size: .6em;
  letter-spacing: .2em;
  pointer-events: none;
}

/* 3. Revealed — remove .redacted-masked class from container */
.op-modal-content:not(.redacted-masked) .redacted {
  color: var(--orange) !important;
  background: rgba(249,115,22,.1) !important;
  border-color: rgba(249,115,22,.35) !important;
  user-select: text;
  cursor: default;
}
.op-modal-content:not(.redacted-masked) .redacted::after {
  display: none !important;
}

/* 4. Not enrolled: locked placeholder, no reveal */
.redacted-locked {
  display: inline;
  background: rgba(239,68,68,.1);
  color: #ef4444;
  border: 1px solid rgba(239,68,68,.2);
  border-radius: 3px;
  padding: .05em .4em;
  font-family: var(--font-head);
  font-size: .8em;
  letter-spacing: .05em;
  user-select: none;
  cursor: not-allowed;
}

/* Reveal bar */
.reveal-bar {
  display: flex;
  align-items: center;
  gap: 1rem;
  flex-wrap: wrap;
  justify-content: space-between;
  margin-top: 1.4rem;
  padding: .85rem 1.1rem;
  background: rgba(239,68,68,.05);
  border: 1px solid rgba(239,68,68,.15);
  border-radius: var(--radius);
}
.reveal-hint { font-size: .82rem; color: var(--text-dim); }
.reveal-btn {
  background: none;
  border: 1px solid rgba(239,68,68,.35);
  color: #ef4444;
  font-family: var(--font-head);
  font-size: .68rem;
  letter-spacing: .08em;
  padding: .45rem 1rem;
  border-radius: var(--radius);
  cursor: pointer;
  transition: background .15s, border-color .15s, color .15s;
  white-space: nowrap;
}
.reveal-btn:hover { background: rgba(239,68,68,.08); }
.reveal-btn.reveal-btn-active {
  background: rgba(249,115,22,.1);
  border-color: rgba(249,115,22,.4);
  color: var(--orange);
}

/* Redacted gate (non-enrolled info box) */
.redacted-gate { display:flex; flex-direction:column; align-items:center; gap:.6rem; text-align:center; margin-top:1.5rem; padding:1.5rem; background:rgba(239,68,68,.04); border:1px solid rgba(239,68,68,.15); border-radius:var(--radius); color:var(--text-dim); font-size:.9rem; line-height:1.6; }
.redacted-gate-icon { font-size:1.6rem; }
.redacted-gate strong { color:#ef4444; }

/* ── Roster ── */
.op-modal-roster{padding:0 2rem 2rem;border-top:1px solid var(--border);margin-top:.5rem}
.roster-header{padding:1.2rem 0 .8rem;display:flex;align-items:center;justify-content:space-between}
.roster-group{margin-bottom:1.2rem}
.roster-group-label{font-family:var(--font-head);font-size:.65rem;letter-spacing:.1em;padding:.4rem 0;border-bottom:1px solid var(--border);margin-bottom:.5rem}
.roster-members{display:flex;flex-direction:column;gap:.3rem}
.roster-member{display:flex;justify-content:space-between;align-items:center;padding:.45rem .8rem;background:var(--bg3);border:1px solid var(--border);border-radius:6px;transition:border-color .15s}
.roster-member:hover{border-color:var(--border-hot)}
.roster-username{font-size:.88rem;font-weight:600;color:var(--text)}
.roster-date{font-size:.72rem;color:var(--text-dim);font-family:var(--font-head);letter-spacing:.06em}

/* ── Modal actions ── */
.op-modal-actions{padding:0 2rem 1.5rem;display:flex;flex-wrap:wrap;gap:.8rem;align-items:center}
.enroll-btn{min-width:200px}
.unenroll-btn{font-size:.78rem}
.enroll-locked{font-family:var(--font-head);font-size:.75rem;letter-spacing:.07em;color:var(--text-dim);padding:.6rem 1rem;background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius)}
.enroll-full{font-family:var(--font-head);font-size:.75rem;letter-spacing:.07em;color:#ef4444;padding:.6rem 1rem;background:rgba(239,68,68,.07);border:1px solid rgba(239,68,68,.2);border-radius:var(--radius)}

/* ── Visitor banner ── */
.visitor-banner-inner{display:flex;align-items:center;gap:1rem;justify-content:space-between;flex-wrap:wrap;padding:.9rem var(--px);background:rgba(249,115,22,.07);border-bottom:1px solid rgba(249,115,22,.2);font-size:.85rem;color:var(--text-dim)}
.visitor-banner-inner strong{color:var(--orange)}
.op-card-public{opacity:.85}
.op-card-locked-text{color:#ef444488;font-style:italic;font-size:.8rem}

/* ── Hero external buttons ── */
.hero-external-btns{display:flex;gap:.8rem;justify-content:center;margin-top:1.5rem;flex-wrap:wrap}
.hero-ext-btn{display:inline-flex;align-items:center;gap:.55rem;font-family:var(--font-head);font-size:.68rem;letter-spacing:.1em;padding:.65rem 1.4rem;border-radius:var(--radius);text-decoration:none;transition:all .2s;border:1px solid}
.hero-ext-discord{background:rgba(88,101,242,.12);border-color:rgba(88,101,242,.35);color:#8b9cf4}
.hero-ext-discord:hover{background:rgba(88,101,242,.22);border-color:#5865f2;color:#fff;transform:translateY(-2px);box-shadow:0 6px 20px rgba(88,101,242,.25)}
.hero-ext-rsi{background:rgba(249,115,22,.08);border-color:rgba(249,115,22,.3);color:var(--orange)}
.hero-ext-rsi:hover{background:rgba(249,115,22,.16);border-color:var(--orange);transform:translateY(-2px);box-shadow:0 6px 20px rgba(249,115,22,.2)}

/* ── Quick date picker ── */
.quick-date-row{display:flex;gap:.6rem;flex-wrap:wrap;align-items:center}
.quick-select{background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);font-family:var(--font-body);font-size:.85rem;padding:.6rem .9rem;cursor:pointer;transition:border-color .2s;flex:1;min-width:130px}
.quick-select:focus{outline:none;border-color:var(--orange)}
.quick-date-sep{color:var(--text-dim);font-size:.78rem;white-space:nowrap}
.quick-date-manual{background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);font-family:var(--font-body);font-size:.82rem;padding:.55rem .8rem;flex:1;min-width:170px;transition:border-color .2s}
.quick-date-manual:focus{outline:none;border-color:var(--orange)}
#opStatusPreview{background:var(--bg3);border:1px solid var(--border);border-radius:4px;padding:.5rem .9rem;display:inline-block;font-size:.78rem;color:var(--text-dim);font-family:var(--font-head);letter-spacing:.07em;margin-top:.8rem}

/* ── Templates ── */
.tpl-bar{padding:.8rem 1.2rem!important}
.tpl-bar-inner{display:flex;align-items:center;gap:.8rem;flex-wrap:wrap}
.tpl-bar-label{font-family:var(--font-head);font-size:.62rem;letter-spacing:.12em;color:var(--text-dim);flex-shrink:0}
.tpl-chip-list{display:flex;gap:.4rem;flex-wrap:wrap;flex:1}
.tpl-chip{display:inline-flex;align-items:center;gap:.2rem;background:var(--bg3);border:1px solid var(--border);border-radius:4px;padding:.15rem .1rem .15rem .5rem}
.tpl-chip-btn{background:none;border:none;color:var(--orange);cursor:pointer;font-family:var(--font-head);font-size:.68rem;letter-spacing:.06em;padding:.1rem .2rem}
.tpl-chip-btn:hover{text-decoration:underline}
.tpl-chip-del{background:none;border:none;color:var(--text-dim);cursor:pointer;font-size:.65rem;padding:.1rem .3rem}
.tpl-chip-del:hover{color:#ef4444}
.tpl-modal-inner{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);width:100%;max-width:680px;max-height:80vh;overflow-y:auto}
.tpl-modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.2rem 1.5rem;border-bottom:1px solid var(--border);position:sticky;top:0;background:var(--bg2);z-index:2}
.tpl-modal-grid{display:grid;gap:.6rem;padding:1.2rem 1.5rem}
.tpl-card{display:flex;align-items:center;gap:1rem;padding:1rem 1.1rem;background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;transition:border-color .2s,transform .15s}
.tpl-card:hover{border-color:var(--orange);transform:translateX(3px)}
.tpl-card-icon{font-size:1.5rem;flex-shrink:0;width:2rem;text-align:center}
.tpl-card-info{flex:1}
.tpl-card-name{font-family:var(--font-head);font-size:.82rem;letter-spacing:.06em;color:var(--text);margin-bottom:.25rem}
.tpl-card-desc{font-size:.78rem;color:var(--text-dim)}
.tpl-card-arrow{color:var(--orange);font-family:var(--font-head);font-size:.9rem;flex-shrink:0}
.tpl-badge-default{display:inline-block;font-size:.58rem;font-family:var(--font-head);letter-spacing:.07em;padding:.12rem .4rem;background:rgba(249,115,22,.08);color:var(--orange);border:1px solid rgba(249,115,22,.2);border-radius:10px;margin-top:.3rem}
.tpl-badge-custom{display:inline-block;font-size:.58rem;font-family:var(--font-head);letter-spacing:.07em;padding:.12rem .4rem;background:rgba(96,165,250,.08);color:#60a5fa;border:1px solid rgba(96,165,250,.2);border-radius:10px;margin-top:.3rem}

/* ── Discord mapping rows ── */
.mapping-row{display:grid;grid-template-columns:1fr 24px 1fr 36px;gap:.6rem;align-items:end;margin-bottom:.7rem;background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius);padding:.8rem}

/* ── Fleet ── */
.fleet-section{padding:0;min-height:70vh}
.fleet-iframe-full{width:100%;min-height:85vh;border:none;display:block;background:var(--bg2)}
.fleet-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:50vh;gap:1rem;color:var(--text-dim)}
.fleet-loading-spinner{width:36px;height:36px;border:3px solid var(--border);border-top-color:var(--orange);border-radius:50%;animation:spin .8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.fleet-setup-card{max-width:560px;margin:4rem auto;background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:2.5rem 2rem;text-align:center}
.fleet-setup-icon{font-size:2.5rem;margin-bottom:1rem}
.fleet-setup-card h3{font-family:var(--font-head);letter-spacing:.1em;font-size:1rem;margin-bottom:1.2rem}
.fleet-setup-steps{text-align:left;display:flex;flex-direction:column;gap:.7rem;margin:1.2rem 0}
.fleet-setup-step{display:flex;gap:.8rem;align-items:flex-start}
.fleet-step-num{flex-shrink:0;width:22px;height:22px;background:rgba(249,115,22,.15);border:1px solid rgba(249,115,22,.3);color:var(--orange);border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--font-head);font-size:.62rem;font-weight:700;margin-top:.1rem}
.fleet-setup-step p{font-size:.85rem;color:var(--text-dim);line-height:1.6;margin:0}
.fleet-error{color:#ef4444;font-size:.82rem;margin-bottom:.8rem}
.fleet-iframe-note{text-align:center;padding:.6rem;font-size:.78rem;color:var(--text-dim)}

/* ── Responsive ops ── */
@media(max-width:900px){
  .ops-columns{grid-template-columns:1fr}
  .ops-col{border-right:none;border-bottom:1px solid var(--border)}
  .ops-col-header{top:56px}
}
