/* ═══════════════════════════════════════════════════════════
   S1MONE Portal · Design System v2
   McKinsey-style: IBM Plex + Navy #002147 + White surfaces
   ═══════════════════════════════════════════════════════════ */

@import url('https://fonts.googleapis.com/css2?family=Libre+Baskerville:ital,wght@0,400;0,700;1,400&family=IBM+Plex+Sans+Condensed:wght@300;400;500;600&family=IBM+Plex+Sans:wght@300;400;500;600&family=IBM+Plex+Mono:wght@400;500&display=swap');

:root {
  /* ── Core Brand ── */
  --mk:    #002147;
  --mk2:   #1A4A7A;
  --mk3:   #4A7FA5;
  --mkl:   #EBF1F8;
  --mk-bg: #F0F4F8;

  /* ── Surface ── */
  --white: #FFFFFF;
  --off:   #F5F6FA;
  --rule:  #D8DEE9;
  --rule2: #EEF0F3;

  /* ── Text ── */
  --ink:   #0D1B2A;
  --ink2:  #2C3848;
  --ink3:  #56677A;
  --silver:#7A8A9A;

  /* ── Status ── */
  --green: #2E7D5E;
  --gbg:   #E6F4EE;
  --gbd:   rgba(46,125,94,.2);
  --amber: #B45309;
  --abg:   #FEF9EE;
  --abd:   rgba(180,83,9,.22);
  --red:   #C8102E;
  --rbg:   #FDECEA;
  --rbd:   rgba(200,16,46,.22);
  --purple:#5B2D8E;
  --pbg:   #F3EEFB;
  --pbd:   rgba(91,45,142,.2);

  /* ── Semantic aliases (backward compat) ── */
  --bg-page:    var(--off);
  --bg-surface: var(--white);
  --bg-card:    var(--white);
  --border:     var(--rule);
  --border-subtle: var(--rule2);

  --text-primary:   var(--ink);
  --text-secondary: var(--ink3);
  --text-muted:     var(--silver);
  --text-ghost:     var(--silver);

  --accent:         var(--mk);
  --accent-hover:   var(--mk2);
  --accent-bg:      var(--mkl);
  --accent-border:  rgba(0,33,71,.18);

  --green-bg:      var(--gbg);
  --green-border:  var(--gbd);
  --orange-bg:     var(--abg);
  --orange-border: var(--abd);
  --red-bg:        var(--rbg);
  --red-border:    var(--rbd);
  --purple-bg:     var(--pbg);
  --purple-border: var(--pbd);

  /* ── Typography ── */
  --font:       'IBM Plex Sans', -apple-system, sans-serif;
  --font-cond:  'IBM Plex Sans Condensed', sans-serif;
  --font-mono:  'IBM Plex Mono', monospace;
  --font-serif: 'Libre Baskerville', Georgia, serif;

  --text-xs:   10px;
  --text-sm:   11px;
  --text-base: 13px;
  --text-md:   14px;
  --text-lg:   16px;
  --text-xl:   20px;
  --text-2xl:  26px;
  --text-3xl:  32px;

  --weight-normal:   400;
  --weight-medium:   500;
  --weight-semibold: 600;

  --tracking-wide:   0.06em;
  --tracking-wider:  0.10em;
  --tracking-widest: 0.14em;

  /* ── 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;
  --space-12:48px;

  /* ── Radius — tight/professional ── */
  --radius-sm: 2px;
  --radius-md: 3px;
  --radius-lg: 4px;
  --radius-xl: 6px;

  /* ── Transition ── */
  --transition: 0.12s ease;
}

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

body {
  background: var(--off);
  color: var(--ink);
  font-family: var(--font);
  font-size: var(--text-base);
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
}

/* ── Header ── */
.s1-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 28px;
  height: 52px;
  background: var(--mk);
  position: sticky;
  top: 0;
  z-index: 100;
}

.s1-brand {
  display: inline-flex;
  align-items: center;
  text-decoration: none;
  flex-shrink: 0;
}

.s1-brand img {
  height: 22px;
  width: auto;
  display: block;
}

.s1-nav-divider {
  color: rgba(255,255,255,.2);
  font-size: 14px;
  margin: 0 6px;
}

.s1-workspace-name {
  font-family: var(--font-cond);
  font-size: 9px;
  font-weight: 600;
  letter-spacing: var(--tracking-wider);
  text-transform: uppercase;
  color: rgba(255,255,255,.42);
}

/* ── Nav Tabs (inside header) ── */
.s1-nav-tabs {
  display: flex;
  gap: 0;
  margin-left: 20px;
  align-items: stretch;
  height: 52px;
}

.s1-nav-tab {
  font-family: var(--font-cond);
  font-size: 10px;
  font-weight: 600;
  letter-spacing: var(--tracking-wider);
  text-transform: uppercase;
  color: rgba(255,255,255,.42);
  text-decoration: none;
  padding: 0 14px;
  display: flex;
  align-items: center;
  border-bottom: 2px solid transparent;
  transition: all var(--transition);
  white-space: nowrap;
}
.s1-nav-tab:hover  { color: rgba(255,255,255,.78); }
.s1-nav-tab.active { color: #fff; border-bottom-color: #fff; }
.s1-nav-tab.active-blue { color: #7EB8E8; border-bottom-color: #7EB8E8; }

/* ── User Chip ── */
.s1-user-chip {
  font-family: var(--font-cond);
  font-size: 9px;
  font-weight: 500;
  letter-spacing: var(--tracking-wide);
  text-transform: uppercase;
  color: rgba(255,255,255,.36);
  padding: 4px 10px;
  border: 1px solid rgba(255,255,255,.14);
  border-radius: 2px;
}

/* ── Buttons ── */
.s1-btn {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-family: var(--font-cond);
  font-size: 10px;
  font-weight: 600;
  letter-spacing: var(--tracking-wider);
  text-transform: uppercase;
  padding: 6px 14px;
  border-radius: var(--radius-md);
  cursor: pointer;
  transition: all var(--transition);
  border: 1px solid transparent;
  text-decoration: none;
  white-space: nowrap;
}

.s1-btn-primary { background: var(--mk); color: #fff; border-color: var(--mk); }
.s1-btn-primary:hover { background: var(--mk2); border-color: var(--mk2); }

.s1-btn-white { background: var(--white); color: var(--ink2); border-color: var(--rule); }
.s1-btn-white:hover { background: var(--off); }

.s1-btn-ghost { background: none; color: rgba(255,255,255,.52); border-color: rgba(255,255,255,.18); }
.s1-btn-ghost:hover { color: #fff; border-color: rgba(255,255,255,.42); }

/* dark-surface ghost (for light bg pages) */
.s1-btn-ghost-dark { background: none; color: var(--silver); border-color: var(--rule); }
.s1-btn-ghost-dark:hover { color: var(--ink2); border-color: var(--mk3); }

.s1-btn-danger { background: none; color: var(--red); border-color: var(--rbd); }
.s1-btn-danger:hover { background: var(--rbg); }

.s1-btn-sm { font-size: 9px; padding: 4px 10px; }

.s1-btn:disabled { opacity: 0.36; cursor: not-allowed; }

/* ── Cards ── */
.s1-card {
  background: var(--white);
  border: 0.5px solid var(--rule);
  border-radius: var(--radius-md);
  transition: border-color var(--transition);
}
.s1-card:hover { border-color: var(--mk3); }

/* ── Section Labels ── */
.s1-section-label {
  font-family: var(--font-cond);
  font-size: 9px;
  font-weight: 600;
  letter-spacing: var(--tracking-widest);
  color: var(--silver);
  text-transform: uppercase;
}

/* ── Divider ── */
.s1-divider { height: 0.5px; background: var(--rule); border: none; margin: 0; }

/* ── Badges ── */
.s1-badge {
  display: inline-block;
  font-family: var(--font-cond);
  font-size: 9px;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  padding: 2px 7px;
  border-radius: var(--radius-sm);
  white-space: nowrap;
}
.s1-badge-blue   { background: var(--mkl); color: var(--mk2); border: 0.5px solid rgba(0,33,71,.18); }
.s1-badge-green  { background: var(--gbg); color: var(--green); border: 0.5px solid var(--gbd); }
.s1-badge-orange { background: var(--abg); color: var(--amber); border: 0.5px solid var(--abd); }
.s1-badge-purple { background: var(--pbg); color: var(--purple); border: 0.5px solid var(--pbd); }
.s1-badge-ghost  { background: var(--rule2); color: var(--silver); border: 0.5px solid var(--rule); }

/* ── Form Inputs ── */
.s1-input {
  width: 100%;
  padding: 9px 12px;
  background: var(--white);
  border: 1px solid var(--rule);
  border-radius: var(--radius-md);
  color: var(--ink);
  font-size: var(--text-base);
  font-family: var(--font);
  outline: none;
  transition: border-color var(--transition), box-shadow var(--transition);
}
.s1-input:focus {
  border-color: var(--mk);
  box-shadow: 0 0 0 2px rgba(0,33,71,.08);
}
.s1-input::placeholder { color: var(--silver); }
select.s1-input { appearance: none; cursor: pointer; }

/* ── Signal Items ── */
.s1-signal {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  background: var(--white);
  border: 0.5px solid var(--rule);
  border-radius: var(--radius-md);
  padding: 12px 16px;
}
.s1-signal-dot { width: 6px; height: 6px; border-radius: 50%; margin-top: 6px; flex-shrink: 0; }
.s1-signal-dot.warn { background: var(--amber); }
.s1-signal-dot.info { background: var(--mk3); }
.s1-signal-dot.ok   { background: var(--green); }
.s1-signal-text { font-size: var(--text-base); color: var(--ink3); line-height: 1.6; }
.s1-signal-text strong { color: var(--ink); font-weight: 500; }

/* ── Error ── */
.s1-error {
  padding: 9px 12px;
  background: var(--rbg);
  border: 0.5px solid var(--rbd);
  border-radius: var(--radius-sm);
  color: var(--red);
  font-family: var(--font-cond);
  font-size: var(--text-sm);
  letter-spacing: 0.02em;
}

/* ── Empty State ── */
.s1-empty {
  text-align: center;
  padding: 56px 20px;
  color: var(--silver);
  font-family: var(--font-cond);
  font-size: var(--text-base);
  letter-spacing: 0.04em;
  line-height: 2;
}

/* ── Scrollbar ── */
::-webkit-scrollbar { width: 5px; height: 5px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: var(--rule); border-radius: 2px; }
::-webkit-scrollbar-thumb:hover { background: var(--silver); }

/* ── Responsive ── */
@media (max-width: 768px) {
  .s1-header { padding: 0 var(--space-5); }
  .s1-nav-tabs { display: none; }
}
