
/* ══════════════════════════════════════════
   UX IMPROVEMENTS — ux-improvements.css
   ══════════════════════════════════════════ */

/* ── FAQ ACCORDION ── */
#faq { background: var(--bg); }
.faq-list { max-width: 820px; margin: 0 auto; display: flex; flex-direction: column; gap: 12px; }
.faq-item {
  border: 1px solid rgba(200,16,46,0.15); border-radius: 8px;
  background: var(--card); overflow: hidden;
  transition: border-color .25s;
}
.faq-item.open { border-color: rgba(200,16,46,0.4); }
.faq-q {
  width: 100%; display: flex; align-items: center; justify-content: space-between;
  padding: 20px 24px; background: none; border: none; cursor: pointer;
  text-align: left; gap: 16px; font-family: var(--font);
}
.faq-q span:first-child { font-size: .95rem; font-weight: 600; color: #ddd; line-height: 1.4; transition: color .2s; }
.faq-item.open .faq-q span:first-child { color: #fff; }
.faq-icon {
  font-size: 1.4rem; font-weight: 300; color: var(--red); flex-shrink: 0;
  transition: transform .3s cubic-bezier(.22,1,.36,1);
  width: 24px; text-align: center; line-height: 1;
}
.faq-item.open .faq-icon { transform: rotate(45deg); }
.faq-a {
  max-height: 0; overflow: hidden;
  transition: max-height .4s cubic-bezier(.22,1,.36,1), padding .3s;
  padding: 0 24px;
}
.faq-item.open .faq-a { max-height: 400px; padding: 0 24px 20px; }
.faq-a p { font-size: .88rem; color: var(--text-muted); line-height: 1.75; }
.faq-a p strong { color: #ddd; }
.faq-a p em { color: rgba(200,16,46,0.9); font-style: normal; }
.faq-q:hover span:first-child { color: #fff; }

/* ── TOAST NOTIFICATION SYSTEM ── */
#toast-container {
  position: fixed; top: 90px; right: 24px; z-index: 99990;
  display: flex; flex-direction: column; gap: 10px;
  pointer-events: none;
}
.toast {
  background: #111; border: 1px solid rgba(200,16,46,0.25);
  border-radius: 8px; padding: 12px 18px; min-width: 240px; max-width: 320px;
  display: flex; align-items: flex-start; gap: 12px;
  box-shadow: 0 8px 32px rgba(0,0,0,0.5);
  transform: translateX(120%); opacity: 0;
  transition: all .35s cubic-bezier(.22,1,.36,1);
  pointer-events: auto;
}
.toast.show { transform: translateX(0); opacity: 1; }
.toast.hide { transform: translateX(120%); opacity: 0; }
.toast-icon { font-size: 1rem; flex-shrink: 0; margin-top: 1px; }
.toast-body { flex: 1; }
.toast-title { font-size: .82rem; font-weight: 700; color: #fff; margin-bottom: 2px; }
.toast-msg { font-size: .76rem; color: var(--text-muted); }
.toast-close { background: none; border: none; color: #555; cursor: pointer; font-size: 1rem; padding: 0; line-height: 1; }
.toast-close:hover { color: #fff; }
.toast.toast-success { border-color: rgba(74,222,128,0.3); }
.toast.toast-info { border-color: rgba(200,16,46,0.3); }
.toast.toast-warn { border-color: rgba(251,191,36,0.3); }

/* ── IMPROVED MOBILE MENU — full overlay ── */
.mobile-overlay {
  position: fixed; inset: 0; z-index: 8000;
  background: rgba(8,8,8,0.98);
  backdrop-filter: blur(20px);
  display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  gap: 0;
  transform: translateX(100%);
  transition: transform .4s cubic-bezier(.22,1,.36,1);
}
.mobile-overlay.open { transform: translateX(0); }
.mobile-overlay-close {
  position: absolute; top: 24px; right: 24px;
  background: none; border: none; color: #888;
  font-size: 1.8rem; cursor: pointer; padding: 8px;
  transition: color .2s;
}
.mobile-overlay-close:hover { color: var(--red); }
.mobile-overlay a {
  font-size: 2rem; font-weight: 800; text-decoration: none;
  color: #888; text-transform: uppercase; letter-spacing: 2px;
  padding: 16px 0; width: 100%; text-align: center;
  border-bottom: 1px solid rgba(200,16,46,0.08);
  transition: color .25s, padding-left .25s;
}
.mobile-overlay a:hover { color: #fff; padding-left: 16px; }
.mobile-overlay a.nav-cta-mobile {
  color: var(--red); margin-top: 24px;
  border: 1px solid rgba(200,16,46,0.3); border-radius: 4px;
  width: auto; padding: 14px 48px;
  font-size: 1.1rem; letter-spacing: 1px;
}
.mobile-overlay a.nav-cta-mobile:hover { background: rgba(200,16,46,0.1); padding-left: 48px; }

/* hide old mobile-menu when overlay is used */
.mobile-menu { display: none !important; }

/* ── SCROLL-SPY NAV ── */
.nav-links a.spy-active {
  color: var(--red) !important;
}
.nav-links a.spy-active::after {
  width: 100% !important;
}

/* ── KEYBOARD HINT TOOLTIP ── */
.aria-shortcut-hint {
  position: fixed; bottom: 100px; right: 96px; z-index: 9400;
  background: #111; border: 1px solid rgba(200,16,46,0.2);
  border-radius: 8px; padding: 10px 14px;
  font-size: .74rem; color: var(--text-muted);
  font-family: var(--mono);
  pointer-events: none;
  opacity: 0; transform: translateY(6px);
  transition: all .3s;
}
.aria-shortcut-hint.show { opacity: 1; transform: translateY(0); }
.aria-shortcut-hint kbd {
  background: rgba(200,16,46,0.15); border: 1px solid rgba(200,16,46,0.3);
  border-radius: 3px; padding: 1px 6px; color: var(--red);
  font-size: .72rem;
}

@media(max-width:768px){
  .faq-q { padding: 16px 18px; }
  .faq-item.open .faq-a { padding: 0 18px 16px; }
  .mobile-overlay a { font-size: 1.5rem; }
}

/* ── LIGHT MODE TOGGLE BUTTON ── */
#light-mode-toggle {
  position: fixed; bottom: 32px; left: 28px; z-index: 9500;
  width: 44px; height: 44px; border-radius: 50%;
  background: rgba(15,15,15,0.9); border: 1px solid rgba(200,16,46,0.3);
  color: var(--text-muted); cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  font-size: 1.1rem; backdrop-filter: blur(8px);
  transition: all .3s cubic-bezier(.22,1,.36,1);
  box-shadow: 0 4px 16px rgba(0,0,0,0.4);
}
#light-mode-toggle:hover {
  border-color: var(--red); color: var(--red);
  transform: scale(1.1);
  box-shadow: 0 6px 24px rgba(200,16,46,0.25);
}
#light-mode-toggle .lm-icon { transition: transform .35s; }

/* ── CURSOR STYLE TOGGLE BUTTON ── */
#cursor-toggle {
  position: fixed; bottom: 84px; left: 28px; z-index: 9500;
  width: 44px; height: 44px; border-radius: 50%;
  background: rgba(15,15,15,0.9); border: 1px solid rgba(200,16,46,0.3);
  color: var(--text-muted); cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  font-size: 1.1rem; backdrop-filter: blur(8px);
  transition: all .3s cubic-bezier(.22,1,.36,1);
  box-shadow: 0 4px 16px rgba(0,0,0,0.4);
}
#cursor-toggle:hover {
  border-color: var(--red); color: var(--red);
  transform: scale(1.1);
  box-shadow: 0 6px 24px rgba(200,16,46,0.25);
}
.cursor-toggle-icon { transition: transform .35s; }

/* ── LIGHT MODE VARIABLES & OVERRIDES ── */
body.light-mode {
  --bg: #f5f5f5;
  --bg2: #ebebeb;
  --bg3: #e0e0e0;
  --card: #ffffff;
  --card2: #f8f8f8;
  --border: rgba(200,16,46,0.18);
  --text: #111111;
  --text-muted: #444444;
  --text-dim: #888888;
}

/* ── LIGHT MODE: GLOBAL TEXT ── */
body.light-mode { color: #111111; }
body.light-mode h1,
body.light-mode h2,
body.light-mode h3,
body.light-mode h4,
body.light-mode h5,
body.light-mode h6 { color: #111111; }
body.light-mode p { color: #444444; }
body.light-mode .section-title { color: #111111; }
body.light-mode .section-sub { color: #444444; }
body.light-mode .section-tag { color: var(--red); }

/* ── LIGHT MODE: NAVBAR ── */
body.light-mode nav {
  background: rgba(245,245,245,0.9);
  border-bottom-color: rgba(200,16,46,0.15);
}
body.light-mode .nav-logo span { color: #111111; }
body.light-mode .nav-links a { color: #555555; }
body.light-mode .nav-links a:hover,
body.light-mode .nav-links a.active { color: #111111; }
body.light-mode .drop-menu {
  background: rgba(255,255,255,0.97);
  box-shadow: 0 16px 48px rgba(0,0,0,0.12);
}
body.light-mode .drop-menu::before { background: rgba(255,255,255,0.97); }
body.light-mode .drop-item { color: #111111; }
body.light-mode .drop-item-title { color: #111111; }
body.light-mode .drop-item-sub { color: #888888; }
body.light-mode .drop-arrow { border-top-color: #555555; }
body.light-mode .hamburger span { background: #111111; }

/* ── LIGHT MODE: HERO ── */
body.light-mode .hero-title { color: #111111; }
body.light-mode .hero-desc { color: #444444; }
body.light-mode .hero-stat-num { color: var(--red); }
body.light-mode .hero-stat-label { color: #888888; }
body.light-mode .hero-badge { color: var(--red); background: rgba(200,16,46,0.08); }
body.light-mode .hero-card { background: #ffffff; }
body.light-mode .hero-card h3 { color: #111111; }
body.light-mode .hero-card p { color: #555555; }

/* ── LIGHT MODE: BUTTONS ── */
body.light-mode .btn-outline {
  color: #111111;
  border-color: rgba(0,0,0,0.2);
}
body.light-mode .btn-outline:hover {
  color: var(--red);
  border-color: var(--red);
}

/* ── LIGHT MODE: CARDS & SECTIONS ── */
body.light-mode .service-card,
body.light-mode .svc-card,
body.light-mode .why-card,
body.light-mode .step,
body.light-mode .type-card,
body.light-mode .partner-card,
body.light-mode .about-info-card,
body.light-mode .attack-card,
body.light-mode .family-badge,
body.light-mode .safety-card,
body.light-mode .mission-card,
body.light-mode .value-card,
body.light-mode .stat-item,
body.light-mode .contact-form-box,
body.light-mode .info-block,
body.light-mode .contact-detail-card,
body.light-mode .team-card {
  background: #ffffff;
  border-color: rgba(200,16,46,0.15);
}
body.light-mode .service-card h3,
body.light-mode .svc-card h3,
body.light-mode .why-card h4,
body.light-mode .step h4,
body.light-mode .type-card h4,
body.light-mode .partner-card h3,
body.light-mode .about-info-card h4,
body.light-mode .attack-card h4,
body.light-mode .mission-card h3,
body.light-mode .value-card h4,
body.light-mode .team-card h4 { color: #111111; }

body.light-mode .service-card > p,
body.light-mode .svc-card p,
body.light-mode .why-card p,
body.light-mode .step p,
body.light-mode .type-card p,
body.light-mode .partner-card p,
body.light-mode .about-info-card p,
body.light-mode .attack-card p,
body.light-mode .mission-card p,
body.light-mode .value-card p,
body.light-mode .feat-list li,
body.light-mode .svc-features li,
body.light-mode .service-features li { color: #555555; }

body.light-mode .why-num { color: rgba(200,16,46,0.2); }
body.light-mode .step-num { color: rgba(200,16,46,0.15); }
body.light-mode .family-badge .name { color: var(--red); }
body.light-mode .family-badge .type { color: #888888; }
body.light-mode .safety-card h4 { color: #2d9e5f; }
body.light-mode .safety-card p { color: #555555; }

/* ── LIGHT MODE: PARTNER HIGHLIGHT BOX ── */
body.light-mode .partner-highlight {
  background: rgba(200,16,46,0.03);
  border-color: rgba(200,16,46,0.2);
}
body.light-mode .partner-highlight p { color: #555555; }

/* ── LIGHT MODE: METRICS ── */
body.light-mode .metric {
  background: rgba(0,0,0,0.04);
  border-color: rgba(200,16,46,0.12);
}
body.light-mode .metric .key { color: #888888; }

/* ── LIGHT MODE: FORMS ── */
body.light-mode .form-group label { color: #555555; }
body.light-mode .form-group input,
body.light-mode .form-group select,
body.light-mode .form-group textarea {
  background: #f0f0f0;
  border-color: rgba(200,16,46,0.2);
  color: #111111;
}
body.light-mode .form-group input::placeholder,
body.light-mode .form-group textarea::placeholder { color: #aaaaaa; }
body.light-mode .contact-form-box h3 { color: #111111; }
body.light-mode .contact-form-box .form-subtitle { color: #888888; }
body.light-mode .info-block h4 { color: var(--red); }
body.light-mode .info-row { color: #555555; }

/* ── LIGHT MODE: FOOTER ── */
body.light-mode footer { background: #ebebeb; }
body.light-mode .footer-brand p { color: #888888; }
body.light-mode .footer-col h5 { color: #555555; }
body.light-mode .footer-col a { color: #888888; }
body.light-mode .footer-col a:hover { color: var(--red); }
body.light-mode .footer-bottom p { color: #888888; }
body.light-mode .footer-bottom { border-top-color: rgba(200,16,46,0.15); }

/* ── LIGHT MODE: BREADCRUMB ── */
body.light-mode .breadcrumb a { color: #888888; }
body.light-mode .breadcrumb span { color: #111111; }

/* ── LIGHT MODE: HERO BADGE ── */
body.light-mode .hero-badge { color: var(--red); }

/* ── LIGHT MODE: SECTION TAG ── */
body.light-mode .section-tag { color: var(--red); }

/* ── LIGHT MODE: PARTNER NAME / FOR ── */
body.light-mode .partner-name { color: var(--red); }
body.light-mode .partner-for { color: #888888; }

/* ── LIGHT MODE: ATTACK TYPE LABEL ── */
body.light-mode .attack-type { color: var(--red); }

/* ── LIGHT MODE: MONO / CODE TEXT ── */
body.light-mode [style*="font-family:var(--mono)"],
body.light-mode [style*="font-family: var(--mono)"] { color: #555555; }

/* ── LIGHT MODE: DETAIL BODY ── */
body.light-mode .detail-body h2 { color: #111111; }
body.light-mode .detail-body p { color: #555555; }

/* ── LIGHT MODE: WHY PHISHING MATTERS SECTION ── */
body.light-mode [style*="color:var(--text-muted)"] { color: #555555; }

/* ── LIGHT MODE: STAT STRIP ── */
body.light-mode .stat-item .num { color: var(--red); }
body.light-mode .stat-item .lbl { color: #888888; }

/* ── LIGHT MODE: TEAM CARD ── */
body.light-mode .team-card span { color: var(--red); }

/* ── LIGHT MODE: TIMELINE ── */
body.light-mode .timeline-item h4 { color: var(--red); }
body.light-mode .timeline-item p { color: #555555; }

/* ── LIGHT MODE: FAQ ── */
body.light-mode .faq-item { background: #ffffff; border-color: rgba(200,16,46,0.15); }
body.light-mode .faq-q span:first-child { color: #333333; }
body.light-mode .faq-item.open .faq-q span:first-child { color: #111111; }
body.light-mode .faq-a p { color: #555555; }
body.light-mode .faq-a p strong { color: #333333; }

/* ── LIGHT MODE: TRUST STRIP ── */
body.light-mode .trust-strip { background: #ebebeb; }

/* ── LIGHT MODE: MOBILE OVERLAY ── */
body.light-mode .mobile-overlay { background: rgba(240,240,240,0.98); }
body.light-mode .mobile-overlay a { color: #777777; }
body.light-mode .mobile-overlay a:hover { color: var(--red); }

/* ── LIGHT MODE: BACK TO TOP ── */
body.light-mode #back-to-top {
  background: rgba(240,240,240,0.9);
  border-color: rgba(200,16,46,0.3);
}

/* ── LIGHT MODE: TOGGLE BUTTON ── */
body.light-mode #light-mode-toggle {
  background: rgba(240,240,240,0.9);
  border-color: rgba(200,16,46,0.25);
  color: #555555;
}
body.light-mode #cursor-toggle {
  background: rgba(240,240,240,0.9);
  border-color: rgba(200,16,46,0.25);
  color: #555555;
}

/* ── LIGHT MODE: TOAST ── */
body.light-mode .toast { background: #ffffff; border-color: rgba(200,16,46,0.2); }
body.light-mode .toast-title { color: #111111; }
body.light-mode .toast-msg { color: #555555; }

/* ── LIGHT MODE: CHATBOT ── */
body.light-mode .chatbot-window { background: #fafafa; border-color: rgba(200,16,46,0.2); }
body.light-mode .chat-header { background: #f0f0f0; }
body.light-mode .chat-header-info h4 { color: #111111; }
body.light-mode .chat-msg.bot .msg-bubble { background: #efefef; border-color: rgba(200,16,46,0.1); color: #333333; }
body.light-mode .chat-msg.bot .msg-bubble strong { color: #111111; }
body.light-mode #chat-input { background: #f0f0f0; border-color: rgba(200,16,46,0.15); color: #111111; }
body.light-mode #chat-input::placeholder { color: #aaaaaa; }
body.light-mode .chat-input-bar { background: #fafafa; }

/* ── LIGHT MODE: COOKIE BAR ── */
body.light-mode #cookie-bar { background: rgba(240,240,240,0.97); border-color: rgba(200,16,46,0.15); }
body.light-mode #cookie-bar p { color: #555555; }
body.light-mode .cookie-decline { color: #777777; border-color: rgba(0,0,0,0.15); }

/* ── LIGHT MODE: CURSOR ── */
body.light-mode #cursor-dot { background: var(--red); }
body.light-mode #cursor-ring { border-color: rgba(200,16,46,0.45); }

/* ── LIGHT MODE: TEAM CARDS ── */
body.light-mode .team-member-card { background: #ffffff; border-color: rgba(200,16,46,0.15); }
body.light-mode .tm-name { color: #111111; }
body.light-mode .tm-tags span { color: #666666; background: rgba(200,16,46,0.06); }
