/* ==========================================
   DESIGN TOKENS + GLOBAL LAYOUT
   Obsidian Monitoring Advisory - Visual Identity & Structure
   
   Single source of truth for all design values.
   Every page MUST import this file FIRST.
   ========================================== */

/* ── Design Tokens ── */
:root {
  /* Typography */
  --font-family: -apple-system, BlinkMacSystemFont, 'SF Pro Text', 'Segoe UI', Roboto, Helvetica, Arial, sans-serif;
  --font-family-mono: 'SF Mono', SFMono-Regular, ui-monospace, Menlo, monospace;
  --font-size-xs: 13px;
  --font-size-sm: 15px;
  --font-size-base: 15px;
  --font-size-md: 16px;
  --font-size-lg: 18px;
  --font-size-xl: 23px;
  --font-size-2xl: 29px;
  --font-size-3xl: 36px;
  --font-size-4xl: 42px;
  --font-size-5xl: 52px;
  --font-weight-normal: 400;
  --font-weight-medium: 500;
  --font-weight-semibold: 600;
  --font-weight-bold: 700;
  --line-height-tight: 1.3;
  --line-height-normal: 1.5;
  --line-height-relaxed: 1.65;

  /* Colors: Brand */
  --color-brand: #2d3967;
  --color-brand-light: #4f5d8a;
  --color-brand-lighter: #e8eaf2;
  /* Electric Blue */
  --color-accent: #3388FF;
  --color-accent-light: #84c3ff;
  --color-accent-bg: #E6F0FF;
  /* Intense Red (uncomment to test) */
  /* --color-accent: #E60023; */
  /* --color-accent-light: #FF1A3D; */
  /* --color-accent-bg: #FFE6EA; */

  /* Dark surface background – single token used by topbar, footer, CTA, form panel, hero banners */
  --color-dark-bg: linear-gradient(135deg, var(--color-brand) 0%, var(--color-accent) 100%);
  /* Pattern image URL (override in :root to change globally) */
  --dark-bg-pattern: url("https://res.cloudinary.com/djeg1yyff/image/upload/v1771252844/site/bg-pattern.png");

  /* Colors: Neutral */
  --color-bg: #f5f6f8;
  --color-surface: #ffffff;
  --color-surface-hover: #f9fafb;
  --color-border: rgba(0, 0, 0, 0.08);
  --color-border-strong: rgba(0, 0, 0, 0.14);
  --color-text-primary: #111827;
  --color-text-secondary: #4b5563;
  --color-text-muted: #6b7280;
  --color-text-faint: #9ca3af;

  /* Colors: Semantic */
  --color-success: #059669;
  --color-success-bg: #d1fae5;
  --color-warning: #d97706;
  --color-warning-bg: #fef3c7;
  --color-error: #dc2626;
  --color-error-bg: #fee2e2;
  --color-info: var(--color-accent);
  --color-info-bg: var(--color-accent-bg);

  /* Spacing */
  --space-1: 4px;
  --space-2: 8px;
  --space-3: 12px;
  --space-4: 16px;
  --space-5: 20px;
  --space-6: 24px;
  --space-8: 32px;
  --space-10: 40px;

  /* Border Radius */
  --radius-sm: 3px;
  --radius-md: 3px;
  --radius-lg: 4px;
  --radius-xl: 6px;
  --radius-full: 9999px;

  /* Shadows */
  --shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.04);
  --shadow-md: 0 2px 8px rgba(0, 0, 0, 0.06);
  --shadow-lg: 0 4px 16px rgba(0, 0, 0, 0.08);
  --shadow-focus: 0 0 0 3px rgba(99, 102, 241, 0.12);

  /* Transitions */
  --transition-fast: 0.15s ease;
  --transition-normal: 0.2s ease;

  /* Layout */
  --content-max-width: 1120px;
  --sidebar-width: 280px;
  --header-height: auto;
}


/* ── Global Reset & Base ── */
*, *::before, *::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html {
  height: 100%;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

body {
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  background: var(--color-bg);
  color: var(--color-text-primary);
  font-family: var(--font-family);
  font-size: var(--font-size-base);
  line-height: var(--line-height-normal);
}


/* ── Page Structure ──
   Every page: <header> + <main class="ma-main"> + <footer>
   Main grows to fill screen, footer sticks to bottom.
   ========================================== */
.ma-main {
  flex: 1 0 auto;
  width: 100%;
}

.ma-main > .page-container {
  max-width: var(--content-max-width);
  margin: 0 auto;
  padding: var(--space-8) var(--space-5);
}


/* ── Header (global) ── */
.ma-header {
  width: 100%;
  background: var(--color-surface);
  border-bottom: 1px solid var(--color-border);
  position: sticky;
  top: 0;
  z-index: 100;
  flex-shrink: 0;
}
.ma-header-inner {
  max-width: var(--content-max-width);
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 8px var(--space-5);
}


/* ── Reusable dark section (gradient + pattern image) ── */
.dark-section {
  position: relative;
  overflow: hidden;
  background: var(--color-dark-bg);
  color: #fff;
}
.dark-section::after {
  content: '';
  position: absolute;
  top: 0; right: 0; bottom: 0;
  width: 55%;
  background: var(--dark-bg-pattern) no-repeat right center;
  background-size: contain;
  opacity: 0.12;
  z-index: 0;
  pointer-events: none;
}
.dark-section > * {
  position: relative;
  z-index: 1;
}

/* ── Footer (global) ── */
.ma-footer {
  width: 100%;
  border-top: none;
  flex-shrink: 0;
  /* inherits dark-section styles when class is added */
}
.ma-footer-inner {
  max-width: var(--content-max-width);
  margin: 0 auto;
  padding: var(--space-8) var(--space-5) var(--space-5);
  color: #fff;
}

/* Brand row: logo + slogan */
.ma-footer-brand {
  margin-bottom: var(--space-5);
}
.ma-logo-line--white { color: #fff !important; }
.ma-logo-line--white.ma-logo-line--light { color: rgba(255,255,255,0.7) !important; }
.ma-footer-slogan {
  font-size: var(--font-size-sm);
  color: rgba(255,255,255,0.6);
  margin-top: var(--space-2);
  font-style: italic;
  letter-spacing: 0.2px;
}

/* Disclaimer */
.ma-footer-disclaimer {
  font-size: var(--font-size-sm);
  color: rgba(255,255,255,0.55);
  line-height: var(--line-height-relaxed);
  max-width: 720px;
  padding-bottom: var(--space-5);
  margin-bottom: var(--space-4);
  border-bottom: 1px solid rgba(255,255,255,0.12);
}

/* Bottom row: copyright + nav links */
.ma-footer-bottom {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-4);
  flex-wrap: wrap;
}
.ma-footer-copyright {
  font-size: var(--font-size-sm);
  color: rgba(255,255,255,0.5);
  white-space: nowrap;
}
.ma-footer-nav {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  flex-wrap: wrap;
}
.ma-footer-link {
  font-size: var(--font-size-sm);
  color: rgba(255,255,255,0.7);
  text-decoration: none;
  transition: color var(--transition-fast);
  white-space: nowrap;
}
.ma-footer-link:hover { color: #fff; }

@media (max-width: 768px) {
  .ma-footer-inner { padding: var(--space-6) var(--space-4) var(--space-4); }
  .ma-footer-brand { text-align: center; }
  .ma-footer-brand .ma-logo { justify-content: center; }
  .ma-footer-slogan { text-align: center; }
  .ma-footer-disclaimer { text-align: center; }
  .ma-footer-bottom { flex-direction: column; text-align: center; gap: var(--space-3); }
  .ma-footer-nav { justify-content: center; }
}


/* ── Form System ──
   Reusable form styles for all pages.
   ========================================== */
.form-group { margin-bottom: var(--space-4); }
.form-group:last-child { margin-bottom: 0; }

.form-label {
  display: block;
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  color: var(--color-text-secondary);
  margin-bottom: var(--space-1);
}

.form-input {
  display: block;
  width: 100%;
  padding: 9px 12px;
  border: 1px solid var(--color-border-strong);
  border-radius: var(--radius-md);
  font-size: var(--font-size-base);
  font-family: var(--font-family);
  color: var(--color-text-primary);
  background: var(--color-surface);
  outline: none;
  transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
}
.form-input:focus {
  border-color: var(--color-accent);
  box-shadow: var(--shadow-focus);
}
.form-input:disabled {
  background: var(--color-surface-hover);
  color: var(--color-text-muted);
  cursor: not-allowed;
}
.form-input::placeholder { color: var(--color-text-faint); }

.form-hint {
  font-size: var(--font-size-xs);
  color: var(--color-text-faint);
  margin-top: 3px;
}

.form-row {
  display: flex;
  gap: var(--space-4);
}
.form-row > .form-group { flex: 1; min-width: 0; }

@media (max-width: 640px) {
  .form-row { flex-direction: column; gap: 0; }
}


/* ── Buttons ── */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 6px;
  padding: 8px 18px;
  border: none; border-radius: var(--radius-md);
  font-size: var(--font-size-sm); font-weight: var(--font-weight-semibold);
  font-family: var(--font-family);
  cursor: pointer; transition: opacity var(--transition-fast);
  text-decoration: none; line-height: 1;
}
.btn:hover { opacity: 0.9; }
.btn:disabled { opacity: 0.5; cursor: not-allowed; }
.btn-primary { background: var(--color-brand); color: #fff; }
.btn-accent { background: var(--color-accent); color: #fff; }


/* ── Section Card ── */
.section-card {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  margin-bottom: var(--space-5);
  overflow: hidden;
}
.section-card-header {
  padding: 14px var(--space-5);
  border-bottom: 1px solid var(--color-border);
  font-size: var(--font-size-md); font-weight: var(--font-weight-semibold);
  color: var(--color-text-primary);
  display: flex; align-items: center; gap: var(--space-2);
}
.section-card-header i { color: var(--color-text-muted); font-size: 14px; }
.section-card-body { padding: var(--space-5); }


/* ── Two-Column Layout ──
   Used on pages with a main content area + sidebar.
   .two-col > .main-col (flex: 1) + .side-col (fixed width)
   Stacks vertically on mobile.
   ========================================== */
.two-col {
  display: flex;
  gap: var(--space-6);
  align-items: flex-start;
}
.two-col > .main-col {
  flex: 1;
  min-width: 0;
}
.two-col > .side-col {
  flex: 0 0 var(--sidebar-width);
  position: sticky;
  top: 80px;
  max-height: calc(100vh - 100px);
  overflow-y: auto;
}

@media (max-width: 900px) {
  .two-col { flex-direction: column; }
  .two-col > .side-col {
    flex: none;
    width: 100%;
    position: static;
    max-height: none;
  }
}


/* ── Sidebar Module ──
   Reusable sidebar section with title + content.
   ========================================== */
.sidebar-section {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: var(--space-4);
  margin-bottom: var(--space-3);
}
/* Flat variant: no background, no border, no padding (title + content only) */
.sidebar-section-flat {
  margin-bottom: var(--space-3);
}
.sidebar-title {
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-semibold);
  color: var(--color-text-primary);
  margin-bottom: var(--space-2);
}
.sidebar-subtitle {
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-normal);
  color: var(--color-text-faint);
  margin-left: 4px;
}
.sidebar-text {
  font-size: var(--font-size-sm);
  color: var(--color-text-muted);
  line-height: var(--line-height-relaxed);
}
.sidebar-list {
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.sidebar-list-item {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 5px 0;
  font-size: var(--font-size-sm);
  color: var(--color-text-secondary);
  cursor: pointer;
  transition: color var(--transition-fast);
}
.sidebar-list-item:hover { color: var(--color-accent); }
.sidebar-list-item .count {
  font-size: var(--font-size-xs);
  color: var(--color-text-faint);
}


/* ── Mini Card ──
   Reusable compact news card for sidebars/modules.
   Used by the SidebarNewsFeed JS component.
   ========================================== */
.mini-card {
  display: block;
  padding: var(--space-3);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  margin-bottom: var(--space-2);
  text-decoration: none;
  transition: all var(--transition-fast);
  background: var(--color-surface);
}
.mini-card:hover {
  border-color: var(--color-accent);
  box-shadow: var(--shadow-sm);
}
.mini-card:last-child { margin-bottom: 0; }
.mini-card-date {
  font-size: 10px;
  font-weight: var(--font-weight-semibold);
  color: var(--color-accent);
  margin-bottom: 3px;
  display: flex;
  align-items: center;
  gap: 4px;
}
.mini-card-title {
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  color: var(--color-text-primary);
  line-height: var(--line-height-tight);
  margin-bottom: 3px;
}
.mini-card-source {
  font-size: var(--font-size-xs);
  color: var(--color-text-faint);
}

/* Show more toggle for mini-card lists */
.mini-card-toggle {
  display: block;
  width: 100%;
  padding: 6px;
  margin-top: var(--space-2);
  text-align: center;
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
  color: var(--color-accent);
  background: none;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  cursor: pointer;
  font-family: var(--font-family);
  transition: all var(--transition-fast);
}
.mini-card-toggle:hover {
  background: var(--color-accent-bg);
  border-color: var(--color-accent);
}


/* ── Multi-Select Filter Component ──
   Reusable dropdown with multi-select, search, chips.
   Used by MultiSelectFilter JS class (multi-select-filter.js).
   ========================================== */
.msf {
  position: relative;
  display: inline-block;
  min-width: 160px;
}

/* Trigger / button */
.msf-trigger {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 7px 10px;
  border: 1px solid var(--color-border-strong);
  border-radius: var(--radius-md);
  font-size: var(--font-size-sm);
  font-family: var(--font-family);
  background: var(--color-surface);
  color: var(--color-text-secondary);
  cursor: pointer;
  transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
  min-height: 34px;
  white-space: nowrap;
  max-width: 320px;
  overflow: hidden;
  width: 100%;
  box-sizing: border-box;
}
.msf-trigger:hover {
  border-color: var(--color-accent);
}
.msf-open .msf-trigger {
  border-color: var(--color-accent);
  box-shadow: var(--shadow-focus);
}
.msf-trigger-icon {
  font-size: 12px;
  color: var(--color-text-faint);
  flex-shrink: 0;
}
.msf-trigger-text {
  flex: 1;
  overflow: hidden;
  text-overflow: ellipsis;
}
.msf-chevron {
  font-size: 10px;
  color: var(--color-text-faint);
  margin-left: auto;
  flex-shrink: 0;
  transition: transform var(--transition-fast);
}
.msf-open .msf-chevron {
  transform: rotate(180deg);
}

/* Selected chips inside trigger */
.msf-chip {
  display: inline-flex;
  align-items: center;
  gap: 3px;
  padding: 1px 7px;
  border-radius: var(--radius-full);
  background: var(--color-accent-bg);
  color: var(--color-accent);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
  line-height: 1.5;
  max-width: 120px;
  white-space: nowrap;
}
.msf-chip-label {
  overflow: hidden;
  text-overflow: ellipsis;
}
.msf-chip-remove {
  cursor: pointer;
  font-size: 13px;
  line-height: 1;
  opacity: 0.7;
  transition: opacity var(--transition-fast);
}
.msf-chip-remove:hover {
  opacity: 1;
}
.msf-chip-more {
  background: var(--color-border-strong);
  color: var(--color-text-secondary);
}

/* Dropdown panel */
.msf-dropdown {
  position: absolute;
  top: calc(100% + 4px);
  left: 0;
  min-width: 260px;
  max-width: 340px;
  background: var(--color-surface);
  border: 1px solid var(--color-border-strong);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-lg);
  z-index: 200;
  animation: msf-fade-in 0.12s ease;
}
@keyframes msf-fade-in {
  from { opacity: 0; transform: translateY(-4px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* Search inside dropdown */
.msf-search-wrap {
  position: relative;
  padding: var(--space-2);
  border-bottom: 1px solid var(--color-border);
}
.msf-search-icon {
  position: absolute;
  left: 16px;
  top: 50%;
  transform: translateY(-50%);
  font-size: 11px;
  color: var(--color-text-faint);
  pointer-events: none;
}
.msf-search {
  width: 100%;
  padding: 6px 10px 6px 28px;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  font-size: var(--font-size-sm);
  font-family: var(--font-family);
  background: var(--color-bg);
  color: var(--color-text-primary);
  outline: none;
  transition: border-color var(--transition-fast);
}
.msf-search:focus {
  border-color: var(--color-accent);
}
.msf-search::placeholder {
  color: var(--color-text-faint);
}

/* Select all / Clear row */
.msf-actions {
  display: flex;
  justify-content: space-between;
  padding: 4px var(--space-2);
  border-bottom: 1px solid var(--color-border);
}
.msf-action-btn {
  background: none;
  border: none;
  font-size: var(--font-size-xs);
  font-family: var(--font-family);
  color: var(--color-accent);
  cursor: pointer;
  padding: 3px 6px;
  border-radius: var(--radius-sm);
  transition: background var(--transition-fast);
  font-weight: var(--font-weight-medium);
}
.msf-action-btn:hover {
  background: var(--color-accent-bg);
}

/* Options list */
.msf-list {
  max-height: 240px;
  overflow-y: auto;
  padding: var(--space-1) 0;
}
.msf-option {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  padding: 6px var(--space-3);
  cursor: pointer;
  transition: background var(--transition-fast);
  font-size: var(--font-size-sm);
  color: var(--color-text-secondary);
  user-select: none;
}
.msf-option:hover {
  background: var(--color-surface-hover);
}
.msf-option-active {
  background: var(--color-accent-bg);
  color: var(--color-accent);
}
.msf-option-active:hover {
  background: var(--color-accent-bg);
}
.msf-option-label {
  flex: 1;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.msf-option-count {
  font-size: var(--font-size-xs);
  color: var(--color-text-faint);
  flex-shrink: 0;
}
.msf-checkbox {
  width: 16px;
  height: 16px;
  border: 1.5px solid var(--color-border-strong);
  border-radius: 3px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  transition: all var(--transition-fast);
  font-size: 9px;
  color: #fff;
}
.msf-checkbox-checked {
  background: var(--color-accent);
  border-color: var(--color-accent);
}
.msf-empty {
  padding: var(--space-4);
  text-align: center;
  font-size: var(--font-size-sm);
  color: var(--color-text-faint);
}

/* Responsive: dropdown full-width on mobile */
@media (max-width: 768px) {
  .msf { min-width: 0; width: 100%; }
  .msf-trigger { width: 100%; max-width: none; }
  .msf-dropdown { min-width: 100%; max-width: none; }
}


/* ==========================================
   HEADER / TOPBAR / NAV / FORM PANEL
   (Critical above-the-fold CSS – must load
    in <head> to prevent FOUC)
   ========================================== */

/* ═══════ TOP BAR ═══════ */
.ma-topbar{
    width:100%;background:var(--color-dark-bg);color:rgba(255,255,255,0.85);
    font-size:var(--font-size-sm);line-height:var(--line-height-normal);z-index:99;flex-shrink:0;
}
.ma-topbar-inner{
    max-width:var(--content-max-width);margin:0 auto;
    display:flex;align-items:center;justify-content:space-between;padding:9px var(--space-5);
}
.ma-topbar-left,.ma-topbar-right{display:flex;align-items:center;gap:var(--space-4);}
.ma-topbar-link{
    color:rgba(255,255,255,0.8);text-decoration:none;transition:color var(--transition-fast);
    white-space:nowrap;display:inline-flex;align-items:center;gap:5px;font-size:var(--font-size-sm);
}
.ma-topbar-link:hover{color:#fff;}
.ma-topbar-link i{font-size:12px;}
.ma-topbar-sep{color:rgba(255,255,255,0.3);user-select:none;}

/* ═══════ MAIN HEADER ═══════ */
.ma-header-left{display:flex;align-items:center;gap:var(--space-5);min-width:0;}
.ma-header-right{display:flex;align-items:center;gap:var(--space-3);flex-shrink:0;}

.ma-logo{display:inline-flex;align-items:center;gap:5px;text-decoration:none;flex-shrink:0;}
.ma-logo:hover{opacity:.85;}
.ma-logo-img{height:52px;width:auto;display:block;}
.ma-logo-text{display:flex;flex-direction:column;line-height:1.15;}
.ma-logo-line{color:var(--color-brand);display:block;font-size:18px;}
.ma-logo-line--brand{font-weight:800;font-size:27px;letter-spacing:0.5px;}
.ma-logo-line--light{font-weight:300;font-size:12px;letter-spacing:0.3px;color:var(--color-text-secondary);}

/* CTA button */
.ma-cta{
    display:inline-flex;align-items:center;gap:6px;
    padding:8px 18px;background:var(--color-brand);color:#fff;
    font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);font-family:var(--font-family);
    border-radius:var(--radius-full);text-decoration:none;white-space:nowrap;
    border:1.5px solid var(--color-brand);cursor:pointer;
    transition:all var(--transition-fast);
}
.ma-cta:hover{background:var(--color-brand-light);border-color:var(--color-brand-light);}
.ma-cta-icon{font-size:9px;transition:transform var(--transition-fast);}
.ma-cta[aria-expanded="true"] .ma-cta-icon{transform:rotate(180deg);}

/* ── Navigation ── */
.ma-nav{display:flex;align-items:center;gap:var(--space-1);}
.ma-nav-link{
    display:inline-flex;align-items:center;gap:5px;padding:7px 14px;
    font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);font-family:var(--font-family);
    color:var(--color-text-primary);text-decoration:none;background:none;border:none;cursor:pointer;
    border-radius:var(--radius-md);transition:color var(--transition-fast),background var(--transition-fast);
    white-space:nowrap;
}
.ma-nav-link:hover,.ma-nav-link[aria-expanded="true"]{color:var(--color-text-primary);background:var(--color-surface-hover);}
.ma-nav-chevron{font-size:9px;color:var(--color-text-faint);transition:transform var(--transition-fast);}
.ma-nav-link[aria-expanded="true"] .ma-nav-chevron{transform:rotate(180deg);}

/* Industries dropdown */
.ma-nav-dropdown{position:relative;}
.ma-nav-panel{
    display:none;position:absolute;left:0;top:calc(100% + 6px);
    min-width:340px;max-width:400px;background:var(--color-surface);
    border:1px solid var(--color-border-strong);border-radius:var(--radius-lg);
    box-shadow:var(--shadow-lg);z-index:250;padding:var(--space-2) 0;
    animation:ma-panel-in .15s ease;
}
.ma-nav-panel.open{display:block;}
@keyframes ma-panel-in{from{opacity:0;transform:translateY(-6px);}to{opacity:1;transform:translateY(0);}}
.ma-nav-panel-item{display:flex;align-items:center;gap:var(--space-3);padding:10px var(--space-4);text-decoration:none;color:var(--color-text-secondary);transition:background var(--transition-fast),color var(--transition-fast);}
.ma-nav-panel-item:hover{background:var(--color-surface-hover);color:var(--color-text-primary);}
.ma-nav-panel-item--overview{color:var(--color-text-primary);font-weight:var(--font-weight-semibold);}
.ma-nav-panel-item--overview .ma-nav-panel-icon{background:var(--color-brand);color:#fff;}
.ma-nav-panel-icon{width:32px;height:32px;border-radius:var(--radius-md);background:var(--color-accent-bg);color:var(--color-accent);display:flex;align-items:center;justify-content:center;font-size:13px;flex-shrink:0;}
.ma-nav-panel-text{flex:1;min-width:0;}
.ma-nav-panel-label{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);line-height:var(--line-height-tight);}
.ma-nav-panel-hint{font-size:var(--font-size-xs);color:var(--color-text-faint);margin-top:1px;}
.ma-nav-panel-arrow{font-size:10px;color:var(--color-text-faint);margin-left:auto;opacity:0;transition:opacity var(--transition-fast),transform var(--transition-fast);}
.ma-nav-panel-item:hover .ma-nav-panel-arrow{opacity:1;transform:translateX(2px);}
.ma-nav-panel-divider{height:1px;background:var(--color-border);margin:var(--space-1) 0;}

/* ═══════ FORM PANEL OVERLAY ═══════ */
.ma-form-backdrop{
    display:none;position:fixed;inset:0;
    background:rgba(0,0,0,0.35);z-index:299;
}
.ma-form-backdrop.open{display:block;animation:ma-backdrop-in .2s ease;}
@keyframes ma-backdrop-in{from{opacity:0;}to{opacity:1;}}

.ma-form-panel{
    display:none;position:fixed;left:0;right:0;
    z-index:300;
    box-shadow:0 8px 32px rgba(0,0,0,0.25);
    max-height:calc(100vh - 80px);overflow-y:auto;
}
.ma-form-panel.open{display:block;animation:ma-panel-drop .2s ease;}
.ma-form-close{
    position:absolute;top:var(--space-4);right:var(--space-5);
    width:36px;height:36px;border-radius:50%;
    background:rgba(255,255,255,0.12);border:1px solid rgba(255,255,255,0.2);
    color:rgba(255,255,255,0.8);font-size:16px;
    display:flex;align-items:center;justify-content:center;
    cursor:pointer;z-index:10;
    transition:background var(--transition-fast),color var(--transition-fast);
}
.ma-form-close:hover{background:rgba(255,255,255,0.22);color:#fff;}
@keyframes ma-panel-drop{from{opacity:0;transform:translateY(-12px);}to{opacity:1;transform:translateY(0);}}

/* ═══════ CONTACT FORM COMPONENT (cf-*) ═══════ */
.cf-widget{
    max-width:var(--content-max-width);margin:0 auto;
    padding:var(--space-6) var(--space-5);
}
.cf-layout{display:flex;gap:var(--space-8);align-items:flex-start;}
.cf-intro{flex:0 0 340px;max-width:340px;}
.cf-form-area{flex:1;min-width:0;}

.cf-title{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:#fff;margin-bottom:var(--space-3);}
.cf-desc{font-size:var(--font-size-sm);color:rgba(255,255,255,0.7);line-height:var(--line-height-relaxed);margin-bottom:var(--space-4);}
.cf-privacy{font-size:var(--font-size-xs);color:rgba(255,255,255,0.45);line-height:var(--line-height-relaxed);}
.cf-privacy a{color:rgba(255,255,255,0.65);text-decoration:underline;}
.cf-privacy a:hover{color:#fff;}

/* Steps dots */
.cf-steps{display:flex;gap:6px;margin-bottom:var(--space-4);}
.cf-step-dot{width:8px;height:8px;border-radius:50%;background:rgba(255,255,255,0.2);transition:all var(--transition-fast);}
.cf-step-dot--active{background:#fff;transform:scale(1.2);}
.cf-step-dot--done{background:rgba(255,255,255,0.5);}

/* Form rows */
.cf-row{display:flex;gap:var(--space-3);margin-bottom:var(--space-3);}
.cf-field{flex:1;min-width:0;}

/* Inputs */
.cf-input{
    display:block;width:100%;padding:11px 14px;
    border:1.5px solid var(--color-border-strong);border-radius:var(--radius-md);
    font-size:var(--font-size-sm);font-family:var(--font-family);
    color:var(--color-text-primary);background:#fff;
    outline:none;transition:border-color var(--transition-fast),box-shadow var(--transition-fast);
    box-sizing:border-box;
}
.cf-input::placeholder{color:var(--color-text-faint);}
.cf-input:focus{border-color:var(--color-accent);box-shadow:0 0 0 3px rgba(51,136,255,0.12);}
.cf-input--error{border-color:var(--color-error);box-shadow:0 0 0 3px var(--color-error-bg);}

/* Select */
.cf-select{appearance:none;-webkit-appearance:none;
    background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");
    background-repeat:no-repeat;background-position:right 12px center;background-size:12px;
    padding-right:34px;cursor:pointer;background-color:#fff;
}
.cf-select option{color:var(--color-text-primary);background:#fff;}

/* Buttons */
.cf-actions{display:flex;align-items:center;gap:var(--space-2);justify-content:flex-end;}
.cf-btn{
    display:inline-flex;align-items:center;justify-content:center;gap:6px;
    padding:11px 28px;border:none;border-radius:var(--radius-full);
    font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);font-family:var(--font-family);
    cursor:pointer;transition:all var(--transition-fast);
}
.cf-btn-next,.cf-btn-submit{background:white;color:var(--color-brand);}
.cf-btn-next:hover,.cf-btn-submit:hover{background:var(--color-accent-bg);filter:brightness(0.9);}
.cf-btn-submit:disabled{opacity:0.6;cursor:not-allowed;}
.cf-btn-back{
    background:rgba(255,255,255,0.1);color:rgba(255,255,255,0.7);
    padding:11px 14px;border-radius:var(--radius-full);
}
.cf-btn-back:hover{background:rgba(255,255,255,0.2);color:#fff;}

/* Spinner */
.cf-spinner{display:inline-block;width:14px;height:14px;border:2px solid rgba(45,57,103,0.3);border-top-color:var(--color-brand);border-radius:50%;animation:cf-spin .6s linear infinite;}
@keyframes cf-spin{to{transform:rotate(360deg);}}

/* Step visibility */
.cf-step{display:none;}
.cf-step.cf-step--visible{display:block;}
.cf-step.cf-step--visible.cf-success{display:flex;}

/* Error */
.cf-error{
    display:none;
    margin-top:var(--space-2);padding:8px 12px;border-radius:var(--radius-md);
    background:var(--color-error-bg);color:var(--color-error);font-size:var(--font-size-xs);
}

/* Success */
.cf-success{
    flex-direction:column;align-items:center;justify-content:center;
    text-align:center;padding:var(--space-6) 0;gap:var(--space-2);
}
.cf-success-icon{font-size:36px;color:var(--color-accent);}
.cf-success-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);color:#fff;}
.cf-success-text{font-size:var(--font-size-sm);color:rgba(255,255,255,0.7);}


/* ═══════ HAMBURGER (mobile only) ═══════ */
.ma-hamburger{
    display:none;background:none;border:none;cursor:pointer;
    padding:6px;width:34px;height:34px;
    flex-direction:column;justify-content:center;align-items:center;gap:4px;
    margin-left:auto;
}
.ma-hamburger span{display:block;width:18px;height:2px;background:var(--color-text-primary);border-radius:1px;transition:all var(--transition-fast);}
.ma-hamburger.active span:nth-child(1){transform:rotate(45deg) translate(3px,3px);}
.ma-hamburger.active span:nth-child(2){opacity:0;}
.ma-hamburger.active span:nth-child(3){transform:rotate(-45deg) translate(4px,-4px);}

/* Mobile nav */
.ma-mobile-nav{display:none;position:absolute;left:0;right:0;top:100%;background:var(--color-surface);border-top:1px solid var(--color-border);border-bottom:1px solid var(--color-border-strong);box-shadow:var(--shadow-lg);z-index:200;max-height:calc(100vh - 60px);overflow-y:auto;}
.ma-mobile-nav.open{display:block;}
.ma-mobile-nav-inner{padding:var(--space-3) var(--space-4);}
.ma-mobile-top-link{display:flex;align-items:center;padding:10px 0;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);text-decoration:none;border:none;background:none;width:100%;cursor:pointer;font-family:var(--font-family);border-bottom:1px solid var(--color-border);}
.ma-mobile-top-link:last-child{border-bottom:none;}
.ma-mobile-top-link:hover{color:var(--color-accent);}
.ma-mobile-top-link--cta{color:var(--color-brand);font-weight:var(--font-weight-semibold);}
.ma-mobile-divider{height:1px;background:var(--color-border-strong);margin:var(--space-1) 0;}
.ma-mobile-section{border-bottom:1px solid var(--color-border);}
.ma-mobile-section-toggle{display:flex;align-items:center;justify-content:space-between;width:100%;padding:10px 0;background:none;border:none;cursor:pointer;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);font-family:var(--font-family);}
.ma-mobile-section-toggle i{font-size:10px;color:var(--color-text-faint);transition:transform var(--transition-fast);}
.ma-mobile-section-toggle.active i{transform:rotate(180deg);}
.ma-mobile-section-body{display:none;padding:0 0 var(--space-2) var(--space-3);}
.ma-mobile-section-body.open{display:block;}
.ma-mobile-link{display:flex;align-items:center;gap:var(--space-2);padding:8px 0;font-size:var(--font-size-sm);color:var(--color-text-secondary);text-decoration:none;transition:color var(--transition-fast);}
.ma-mobile-link i{width:16px;text-align:center;font-size:11px;color:var(--color-text-faint);}
.ma-mobile-link:hover{color:var(--color-accent);}
.ma-mobile-link--overview{font-weight:var(--font-weight-semibold);color:var(--color-text-primary);}
.ma-mobile-link--overview i{color:var(--color-brand);}

/* ═══════ HEADER/NAV RESPONSIVE ═══════ */
@media(max-width:768px){
    .ma-topbar{display:none;}
    .ma-header-inner{padding:10px var(--space-4);}
    .ma-header-left{gap:var(--space-2);}
    .ma-logo-line--brand{font-size:16px;}
    .ma-logo-line--light{font-size:10px;}
    .ma-logo-img{height:26px;}
    .ma-nav{display:none;}
    .ma-header-right{display:none;}
    .ma-hamburger{display:flex;}
    /* Form panel responsive */
    .cf-layout{flex-direction:column;gap:var(--space-4);}
    .cf-intro{flex:none;max-width:none;}
    .cf-row{flex-direction:column;gap:var(--space-2);}
    .cf-widget{padding:var(--space-5) var(--space-4);}
}


/* ── Logo carousel (reusable component) ── */
.logos-band {
    padding: var(--space-8) 0;
    overflow: hidden;
    background: var(--color-bg);
    border-top: 1px solid var(--color-border);
    border-bottom: 1px solid var(--color-border);
}
.logos-band-title {
    text-align: center;
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-semibold);
    color: var(--color-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.5px;
    margin-bottom: var(--space-5);
}
.logos-track-wrapper {
    overflow: hidden;
    -webkit-mask-image: linear-gradient(to right, transparent, black 80px, black calc(100% - 80px), transparent);
    mask-image: linear-gradient(to right, transparent, black 80px, black calc(100% - 80px), transparent);
}
.logos-track {
    display: flex;
    align-items: center;
    gap: var(--space-6);
    width: max-content;
    animation: logos-scroll 250s linear infinite;
}
.logos-track:hover { animation-play-state: paused; }
.logos-track img {
    height: auto;
    max-width: 180px;
    max-height: 44px;
    opacity: 0.55;
    filter: grayscale(40%);
    transition: opacity var(--transition-fast), filter var(--transition-fast);
    flex-shrink: 0;
}
.logos-track img:hover {
    opacity: 1;
    filter: grayscale(0%);
}
@keyframes logos-scroll {
    from { transform: translateX(0); }
    to { transform: translateX(-50%); }
}
