/* ═══════════════════════════════════════
   FLIGHTDECK — Fresh CSS
   Fixed topbar. Body scrolls. Simple.
═══════════════════════════════════════ */

:root {
  --bg:        #07090f;
  --bg1:       #0c0f1a;
  --bg2:       #111520;
  --bg3:       #161b2e;
  --border:    #1e2540;
  --border2:   #262f4a;

  --cyan:      #00d4ff;
  --cyan-dim:  rgba(0,212,255,0.1);
  --green:     #00e676;
  --amber:     #ffab00;
  --amber-dim: rgba(255,171,0,0.1);
  --red:       #ff3d57;
  --red-dim:   rgba(255,61,87,0.1);

  --text:      #dde4f0;
  --text2:     #6b7a99;
  --text3:     #3a4560;

  --mono:      'Share Tech Mono', monospace;
  --sans:      'Barlow', sans-serif;
  --cond:      'Barlow Condensed', sans-serif;

  --topbar-h:  52px;
  --radius:    4px;
  --radius-lg: 10px;
  --ease:      0.18s ease;
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

html {
  height: 100%;
}

body {
  background: var(--bg);
  color: var(--text);
  font-family: var(--sans);
  font-size: 16px;
  line-height: 1.7;
  /* Body scrolls normally — no overflow tricks */
}

::-webkit-scrollbar { width: 4px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: var(--border2); border-radius: 2px; }

/* ══════════════════════════════════════
   SCREENS — simple show/hide
══════════════════════════════════════ */
.screen { display: block; }

/* ══════════════════════════════════════
   SHARED
══════════════════════════════════════ */
.fd-wing-logo { flex-shrink: 0; display: block; }
.fd-wing-sm { width: 22px; height: 22px; }
.brand-name { font-family: var(--cond); font-size: 14px; font-weight: 700; letter-spacing: 3px; color: var(--text); }

/* ── Buttons ── */
.btn {
  font-family: var(--cond); font-weight: 700; letter-spacing: 1.5px;
  border: none; border-radius: 8px; cursor: pointer;
  transition: all 0.15s ease; display: inline-flex; align-items: center; gap: 8px;
  white-space: nowrap;
}
.btn-primary  {
  background: var(--cyan); color: var(--bg);
  font-size: 12px; padding: 11px 22px;
  box-shadow: 0 2px 12px rgba(0,212,255,0.2);
}
.btn-primary:hover {
  background: #22daff;
  box-shadow: 0 4px 20px rgba(0,212,255,0.4);
  transform: translateY(-1px);
}
.btn-primary:active { transform: translateY(0); box-shadow: 0 2px 8px rgba(0,212,255,0.2); }
.btn-primary:disabled { opacity: 0.5; cursor: not-allowed; transform: none; box-shadow: none; }
.btn-full     { width: 100%; justify-content: center; }

.btn-ghost    {
  background: transparent; color: var(--text2);
  border: 1px solid var(--border2); font-size: 12px; padding: 10px 20px;
}
.btn-ghost:hover { color: var(--text); border-color: rgba(110,126,160,0.6); background: rgba(255,255,255,0.04); }
.btn-ghost:active { background: rgba(255,255,255,0.06); }

.btn-danger   { background: var(--red); color: #fff; font-size: 12px; padding: 10px 20px; box-shadow: 0 2px 10px rgba(255,61,87,0.2); }
.btn-danger:hover { background: #ff5568; box-shadow: 0 4px 16px rgba(255,61,87,0.35); transform: translateY(-1px); }
.btn-ghost.btn-danger { background: transparent; color: var(--red); border-color: rgba(255,61,87,0.3); box-shadow: none; }
.btn-ghost.btn-danger:hover { background: var(--red-dim); border-color: var(--red); transform: none; }
.btn-sm       { padding: 7px 14px; font-size: 11px; letter-spacing: 1px; }

.btn-ghost-sm {
  background: transparent; color: var(--text2);
  border: 1px solid var(--border); border-radius: 8px;
  font-family: var(--cond); font-size: 12px; font-weight: 600; letter-spacing: 1px;
  padding: 8px 16px; cursor: pointer; transition: all 0.15s ease;
}
.btn-ghost-sm:hover { color: var(--text); border-color: var(--border2); background: rgba(255,255,255,0.04); }

.btn-cyan-sm {
  background: var(--cyan); color: var(--bg);
  border: none; border-radius: 8px;
  font-family: var(--cond); font-size: 12px; font-weight: 700; letter-spacing: 1px;
  padding: 8px 16px; cursor: pointer; transition: all 0.15s ease;
  box-shadow: 0 2px 10px rgba(0,212,255,0.2);
}
.btn-cyan-sm:hover { background: #22daff; box-shadow: 0 4px 16px rgba(0,212,255,0.35); transform: translateY(-1px); }

.btn-hero {
  background: var(--cyan); color: var(--bg);
  border: none; border-radius: 10px;
  font-family: var(--cond); font-size: 14px; font-weight: 700; letter-spacing: 2px;
  padding: 15px 34px; cursor: pointer; transition: all 0.2s ease;
  display: inline-flex; align-items: center; gap: 10px;
  box-shadow: 0 4px 24px rgba(0,212,255,0.3);
}
.btn-hero:hover { background: #22daff; box-shadow: 0 6px 36px rgba(0,212,255,0.5); transform: translateY(-2px); }
.btn-hero:active { transform: translateY(0); }
.btn-arrow { font-size: 16px; transition: transform 0.15s ease; }
.btn-hero:hover .btn-arrow { transform: translateX(5px); }

/* ── Spinner ── */
.spinner {
  width: 14px; height: 14px;
  border: 2px solid rgba(255,255,255,0.3); border-top-color: #fff;
  border-radius: 50%; animation: spin 0.7s linear infinite;
  display: inline-block; vertical-align: middle;
}
@keyframes spin { to { transform: rotate(360deg); } }

/* ── Fields ── */
.field { display: flex; flex-direction: column; gap: 6px; margin-bottom: 16px; }
.field-row { display: flex; gap: 14px; }
.field-row .field { flex: 1; margin-bottom: 0; }
.field-label { font-family: var(--mono); font-size: 11px; letter-spacing: 1.5px; color: var(--text2); }
.field-input, .field-textarea {
  background: var(--bg2); border: 1px solid var(--border); border-radius: 8px;
  padding: 12px 14px; color: var(--text); font-family: var(--sans); font-size: 15px;
  outline: none; transition: border-color 0.15s ease, box-shadow 0.15s ease; width: 100%;
}
.field-input:focus, .field-textarea:focus { border-color: var(--cyan); background: var(--bg3); box-shadow: 0 0 0 3px rgba(0,212,255,0.07); }
.field-input::placeholder, .field-textarea::placeholder { color: var(--text3); font-weight: 300; }
.field-textarea { resize: vertical; line-height: 1.6; min-height: 90px; }
input[type="date"]::-webkit-calendar-picker-indicator { filter: invert(0.5); cursor: pointer; }
.icao { font-family: var(--mono); font-size: 15px; text-transform: uppercase; letter-spacing: 2px; }
.sector-arrow { flex: 0 0 auto; font-size: 18px; color: var(--text3); padding-top: 24px; }

/* ══════════════════════════════════════
   MARKETING
══════════════════════════════════════ */
.mkt-nav {
  position: fixed; top: 0; left: 0; right: 0; height: 60px;
  background: rgba(7,9,15,0.92); backdrop-filter: blur(16px);
  border-bottom: 1px solid rgba(30,37,64,0.6);
  display: flex; align-items: center; justify-content: space-between;
  padding: 0 32px; z-index: 100;
}
.mkt-nav-brand { display: flex; align-items: center; gap: 10px; }
.mkt-nav-actions { display: flex; align-items: center; gap: 10px; }

/* Hero */
.hero {
  min-height: 100vh; display: flex; align-items: center;
  padding: 90px 32px 60px; position: relative; overflow: hidden; gap: 60px;
}
.hero-bg { position: absolute; inset: 0; pointer-events: none; }
.hero-grid {
  position: absolute; inset: 0;
  background-image: linear-gradient(rgba(0,212,255,0.04) 1px,transparent 1px), linear-gradient(90deg,rgba(0,212,255,0.04) 1px,transparent 1px);
  background-size: 48px 48px;
}
.hero-glow {
  position: absolute; top: 20%; left: 40%; width: 700px; height: 700px;
  background: radial-gradient(ellipse,rgba(0,212,255,0.07) 0%,transparent 70%);
  transform: translate(-50%,-50%);
}
.hero-content { flex: 1; max-width: 600px; position: relative; z-index: 1; animation: fadeUp 0.8s ease both; }
.hero-eyebrow {
  font-family: var(--mono); font-size: 10px; letter-spacing: 4px; color: var(--cyan);
  margin-bottom: 20px; display: flex; align-items: center; gap: 10px;
}
.hero-eyebrow::before { content: ''; width: 24px; height: 1px; background: var(--cyan); }
.hero-title {
  font-family: var(--cond); font-size: clamp(52px,7vw,84px);
  font-weight: 800; line-height: 0.95; color: var(--text);
  margin-bottom: 24px; letter-spacing: -1px;
}
.hero-title-accent { color: var(--cyan); display: block; }
.hero-desc {
  font-size: 18px; font-weight: 300; color: var(--text2);
  line-height: 1.75; margin-bottom: 36px; max-width: 480px;
}
.hero-actions { display: flex; flex-direction: column; align-items: flex-start; gap: 14px; }
.hero-note { font-family: var(--mono); font-size: 10px; color: var(--text3); letter-spacing: 1px; }

/* Hero visual cards */
.hero-visual { flex: 0 0 320px; position: relative; height: 340px; z-index: 1; animation: fadeUp 0.8s 0.2s ease both; }
.hv-card { position: absolute; background: var(--bg1); border: 1px solid var(--border); border-radius: var(--radius-lg); padding: 16px 20px; box-shadow: 0 8px 32px rgba(0,0,0,0.4); }
.hv-label { font-family: var(--mono); font-size: 8px; letter-spacing: 3px; color: var(--text3); margin-bottom: 8px; }
.hv-card-1 { top: 0; left: 0; width: 210px; }
.hv-flight { font-family: var(--mono); font-size: 13px; color: var(--cyan); letter-spacing: 1px; margin-bottom: 6px; }
.hv-phase  { font-family: var(--cond); font-size: 12px; color: var(--text2); background: var(--bg3); padding: 3px 8px; border-radius: 3px; display: inline-block; }
.hv-card-2 { top: 10px; right: 0; width: 150px; border-color: rgba(0,212,255,0.25); background: rgba(0,212,255,0.05); }
.hv-time   { font-family: var(--mono); font-size: 22px; color: var(--cyan); letter-spacing: 2px; }
.hv-card-3 { bottom: 10px; left: 20px; width: 200px; }
.hv-stat   { font-family: var(--cond); font-size: 30px; font-weight: 700; color: var(--text); line-height: 1; margin-bottom: 8px; }
.hv-stat span { font-size: 14px; color: var(--text2); font-weight: 400; }
.hv-badge  { font-family: var(--mono); font-size: 9px; letter-spacing: 1px; padding: 3px 8px; border-radius: 3px; display: inline-block; }
.hv-badge.reportable { color: var(--amber); background: var(--amber-dim); border: 1px solid rgba(255,171,0,0.2); }
.hv-plane  { position: absolute; top: 50%; right: -10px; font-size: 56px; transform: translateY(-50%) rotate(45deg); opacity: 0.05; }

/* Stats bar */
.mkt-stats-bar {
  background: var(--bg1);
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 16px 32px;
  gap: 20px;
  flex-wrap: wrap;
}
.mkt-stat { display: flex; align-items: center; gap: 8px; }
.mkt-stat-icon { font-size: 16px; }
.mkt-stat-text { font-family: var(--mono); font-size: 11px; color: var(--text2); letter-spacing: 1px; }
.mkt-stat-divider { color: var(--text3); font-size: 18px; }

/* Features */
.features { padding: 80px 32px; background: var(--bg); }
.features-inner { max-width: 960px; margin: 0 auto; }
.section-eyebrow {
  font-family: var(--mono); font-size: 10px; letter-spacing: 4px; color: var(--cyan);
  margin-bottom: 16px; display: flex; align-items: center; gap: 10px;
}
.section-eyebrow::before { content: ''; width: 24px; height: 1px; background: var(--cyan); }
.section-title {
  font-family: var(--cond); font-size: clamp(28px,4vw,44px);
  font-weight: 700; line-height: 1.15; color: var(--text); margin-bottom: 44px;
}
.features-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 16px; }
.feat-card {
  background: var(--bg1); border: 1px solid var(--border);
  border-radius: var(--radius-lg); padding: 24px;
  transition: border-color var(--ease);
}
.feat-card:hover { border-color: var(--border2); }
.feat-icon { font-size: 28px; margin-bottom: 12px; }
.feat-title { font-family: var(--cond); font-size: 17px; font-weight: 700; letter-spacing: 1px; color: var(--text); margin-bottom: 8px; }
.feat-desc { font-size: 14px; color: var(--text2); line-height: 1.7; font-weight: 300; }

/* How it works */
.mkt-how {
  padding: 80px 32px;
  background: var(--bg1);
  border-top: 1px solid var(--border);
}
.mkt-steps { display: flex; flex-direction: column; gap: 0; max-width: 600px; }
.mkt-step {
  display: flex;
  gap: 20px;
  align-items: flex-start;
}
.mkt-step-num {
  font-family: var(--mono);
  font-size: 11px;
  color: var(--cyan);
  letter-spacing: 2px;
  background: var(--cyan-dim);
  border: 1px solid rgba(0,212,255,0.2);
  border-radius: var(--radius);
  padding: 6px 10px;
  flex-shrink: 0;
  margin-top: 4px;
}
.mkt-step-content { flex: 1; padding-bottom: 8px; }
.mkt-step-title { font-family: var(--cond); font-size: 17px; font-weight: 700; color: var(--text); margin-bottom: 6px; letter-spacing: 0.5px; }
.mkt-step-desc { font-size: 14px; color: var(--text2); line-height: 1.7; font-weight: 300; }
.mkt-step-line {
  width: 1px; height: 28px;
  background: var(--border);
  margin-left: 32px;
}

/* CTA */
.cta-section { padding: 80px 32px; text-align: center; position: relative; overflow: hidden; }
.cta-section::before { content: ''; position: absolute; inset: 0; background: radial-gradient(ellipse at center,rgba(0,212,255,0.06) 0%,transparent 70%); }
.cta-inner { position: relative; z-index: 1; }
.cta-callsign {
  font-family: var(--mono); font-size: 9px; letter-spacing: 4px;
  color: var(--cyan); margin-bottom: 16px; opacity: 0.7;
}
.cta-title {
  font-family: var(--cond); font-size: clamp(30px,5vw,52px);
  font-weight: 700; color: var(--text); margin-bottom: 16px; line-height: 1.1;
}
.cta-desc  { font-size: 16px; color: var(--text2); margin-bottom: 32px; font-weight: 300; max-width: 480px; margin-left: auto; margin-right: auto; }
.cta-note  { margin-top: 16px; font-size: 14px; color: var(--text3); }
.cta-link  { color: var(--cyan); text-decoration: none; transition: opacity var(--ease); }
.cta-link:hover { opacity: 0.8; }

/* Footer */
.mkt-footer {
  padding: 24px 32px;
  border-top: 1px solid var(--border);
  display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 10px;
}
.footer-brand { display: flex; align-items: center; gap: 8px; }
.footer-tagline { font-family: var(--sans); font-size: 13px; color: var(--text3); font-weight: 300; }
.footer-note  { font-family: var(--mono); font-size: 10px; color: var(--text3); letter-spacing: 1px; }

/* ══════════════════════════════════════
   AUTH
══════════════════════════════════════ */
.auth-wrap {
  min-height: 100vh; display: flex; align-items: center; justify-content: center;
  padding: 80px 20px 40px; position: relative;
}
.auth-wrap::before {
  content: ''; position: fixed; inset: 0;
  background-image: linear-gradient(rgba(0,212,255,0.03) 1px,transparent 1px), linear-gradient(90deg,rgba(0,212,255,0.03) 1px,transparent 1px);
  background-size: 40px 40px; pointer-events: none;
}
.auth-back { position: fixed; top: 20px; left: 24px; background: none; border: none; color: var(--text3); font-family: var(--mono); font-size: 11px; letter-spacing: 1px; cursor: pointer; transition: color var(--ease); z-index: 10; }
.auth-back:hover { color: var(--cyan); }
.auth-card { background: var(--bg1); border: 1px solid var(--border); border-radius: var(--radius-lg); padding: 36px 32px; width: 100%; max-width: 400px; position: relative; box-shadow: 0 24px 80px rgba(0,0,0,0.6); animation: fadeUp 0.3s ease both; }
.auth-brand { display: flex; align-items: center; gap: 14px; margin-bottom: 28px; }
.auth-brand-name { font-family: var(--cond); font-size: 18px; font-weight: 700; letter-spacing: 4px; display: block; }
.auth-brand-sub  { font-family: var(--mono); font-size: 9px; letter-spacing: 2px; color: var(--text3); display: block; margin-top: 2px; }
.auth-tabs { display: flex; background: var(--bg2); border: 1px solid var(--border); border-radius: 10px; padding: 3px; margin-bottom: 22px; }
.auth-tab  { flex: 1; background: transparent; border: none; color: var(--text3); font-family: var(--cond); font-size: 11px; font-weight: 700; letter-spacing: 2px; padding: 9px; border-radius: 8px; cursor: pointer; transition: all 0.15s ease; }
.auth-tab.active { background: var(--bg3); color: var(--cyan); box-shadow: 0 1px 4px rgba(0,0,0,0.3); }
.auth-message { font-size: 12px; padding: 10px 14px; border-radius: var(--radius); margin-bottom: 16px; line-height: 1.5; }
.auth-message-error   { background: var(--red-dim); border: 1px solid rgba(255,61,87,0.25); color: var(--red); }
.auth-message-success { background: rgba(0,230,118,0.08); border: 1px solid rgba(0,230,118,0.2); color: var(--green); }
.auth-form .field { margin-bottom: 14px; }
.auth-divider { display: flex; align-items: center; gap: 12px; margin: 18px 0; }
.auth-divider::before, .auth-divider::after { content: ''; flex: 1; height: 1px; background: var(--border); }
.auth-divider span { font-family: var(--mono); font-size: 10px; color: var(--text3); letter-spacing: 1px; white-space: nowrap; }
.oauth-buttons { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; margin-bottom: 18px; }
.oauth-buttons-single { grid-template-columns: 1fr; }
.oauth-btn { display: flex; align-items: center; justify-content: center; gap: 8px; background: var(--bg2); border: 1px solid var(--border); border-radius: var(--radius); padding: 11px; color: var(--text2); font-family: var(--sans); font-size: 13px; font-weight: 500; cursor: pointer; transition: all var(--ease); }
.oauth-btn:hover { border-color: var(--border2); color: var(--text); background: var(--bg3); }
.auth-footer { text-align: center; }
.auth-footer a { font-family: var(--mono); font-size: 10px; color: var(--text3); text-decoration: none; letter-spacing: 1px; transition: color var(--ease); }
.auth-footer a:hover { color: var(--cyan); }

/* ══════════════════════════════════════
   APP SHELL
   Fixed topbar. Content scrolls naturally.
══════════════════════════════════════ */

/* Fixed topbar — always visible at top */
.app-topbar {
  position: fixed;
  top: 0; left: 0; right: 0;
  height: var(--topbar-h);
  background: var(--bg1);
  border-bottom: 1px solid var(--border);
  display: flex; align-items: center; justify-content: space-between;
  padding: 0 20px;
  z-index: 80;
}
.app-topbar-left  { display: flex; align-items: center; gap: 10px; }
.app-topbar-title { font-family: var(--cond); font-size: 15px; font-weight: 700; letter-spacing: 3px; color: var(--text); }
.app-topbar-right { display: flex; align-items: center; gap: 16px; }
.app-utc          { font-family: var(--mono); font-size: 15px; color: var(--cyan); letter-spacing: 2px; }
.app-utc span     { font-size: 9px; color: var(--text3); margin-left: 4px; letter-spacing: 2px; }
.app-menu-btn     { background: none; border: none; color: var(--text2); font-size: 20px; cursor: pointer; padding: 4px 8px; transition: color var(--ease); }
.app-menu-btn:hover { color: var(--cyan); }

/* Slide-in menu */
.app-menu-overlay { display: none; position: fixed; inset: 0; background: rgba(0,0,0,0.6); z-index: 90; backdrop-filter: blur(3px); }
.app-menu-overlay.open { display: block; }
.app-menu { position: fixed; top: 0; right: -300px; bottom: 0; width: 280px; background: var(--bg1); border-left: 1px solid var(--border); z-index: 100; transition: right 0.25s ease; display: flex; flex-direction: column; }
.app-menu.open { right: 0; }
.app-menu-header { display: flex; align-items: center; justify-content: space-between; padding: 20px 20px 16px; border-bottom: 1px solid var(--border); }
.app-menu-user   { font-family: var(--mono); font-size: 11px; color: var(--text2); letter-spacing: 0.5px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; max-width: 200px; }
.app-menu-close  { background: none; border: none; color: var(--text3); font-size: 16px; cursor: pointer; padding: 4px; transition: color var(--ease); }
.app-menu-close:hover { color: var(--text); }
.app-menu-list   { list-style: none; padding: 12px 8px; flex: 1; overflow-y: auto; }
.app-menu-item   { display: flex; align-items: center; gap: 12px; padding: 12px; border-radius: var(--radius); cursor: pointer; color: var(--text2); font-family: var(--cond); font-size: 16px; font-weight: 600; letter-spacing: 1px; transition: all var(--ease); margin-bottom: 2px; }
.app-menu-item:hover { background: var(--bg2); color: var(--text); }
.app-menu-footer { padding: 16px; border-top: 1px solid var(--border); }
.signout-btn     {
  background: transparent; border: 1px solid var(--border); border-radius: 8px;
  color: var(--text3); font-family: var(--mono); font-size: 9px; letter-spacing: 2px;
  padding: 10px 14px; cursor: pointer; transition: all 0.15s ease; width: 100%;
}
.signout-btn:hover { color: var(--red); border-color: rgba(255,61,87,0.35); background: rgba(255,61,87,0.05); }

/* Views — push content below fixed topbar, scroll naturally */
.app-views { padding-top: var(--topbar-h); }

.app-view { display: none; }
.app-view.active { display: block; }

.view-inner { max-width: 680px; margin: 0 auto; padding: 24px 20px 80px; }

.view-back {
  font-family: var(--mono); font-size: 11px; color: var(--text3);
  letter-spacing: 1px; cursor: pointer; margin-bottom: 24px;
  display: inline-flex; align-items: center; gap: 6px;
  background: var(--bg2); border: 1px solid var(--border);
  border-radius: 20px; padding: 6px 14px;
  transition: all 0.15s ease;
}
.view-back:hover { color: var(--cyan); border-color: rgba(0,212,255,0.3); background: rgba(0,212,255,0.05); }

/* ══════════════════════════════════════
   DASHBOARD
══════════════════════════════════════ */
.dashboard { max-width: 700px; margin: 0 auto; padding: 32px 20px 80px; }
.dash-header  { margin-bottom: 28px; }
.dash-greeting { font-family: var(--cond); font-size: clamp(28px,5vw,40px); font-weight: 700; color: var(--text); letter-spacing: 1px; animation: fadeUp 0.5s ease both; }
.dash-date    { font-family: var(--mono); font-size: 11px; color: var(--text3); letter-spacing: 2px; margin-top: 6px; animation: fadeUp 0.5s 0.1s ease both; }

.dash-clock-block {
  background: var(--bg1); border: 1px solid var(--border); border-radius: var(--radius-lg);
  padding: 16px 24px; margin-bottom: 28px; position: relative; overflow: hidden;
  animation: fadeUp 0.5s 0.15s ease both;
}
.dash-clock-block::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 2px; background: linear-gradient(90deg,var(--cyan),transparent); }
.dash-utc-time  { font-family: var(--mono); font-size: 28px; color: var(--cyan); letter-spacing: 3px; line-height: 1; margin-bottom: 4px; }
.dash-utc-label { font-family: var(--mono); font-size: 9px; letter-spacing: 3px; color: var(--text3); margin-bottom: 2px; }
.dash-utc-date  { font-family: var(--mono); font-size: 11px; color: var(--text2); letter-spacing: 2px; }

.dash-section-label { font-family: var(--mono); font-size: 9px; letter-spacing: 3px; color: var(--text3); margin-bottom: 16px; animation: fadeUp 0.5s 0.2s ease both; }

.dash-grid { display: grid; grid-template-columns: repeat(2,1fr); gap: 12px; max-width: 400px; animation: fadeUp 0.5s 0.25s ease both; }
.dash-tile { background: var(--bg1); border: 1px solid var(--border); border-radius: var(--radius-lg); padding: 20px 16px; cursor: pointer; transition: all var(--ease); display: flex; flex-direction: column; align-items: center; text-align: center; gap: 8px; }
.dash-tile:hover { border-color: var(--cyan); background: var(--cyan-dim); transform: translateY(-2px); box-shadow: 0 8px 24px rgba(0,0,0,0.3); }
.dash-tile-icon { font-size: 26px; }
.dash-tile-name { font-family: var(--cond); font-size: 14px; font-weight: 700; letter-spacing: 1px; color: var(--text); }
.dash-tile-desc  { font-family: var(--mono); font-size: 10px; color: var(--text3); letter-spacing: 0.5px; }
.dash-tile-count { font-family: var(--mono); font-size: 10px; color: var(--cyan); letter-spacing: 1px; }

/* ══════════════════════════════════════
   FORM
══════════════════════════════════════ */
.form-card { background: var(--bg1); border: 1px solid var(--border); border-radius: var(--radius-lg); padding: 24px; margin-bottom: 16px; }
.form-section-label { font-family: var(--mono); font-size: 11px; letter-spacing: 2px; color: var(--text2); margin-bottom: 20px; padding-bottom: 12px; border-bottom: 1px solid var(--border); }
.tem-card { border-color: rgba(0,212,255,0.12); }

.phase-pills { display: flex; flex-wrap: wrap; gap: 8px; }
.phase-pill  { background: var(--bg2); border: 1px solid var(--border); border-radius: 20px; padding: 8px 16px; color: var(--text2); font-family: var(--cond); font-size: 14px; font-weight: 600; letter-spacing: 1px; cursor: pointer; transition: all var(--ease); }
.phase-pill:hover    { border-color: var(--cyan); color: var(--cyan); }
.phase-pill.selected { background: var(--cyan-dim); border-color: var(--cyan); color: var(--cyan); }

.reportable-toggle { display: flex; align-items: center; gap: 14px; background: var(--bg2); border: 1px solid var(--border); border-radius: var(--radius); padding: 14px 16px; cursor: pointer; transition: border-color var(--ease); user-select: none; margin-top: 4px; }
.reportable-toggle.on { border-color: var(--amber); background: var(--amber-dim); }
.toggle-track { width: 38px; height: 22px; background: var(--border2); border-radius: 11px; position: relative; flex-shrink: 0; transition: background var(--ease); }
.reportable-toggle.on .toggle-track { background: var(--amber); }
.toggle-thumb { width: 16px; height: 16px; background: var(--text2); border-radius: 50%; position: absolute; top: 3px; left: 3px; transition: all var(--ease); }
.reportable-toggle.on .toggle-thumb { left: 19px; background: var(--bg); }
.toggle-title { font-family: var(--mono); font-size: 10px; letter-spacing: 2px; color: var(--text2); display: block; }
.reportable-toggle.on .toggle-title { color: var(--amber); }
.toggle-sub   { font-size: 12px; color: var(--text3); display: block; margin-top: 2px; }

.form-actions { display: flex; gap: 12px; justify-content: flex-end; margin-top: 4px; }
.save-toast   { text-align: center; font-family: var(--mono); font-size: 12px; color: var(--green); letter-spacing: 1px; margin-top: 14px; opacity: 0; transition: opacity 0.3s ease; }
.save-toast.show { opacity: 1; }

/* ══════════════════════════════════════
   LOG REVIEW
══════════════════════════════════════ */
.log-toolbar { display: flex; align-items: center; justify-content: space-between; margin-bottom: 20px; }
.log-stats   { font-family: var(--mono); font-size: 13px; color: var(--text3); letter-spacing: 1px; }
.log-empty   { display: none; text-align: center; padding: 60px 20px; }
.log-empty.show { display: block; }
.empty-icon  { font-size: 40px; color: var(--text3); margin-bottom: 16px; }
.empty-text  { color: var(--text3); line-height: 1.7; margin-bottom: 24px; }
.loading-state { display: flex; justify-content: center; padding: 40px; }
.loading-dots { display: flex; gap: 6px; }
.loading-dots span { width: 7px; height: 7px; border-radius: 50%; background: var(--cyan); animation: dot 1.2s infinite ease-in-out; }
.loading-dots span:nth-child(2) { animation-delay: 0.2s; }
.loading-dots span:nth-child(3) { animation-delay: 0.4s; }
@keyframes dot { 0%,80%,100% { transform:scale(0.5);opacity:0.4; } 40% { transform:scale(1);opacity:1; } }

.log-list { display: flex; flex-direction: column; gap: 10px; }
.log-entry { background: var(--bg1); border: 1px solid var(--border); border-radius: var(--radius-lg); padding: 16px 20px; cursor: pointer; transition: all var(--ease); animation: slideIn 0.2s ease; }
@keyframes slideIn { from { opacity:0;transform:translateY(6px); } to { opacity:1;transform:none; } }
.log-entry:hover { border-color: var(--border2); background: var(--bg2); }
.log-entry.reportable { border-left: 3px solid var(--amber); }
.entry-top    { display: flex; align-items: center; justify-content: space-between; margin-bottom: 10px; }
.entry-flight { display: flex; align-items: center; gap: 12px; }
.entry-num    { font-family: var(--mono); font-size: 16px; color: var(--cyan); letter-spacing: 1px; }
.entry-sector { font-family: var(--cond); font-size: 15px; font-weight: 600; color: var(--text); letter-spacing: 2px; }
.entry-date   { font-family: var(--mono); font-size: 12px; color: var(--text3); letter-spacing: 1px; }
.entry-meta   { display: flex; align-items: center; gap: 14px; flex-wrap: wrap; }
.entry-tag    { font-family: var(--mono); font-size: 10px; color: var(--text3); }
.entry-phase  { font-family: var(--cond); font-size: 11px; font-weight: 600; letter-spacing: 1px; color: var(--text2); background: var(--bg3); padding: 2px 8px; border-radius: 3px; }
.entry-reportable-badge { font-family: var(--mono); font-size: 9px; letter-spacing: 1px; color: var(--amber); background: var(--amber-dim); border: 1px solid rgba(255,171,0,0.2); padding: 2px 7px; border-radius: 3px; }
.entry-preview { font-size: 13px; color: var(--text2); line-height: 1.5; margin-top: 10px; padding-top: 10px; border-top: 1px solid var(--border); overflow: hidden; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; }

/* ══════════════════════════════════════
   MODALS
══════════════════════════════════════ */
.modal-overlay { display: none; position: fixed; inset: 0; background: rgba(0,0,0,0.75); z-index: 200; align-items: center; justify-content: center; padding: 20px; backdrop-filter: blur(4px); }
.modal-overlay.open { display: flex; }
.modal { background: var(--bg1); border: 1px solid var(--border2); border-radius: var(--radius-lg); width: 100%; max-width: 600px; max-height: 85vh; display: flex; flex-direction: column; animation: modalIn 0.2s ease; }
@keyframes modalIn { from { opacity:0;transform:scale(0.97) translateY(10px); } to { opacity:1;transform:none; } }
.modal-sm { max-width: 360px; padding: 28px; }
.modal-header { display: flex; align-items: center; justify-content: space-between; padding: 16px 20px; border-bottom: 1px solid var(--border); flex-shrink: 0; }
.modal-flight-id { font-family: var(--mono); font-size: 14px; color: var(--cyan); letter-spacing: 2px; }
.modal-header-actions { display: flex; align-items: center; gap: 8px; }
.modal-close { background: none; border: none; color: var(--text3); font-size: 16px; cursor: pointer; padding: 4px 8px; transition: color var(--ease); margin-left: 4px; }
.modal-close:hover { color: var(--text); }
.modal-body { overflow-y: auto; padding: 20px; flex: 1; }
.detail-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; margin-bottom: 20px; }
.detail-field { display: flex; flex-direction: column; gap: 4px; }
.detail-label { font-family: var(--mono); font-size: 9px; letter-spacing: 2px; color: var(--text3); }
.detail-value { font-size: 14px; color: var(--text); font-weight: 500; }
.detail-value.mono { font-family: var(--mono); color: var(--cyan); letter-spacing: 1px; }
.reportable-banner { font-family: var(--mono); font-size: 10px; letter-spacing: 2px; color: var(--amber); background: var(--amber-dim); border: 1px solid rgba(255,171,0,0.25); border-radius: var(--radius); padding: 10px 14px; margin-bottom: 14px; }
.detail-section { margin-top: 18px; padding-top: 18px; border-top: 1px solid var(--border); }
.detail-section-label { font-family: var(--mono); font-size: 9px; letter-spacing: 2px; color: var(--text3); margin-bottom: 10px; }
.detail-text { font-size: 14px; color: var(--text2); line-height: 1.7; white-space: pre-wrap; }
.delete-confirm-text { color: var(--text2); line-height: 1.6; margin-bottom: 20px; font-size: 14px; }
.delete-actions { display: flex; gap: 10px; justify-content: flex-end; }

/* ══════════════════════════════════════
   CAREER
══════════════════════════════════════ */
.career-save-indicator { font-family: var(--mono); font-size: 11px; color: var(--green); letter-spacing: 1px; text-align: right; margin-bottom: 8px; opacity: 0; transition: opacity 0.3s ease; }
.career-save-indicator.show { opacity: 1; }
.career-card { background: var(--bg1); border: 1px solid var(--border); border-radius: var(--radius-lg); padding: 24px; margin-bottom: 16px; }
.career-card-title { font-family: var(--mono); font-size: 11px; letter-spacing: 2px; color: var(--text2); margin-bottom: 20px; padding-bottom: 12px; border-bottom: 1px solid var(--border); }
.sub-section-label { font-family: var(--mono); font-size: 9px; letter-spacing: 2px; color: var(--text3); margin: 18px 0 10px; }
.hours-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 14px; margin-bottom: 8px; }
.hours-cell { display: flex; flex-direction: column; gap: 6px; }
.hours-input { font-family: var(--mono); font-size: 20px; font-weight: 500; text-align: right; }
.type-row { display: grid; grid-template-columns: 1fr 80px 80px 80px 32px; gap: 8px; align-items: center; margin-bottom: 8px; }
.type-name-input  { font-family: var(--mono); font-size: 13px; }
.hours-input-sm   { font-family: var(--mono); font-size: 13px; text-align: right; padding: 8px; }
.type-row-hours   { display: flex; gap: 8px; flex-shrink: 0; }
.type-row-hours > div { display: flex; flex-direction: column; gap: 4px; }
.exp-summary-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 2px; background: var(--border); border-radius: var(--radius); overflow: hidden; margin-bottom: 16px; }
.exp-summary-cell { background: var(--bg2); padding: 20px 16px; text-align: center; }
.exp-summary-value { font-family: var(--mono); font-size: clamp(28px,5vw,42px); color: var(--cyan); line-height: 1; margin-bottom: 8px; }
.exp-summary-label { font-family: var(--mono); font-size: 9px; letter-spacing: 2px; color: var(--text3); }
.exp-breakdown-toggle { background: none; border: none; color: var(--text3); font-family: var(--mono); font-size: 10px; letter-spacing: 1px; cursor: pointer; padding: 4px 0; transition: color var(--ease); }
.exp-breakdown-toggle:hover { color: var(--cyan); }
.exp-breakdown-panel { max-height: 0; overflow: hidden; transition: max-height 0.35s ease; }
.exp-breakdown-panel.open { max-height: 1000px; }
.expiry-list { display: flex; flex-direction: column; gap: 10px; }
.expiry-row { display: flex; align-items: center; justify-content: space-between; gap: 14px; padding: 12px 14px; background: var(--bg2); border: 1px solid var(--border); border-radius: var(--radius); }
.expiry-info { display: flex; align-items: center; gap: 10px; flex: 1; min-width: 0; }
.expiry-name { font-size: 14px; color: var(--text); font-weight: 500; white-space: nowrap; }
.expiry-input-wrap { display: flex; align-items: center; gap: 10px; flex-shrink: 0; }
.expiry-date-input { width: 150px; font-family: var(--mono); font-size: 12px; padding: 7px 10px; }
.expiry-date-display { font-family: var(--mono); font-size: 11px; color: var(--text3); white-space: nowrap; }
.expiry-badge { font-family: var(--mono); font-size: 11px; letter-spacing: 1px; padding: 3px 8px; border-radius: 3px; white-space: nowrap; flex-shrink: 0; }
.expiry-badge.green   { color: var(--green); background: rgba(0,230,118,0.08); border: 1px solid rgba(0,230,118,0.2); }
.expiry-badge.amber   { color: var(--amber); background: var(--amber-dim); border: 1px solid rgba(255,171,0,0.25); }
.expiry-badge.red,
.expiry-badge.expired { color: var(--red); background: var(--red-dim); border: 1px solid rgba(255,61,87,0.25); }
.atpl-row { background: var(--bg2); border: 1px solid var(--border); border-radius: var(--radius); padding: 14px; margin-bottom: 10px; }
.atpl-row-top { display: flex; gap: 10px; align-items: center; margin-bottom: 12px; }
.atpl-subject-input { flex: 1; font-size: 14px; font-weight: 500; }
.atpl-row-bottom { display: flex; gap: 14px; align-items: flex-end; flex-wrap: wrap; }
.atpl-date-wrap { display: flex; flex-direction: column; gap: 5px; }
.atpl-select { width: 70px; font-family: var(--mono); font-size: 12px; padding: 8px; }
.atpl-year-input { width: 90px; font-family: var(--mono); font-size: 12px; }
.atpl-viva-wrap { display: flex; flex-direction: column; gap: 5px; }
.viva-toggle { display: flex; align-items: center; gap: 8px; cursor: pointer; user-select: none; }
.viva-label  { font-family: var(--mono); font-size: 11px; color: var(--text2); }
.viva-toggle.on .viva-label  { color: var(--green); }
.viva-toggle.on .toggle-track { background: var(--green); }
.viva-toggle.on .toggle-thumb { left: 19px; background: var(--bg); }
.atpl-expiry-wrap { display: flex; flex-direction: column; gap: 4px; margin-left: auto; align-items: flex-end; }
.atpl-validity { font-family: var(--mono); font-size: 10px; color: var(--text3); letter-spacing: 0.5px; }
.cpl-note { font-family: var(--mono); font-size: 10px; color: var(--green); letter-spacing: 0.5px; align-self: flex-end; padding-bottom: 8px; }
.custom-label-input { flex: 1; font-size: 13px; min-width: 160px; }
.remove-btn { background: none; border: none; color: var(--text3); font-size: 13px; cursor: pointer; padding: 4px 6px; border-radius: 3px; transition: all var(--ease); flex-shrink: 0; }
.remove-btn:hover { color: var(--red); background: var(--red-dim); }
.empty-hint { font-family: var(--mono); font-size: 11px; color: var(--text3); letter-spacing: 0.5px; padding: 10px 0; line-height: 1.6; }
.atpl-warning-banner { display: flex; align-items: flex-start; gap: 14px; background: rgba(255,61,87,0.08); border: 1px solid rgba(255,61,87,0.3); border-radius: var(--radius-lg); padding: 16px 20px; margin-bottom: 20px; }
.atpl-warning-icon  { font-size: 20px; flex-shrink: 0; }
.atpl-warning-title { font-family: var(--mono); font-size: 10px; letter-spacing: 2px; color: var(--red); margin-bottom: 6px; }
.atpl-warning-item  { font-family: var(--mono); font-size: 11px; color: rgba(255,61,87,0.8); letter-spacing: 0.5px; margin-top: 3px; }
.career-export-row  { display: flex; justify-content: flex-end; margin-top: 8px; padding-bottom: 20px; }
.exam-type-toggle { display: flex; background: var(--bg3); border-radius: var(--radius); padding: 3px; flex-shrink: 0; }
.exam-type-btn { background: transparent; border: none; color: var(--text3); font-family: var(--mono); font-size: 10px; font-weight: 700; letter-spacing: 1px; padding: 5px 12px; border-radius: 3px; cursor: pointer; transition: all var(--ease); }
.exam-type-btn.active { background: var(--cyan); color: var(--bg); }

/* ══════════════════════════════════════
   ANIMATIONS
══════════════════════════════════════ */
@keyframes fadeUp { from { opacity:0;transform:translateY(16px); } to { opacity:1;transform:none; } }

/* ══════════════════════════════════════
   MOBILE
══════════════════════════════════════ */

  .hero { flex-direction: column; padding: 90px 20px 40px; gap: 40px; }
  .hero-visual { display: none; }
  .features { padding: 60px 20px; }
  .features-grid { grid-template-columns: 1fr; }
  .cta-section { padding: 60px 20px; }
  .mkt-footer { flex-direction: column; gap: 12px; text-align: center; padding: 24px 20px; }
  .dash-grid { grid-template-columns: repeat(2,1fr); max-width: 100%; }
  .field-row { flex-direction: column; gap: 0; }
  .field-row .field { margin-bottom: 16px; }
  .sector-arrow { display: none; }
  .detail-grid { grid-template-columns: 1fr; }
  .expiry-row { flex-direction: column; align-items: flex-start; }
  .expiry-date-input { width: 100%; }
  .atpl-row-bottom { gap: 10px; }
  .atpl-expiry-wrap { margin-left: 0; align-items: flex-start; }
  .hours-grid { grid-template-columns: 1fr; }
  .type-row { grid-template-columns: 1fr; }
  .type-row-hours { flex-wrap: wrap; }
}

/* ══════════════════════════════════════
   DASHBOARD — Quote + Tool Pills
══════════════════════════════════════ */
.dash-quote {
  margin-top: 10px;
  font-family: var(--sans);
  font-style: italic;
  font-size: 13px;
  color: var(--text3);
  line-height: 1.6;
  max-width: 520px;
}
.quote-text   { display: block; margin-bottom: 4px; }
.quote-author { display: block; font-family: var(--mono); font-size: 10px; font-style: normal; color: var(--text3); letter-spacing: 1px; }

/* Tool pills — horizontal row */
.dash-tools {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  animation: fadeUp 0.5s 0.25s ease both;
}

.dash-tool {
  display: flex;
  align-items: center;
  gap: 10px;
  background: var(--bg1);
  border: 1px solid var(--border);
  border-radius: 40px;
  padding: 12px 20px;
  cursor: pointer;
  transition: all var(--ease);
  text-decoration: none;
}

.dash-tool:hover {
  border-color: var(--cyan);
  background: var(--cyan-dim);
  transform: translateY(-1px);
  box-shadow: 0 4px 16px rgba(0,0,0,0.3);
}

.dash-tool-icon { font-size: 20px; }

.dash-tool-name {
  font-family: var(--cond);
  font-size: 16px;
  font-weight: 700;
  letter-spacing: 1px;
  color: var(--text);
  white-space: nowrap;
}

/* ══════════════════════════════════════
   CAREER PAGE
══════════════════════════════════════ */
.career-toprow {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 20px;
}

.career-top-actions {
  display: flex;
  align-items: center;
  gap: 12px;
}

/* Experience block */
.career-exp-block {
  background: var(--bg1);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  overflow: hidden;
  margin-bottom: 20px;
}

.exp-total-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 24px;
  cursor: pointer;
  transition: background var(--ease);
}

.exp-total-row:hover { background: var(--bg2); }

.exp-total-value {
  font-family: var(--mono);
  font-size: clamp(36px, 6vw, 52px);
  color: var(--cyan);
  line-height: 1;
  margin-bottom: 4px;
}

.exp-total-label {
  font-family: var(--mono);
  font-size: 9px;
  letter-spacing: 3px;
  color: var(--text3);
}

.exp-total-chevron {
  font-size: 14px;
  color: var(--text3);
  transition: transform var(--ease);
}

/* Breakdown panel */
.exp-breakdown {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.35s ease;
  border-top: 0px solid var(--border);
}

.exp-breakdown.open {
  max-height: 800px;
  border-top: 1px solid var(--border);
}

.exp-breakdown-inner { padding: 20px 24px 24px; }

.exp-edit-row { margin-bottom: 16px; }
.exp-edit-field { max-width: 200px; }

.exp-types-label {
  font-family: var(--mono);
  font-size: 9px;
  letter-spacing: 2px;
  color: var(--text3);
  margin-bottom: 12px;
  display: flex;
  align-items: center;
  gap: 12px;
}

.exp-type-row {
  display: flex;
  align-items: flex-end;
  gap: 10px;
  margin-bottom: 10px;
  padding: 12px;
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: var(--radius);
}

.exp-type-row > .field-input { flex: 1; }

.exp-type-sub {
  display: flex;
  gap: 8px;
  flex-shrink: 0;
}

.exp-type-sub > div {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.exp-type-sub .field-input { width: 80px; }

/* Records section */
.career-records-section { margin-top: 8px; }

.career-records-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 14px;
}

.career-section-label {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 2px;
  color: var(--text2);
}

.career-empty {
  text-align: center;
  padding: 48px 20px;
  background: var(--bg1);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
}

.career-record-list {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

/* Record card */
.career-record-card {
  background: var(--bg1);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 16px 18px;
  transition: border-color var(--ease);
}

.career-record-card:hover { border-color: var(--border2); }
.career-record-card.red,
.career-record-card.expired { border-left: 3px solid var(--red); }
.career-record-card.amber   { border-left: 3px solid var(--amber); }
.career-record-card.green   { border-left: 3px solid var(--green); }
.career-record-card.lifetime { border-left: 3px solid var(--cyan); }

.record-card-top {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 10px;
}

.record-card-title {
  font-size: 16px;
  font-weight: 600;
  color: var(--text);
  margin-bottom: 3px;
}

.record-card-sub {
  font-family: var(--mono);
  font-size: 12px;
  color: var(--text3);
  letter-spacing: 0.5px;
}

.record-card-right {
  text-align: right;
  flex-shrink: 0;
}

.record-expiry-date {
  font-family: var(--mono);
  font-size: 11px;
  color: var(--text3);
  margin-top: 4px;
  letter-spacing: 0.5px;
}

.record-card-details { margin-bottom: 10px; }

.record-limitation {
  font-family: var(--mono);
  font-size: 11px;
  color: var(--amber);
  background: var(--amber-dim);
  border: 1px solid rgba(255,171,0,0.2);
  border-radius: var(--radius);
  padding: 6px 10px;
  display: inline-block;
}

.record-notes {
  font-size: 13px;
  color: var(--text3);
  line-height: 1.5;
}

.record-note {
  font-family: var(--mono);
  font-size: 10px;
  color: var(--text3);
}

.record-endorsements {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.endorsement-pill {
  font-family: var(--mono);
  font-size: 10px;
  background: var(--bg3);
  border: 1px solid var(--border);
  border-radius: 20px;
  padding: 3px 10px;
  color: var(--text2);
  letter-spacing: 0.5px;
}

.endorsement-role {
  color: var(--cyan);
  margin-left: 4px;
}

.record-card-actions {
  display: flex;
  gap: 8px;
  padding-top: 10px;
  border-top: 1px solid var(--border);
}

.record-action-btn {
  background: none;
  border: none;
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 2px;
  color: var(--text3);
  cursor: pointer;
  padding: 2px 0;
  transition: color var(--ease);
}

.record-action-btn:hover { color: var(--cyan); }
.record-action-delete:hover { color: var(--red) !important; }

/* ══════════════════════════════════════
   CAREER MODAL
══════════════════════════════════════ */
.career-modal-overlay {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.75);
  z-index: 200;
  align-items: flex-end;
  justify-content: center;
  backdrop-filter: blur(4px);
  padding: 0;
}

.career-modal-overlay.open { display: flex; }

.career-modal {
  background: var(--bg1);
  border: 1px solid var(--border2);
  border-radius: 16px 16px 0 0;
  width: 100%;
  max-width: 560px;
  max-height: 90vh;
  overflow-y: auto;
  animation: slideUp 0.25s ease;
}

@keyframes slideUp {
  from { transform: translateY(40px); opacity: 0; }
  to   { transform: none; opacity: 1; }
}

.career-modal-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 18px 20px 14px;
  border-bottom: 1px solid var(--border);
  position: sticky;
  top: 0;
  background: var(--bg1);
  z-index: 1;
}

.career-modal-title {
  font-family: var(--mono);
  font-size: 13px;
  letter-spacing: 3px;
  color: var(--text2);
}

.career-modal-form {
  padding: 20px;
}

.career-modal-actions {
  display: flex;
  gap: 10px;
  justify-content: flex-end;
  margin-top: 20px;
  padding-top: 16px;
  border-top: 1px solid var(--border);
}

/* Record type selector grid */
.record-type-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 10px;
  padding: 20px;
}

.record-type-btn {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 20px 12px;
  cursor: pointer;
  transition: all var(--ease);
  font-family: var(--cond);
  font-size: 15px;
  font-weight: 600;
  letter-spacing: 1px;
  color: var(--text2);
}

.record-type-btn:hover {
  border-color: var(--cyan);
  color: var(--cyan);
  background: var(--cyan-dim);
}

.record-type-icon { font-size: 24px; }

/* Toggle pills */
.toggle-pills {
  display: flex;
  gap: 0;
  background: var(--bg3);
  border-radius: var(--radius);
  padding: 3px;
  width: fit-content;
  margin-bottom: 8px;
}

.toggle-pill {
  background: transparent;
  border: none;
  color: var(--text3);
  font-family: var(--mono);
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 1px;
  padding: 6px 16px;
  border-radius: 3px;
  cursor: pointer;
  transition: all var(--ease);
}

.toggle-pill.active {
  background: var(--cyan);
  color: var(--bg);
}

/* Display field (non-editable computed value) */
.field-input-display {
  background: var(--bg3);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 10px 12px;
  color: var(--cyan);
  font-family: var(--mono);
  font-size: 13px;
  letter-spacing: 1px;
}

/* Endorsement rows */
.endorsement-row {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 8px;
}

.endorsement-row .field-input { flex: 1; }

/* Remove button */
.remove-btn {
  background: none; border: none; color: var(--text3); font-size: 13px;
  cursor: pointer; padding: 4px 6px; border-radius: 3px; transition: all var(--ease); flex-shrink: 0;
}
.remove-btn:hover { color: var(--red); background: var(--red-dim); }

/* Empty hint */
.empty-hint { font-family: var(--mono); font-size: 11px; color: var(--text3); letter-spacing: 0.5px; padding: 8px 0; line-height: 1.6; }

/* Save indicator */
.career-save-indicator { font-family: var(--mono); font-size: 10px; color: var(--green); letter-spacing: 1px; opacity: 0; transition: opacity 0.3s ease; }
.career-save-indicator.show { opacity: 1; }

/* Expiry badges */
.expiry-badge { font-family: var(--mono); font-size: 11px; letter-spacing: 1px; padding: 3px 8px; border-radius: 3px; white-space: nowrap; display: inline-block; }
.expiry-badge.green    { color: var(--green); background: rgba(0,230,118,0.08); border: 1px solid rgba(0,230,118,0.2); }
.expiry-badge.amber    { color: var(--amber); background: var(--amber-dim); border: 1px solid rgba(255,171,0,0.25); }
.expiry-badge.red,
.expiry-badge.expired  { color: var(--red); background: var(--red-dim); border: 1px solid rgba(255,61,87,0.25); }
.expiry-badge.lifetime { color: var(--cyan); background: var(--cyan-dim); border: 1px solid rgba(0,212,255,0.2); }


  .career-modal { border-radius: var(--radius-lg) var(--radius-lg) 0 0; }
  .exp-type-row { flex-wrap: wrap; }
  .exp-type-sub .field-input { width: 70px; }
  .dash-tools { gap: 8px; }
  .career-toprow { flex-direction: column; align-items: flex-start; gap: 10px; }
}

/* ══════════════════════════════════════
   AIRPORT BRIEFING
══════════════════════════════════════ */

/* Search */
.airport-search-wrap {
  display: flex;
  gap: 10px;
  align-items: center;
  margin-bottom: 24px;
}

.airport-search-box {
  flex: 1;
  display: flex;
  align-items: center;
  gap: 10px;
  background: var(--bg1);
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 11px 16px;
  transition: border-color 0.15s ease;
}

.airport-search-box:focus-within { border-color: var(--cyan); box-shadow: 0 0 0 3px rgba(0,212,255,0.06); }
.airport-search-icon { font-size: 15px; opacity: 0.6; }

.airport-search-input {
  flex: 1;
  background: none;
  border: none;
  outline: none;
  color: var(--text);
  font-family: var(--mono);
  font-size: 16px;
  letter-spacing: 3px;
  text-transform: uppercase;
}

.airport-search-input::placeholder {
  color: var(--text3);
  font-size: 13px;
  letter-spacing: 1px;
  text-transform: none;
  font-family: var(--sans);
}

/* Search results */
.airport-result-row {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 14px 16px;
  background: var(--bg1);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  margin-bottom: 6px;
  cursor: pointer;
  transition: all var(--ease);
}

.airport-result-row:hover { border-color: var(--cyan); background: var(--cyan-dim); }
.airport-result-icao { font-family: var(--mono); font-size: 18px; color: var(--cyan); letter-spacing: 2px; font-weight: 600; }
.airport-result-iata { font-family: var(--mono); font-size: 11px; color: var(--text3); letter-spacing: 1px; background: var(--bg3); border: 1px solid var(--border); border-radius: 4px; padding: 2px 6px; flex-shrink: 0; }
.airport-result-name { flex: 1; color: var(--text2); font-size: 14px; }
.airport-result-sub  { color: var(--text3); font-size: 12px; }
.airport-result-arrow { color: var(--text3); font-size: 14px; }

.airport-no-results {
  padding: 28px 16px;
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
}
.no-results-icon {
  font-size: 32px;
  margin-bottom: 4px;
  opacity: 0.6;
}
.no-results-title {
  font-family: var(--mono);
  font-size: 13px;
  color: var(--text);
  margin: 0;
}
.no-results-hint {
  font-family: var(--mono);
  font-size: 11px;
  color: var(--text3);
  line-height: 1.6;
  margin: 0;
  max-width: 300px;
}
.no-results-add-btn {
  margin-top: 8px;
  font-size: 12px;
  letter-spacing: 1px;
}

/* Section label */
.airport-section-label {
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 3px;
  color: var(--text3);
  margin-bottom: 14px;
}

/* Recent cards */
.airport-recent-list {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-bottom: 24px;
}

.airport-recent-card {
  display: flex;
  align-items: center;
  gap: 14px;
  background: var(--bg1);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 14px 18px;
  cursor: pointer;
  transition: all var(--ease);
}

.airport-recent-card:hover { border-color: var(--cyan); background: var(--cyan-dim); }
.airport-recent-icao { font-family: var(--mono); font-size: 18px; color: var(--cyan); letter-spacing: 2px; font-weight: 600; min-width: 60px; }
.airport-recent-name { flex: 1; color: var(--text2); font-size: 14px; }
.airport-recent-meta { font-family: var(--mono); font-size: 10px; color: var(--text3); letter-spacing: 0.5px; white-space: nowrap; }

/* Airport page header */
.airport-page-header {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 20px;
  flex-wrap: wrap;
}

/* The ← Airports back button gets special treatment inside airport page */
.airport-page-header .view-back {
  margin-bottom: 0;
  flex-shrink: 0;
}

.airport-page-title {
  flex: 1;
  display: flex;
  align-items: baseline;
  gap: 10px;
  min-width: 0;
}

.airport-page-icao { font-family: var(--mono); font-size: 22px; color: var(--cyan); letter-spacing: 3px; font-weight: 700; }
.airport-page-name { font-size: 13px; color: var(--text2); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }

/* Tabs */
.airport-tabs {
  display: flex;
  gap: 0;
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 3px;
  margin-bottom: 20px;
  width: fit-content;
}

.airport-tab {
  background: transparent;
  border: none;
  color: var(--text3);
  font-family: var(--cond);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 2px;
  padding: 8px 22px;
  border-radius: 8px;
  cursor: pointer;
  transition: all 0.15s ease;
}

.airport-tab.active { background: var(--bg3); color: var(--cyan); box-shadow: 0 1px 4px rgba(0,0,0,0.3); }

/* Briefing field sections */
.briefing-field-section {
  background: var(--bg1);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 20px;
  margin-bottom: 12px;
}

.briefing-field-header {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 14px;
  padding-bottom: 12px;
  border-bottom: 1px solid var(--border);
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 2px;
  color: var(--text2);
}

.briefing-field-icon { font-size: 16px; }

.briefing-empty-field {
  font-family: var(--mono);
  font-size: 11px;
  color: var(--text3);
  padding: 8px 0;
}

/* Tip cards */
.tip-card {
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 14px;
  margin-bottom: 10px;
}

.tip-text {
  font-size: 15px;
  color: var(--text);
  line-height: 1.65;
  margin-bottom: 10px;
  white-space: pre-wrap;
}

.tip-meta {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 10px;
}

.tip-author { font-family: var(--mono); font-size: 11px; color: var(--cyan); letter-spacing: 0.5px; }
.tip-date   { font-family: var(--mono); font-size: 10px; color: var(--text3); }

.tip-actions {
  display: flex;
  align-items: center;
  gap: 10px;
  padding-top: 8px;
  border-top: 1px solid var(--border);
  flex-wrap: wrap;
}

.tip-vote-btn {
  background: var(--bg3);
  border: 1px solid var(--border);
  border-radius: 20px;
  color: var(--text2);
  font-family: var(--mono);
  font-size: 11px;
  padding: 5px 12px;
  cursor: pointer;
  transition: all 0.15s ease;
}

.tip-vote-btn:hover  { border-color: var(--green); color: var(--green); background: rgba(0,230,118,0.05); }
.tip-vote-btn.voted  { background: rgba(0,230,118,0.1); border-color: var(--green); color: var(--green); }
.tip-vote-btn.voted-down { background: var(--red-dim); border-color: var(--red); color: var(--red); }

.tip-flag-btn {
  background: none;
  border: none;
  font-family: var(--mono);
  font-size: 10px;
  color: var(--text3);
  cursor: pointer;
  padding: 4px 6px;
  transition: color var(--ease);
  margin-left: auto;
}

.tip-flag-btn:hover  { color: var(--amber); }
.tip-flag-btn.flagged { color: var(--amber); }

.tip-action-btn {
  background: none;
  border: none;
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 1px;
  color: var(--text3);
  cursor: pointer;
  padding: 4px 6px;
  transition: color var(--ease);
}

.tip-action-btn:hover   { color: var(--cyan); }
.tip-delete-btn:hover   { color: var(--red) !important; }

/* Approaches */
.approach-pills-display {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-bottom: 8px;
}

.approach-pill-display {
  background: var(--cyan-dim);
  border: 1px solid rgba(0,212,255,0.25);
  border-radius: 20px;
  padding: 4px 12px;
  font-family: var(--mono);
  font-size: 11px;
  color: var(--cyan);
  letter-spacing: 0.5px;
}

.approach-picker {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.approach-checkbox { display: flex; align-items: center; cursor: pointer; }
.approach-check-input { display: none; }

.approach-check-label {
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: 20px;
  padding: 6px 14px;
  font-family: var(--mono);
  font-size: 11px;
  color: var(--text2);
  cursor: pointer;
  transition: all var(--ease);
  letter-spacing: 0.5px;
}

.approach-check-input:checked + .approach-check-label {
  background: var(--cyan-dim);
  border-color: var(--cyan);
  color: var(--cyan);
}

/* Contributors */
.contributors-list { display: flex; flex-direction: column; gap: 14px; }

.contributor-card {
  background: var(--bg1);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 16px 18px;
}

.contributor-name {
  font-size: 15px;
  font-weight: 600;
  color: var(--text);
  margin-bottom: 12px;
  padding-bottom: 10px;
  border-bottom: 1px solid var(--border);
}

.contributor-tip-row {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: 8px 0;
  border-bottom: 1px solid var(--border);
  font-size: 13px;
}

.contributor-tip-row:last-child { border-bottom: none; }
.contributor-tip-field   { font-family: var(--mono); font-size: 10px; color: var(--text3); white-space: nowrap; min-width: 120px; }
.contributor-tip-preview { flex: 1; color: var(--text2); }
.contributor-tip-date    { font-family: var(--mono); font-size: 10px; color: var(--text3); white-space: nowrap; }

/* My contributions */
.my-contrib-airport {
  background: var(--bg1);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  margin-bottom: 14px;
  overflow: hidden;
}

.my-contrib-airport-header {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 14px 18px;
  background: var(--bg2);
  cursor: pointer;
  transition: background var(--ease);
  border-bottom: 1px solid var(--border);
}

.my-contrib-airport-header:hover { background: var(--cyan-dim); }

.my-contrib-tip {
  padding: 14px 18px;
  border-bottom: 1px solid var(--border);
}

.my-contrib-tip:last-child { border-bottom: none; }
.my-contrib-tip.contrib-removed { opacity: 0.5; }

.my-contrib-tip-header {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 6px;
  flex-wrap: wrap;
}

.contrib-removed-badge {
  font-family: var(--mono);
  font-size: 9px;
  letter-spacing: 1px;
  color: var(--red);
  background: var(--red-dim);
  border: 1px solid rgba(255,61,87,0.25);
  padding: 2px 6px;
  border-radius: 3px;
}

.my-contrib-actions {
  display: flex;
  gap: 8px;
  margin-top: 8px;
}

.airport-empty {
  text-align: center;
  padding: 48px 20px;
  background: var(--bg1);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
}


  .airport-page-header { gap: 8px; }
  .contributor-tip-row { flex-direction: column; gap: 4px; }
  .contributor-tip-field { min-width: unset; }
}

/* ─── Compact briefing row ─── */
.briefing-compact-row {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 10px;
  margin-bottom: 12px;
}

.briefing-compact-cell {
  background: var(--bg1);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 14px;
}

.briefing-compact-header {
  display: flex;
  align-items: center;
  gap: 6px;
  margin-bottom: 10px;
  padding-bottom: 8px;
  border-bottom: 1px solid var(--border);
}

.briefing-compact-label {
  font-family: var(--mono);
  font-size: 9px;
  letter-spacing: 1.5px;
  color: var(--text2);
}

.briefing-compact-cell .tip-card {
  padding: 10px;
  margin-bottom: 6px;
}

.briefing-compact-cell .tip-text {
  font-size: 13px;
  margin-bottom: 6px;
}

.briefing-compact-cell .tip-meta {
  flex-direction: column;
  gap: 2px;
  margin-bottom: 6px;
}

.briefing-compact-cell .tip-actions {
  flex-wrap: wrap;
  gap: 6px;
}


}

/* ══════════════════════════════════════
   MOBILE OPTIMISATION
   Base: 768px tablets, 480px phones
══════════════════════════════════════ */

/* ── Tablet ── */
@media (max-width: 768px) {

  /* Marketing */
  .mkt-nav { padding: 0 16px; }
  .hero { flex-direction: column; padding: 80px 20px 48px; gap: 40px; min-height: auto; }
  .hero-visual { width: 100%; max-width: 400px; height: 280px; margin: 0 auto; }
  .hero-content { max-width: 100%; }
  .hero-title { font-size: clamp(44px, 10vw, 68px); }
  .hero-desc { font-size: 16px; max-width: 100%; }
  .hero-actions { align-items: stretch; width: 100%; }
  .btn-hero { width: 100%; justify-content: center; padding: 16px 24px; font-size: 15px; }
  .mkt-stats-bar { gap: 14px; padding: 14px 20px; justify-content: flex-start; }
  .mkt-stat-divider { display: none; }
  .features { padding: 56px 20px; }
  .features-grid { grid-template-columns: 1fr 1fr; gap: 12px; }
  .mkt-how { padding: 56px 20px; }
  .cta-section { padding: 56px 20px; }
  .cta-desc { font-size: 15px; }
  .mkt-footer { flex-direction: column; gap: 8px; text-align: center; padding: 20px; }
  .footer-tagline { display: none; }

  /* App topbar */
  .app-topbar { padding: 0 14px; }
  .app-topbar-title { font-size: 13px; letter-spacing: 2px; }
  .app-utc { font-size: 13px; }

  /* Dashboard */
  .dashboard { padding: 20px 16px 80px; }
  .dash-header { margin-bottom: 20px; }
  .dash-clock-block { padding: 14px 18px; margin-bottom: 20px; }
  .dash-utc-time { font-size: 24px; letter-spacing: 2px; }
  .dash-tools { gap: 8px; }
  .dash-tool { padding: 10px 16px; }
  .dash-tool-name { font-size: 14px; }

  /* Views */
  .view-inner { padding: 20px 14px 80px; }

  /* Forms — stack all field rows */
  .field-row { flex-direction: column; gap: 0; }
  .field-row .field { margin-bottom: 14px; }
  .sector-arrow { display: none; }
  .field-input, .field-textarea { font-size: 16px; padding: 13px 14px; }
  .field-label { font-size: 10px; }

  /* Modals — slide up from bottom */
  .modal-overlay { align-items: flex-end; padding: 0; }
  .modal { border-radius: var(--radius-lg) var(--radius-lg) 0 0; max-height: 92vh; max-width: 100%; }
  .modal-sm { max-width: 100%; border-radius: var(--radius-lg) var(--radius-lg) 0 0; }
  .detail-grid { grid-template-columns: 1fr 1fr; gap: 12px; }

  /* Career modal */
  .career-modal { border-radius: var(--radius-lg) var(--radius-lg) 0 0; max-width: 100%; }
  .career-toprow { flex-direction: column; align-items: flex-start; gap: 10px; }
  .exp-summary-value { font-size: 32px; }
  .exp-type-row { flex-wrap: wrap; }
  .exp-type-sub .field-input { width: 80px; }
  .expiry-row { flex-direction: column; align-items: flex-start; gap: 8px; }
  .expiry-date-input { width: 100%; }
  .atpl-row-bottom { gap: 10px; }
  .atpl-expiry-wrap { margin-left: 0; align-items: flex-start; }
  .record-type-grid { grid-template-columns: repeat(2,1fr); gap: 8px; }
  .record-card-top { flex-direction: column; gap: 8px; align-items: flex-start; }
  .record-card-right { align-self: flex-start; }

  /* Airport briefing */
  .airport-search-wrap { flex-direction: column; gap: 8px; }
  .airport-page-header { flex-wrap: wrap; gap: 8px; }
  .airport-page-icao { font-size: 20px; }
  .briefing-compact-row { grid-template-columns: 1fr; gap: 8px; }
  .contributor-tip-row { flex-direction: column; gap: 3px; }
  .contributor-tip-field { min-width: unset; }

  /* Phase pills — wrap nicely */
  .phase-pills { gap: 6px; }
  .phase-pill { padding: 8px 12px; font-size: 13px; }

  /* Log entry */
  .entry-top { flex-direction: column; align-items: flex-start; gap: 4px; }
  .entry-date { font-size: 11px; }

  /* Menu items */
  .app-menu-item { padding: 14px 12px; font-size: 16px; }
}

/* ── Phone ── */
@media (max-width: 480px) {

  /* Topbar */
  .app-topbar-title { font-size: 12px; letter-spacing: 1.5px; }
  .app-utc { font-size: 12px; letter-spacing: 1px; }
  .app-utc span { display: none; }

  /* Dashboard */
  .dash-greeting { font-size: 26px; }
  .dash-quote { font-size: 12px; }
  .dash-utc-time { font-size: 22px; }
  .dash-tools { flex-direction: column; gap: 8px; }
  .dash-tool { width: 100%; justify-content: flex-start; padding: 14px 18px; border-radius: var(--radius-lg); }
  .dash-tool-icon { font-size: 22px; width: 28px; text-align: center; }
  .dash-tool-name { font-size: 15px; }

  /* Views */
  .view-inner { padding: 16px 12px 80px; }
  .view-back { font-size: 12px; margin-bottom: 16px; }

  /* Form cards */
  .form-card { padding: 16px 14px; }
  .form-section-label { font-size: 10px; letter-spacing: 1.5px; }
  .field-input, .field-textarea { font-size: 16px; padding: 13px 12px; border-radius: var(--radius-lg); }
  .field-label { font-size: 10px; letter-spacing: 1px; }

  /* Larger touch targets for buttons */
  .btn { padding: 13px 22px; font-size: 12px; }
  .btn-sm { padding: 10px 14px; font-size: 11px; }
  .btn-primary { padding: 14px 24px; }

  /* Phase pills full width on tiny screens */
  .phase-pill { padding: 10px 14px; font-size: 14px; }

  /* Detail grid — single column on phone */
  .detail-grid { grid-template-columns: 1fr; }
  .detail-value { font-size: 15px; }

  /* Log entries */
  .log-entry { padding: 14px 14px; }
  .entry-num { font-size: 15px; }
  .entry-sector { font-size: 14px; }

  /* Form actions */
  .form-actions { flex-direction: column-reverse; gap: 8px; }
  .form-actions .btn { width: 100%; justify-content: center; }

  /* Reportable toggle */
  .reportable-toggle { padding: 14px; }
  .toggle-title { font-size: 11px; }

  /* Career */
  .exp-summary-grid { grid-template-columns: repeat(3,1fr); }
  .exp-summary-value { font-size: 24px; }
  .exp-summary-label { font-size: 8px; }
  .career-records-header { flex-direction: row; align-items: center; }
  .record-card-title { font-size: 15px; }
  .record-card-actions { gap: 6px; }
  .hours-grid { grid-template-columns: 1fr; gap: 12px; }
  .toggle-pills { flex-wrap: wrap; }
  .record-type-grid { grid-template-columns: repeat(2,1fr); }
  .record-type-btn { padding: 16px 10px; font-size: 13px; }
  .record-type-icon { font-size: 22px; }
  .approach-picker { gap: 6px; }
  .approach-check-label { padding: 8px 12px; font-size: 12px; }

  /* Airport */
  .airport-search-input { font-size: 18px; }
  .airport-recent-card { padding: 12px 14px; }
  .airport-recent-icao { font-size: 16px; }
  .airport-page-icao { font-size: 20px; }
  .airport-tabs { width: 100%; }
  .airport-tab { flex: 1; text-align: center; }
  .briefing-compact-row { grid-template-columns: 1fr; }
  .briefing-compact-cell { padding: 12px; }
  .tip-card { padding: 12px; }
  .tip-text { font-size: 14px; }
  .tip-vote-btn { padding: 6px 12px; font-size: 12px; }
  .airport-page-header { gap: 6px; }
  .airport-page-header .btn-sm { padding: 10px 16px; font-size: 11px; }

  /* Modals */
  .career-modal-form { padding: 14px; }
  .career-modal-header { padding: 14px 16px 12px; }
  .career-modal-title { font-size: 12px; }
  .modal-body { padding: 14px; }
  .modal-header { padding: 14px 16px; }

  /* Menu */
  .app-menu { width: 100%; right: -100%; }
  .app-menu-item { font-size: 16px; padding: 16px 14px; }

  /* Auth */
  .auth-card { padding: 28px 20px; }

  /* Marketing phone */
  .hero { padding: 76px 16px 40px; }
  .hero-title { font-size: clamp(40px, 11vw, 56px); }
  .hero-desc { font-size: 15px; }
  .hero-visual { display: none; }
  .features-grid { grid-template-columns: 1fr; }
  .feat-card { padding: 18px; }
  .mkt-steps { gap: 0; }
  .mkt-stat-text { font-size: 10px; }
  .cta-title { font-size: clamp(28px, 8vw, 40px); }
  .mkt-nav { padding: 0 14px; }
  .mkt-nav .brand-name { font-size: 12px; letter-spacing: 2px; }
  .section-title { margin-bottom: 28px; }
}

/* ══════════════════════════════════════
   DASHBOARD — Expiry Alerts
══════════════════════════════════════ */
.dash-alerts-block {
  margin-bottom: 28px;
  animation: fadeUp 0.4s 0.1s ease both;
}

.dash-alert-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 12px 16px;
  border-radius: 10px;
  margin-bottom: 8px;
  cursor: pointer;
  transition: opacity 0.15s ease, transform 0.15s ease;
  border: 1px solid transparent;
}

.dash-alert-row:hover { opacity: 0.85; transform: translateX(2px); }

.dash-alert-expired {
  background: rgba(255,61,87,0.08);
  border-color: rgba(255,61,87,0.3);
}
.dash-alert-red {
  background: rgba(255,61,87,0.06);
  border-color: rgba(255,61,87,0.2);
}
.dash-alert-amber {
  background: rgba(255,171,0,0.06);
  border-color: rgba(255,171,0,0.2);
}

.dash-alert-name {
  font-family: var(--cond);
  font-size: 15px;
  font-weight: 600;
  letter-spacing: 0.5px;
}

.dash-alert-expired .dash-alert-name,
.dash-alert-red .dash-alert-name { color: var(--red); }
.dash-alert-amber .dash-alert-name { color: var(--amber); }

.dash-alert-badge {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.5px;
  white-space: nowrap;
  flex-shrink: 0;
}

.dash-alert-expired .dash-alert-badge,
.dash-alert-red .dash-alert-badge { color: var(--red); }
.dash-alert-amber .dash-alert-badge { color: var(--amber); }

/* ══════════════════════════════════════
   WATERMARK
══════════════════════════════════════ */
.dash-watermark {
  margin-top: 48px;
  text-align: center;
  font-family: var(--sans);
  font-size: 11px;
  font-weight: 300;
  font-style: italic;
  color: var(--text3);
  letter-spacing: 0.3px;
  opacity: 0.5;
  user-select: none;
}


.profile-btn {
  display: flex;
  align-items: center;
  gap: 8px;
  background: transparent;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  color: var(--text2);
  font-family: var(--cond);
  font-size: 13px;
  font-weight: 600;
  letter-spacing: 1px;
  padding: 10px 14px;
  cursor: pointer;
  transition: all var(--ease);
  width: 100%;
  margin-bottom: 8px;
  text-align: left;
}

.profile-btn:hover {
  color: var(--cyan);
  border-color: rgba(0,212,255,0.3);
  background: var(--cyan-dim);
}

.profile-save-confirm {
  font-family: var(--mono);
  font-size: 11px;
  color: var(--green);
  letter-spacing: 1px;
  padding: 8px 0;
  text-align: center;
}

.delete-account-btn {
  background: none;
  border: none;
  color: var(--text3);
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 1px;
  cursor: pointer;
  padding: 4px 0;
  transition: color var(--ease);
  width: 100%;
  text-align: left;
}

.delete-account-btn:hover { color: var(--red); }

/* ══════════════════════════════════════
   WORLD TIME
══════════════════════════════════════ */
.worldtime-wrap {
  display: flex;
  flex-direction: column;
  padding-bottom: 80px;
}

.worldtime-header {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 12px 16px;
  background: var(--bg1);
  border-bottom: 1px solid var(--border);
  flex-wrap: wrap;
}

.worldtime-utc-block {
  display: flex;
  align-items: baseline;
  gap: 8px;
  flex-shrink: 0;
}

.worldtime-utc-label {
  font-family: var(--mono);
  font-size: 9px;
  letter-spacing: 3px;
  color: var(--text3);
}

.worldtime-utc-time {
  font-family: var(--mono);
  font-size: 22px;
  color: var(--cyan);
  letter-spacing: 3px;
}

.worldtime-search-wrap {
  flex: 1;
  position: relative;
  min-width: 200px;
}

.worldtime-search {
  width: 100%;
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 10px 14px;
  color: var(--text);
  font-family: var(--sans);
  font-size: 15px;
  outline: none;
  transition: border-color var(--ease);
}

.worldtime-search:focus { border-color: var(--cyan); }
.worldtime-search::placeholder { color: var(--text3); }

/* Globe canvas */
.globe-container {
  width: 100%;
  height: 380px;
  background: transparent;
  position: relative;
  cursor: grab;
  overflow: hidden;
}

.globe-container:active { cursor: grabbing; }

.globe-error {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 100%;
  color: var(--text3);
  font-family: var(--mono);
  font-size: 12px;
  text-align: center;
  line-height: 1.8;
}

/* Tooltip */
.globe-tooltip {
  position: fixed;
  background: var(--bg1);
  border: 1px solid var(--cyan);
  border-radius: var(--radius-lg);
  padding: 10px 14px;
  pointer-events: none;
  z-index: 300;
  min-width: 140px;
  box-shadow: 0 8px 32px rgba(0,0,0,0.5);
  animation: fadeUp 0.15s ease both;
}

.globe-tooltip-city    { font-family: var(--cond); font-size: 16px; font-weight: 700; color: var(--text); letter-spacing: 0.5px; }
.globe-tooltip-country { font-family: var(--mono); font-size: 10px; color: var(--text3); margin-bottom: 6px; }
.globe-tooltip-time    { font-family: var(--mono); font-size: 20px; color: var(--cyan); letter-spacing: 2px; }
.globe-tooltip-offset  { font-family: var(--mono); font-size: 10px; color: var(--text3); margin-bottom: 4px; }
.globe-tooltip-hint    { font-family: var(--mono); font-size: 9px; color: var(--text3); letter-spacing: 1px; border-top: 1px solid var(--border); padding-top: 4px; margin-top: 4px; }

/* Legend */
.worldtime-legend {
  display: flex;
  align-items: center;
  gap: 16px;
  padding: 8px 16px;
  background: var(--bg1);
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
  flex-wrap: wrap;
}

.legend-item { display: flex; align-items: center; gap: 5px; font-family: var(--mono); font-size: 10px; color: var(--text3); }
.legend-dot { width: 8px; height: 8px; border-radius: 50%; display: inline-block; }
.legend-dot.day    { background: #00d4ff; }
.legend-dot.night  { background: #003355; border: 1px solid #006699; }
.legend-dot.pinned { background: #ffaa00; }
.legend-hint { font-family: var(--mono); font-size: 10px; color: var(--text3); margin-left: auto; letter-spacing: 0.5px; }

/* Search results dropdown */
.wt-search-results {
  position: absolute;
  top: calc(100% + 6px);
  left: 0; right: 0;
  background: var(--bg1);
  border: 1px solid var(--border2);
  border-radius: var(--radius-lg);
  z-index: 200;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(0,0,0,0.5);
}

.wt-result-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 10px 14px;
  cursor: pointer;
  border-bottom: 1px solid var(--border);
  transition: background var(--ease);
}

.wt-result-row:last-child { border-bottom: none; }
.wt-result-row:hover { background: var(--bg2); }

.wt-result-left  { display: flex; flex-direction: column; gap: 2px; }
.wt-result-city  { font-size: 14px; font-weight: 600; color: var(--text); }
.wt-result-country { font-family: var(--mono); font-size: 10px; color: var(--text3); }
.wt-result-right { text-align: right; }
.wt-result-time  { font-family: var(--mono); font-size: 14px; color: var(--cyan); display: block; }
.wt-result-offset { font-family: var(--mono); font-size: 10px; color: var(--text3); display: block; }
.wt-no-result { padding: 12px 14px; font-family: var(--mono); font-size: 11px; color: var(--text3); }

/* Pinned zones */
.pinned-zones-header { padding: 16px 16px 8px; }

.pinned-zones {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
  gap: 10px;
  padding: 0 16px 16px;
}

.worldtime-hint {
  grid-column: 1 / -1;
  font-family: var(--mono);
  font-size: 11px;
  color: var(--text3);
  text-align: center;
  padding: 24px 0;
  letter-spacing: 0.5px;
}

/* Timezone cards */
.tz-card {
  background: var(--bg1);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 14px;
  transition: border-color var(--ease);
}

.tz-card.tz-day   { border-left: 3px solid var(--cyan); }
.tz-card.tz-night { border-left: 3px solid #1e3a5f; }

.tz-card-top { display: flex; justify-content: space-between; align-items: flex-start; margin-bottom: 8px; }
.tz-card-city    { font-family: var(--cond); font-size: 15px; font-weight: 700; color: var(--text); }
.tz-card-country { font-family: var(--mono); font-size: 9px; color: var(--text3); letter-spacing: 0.5px; margin-top: 2px; }

.tz-unpin {
  background: none; border: none; color: var(--text3); font-size: 12px;
  cursor: pointer; padding: 2px; transition: color var(--ease); flex-shrink: 0;
}
.tz-unpin:hover { color: var(--red); }

.tz-card-time {
  font-family: var(--mono);
  font-size: 26px;
  color: var(--cyan);
  letter-spacing: 2px;
  margin-bottom: 4px;
  line-height: 1;
}

.tz-card-meta { display: flex; justify-content: space-between; align-items: center; margin-bottom: 6px; }
.tz-card-date   { font-family: var(--mono); font-size: 10px; color: var(--text3); }
.tz-card-offset { font-family: var(--mono); font-size: 10px; color: var(--text2); }

.tz-day-indicator { font-family: var(--mono); font-size: 9px; color: var(--text3); letter-spacing: 1px; }
.tz-card.tz-day .tz-day-indicator { color: var(--amber); }

@media (max-width: 480px) {
  .globe-container { height: 300px; }
  .worldtime-utc-time { font-size: 18px; }
  .pinned-zones { grid-template-columns: 1fr 1fr; }
  .tz-card-time { font-size: 22px; }
  .legend-hint { display: none; }
}

/* ── Edit button in modal ── */
.btn-edit {
  color: var(--cyan);
  border-color: var(--cyan);
}
.btn-edit:hover { background: rgba(0,212,255,0.08); }

/* ── Update button ── */
.update-btn {
  display: none;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  background: var(--cyan);
  border: none;
  border-radius: 50%;
  cursor: pointer;
  flex-shrink: 0;
  position: relative;
}

.update-icon {
  font-size: 14px;
  font-weight: 700;
  color: var(--bg);
  line-height: 1;
}

.update-btn.pulse {
  animation: updatePulse 2s ease-in-out infinite;
}

@keyframes updatePulse {
  0%, 100% { box-shadow: 0 0 0 0 rgba(0, 212, 255, 0.5); }
  50%       { box-shadow: 0 0 0 6px rgba(0, 212, 255, 0); }
}

/* ══════════════════════════════════════
   FLIGHT LOG INSIGHTS
══════════════════════════════════════ */

.log-toolbar-actions {
  display: flex;
  gap: 8px;
  align-items: center;
}

.insights-wrap {
  display: flex;
  flex-direction: column;
  gap: 14px;
  padding: 16px 0 80px;
}

.insights-empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 60px 20px;
  gap: 12px;
}

/* Stats row */
.insights-stats-row {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 10px;
}

.insights-stat {
  background: var(--bg1);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 14px 10px;
  text-align: center;
}

.insights-stat-val {
  font-family: var(--cond);
  font-size: 22px;
  font-weight: 700;
  color: var(--text);
  line-height: 1.1;
  margin-bottom: 4px;
  word-break: break-word;
}

.insights-stat-val.insights-stat-red  { color: var(--red); }
.insights-stat-val.insights-stat-cyan { color: var(--cyan); font-size: 14px; }

.insights-stat-label {
  font-family: var(--mono);
  font-size: 8px;
  color: var(--text3);
  letter-spacing: 1.5px;
}

/* Card */
.insights-card {
  background: var(--bg1);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 16px;
}

.insights-card-title {
  font-family: var(--mono);
  font-size: 9px;
  letter-spacing: 2px;
  color: var(--text3);
  margin-bottom: 14px;
}

/* Reportable split bar */
.insights-split-bar {
  display: flex;
  height: 10px;
  border-radius: 5px;
  overflow: hidden;
  background: var(--bg2);
  margin-bottom: 10px;
}

.insights-split-seg { height: 100%; transition: width 0.4s ease; }
.insights-split-red   { background: var(--red); }
.insights-split-green { background: var(--green); }

.insights-split-legend {
  display: flex;
  gap: 16px;
  flex-wrap: wrap;
  font-family: var(--mono);
  font-size: 10px;
  color: var(--text2);
}

/* Legend dot */
.insights-legend-dot {
  display: inline-block;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  margin-right: 4px;
  vertical-align: middle;
}

/* Phase donut */
.insights-phase-wrap {
  display: flex;
  align-items: center;
  gap: 16px;
}

.insights-donut {
  flex-shrink: 0;
  width: 130px;
}

.insights-phase-legend {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.insights-legend-row {
  display: flex;
  align-items: center;
  gap: 6px;
  font-family: var(--mono);
  font-size: 10px;
}

.insights-legend-phase {
  flex: 1;
  color: var(--text2);
}

.insights-legend-count {
  color: var(--text);
  font-weight: 600;
  min-width: 20px;
  text-align: right;
}

.insights-legend-pct {
  color: var(--text3);
  min-width: 32px;
  text-align: right;
}

/* Bar chart */
.insights-bar-wrap {
  margin-bottom: 10px;
}

.insights-bar-legend {
  display: flex;
  gap: 16px;
  font-family: var(--mono);
  font-size: 10px;
  color: var(--text2);
}

/* Top routes */
.insights-route-row {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 10px;
}

.insights-route-rank {
  font-family: var(--mono);
  font-size: 10px;
  color: var(--text3);
  width: 14px;
  flex-shrink: 0;
}

.insights-route-name {
  font-family: var(--mono);
  font-size: 12px;
  color: var(--cyan);
  width: 90px;
  flex-shrink: 0;
}

.insights-route-bar-wrap {
  flex: 1;
  height: 6px;
  background: var(--bg2);
  border-radius: 3px;
  overflow: hidden;
}

.insights-route-bar {
  height: 100%;
  background: var(--cyan);
  opacity: 0.4;
  border-radius: 3px;
  transition: width 0.4s ease;
}

.insights-route-count {
  font-family: var(--mono);
  font-size: 11px;
  color: var(--text2);
  width: 20px;
  text-align: right;
  flex-shrink: 0;
}

/* Word chips */
.insights-words-wrap {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.insights-word-chip {
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: 20px;
  padding: 5px 12px;
  font-family: var(--mono);
  font-size: 11px;
  color: var(--text2);
  display: flex;
  align-items: center;
  gap: 6px;
}

.insights-word-count {
  color: var(--cyan);
  font-size: 10px;
}

@media (max-width: 480px) {
  .insights-stat-val { font-size: 18px; }
  .insights-stat-val.insights-stat-cyan { font-size: 12px; }
  .insights-donut { width: 110px; }
  .insights-legend-row { font-size: 9px; }
}

/* ══════════════════════════════════════
   MARKETING PAGE REDESIGN
══════════════════════════════════════ */

/* ── Hero phone mockup ── */
.hv-phone {
  width: 200px;
  background: #0c0f1a;
  border-radius: 32px;
  border: 1.5px solid rgba(0,212,255,0.2);
  box-shadow: 0 32px 80px rgba(0,0,0,0.6), 0 0 0 5px rgba(0,212,255,0.03);
  overflow: hidden;
  flex-shrink: 0;
}
.hv-phone-bar {
  display: flex; align-items: center; justify-content: space-between;
  padding: 8px 12px; background: #0c0f1a;
  border-bottom: 1px solid #1e2540;
}
.hv-phone-brand { font-family: var(--cond); font-size: 8px; font-weight:700; letter-spacing:2px; color:#dde4f0; }
.hv-phone-utc   { font-family: var(--mono); font-size: 8px; color: #00d4ff; letter-spacing:1px; }
.hv-phone-body  { padding: 10px 12px; }
.hv-phone-greeting { font-family: var(--cond); font-size: 13px; font-weight:700; color:#dde4f0; margin-bottom:8px; }
.hv-phone-clock {
  background: #07090f; border: 1px solid #1e2540; border-radius:6px;
  padding: 8px 10px; margin-bottom:8px; position:relative; overflow:hidden;
}
.hv-phone-clock::before { content:''; position:absolute; top:0; left:0; right:0; height:1.5px; background:linear-gradient(90deg,#00d4ff,transparent); }
.hv-phone-time  { font-family: var(--mono); font-size: 16px; color:#00d4ff; letter-spacing:2px; line-height:1; margin-bottom:2px; }
.hv-phone-tz    { font-family: var(--mono); font-size: 6px; letter-spacing:2px; color:#3a4560; }
.hv-phone-alert {
  display:flex; align-items:center; justify-content:space-between;
  background:rgba(255,171,0,0.06); border:1px solid rgba(255,171,0,0.2);
  border-radius:5px; padding:5px 8px; margin-bottom:8px;
}
.hv-alert-name  { font-family:var(--cond); font-size:9px; font-weight:600; color:#ffab00; }
.hv-alert-badge { font-family:var(--mono); font-size:7px; color:#ffab00; }
.hv-phone-tools-label { font-family:var(--mono); font-size:7px; letter-spacing:2px; color:#3a4560; margin-bottom:6px; }
.hv-phone-tools { display:grid; grid-template-columns:1fr 1fr; gap:5px; }
.hv-tool {
  display:flex; align-items:center; gap:5px;
  background:#0c0f1a; border:1px solid #1e2540; border-radius:20px;
  padding:5px 8px; font-family:var(--cond); font-size:8px; font-weight:600;
  color:#dde4f0; letter-spacing:0.5px;
}
/* Keep original hv-card-1 and hv-card-3 floating around the phone */
.hero-visual {
  flex: 0 0 320px; position: relative; height: 380px; z-index:1;
  animation: fadeUp 0.8s 0.2s ease both;
  display: flex; align-items: center; justify-content: center;
}
.hv-card { position:absolute; background:var(--bg1); border:1px solid var(--border); border-radius:var(--radius-lg); padding:14px 18px; box-shadow:0 8px 32px rgba(0,0,0,0.4); }
.hv-label { font-family:var(--mono); font-size:8px; letter-spacing:3px; color:var(--text3); margin-bottom:8px; }
.hv-card-1 { top:10px; left:-20px; width:180px; }
.hv-card-2 { display:none; }
.hv-card-3 { bottom:20px; right:-20px; width:175px; }
.hv-flight { font-family:var(--mono); font-size:12px; color:var(--cyan); letter-spacing:1px; margin-bottom:5px; }
.hv-phase  { font-family:var(--cond); font-size:11px; color:var(--text2); background:var(--bg3); padding:3px 8px; border-radius:3px; display:inline-block; }
.hv-stat   { font-family:var(--cond); font-size:26px; font-weight:700; color:var(--text); line-height:1; margin-bottom:6px; }
.hv-stat span { font-size:13px; color:var(--text2); font-weight:400; }
.hv-badge  { font-family:var(--mono); font-size:9px; letter-spacing:1px; padding:3px 8px; border-radius:3px; display:inline-block; }
.hv-plane, .hv-time { display:none; }

/* ── Trust bar ── */
.mkt-trust-bar {
  display:flex; align-items:center; justify-content:center; flex-wrap:wrap;
  gap:8px 24px; padding:16px 32px;
  background:#0c0f1a; border-top:1px solid var(--border); border-bottom:1px solid var(--border);
}
.mkt-trust-item { display:flex; align-items:center; gap:7px; font-family:var(--mono); font-size:11px; color:var(--text2); letter-spacing:0.5px; }
.mkt-trust-dot  { color:var(--text3); font-size:18px; }
/* Hide old stats bar */
.mkt-stats-bar { display:none; }
/* Hide old features grid */
.features { display:none; }

/* ── Feature sections ── */
.mkt-feature { padding: 90px 40px; background: var(--bg); }
.mkt-feature-alt { background: var(--bg1); border-top:1px solid var(--border); border-bottom:1px solid var(--border); }
.mkt-feature-inner {
  max-width: 1040px; margin: 0 auto;
  display: flex; align-items: center; gap: 64px;
}
.mkt-feature-inner-rev { flex-direction: row-reverse; }
.mkt-feature-text { flex:1; max-width:460px; }
.mkt-feature-title {
  font-family: var(--cond); font-size: clamp(26px,3.5vw,42px);
  font-weight:700; line-height:1.1; color:var(--text); margin-bottom:18px; letter-spacing:-0.5px;
}
.mkt-feature-desc { font-size:15px; color:var(--text2); line-height:1.8; font-weight:300; }
.mkt-feature-bullets { list-style:none; margin-top:20px; display:flex; flex-direction:column; gap:9px; }
.mkt-feature-bullets li {
  font-family:var(--mono); font-size:11px; color:var(--text2);
  letter-spacing:0.5px; display:flex; align-items:center; gap:10px;
}
.mkt-feature-bullets li::before { content:''; width:14px; height:1px; background:var(--cyan); flex-shrink:0; }
.mkt-feature-visual { flex:0 0 auto; }

/* ── Phone mockup shell ── */
.mkt-phone {
  width: 230px;
  background: #07090f;
  border-radius: 36px;
  border: 1.5px solid rgba(0,212,255,0.18);
  box-shadow: 0 28px 70px rgba(0,0,0,0.65), 0 0 0 5px rgba(0,212,255,0.03);
  overflow: hidden;
}
.mkt-phone-chrome { background:#0c0f1a; padding:10px 0 0; display:flex; justify-content:center; border-bottom:1px solid #1e2540; }
.mkt-phone-notch  { width:60px; height:16px; background:#07090f; border-radius:0 0 10px 10px; margin-bottom:0; }
.mkt-phone-screen { background:#07090f; }
.mkt-phone-chin   { height:22px; background:#07090f; display:flex; align-items:center; justify-content:center; }
.mkt-phone-chin::after { content:''; width:56px; height:4px; background:rgba(255,255,255,0.12); border-radius:2px; }
.mkt-screen-topbar {
  padding:8px 14px; background:#0c0f1a; border-bottom:1px solid #1e2540;
  font-family:var(--cond); font-size:9px; font-weight:700; letter-spacing:2.5px; color:#6b7a99;
  text-align:center;
}
.mkt-screen-body { padding:12px 14px; }

/* Airport Briefing mockup elements */
.mkt-search-bar {
  background:#0c0f1a; border:1px solid #1e2540; border-radius:8px;
  padding:7px 10px; margin-bottom:10px;
  font-family:var(--mono); font-size:10px; color:#3a4560; display:flex; align-items:center; gap:5px;
}
.mkt-airport-hdr { display:flex; align-items:baseline; gap:8px; margin-bottom:10px; padding-bottom:8px; border-bottom:1px solid #1e2540; }
.mkt-airport-icao { font-family:var(--mono); font-size:18px; color:#00d4ff; letter-spacing:3px; font-weight:700; }
.mkt-airport-name { font-size:11px; color:#6b7a99; }
.mkt-tip-section-lbl { font-family:var(--mono); font-size:8px; letter-spacing:1.5px; color:#3a4560; margin-bottom:5px; margin-top:8px; }
.mkt-tip { background:#0c0f1a; border:1px solid #1e2540; border-radius:5px; padding:8px 10px; margin-bottom:4px; }
.mkt-tip-text { font-size:9px; color:#9aa5bf; line-height:1.6; margin-bottom:5px; }
.mkt-tip-foot { display:flex; align-items:center; justify-content:space-between; }
.mkt-tip-author { font-family:var(--mono); font-size:8px; color:#00d4ff; }
.mkt-tip-votes  { font-family:var(--mono); font-size:8px; color:#3a4560; }
.mkt-approach-pills { display:flex; flex-wrap:wrap; gap:4px; margin-top:4px; }
.mkt-approach-pill {
  font-family:var(--mono); font-size:8px; padding:3px 8px;
  background:rgba(0,212,255,0.08); border:1px solid rgba(0,212,255,0.2);
  border-radius:10px; color:#00d4ff;
}

/* Flight Log mockup elements */
.mkt-log-detail-lbl { font-family:var(--mono); font-size:8px; letter-spacing:1.5px; color:#3a4560; margin-bottom:6px; padding-bottom:5px; border-bottom:1px solid #1e2540; }
.mkt-log-fields { display:flex; gap:8px; margin-bottom:7px; }
.mkt-log-field  { flex:1; }
.mkt-lf-lbl     { font-family:var(--mono); font-size:7px; letter-spacing:1px; color:#3a4560; margin-bottom:2px; }
.mkt-lf-val     { font-size:9px; color:#dde4f0; background:#0c0f1a; border:1px solid #1e2540; border-radius:3px; padding:4px 6px; }
.mkt-lf-mono    { font-family:var(--mono); letter-spacing:1px; color:#00d4ff; }
.mkt-log-route  { display:flex; align-items:center; gap:6px; margin-bottom:7px; }
.mkt-route-icao { font-family:var(--mono); font-size:14px; color:#00d4ff; letter-spacing:2px; font-weight:700; }
.mkt-route-arrow { font-family:var(--mono); font-size:9px; color:#3a4560; flex:1; text-align:center; }
.mkt-phase-row  { display:flex; gap:4px; flex-wrap:wrap; margin-bottom:8px; }
.mkt-phase-pill { font-family:var(--mono); font-size:7px; padding:3px 7px; background:#0c0f1a; border:1px solid #1e2540; border-radius:10px; color:#6b7a99; }
.mkt-phase-active { background:rgba(0,212,255,0.08); border-color:rgba(0,212,255,0.35); color:#00d4ff; }
.mkt-tem-lbl    { font-family:var(--mono); font-size:8px; letter-spacing:1.5px; color:#3a4560; margin-bottom:6px; padding-bottom:5px; border-bottom:1px solid #1e2540; }
.mkt-tem-block  { margin-bottom:6px; }
.mkt-tem-field-lbl { font-family:var(--mono); font-size:7px; letter-spacing:1px; color:#3a4560; margin-bottom:3px; }
.mkt-tem-text   { font-size:8px; color:#9aa5bf; background:#0c0f1a; border:1px solid #1e2540; border-radius:3px; padding:5px; line-height:1.6; }
.mkt-save-row   { display:flex; align-items:center; justify-content:space-between; margin-top:8px; gap:6px; }
.mkt-reportable-badge { font-family:var(--mono); font-size:7px; letter-spacing:1px; color:#ffab00; background:rgba(255,171,0,0.08); border:1px solid rgba(255,171,0,0.25); border-radius:3px; padding:4px 7px; }
.mkt-save-btn   { background:#00d4ff; color:#07090f; font-family:var(--cond); font-size:8px; font-weight:700; letter-spacing:1.5px; padding:6px 10px; border-radius:5px; flex-shrink:0; }

/* ── Others grid ── */
.mkt-others { padding:80px 40px; background:var(--bg); }
.mkt-others-inner { max-width:960px; margin:0 auto; }
.mkt-others-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:14px; }
.mkt-other-card {
  background:var(--bg1); border:1px solid var(--border); border-radius:var(--radius-lg);
  padding:22px 18px; transition:border-color 0.15s ease;
}
.mkt-other-card:hover { border-color:var(--border2); }
.mkt-other-icon  { font-size:26px; margin-bottom:10px; }
.mkt-other-title { font-family:var(--cond); font-size:16px; font-weight:700; letter-spacing:1px; color:var(--text); margin-bottom:8px; }
.mkt-other-desc  { font-size:13px; color:var(--text2); line-height:1.7; font-weight:300; }

/* ── Offline / PWA section ── */
.mkt-offline { padding:80px 40px; background:var(--bg1); border-top:1px solid var(--border); }
.mkt-offline-inner { max-width:960px; margin:0 auto; display:flex; gap:80px; align-items:flex-start; }
.mkt-offline-text { flex:1; }
.mkt-pwa-steps { flex:0 0 400px; display:flex; gap:20px; align-items:stretch; }
.mkt-pwa-platform { flex:1; }
.mkt-pwa-platform-name {
  display:flex; align-items:center; gap:8px;
  font-family:var(--cond); font-size:14px; font-weight:700; letter-spacing:1px; color:var(--text);
  margin-bottom:16px; padding-bottom:12px; border-bottom:1px solid var(--border);
}
.mkt-pwa-step {
  display:flex; align-items:flex-start; gap:10px;
  font-size:13px; color:var(--text2); line-height:1.6; margin-bottom:10px;
}
.mkt-pwa-step strong { color:var(--text); }
.mkt-pwa-num {
  font-family:var(--mono); font-size:10px; color:var(--cyan);
  background:var(--cyan-dim); border:1px solid rgba(0,212,255,0.2);
  border-radius:3px; padding:3px 7px; flex-shrink:0; margin-top:2px;
  letter-spacing:1px;
}
.mkt-pwa-icon { font-family:var(--mono); color:var(--cyan); font-size:13px; }
.mkt-pwa-divider { width:1px; background:var(--border); flex-shrink:0; }

/* ── About section ── */
.mkt-about { padding:90px 40px; background:var(--bg); border-top:1px solid var(--border); }
.mkt-about-inner {
  max-width:960px; margin:0 auto;
  display:flex; gap:64px; align-items:flex-start;
}
.mkt-about-photo-wrap { flex:0 0 220px; }
.mkt-about-photo {
  width:220px; height:280px; object-fit:cover; object-position:center top;
  border-radius:12px;
  border:1px solid var(--border);
  box-shadow:0 16px 48px rgba(0,0,0,0.5);
  display:block;
}
.mkt-about-caption { margin-top:14px; text-align:center; }
.mkt-about-name { font-family:var(--cond); font-size:18px; font-weight:700; color:var(--text); letter-spacing:1px; }
.mkt-about-role { font-family:var(--mono); font-size:10px; color:var(--text3); letter-spacing:1px; margin-top:4px; }
.mkt-about-text { flex:1; }
.mkt-about-message { margin-top:4px; }
.mkt-about-message p {
  font-size:15px; color:var(--text2); line-height:1.85; font-weight:300;
  margin-bottom:16px;
}
.mkt-about-sign {
  font-family:var(--cond); font-size:18px; font-weight:600; color:var(--cyan);
  margin-top:24px; letter-spacing:0.5px;
}

/* ── Responsive ── */
@media (max-width:900px) {
  .mkt-feature-inner, .mkt-feature-inner-rev { flex-direction:column; gap:40px; }
  .mkt-feature-text { max-width:100%; }
  .mkt-feature { padding:60px 24px; }
  .mkt-others { padding:60px 24px; }
  .mkt-others-grid { grid-template-columns:1fr 1fr; }
  .mkt-offline { padding:60px 24px; }
  .mkt-offline-inner { flex-direction:column; gap:40px; }
  .mkt-pwa-steps { flex:unset; width:100%; }
  .mkt-about { padding:60px 24px; }
  .mkt-about-inner { flex-direction:column; align-items:center; gap:36px; }
  .mkt-about-photo-wrap { flex:unset; }
  .mkt-trust-bar { padding:14px 20px; gap:8px 16px; }
  .hero-visual { display:none; }
}
@media (max-width:600px) {
  .mkt-others-grid { grid-template-columns:1fr; }
  .mkt-pwa-steps { flex-direction:column; gap:24px; }
  .mkt-pwa-divider { display:none; }
  .mkt-about-photo { width:180px; height:230px; }
  .mkt-about-photo-wrap { flex:unset; }
}

/* ── Airport offline states ── */
.airport-offline-banner {
  background: var(--bg2);
  border: 1px solid var(--border2);
  border-radius: var(--radius);
  padding: 8px 14px;
  font-family: var(--mono);
  font-size: 10px;
  color: var(--text3);
  letter-spacing: 1px;
  margin-bottom: 12px;
}

.airport-cache-badge {
  font-family: var(--mono);
  font-size: 10px;
  color: var(--text3);
  letter-spacing: 0.5px;
  padding: 6px 16px;
  border-bottom: 1px solid var(--border);
}

.recent-cached-badge {
  display: none; /* removed — offline availability shown via card border only */
}

/* Subtle left-border glow on cached airport cards */
.airport-card-cached {
  border-left: 2px solid rgba(0, 212, 255, 0.35);
}

/* ── Cache section in burger menu ── */
.app-menu-cache-section {
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 12px 14px;
  margin-bottom: 12px;
}

.app-menu-cache-info {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  margin-bottom: 10px;
}

.app-menu-cache-label {
  font-family: var(--mono);
  font-size: 9px;
  letter-spacing: 2px;
  color: var(--text3);
}

.app-menu-cache-size {
  font-family: var(--mono);
  font-size: 10px;
  color: var(--text2);
}

.app-menu-clear-cache-btn {
  width: 100%;
  background: transparent;
  border: 1px solid var(--border);
  border-radius: 6px;
  color: var(--text3);
  font-family: var(--mono);
  font-size: 9px;
  letter-spacing: 1.5px;
  padding: 8px 12px;
  cursor: pointer;
  transition: all 0.15s ease;
  text-transform: uppercase;
}

.app-menu-clear-cache-btn:hover {
  color: var(--text);
  border-color: var(--border2);
  background: var(--bg3, rgba(255,255,255,0.04));
}

/* ── Toast notification ── */
.app-cache-toast {
  position: fixed;
  bottom: 32px;
  left: 50%;
  transform: translateX(-50%) translateY(12px);
  background: var(--bg2);
  border: 1px solid var(--border2);
  border-radius: 8px;
  padding: 10px 20px;
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.5px;
  color: var(--text2);
  white-space: nowrap;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.2s ease, transform 0.2s ease;
  z-index: 999;
}

.app-cache-toast.visible {
  opacity: 1;
  transform: translateX(-50%) translateY(0);
}

.airport-offline-search {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 16px;
  font-family: var(--sans);
  font-size: 13px;
  color: var(--text2);
  line-height: 1.5;
}

.airport-offline-icon {
  font-size: 24px;
  flex-shrink: 0;
}

/* ══════════════════════════════════════
   ROSTER INSIGHTS
══════════════════════════════════════ */

/* ── Dashboard tile states ── */
.dash-tool-coming-soon {
  opacity: 0.45;
  cursor: default;
}
.dash-tool-coming-soon:hover {
  border-color: var(--border) !important;
  background: var(--bg1) !important;
  transform: none !important;
  box-shadow: none !important;
}
.dash-tool-badge {
  font-family: var(--mono);
  font-size: 8px;
  letter-spacing: 1.5px;
  color: var(--text3);
  background: var(--bg2);
  border: 1px solid var(--border2);
  border-radius: 20px;
  padding: 3px 8px;
  white-space: nowrap;
}

/* ── Coming soon modal ── */
.coming-soon-modal {
  background: var(--bg1);
  border: 1px solid var(--border2);
  border-radius: 20px;
  padding: 32px 24px;
  max-width: 340px;
  width: 90%;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
  text-align: center;
}
.coming-soon-icon { font-size: 40px; }
.coming-soon-title {
  font-family: var(--cond);
  font-size: 22px;
  font-weight: 700;
  letter-spacing: 2px;
  color: var(--text);
}
.coming-soon-sub {
  font-family: var(--mono);
  font-size: 9px;
  letter-spacing: 3px;
  color: var(--cyan);
  background: rgba(0,212,255,0.08);
  border: 1px solid rgba(0,212,255,0.2);
  border-radius: 20px;
  padding: 4px 12px;
}
.coming-soon-desc {
  font-size: 13px;
  color: var(--text3);
  line-height: 1.6;
  max-width: 280px;
}
.coming-soon-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  justify-content: center;
  margin: 4px 0;
}
.coming-soon-tag {
  font-family: var(--mono);
  font-size: 9px;
  letter-spacing: 1px;
  color: var(--text2);
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: 20px;
  padding: 4px 10px;
}

/* ── Upload screen ── */
.roster-upload-wrap {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 60vh;
  padding: 24px;
}
.roster-upload-card {
  background: var(--bg1);
  border: 1px solid var(--border);
  border-radius: 20px;
  padding: 40px 28px;
  max-width: 320px;
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 14px;
  text-align: center;
}
.roster-upload-icon { font-size: 44px; }
.roster-upload-title {
  font-family: var(--cond);
  font-size: 20px;
  font-weight: 700;
  letter-spacing: 1px;
  color: var(--text);
}
.roster-upload-desc {
  font-size: 13px;
  color: var(--text3);
  line-height: 1.6;
}
.roster-upload-btn {
  background: var(--cyan);
  color: var(--bg);
  font-family: var(--cond);
  font-size: 14px;
  font-weight: 700;
  letter-spacing: 2px;
  padding: 12px 28px;
  border-radius: 40px;
  cursor: pointer;
  border: none;
  transition: opacity var(--ease);
}
.roster-upload-btn:hover { opacity: 0.85; }
.roster-upload-new {
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 1px;
  color: var(--cyan);
  background: rgba(0,212,255,0.08);
  border: 1px solid rgba(0,212,255,0.25);
  border-radius: 20px;
  padding: 6px 14px;
  cursor: pointer;
  white-space: nowrap;
  transition: background var(--ease);
}
.roster-upload-new:hover { background: rgba(0,212,255,0.15); }
.roster-upload-hint {
  font-family: var(--mono);
  font-size: 9px;
  color: var(--text3);
  letter-spacing: 0.5px;
}
.roster-parsing-state {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 16px;
}

/* ── Roster dashboard wrap ── */
.roster-wrap {
  display: flex;
  flex-direction: column;
  padding-bottom: 80px;
}

/* ── Month tabs + header ── */
.roster-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding: 12px 16px;
  background: var(--bg1);
  border-bottom: 1px solid var(--border);
  flex-wrap: wrap;
}
.roster-month-tabs {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
}
.roster-month-tab {
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 1px;
  color: var(--text3);
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: 20px;
  padding: 5px 12px;
  cursor: pointer;
  transition: all var(--ease);
}
.roster-month-tab.active {
  color: var(--cyan);
  border-color: var(--cyan);
  background: rgba(0,212,255,0.08);
}

/* ── Stats strip ── */
.roster-stats {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  background: var(--border);
  border-bottom: 1px solid var(--border);
}
.roster-stat {
  background: var(--bg1);
  padding: 16px 10px;
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
}
.roster-stat-warn { background: rgba(255,171,64,0.06); }
.roster-stat-val {
  font-family: var(--mono);
  font-size: 22px;
  font-weight: 700;
  color: var(--cyan);
  line-height: 1;
}
.roster-stat-warn .roster-stat-val { color: var(--amber); }
.roster-stat-label {
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 1.2px;
  color: var(--text2);
}
.roster-stat-diff {
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.5px;
  padding: 2px 7px;
  border-radius: 10px;
  margin-top: 2px;
}
.roster-stat-diff.pos { color: var(--green); background: rgba(0,230,118,0.08); }
.roster-stat-diff.neg { color: var(--red);   background: rgba(255,61,87,0.08);  }

/* ── Stats extras ── */
.roster-stat-divide { color: var(--text3); font-size: 14px; margin: 0 2px; }
.roster-stat-wide   { grid-column: span 2; }
.roster-stat-night  { background: rgba(0,212,255,0.04); }
.roster-stat-night .roster-stat-val { color: var(--cyan); }

/* ── Map (Leaflet) ── */
.roster-map-wrap {
  position: relative;
  background: #040810;
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
}
.roster-map-canvas {
  width: 100%;
  height: 420px;
  overflow: hidden;
  position: relative;
  z-index: 0;
}
.leaflet-container { background: #07090f !important; }
.roster-map-tooltip .leaflet-tooltip-content { background: transparent; border: none; }
.leaflet-tooltip { background: rgba(7,9,15,0.85) !important; border: 1px solid var(--border2) !important; border-radius: 6px !important; padding: 4px 8px !important; box-shadow: none !important; }
.roster-map-legend {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 10px 16px;
  background: var(--bg1);
  border-top: 1px solid var(--border);
  flex-wrap: wrap;
}
.roster-legend-item {
  display: flex;
  align-items: center;
  gap: 5px;
  font-family: var(--mono);
  font-size: 11px;
  color: var(--text2);
}
.roster-legend-dot {
  width: 8px; height: 8px;
  border-radius: 50%;
  flex-shrink: 0;
  display: inline-block;
}
.roster-legend-dot.white  { background: #ffffff; }
.roster-legend-dot.cyan   { background: #00d4ff; }
.roster-legend-dot.amber  { background: #ffab40; }
.roster-legend-dot.purple { background: #b060ff; }

/* ── Roster Breakdown ── */
.roster-breakdown-wrap {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1px;
  background: var(--border);
  border-bottom: 1px solid var(--border);
}
.roster-breakdown-chart, .roster-allowance-panel {
  background: var(--bg1);
  padding: 20px 16px;
}
.pie-chart-inner {
  display: flex;
  align-items: center;
  gap: 16px;
  flex-wrap: wrap;
}
.pie-legend {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.pie-legend-item {
  display: flex;
  align-items: center;
  gap: 7px;
  font-family: var(--mono);
  font-size: 12px;
}
.pie-legend-dot {
  width: 9px; height: 9px;
  border-radius: 50%;
  flex-shrink: 0;
}
.pie-legend-label { color: var(--text); flex: 1; }
.pie-legend-count { color: var(--text); font-weight: 700; min-width: 18px; text-align: right; }

/* ── Allowance panel ── */
.allowance-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 8px 0;
  border-bottom: 1px solid var(--border);
}
.allowance-row:last-child { border-bottom: none; }
.allowance-label {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.8px;
  color: var(--text2);
}
.allowance-val {
  font-family: var(--mono);
  font-size: 15px;
  font-weight: 700;
  color: var(--text);
}
.allowance-val.night  { color: var(--cyan); }
.allowance-val.cyan   { color: var(--cyan); }
.allowance-val.amber  { color: var(--amber); }
.allowance-val.purple { color: #b060ff; }

/* ── Enhanced Fatigue card ── */
.fatigue-section-label {
  font-family: var(--mono);
  font-size: 9px;
  letter-spacing: 2px;
  color: var(--text3);
  margin: 4px 0 10px;
  text-transform: uppercase;
}
.fatigue-divider {
  height: 1px;
  background: var(--border);
  margin: 14px 0;
}
.fatigue-ftl-row {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 0;
  border-bottom: 1px solid var(--border);
}
.fatigue-ftl-row:last-of-type { border-bottom: none; }
.fatigue-ftl-date {
  font-family: var(--mono);
  font-size: 13px;
  font-weight: 700;
  color: var(--text);
  min-width: 72px;
}
.fatigue-ftl-detail {
  font-family: var(--mono);
  font-size: 11px;
  color: var(--text3);
  flex: 1;
}
.fatigue-consec-row {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 0;
  border-bottom: 1px solid var(--border);
}
.fatigue-consec-row:last-of-type { border-bottom: none; }
.fatigue-consec-badge {
  font-family: var(--mono);
  font-size: 18px;
  font-weight: 700;
  color: var(--amber);
  min-width: 60px;
}
.fatigue-consec-range {
  font-family: var(--mono);
  font-size: 12px;
  color: var(--text3);
  flex: 1;
}
.fatigue-score-wrap {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 5px;
  flex-shrink: 0;
  min-width: 110px;
}
.fatigue-score-bar {
  width: 100%;
  height: 3px;
  background: var(--border2);
  border-radius: 2px;
  overflow: hidden;
}
.fatigue-score-fill {
  height: 100%;
  border-radius: 2px;
  transition: width 0.4s ease;
}
.fatigue-ok-msg {
  font-family: var(--mono);
  font-size: 12px;
  color: var(--green);
  padding: 12px 0;
  letter-spacing: 0.5px;
}
.fatigue-crit {
  color: #ff3d57;
  background: rgba(255,61,87,0.15);
  border: 1px solid rgba(255,61,87,0.3);
}

/* ── Cards ── */
.roster-card {
  background: var(--bg1);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 16px;
  margin: 0 16px 12px;
}
.roster-card:first-of-type { margin-top: 16px; }
.roster-card-title {
  font-family: var(--mono);
  font-size: 12px;
  letter-spacing: 1.5px;
  color: var(--text2);
  margin-bottom: 14px;
  display: flex;
  align-items: center;
  gap: 10px;
}

/* ── Fatigue card ── */
.roster-card-fatigue {
  border-left: 3px solid var(--amber);
  margin-top: 16px;
}
.fatigue-day-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 10px 0;
  border-bottom: 1px solid var(--border);
}
.fatigue-day-row:last-child { border-bottom: none; }
.fatigue-day-left { display: flex; flex-direction: column; gap: 3px; }
.fatigue-day-date {
  font-family: var(--mono);
  font-size: 15px;
  font-weight: 700;
  color: var(--text);
}
.fatigue-day-reasons {
  font-family: var(--mono);
  font-size: 12px;
  color: var(--text3);
  letter-spacing: 0.3px;
}
.fatigue-day-tag {
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 1.5px;
  border-radius: 20px;
  padding: 4px 10px;
  white-space: nowrap;
  flex-shrink: 0;
}
.fatigue-high {
  color: var(--red);
  background: rgba(255,61,87,0.1);
  border: 1px solid rgba(255,61,87,0.25);
}
.fatigue-mod {
  color: var(--amber);
  background: rgba(255,171,64,0.1);
  border: 1px solid rgba(255,171,64,0.25);
}

/* ── Layovers ── */
.roster-layover-row {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 0;
  border-bottom: 1px solid var(--border);
  flex-wrap: wrap;
}
.roster-layover-row:last-child { border-bottom: none; }
.roster-layover-city {
  font-family: var(--mono);
  font-size: 15px;
  font-weight: 700;
  color: var(--amber);
  width: 44px;
  flex-shrink: 0;
}
.roster-layover-city.intl { color: #b060ff; }
.roster-layover-hotel { font-size: 13px; color: var(--text); flex: 1; }
.roster-layover-date  { font-family: var(--mono); font-size: 12px; color: var(--text2); }

/* ── Captains — clickable rows ── */
.roster-captain-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 13px 0;
  border-bottom: 1px solid var(--border);
  cursor: pointer;
  transition: background var(--ease);
  border-radius: 6px;
  gap: 12px;
}
.roster-captain-row:last-child { border-bottom: none; }
.roster-captain-row:active { background: rgba(0,212,255,0.04); }
.roster-captain-row-left { display: flex; flex-direction: column; gap: 4px; flex: 1; min-width: 0; }
.roster-captain-row-name {
  font-family: var(--cond);
  font-size: 17px;
  font-weight: 700;
  color: var(--text);
  letter-spacing: 0.3px;
}
.roster-captain-row-routes {
  font-family: var(--mono);
  font-size: 11px;
  color: var(--text2);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.roster-captain-row-right {
  display: flex;
  align-items: center;
  gap: 4px;
  flex-shrink: 0;
}
.roster-captain-sector-count {
  font-family: var(--mono);
  font-size: 20px;
  font-weight: 700;
  color: var(--cyan);
}
.roster-captain-sector-label {
  font-family: var(--mono);
  font-size: 10px;
  color: var(--text3);
  margin-right: 4px;
}
.roster-captain-chevron {
  font-size: 20px;
  color: var(--text3);
  line-height: 1;
}

/* ── Captain detail modal ── */
.captain-modal-overlay {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.65);
  z-index: 200;
  align-items: flex-end;
  justify-content: center;
  backdrop-filter: blur(3px);
}
.captain-modal-overlay.open {
  display: flex;
  animation: overlayIn 0.2s ease;
}
@keyframes overlayIn { from { opacity:0; } to { opacity:1; } }
.captain-modal-sheet {
  background: var(--bg1);
  border: 1px solid var(--border2);
  border-radius: 24px 24px 0 0;
  width: 100%;
  max-width: 600px;
  max-height: 82vh;
  display: flex;
  flex-direction: column;
  animation: sheetUp 0.28s cubic-bezier(0.34,1.3,0.64,1);
  overflow: hidden;
}
@keyframes sheetUp { from { transform: translateY(60px); opacity:0; } to { transform: translateY(0); opacity:1; } }
.captain-modal-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  padding: 20px 20px 16px;
  border-bottom: 1px solid var(--border);
  flex-shrink: 0;
}
.captain-modal-label {
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 2px;
  color: var(--text3);
  margin-bottom: 4px;
}
.captain-modal-name {
  font-family: var(--cond);
  font-size: 24px;
  font-weight: 700;
  color: var(--text);
  letter-spacing: 0.5px;
}
.captain-modal-close {
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: 50%;
  width: 34px; height: 34px;
  color: var(--text2);
  font-size: 14px;
  cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
  transition: all var(--ease);
}
.captain-modal-close:hover { color: var(--text); border-color: var(--border2); }
.captain-modal-stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1px;
  background: var(--border);
  border-bottom: 1px solid var(--border);
  flex-shrink: 0;
}
.cmo-stat {
  background: var(--bg);
  padding: 14px 8px;
  text-align: center;
}
.cmo-val {
  font-family: var(--mono);
  font-size: 20px;
  font-weight: 700;
  color: var(--cyan);
  line-height: 1;
}
.stl-cleared-val {
  font-family: var(--mono);
  font-size: 20px;
  font-weight: 700;
  color: var(--green);
  line-height: 1;
}
.cmo-val-dim {
  font-family: var(--mono);
  font-size: 20px;
  font-weight: 700;
  color: var(--text3);
  line-height: 1;
}
.cmo-label {
  font-family: var(--mono);
  font-size: 8px;
  letter-spacing: 1.5px;
  color: var(--text3);
  margin-top: 4px;
}
.captain-modal-duties {
  overflow-y: auto;
  flex: 1;
  padding: 8px 0 24px;
}
.cmo-duty-block {
  padding: 12px 20px;
  border-bottom: 1px solid var(--border);
}
.cmo-duty-block:last-child { border-bottom: none; }
.cmo-duty-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 10px;
  flex-wrap: wrap;
  gap: 6px;
}
.cmo-duty-date {
  font-family: var(--mono);
  font-size: 14px;
  font-weight: 700;
  color: var(--text);
}
.cmo-duty-times {
  font-family: var(--mono);
  font-size: 11px;
  color: var(--text3);
  letter-spacing: 0.5px;
}
.cmo-flight-row {
  display: flex;
  align-items: center;
  gap: 10px;
  background: var(--bg2);
  border-radius: 8px;
  padding: 9px 12px;
  margin-bottom: 6px;
}
.cmo-flt-num {
  font-family: var(--mono);
  font-size: 14px;
  color: var(--cyan);
  font-weight: 700;
  min-width: 44px;
}
.cmo-flt-route {
  font-family: var(--mono);
  font-size: 13px;
  color: var(--text2);
  flex: 1;
}
.cmo-flt-times {
  font-family: var(--mono);
  font-size: 12px;
  color: var(--text3);
  flex-shrink: 0;
}

/* ── Long halts card ── */
.roster-card-halts {
  border-left: 3px solid var(--cyan);
}
.roster-halt-total-badge {
  font-family: var(--mono);
  font-size: 11px;
  color: var(--cyan);
  background: rgba(0,212,255,0.1);
  border: 1px solid rgba(0,212,255,0.2);
  border-radius: 20px;
  padding: 2px 10px;
  letter-spacing: 0.5px;
}
.roster-halt-row {  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 11px 0;
  border-bottom: 1px solid var(--border);
}
.roster-halt-row:last-child { border-bottom: none; }
.roster-halt-left { display: flex; flex-direction: column; gap: 4px; }
.roster-halt-station {
  font-family: var(--mono);
  font-size: 15px;
  font-weight: 700;
  color: var(--text);
}
.roster-halt-flights {
  font-family: var(--mono);
  font-size: 11px;
  color: var(--text3);
}
.roster-halt-right {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 3px;
  flex-shrink: 0;
}
.roster-halt-dur {
  font-family: var(--mono);
  font-size: 16px;
  font-weight: 700;
  color: var(--cyan);
}
.roster-halt-date {
  font-family: var(--mono);
  font-size: 10px;
  color: var(--text3);
}
.halt-no-allowance { opacity: 0.55; }
.halt-no-allowance .roster-halt-dur { color: var(--text3); }
.halt-exact-label {
  font-family: var(--mono);
  font-size: 8px;
  font-weight: 700;
  letter-spacing: 0.8px;
  color: var(--text3);
  text-transform: uppercase;
}

/* ── Old captain block styles (kept for compat) ── */
.roster-captain-block {
  border-bottom: 1px solid var(--border);
  padding: 12px 0;
}
.roster-captain-block:last-child { border-bottom: none; padding-bottom: 0; }
.roster-captain-name {
  font-family: var(--cond);
  font-size: 15px;
  font-weight: 700;
  color: var(--text);
  letter-spacing: 0.5px;
  margin-bottom: 8px;
}
.roster-captain-flights { display: flex; flex-direction: column; gap: 5px; }
.roster-captain-flight {
  display: flex;
  align-items: center;
  gap: 10px;
  background: var(--bg2);
  border-radius: 8px;
  padding: 6px 10px;
}
.rcf-num {
  font-family: var(--mono);
  font-size: 12px;
  color: var(--cyan);
  font-weight: 700;
  min-width: 38px;
}
.rcf-route {
  font-family: var(--mono);
  font-size: 11px;
  color: var(--text2);
  flex: 1;
}
.rcf-date {
  font-family: var(--mono);
  font-size: 10px;
  color: var(--text3);
  flex-shrink: 0;
}

@media (max-width: 480px) {
  .roster-stats              { grid-template-columns: repeat(3,1fr); }
  .roster-stat-val           { font-size: 17px; }
  .roster-stat-label         { font-size: 8px; }
  .roster-stat-wide          { grid-column: span 3; }
  .roster-map-canvas         { height: 300px; }
  .roster-card               { margin: 0 10px 10px; }
  .captain-modal-stats       { grid-template-columns: repeat(2,1fr); }
  .cmo-val                   { font-size: 18px; }
  .roster-breakdown-wrap     { grid-template-columns: 1fr; }
  .pie-chart-inner           { justify-content: center; }
}

/* ── STL Captain Styles ── */
.roster-captain-row.stl-captain {
  background: rgba(0,230,118,0.04);
  border-radius: 8px;
  border-left: 3px solid var(--green);
  padding-left: 8px;
}
.roster-captain-row.stl-captain:active {
  background: rgba(0,230,118,0.08);
}
.roster-captain-row-name.stl-name {
  color: var(--green);
}
.stl-badge-inline {
  font-family: var(--mono);
  font-size: 9px;
  letter-spacing: 1.5px;
  color: var(--green);
  background: rgba(0,230,118,0.12);
  border: 1px solid rgba(0,230,118,0.3);
  border-radius: 4px;
  padding: 2px 7px;
  display: inline-block;
  margin-bottom: 3px;
}
.roster-captain-sector-count.stl-count {
  color: var(--green);
}

/* ── Captain modal STL badge ── */
.captain-modal-stl-badge {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 2px;
  color: var(--green);
  background: rgba(0,230,118,0.12);
  border: 1px solid rgba(0,230,118,0.35);
  border-radius: 6px;
  padding: 3px 10px;
  margin-left: 10px;
  vertical-align: middle;
}
.cmo-stat-stl {
  background: rgba(0,230,118,0.06) !important;
  border-left: 1px solid rgba(0,230,118,0.2);
}
.stl-val {
  color: var(--green) !important;
  font-size: 22px;
}

/* ── STL Block Hours Panel ── */
.roster-stl-panel {
  border-top: 1px solid var(--border);
}
.roster-stl-chart-wrap {
  background: var(--bg1);
  padding: 20px 16px;
}
.roster-stl-info {
  background: var(--bg1);
  padding: 20px 16px;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.stl-info-text {
  font-family: var(--sans);
  font-size: 12px;
  color: var(--text3);
  line-height: 1.5;
  margin-bottom: 6px;
}
.stl-pie-inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
}
.stl-pie-sub {
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.stl-pie-hrs {
  font-family: var(--mono);
  font-size: 22px;
  font-weight: 700;
  color: var(--green);
}
.stl-pie-label {
  font-family: var(--mono);
  font-size: 10px;
  color: var(--text3);
  letter-spacing: 0.5px;
}
.stl-stat-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 8px 0;
  border-bottom: 1px solid var(--border);
}
.stl-stat-row:last-child { border-bottom: none; }
.stl-stat-label {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.8px;
  color: var(--text2);
}
.stl-stat-val {
  font-family: var(--mono);
  font-size: 16px;
  font-weight: 700;
  color: var(--text2);
}
.stl-stat-val.stl-green { color: var(--green); }

/* ── Month tab delete button ── */
.roster-month-tab-wrap {
  display: inline-flex;
  align-items: center;
  gap: 2px;
}
.roster-month-delete {
  background: none;
  border: none;
  color: var(--text3);
  font-size: 11px;
  padding: 2px 5px;
  cursor: pointer;
  border-radius: 4px;
  line-height: 1;
  transition: color var(--ease), background var(--ease);
  flex-shrink: 0;
}
.roster-month-delete:hover {
  color: var(--red);
  background: rgba(255,61,87,0.1);
}

/* ── Delete confirmation toast ── */
.roster-delete-toast {
  position: fixed;
  bottom: 24px;
  left: 50%;
  transform: translateX(-50%);
  background: var(--bg2);
  border: 1px solid var(--border2);
  border-radius: 14px;
  padding: 14px 18px;
  display: flex;
  align-items: center;
  gap: 12px;
  z-index: 500;
  box-shadow: 0 8px 32px rgba(0,0,0,0.4);
  animation: toastUp 0.2s ease;
  white-space: nowrap;
}
@keyframes toastUp {
  from { transform: translateX(-50%) translateY(16px); opacity: 0; }
  to   { transform: translateX(-50%) translateY(0);    opacity: 1; }
}
.roster-delete-toast-msg {
  font-family: var(--mono);
  font-size: 13px;
  color: var(--text2);
}
.roster-delete-toast-msg strong {
  color: var(--text);
}
.roster-delete-toast-yes {
  background: rgba(255,61,87,0.15);
  border: 1px solid rgba(255,61,87,0.4);
  color: var(--red);
  font-family: var(--mono);
  font-size: 12px;
  letter-spacing: 1px;
  border-radius: 8px;
  padding: 6px 14px;
  cursor: pointer;
  transition: all var(--ease);
}
.roster-delete-toast-yes:hover {
  background: rgba(255,61,87,0.25);
}
.roster-delete-toast-no {
  background: var(--bg1);
  border: 1px solid var(--border);
  color: var(--text3);
  font-family: var(--mono);
  font-size: 12px;
  letter-spacing: 1px;
  border-radius: 8px;
  padding: 6px 14px;
  cursor: pointer;
  transition: all var(--ease);
}
.roster-delete-toast-no:hover {
  color: var(--text2);
  border-color: var(--border2);
}

/* ── Fatigue Board ── */
.fatigue-hint {
  font-family: var(--mono);
  font-size: 11px;
  color: var(--text2);
  margin: 0 0 14px;
  letter-spacing: 0.3px;
}
.fatigue-board {
  display: flex;
  flex-direction: column;
  gap: 3px;
}

/* Base row */
.fb-day {
  display: flex;
  align-items: center;
  gap: 12px;
  min-height: 36px;
  border-radius: 8px;
  padding: 0 10px 0 0;
  position: relative;
  overflow: hidden;
}

/* Date column */
.fb-date-col {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  width: 36px;
  flex-shrink: 0;
  padding: 8px 0;
}
.fb-date-num {
  font-family: var(--mono);
  font-size: 14px;
  font-weight: 700;
  color: var(--text);
  line-height: 1;
}
.fb-day-name {
  font-family: var(--mono);
  font-size: 8px;
  color: var(--text2);
  letter-spacing: 0.5px;
  margin-top: 2px;
}
.fb-dim { color: var(--text3) !important; }

/* Blank day — thin quiet line */
.fb-blank {
  min-height: 28px;
  opacity: 0.4;
}
.fb-blank .fb-date-col { padding: 4px 0; }

/* OFG — green */
.fb-ofg {
  background: rgba(0,230,118,0.12);
  border: 1px solid rgba(0,230,118,0.25);
}
.fb-ofg .fb-date-num { color: var(--green); }
.fb-ofg .fb-day-name { color: var(--green); opacity: 0.7; }

/* ROFF — softer green */
.fb-roff {
  background: rgba(0,230,118,0.08);
  border: 1px solid rgba(0,230,118,0.18);
}
.fb-roff .fb-date-num { color: var(--green); }
.fb-roff .fb-day-name { color: var(--green); opacity: 0.7; }

/* Standby — muted amber */
.fb-sby {
  background: rgba(255,171,64,0.07);
  border: 1px solid rgba(255,171,64,0.18);
}
.fb-sby .fb-date-num { color: var(--amber); }
.fb-sby .fb-day-name { color: var(--amber); opacity: 0.7; }

/* Training — cyan/blue */
.fb-training {
  background: rgba(0,212,255,0.06);
  border: 1px solid rgba(0,212,255,0.18);
}
.fb-training .fb-date-num { color: var(--cyan); }
.fb-training .fb-day-name { color: var(--cyan); opacity: 0.7; }

/* Leave (OFB / PCL / PL) — same visual as OFG but softer */
.fb-leave {
  background: rgba(0,230,118,0.06);
  border: 1px solid rgba(0,230,118,0.18);
}
.fb-leave .fb-date-num { color: var(--green); opacity: 0.7; }
.fb-leave .fb-day-name { color: var(--green); opacity: 0.5; }

/* Special label (OFG / ROFF / SBY) */
.fb-special-label {
  font-family: var(--mono);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 1.5px;
  color: inherit;
  flex: 1;
}
.fb-ofg .fb-special-label,
.fb-roff .fb-special-label     { color: var(--green); }
.fb-sby  .fb-special-label     { color: var(--amber); }
.fb-training .fb-special-label { color: var(--cyan); }
.fb-leave .fb-special-label    { color: var(--green); opacity: 0.7; }

/* Duty card */
.fb-duty {
  background: var(--bg2);
  border: 1px solid var(--border);
  cursor: pointer;
  transition: filter 0.1s;
  padding: 0;
}
.fb-duty:active { filter: brightness(1.15); }

/* Fatigue colour states */
.fb-duty-normal { border-left: 3px solid transparent; }
.fb-duty-amber  { border-left: 3px solid var(--amber); background: rgba(255,171,64,0.06); }
.fb-duty-red    { border-left: 3px solid var(--red);   background: rgba(255,61,87,0.08); }

/* Duty body */
.fb-body {
  flex: 1;
  min-width: 0;
  padding: 9px 0;
}
.fb-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
}
.fb-route {
  display: flex;
  align-items: center;
  flex-wrap: nowrap;
  gap: 2px;
  overflow: hidden;
}
.fb-code {
  font-family: var(--mono);
  font-size: 12px;
  font-weight: 700;
  color: var(--text2);
}
.fb-away {
  color: var(--cyan);
}
.fb-arr {
  font-family: var(--mono);
  font-size: 11px;
  color: var(--text3);
  padding: 0 1px;
}
.fb-meta {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-shrink: 0;
}
.fb-rpt {
  font-family: var(--mono);
  font-size: 11px;
  color: var(--text2);
}
.fb-sec {
  font-family: var(--mono);
  font-size: 10px;
  color: var(--text3);
  letter-spacing: 0.5px;
}

/* Flag tags */
.fb-flags {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
  margin-top: 5px;
}
.fb-flag {
  font-family: var(--mono);
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 1px;
  padding: 2px 7px;
  border-radius: 20px;
  color: var(--text);
  background: rgba(255,255,255,0.07);
  border: 1px solid rgba(255,255,255,0.12);
}
.fb-duty-amber .fb-flag { color: var(--amber); background: rgba(255,171,64,0.1); border-color: rgba(255,171,64,0.25); }
.fb-duty-red   .fb-flag { color: var(--red);   background: rgba(255,61,87,0.1);  border-color: rgba(255,61,87,0.25); }

/* Right-side fatigue bar */
.fb-bar {
  width: 3px;
  align-self: stretch;
  flex-shrink: 0;
  border-radius: 0 8px 8px 0;
}
.fb-bar-amber { background: var(--amber); }
.fb-bar-red   { background: var(--red); }


/* ── Fatigue Day Popup ── */
.fatigue-popup-overlay {
  position: fixed;
  inset: 0;
  z-index: 400;
  background: rgba(0,0,0,0.6);
  display: flex;
  align-items: flex-end;
  animation: fadeIn 0.15s ease;
}
.fatigue-popup-sheet {
  width: 100%;
  background: var(--bg1);
  border-top: 1px solid var(--border2);
  border-radius: 20px 20px 0 0;
  padding: 20px 20px 40px;
  animation: slideUp 0.22s cubic-bezier(0.34,1.2,0.64,1);
}
.fatigue-popup-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  margin-bottom: 18px;
}
.fatigue-popup-title-wrap {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.fatigue-popup-date {
  font-family: var(--mono);
  font-size: 15px;
  font-weight: 700;
  color: var(--text);
  letter-spacing: 1.5px;
}
.fatigue-popup-close {
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: 50%;
  width: 30px; height: 30px;
  color: var(--text2);
  font-size: 14px;
  cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.fatigue-popup-stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1px;
  background: var(--border);
  border-radius: 12px;
  overflow: hidden;
  margin-bottom: 16px;
}
.fatigue-popup-stat {
  background: var(--bg2);
  text-align: center;
  padding: 12px 4px;
}
.fatigue-popup-stat-val {
  font-family: var(--mono);
  font-size: 15px;
  font-weight: 700;
  color: var(--text);
  line-height: 1;
}
.popup-val-warn { color: var(--red) !important; }
.popup-stat-warn { background: rgba(255,61,87,0.08) !important; }
.fatigue-popup-stat-label {
  font-family: var(--mono);
  font-size: 8px;
  color: var(--text2);
  letter-spacing: 1px;
  margin-top: 5px;
  text-transform: uppercase;
}
.fatigue-popup-route-wrap {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 4px;
  padding: 12px 14px;
  background: var(--bg2);
  border-radius: 10px;
}
.popup-route-code {
  font-family: var(--mono);
  font-size: 14px;
  font-weight: 700;
  color: var(--cyan);
  background: rgba(0,212,255,0.1);
  border: 1px solid rgba(0,212,255,0.25);
  border-radius: 6px;
  padding: 4px 10px;
  letter-spacing: 1px;
}
.popup-route-arrow {
  font-family: var(--mono);
  font-size: 13px;
  color: var(--text3);
  padding: 0 2px;
}
.popup-flags {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: 12px;
}
.popup-flag {
  font-family: var(--mono);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 1px;
  padding: 4px 10px;
  border-radius: 20px;
  color: var(--red);
  background: rgba(255,61,87,0.1);
  border: 1px solid rgba(255,61,87,0.3);
}

/* ── Rest Period Timeline ── */
.rest-timeline {
  display: flex;
  flex-direction: column;
  gap: 6px;
  margin-top: 8px;
}
.rest-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 10px 12px;
  border-radius: 10px;
  border-left: 3px solid transparent;
}
.rest-green {
  background: rgba(0,230,118,0.06);
  border-left-color: var(--green);
}
.rest-amber {
  background: rgba(255,171,64,0.08);
  border-left-color: var(--amber);
}
.rest-red {
  background: rgba(255,61,87,0.08);
  border-left-color: var(--red);
}
.rest-row-left {
  display: flex;
  flex-direction: column;
  gap: 4px;
  min-width: 0;
}
.rest-row-flights {
  display: flex;
  align-items: center;
  gap: 5px;
  flex-wrap: wrap;
}
.rest-flt {
  font-family: var(--mono);
  font-size: 13px;
  font-weight: 700;
  color: var(--text);
}
.rest-arr, .rest-dep {
  font-family: var(--mono);
  font-size: 11px;
  color: var(--text3);
}
.rest-arrow {
  font-family: var(--mono);
  font-size: 11px;
  color: var(--text3);
  padding: 0 2px;
}
.rest-row-dates {
  font-family: var(--mono);
  font-size: 10px;
  color: var(--text3);
  letter-spacing: 0.5px;
}
.rest-row-right {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 3px;
  flex-shrink: 0;
}
.rest-dur {
  font-family: var(--mono);
  font-size: 17px;
  font-weight: 700;
}
.rest-dur-green { color: var(--green); }
.rest-dur-amber { color: var(--amber); }
.rest-dur-red   { color: var(--red);   }
.rest-label {
  font-family: var(--mono);
  font-size: 9px;
  letter-spacing: 1.5px;
  padding: 2px 7px;
  border-radius: 20px;
}
.rest-label-green {
  color: var(--green);
  background: rgba(0,230,118,0.12);
}
.rest-label-amber {
  color: var(--amber);
  background: rgba(255,171,64,0.12);
}
.rest-label-red {
  color: var(--red);
  background: rgba(255,61,87,0.12);
}
