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

:root {
  --navy:   #1a3d7c;
  --blue:   #2B5DAD;
  --gray:   #898A8D;
  --light:  #f4f6fb;
  --border: #d0d7e6;
  --white:  #ffffff;
  --red:    #c0392b;
  --green:  #27ae60;
  --yellow: #f39c12;
  --sb-width: 220px;
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
body { font-family: 'IBM Plex Sans', sans-serif; background: #fff; color: #222; min-height: 100vh; }

/* ── TOPBAR ── */
.pws-topbar {
  height: 52px; background: #fff;
  border-bottom: 0.5px solid var(--border);
  display: flex; align-items: center; justify-content: space-between;
  padding: 0 1.5rem; position: sticky; top: 0; z-index: 200;
}
.pws-topbar-left { display: flex; align-items: center; gap: 12px; }
.pws-wordmark { display: flex; flex-direction: column; line-height: 1; }
.pws-wordmark-pws { font-size: 14px; font-weight: 800; letter-spacing: .12em; color: var(--blue); text-transform: uppercase; }
.pws-wordmark-connect { font-size: 8px; font-weight: 600; letter-spacing: .22em; color: var(--gray); text-transform: uppercase; margin-top: 2px; }
.pws-divider-v { width: 0.5px; height: 28px; background: var(--border); }
.pws-page-name { font-size: 13px; color: var(--gray); font-weight: 500; }
.pws-topbar-right { display: flex; align-items: center; gap: 14px; }
.pws-status { display: flex; align-items: center; gap: 5px; font-size: 11px; color: var(--green); }
.pws-status-dot { width: 6px; height: 6px; border-radius: 50%; background: var(--green); }
.pws-user { display: flex; align-items: center; gap: 7px; font-size: 12px; color: var(--gray); }
.pws-avatar { width: 26px; height: 26px; border-radius: 50%; background: #e8eef8; border: 0.5px solid var(--border); display: flex; align-items: center; justify-content: center; font-size: 10px; font-weight: 700; color: var(--blue); }

/* ── APP SHELL (sidebar + main) ── */
.pws-shell { display: flex; min-height: calc(100vh - 52px); }

/* ── SIDEBAR ── */
.pws-sidebar {
  width: var(--sb-width); flex-shrink: 0;
  background: #fff; border-right: 0.5px solid var(--border);
  display: flex; flex-direction: column;
  position: sticky; top: 52px; height: calc(100vh - 52px); overflow-y: auto;
}
.pws-sb-logo { padding: 1rem 1rem .85rem; border-bottom: 0.5px solid var(--border); }
.pws-sb-logo svg { width: 110px; height: auto; }
.pws-sb-section { font-size: 9px; font-weight: 700; text-transform: uppercase; letter-spacing: .1em; color: #ccc; padding: .75rem 1rem .3rem; }
.pws-sb-item {
  display: flex; align-items: center; gap: 9px; padding: .55rem 1rem;
  font-size: 12.5px; color: var(--gray); cursor: pointer;
  border-left: 2.5px solid transparent; text-decoration: none;
  transition: all .12s;
}
.pws-sb-item:hover { color: var(--navy); background: #f5f8ff; }
.pws-sb-item.active { color: var(--navy); font-weight: 600; border-left-color: var(--blue); background: #f0f4fc; }
.pws-sb-item.soon { opacity: .35; cursor: default; }
.pws-sb-item.soon:hover { color: var(--gray); background: none; }
.pws-sb-item i { font-size: 15px; flex-shrink: 0; }
.pws-sb-footer { margin-top: auto; padding: .75rem 1rem; border-top: 0.5px solid var(--border); }
.pws-sb-home { display: flex; align-items: center; gap: 6px; font-size: 11px; color: #aaa; text-decoration: none; cursor: pointer; }
.pws-sb-home:hover { color: var(--blue); }
.pws-sb-home i { font-size: 13px; }

/* ── MAIN CONTENT ── */
.pws-main { flex: 1; background: #f9fafb; min-width: 0; }
.pws-main-inner { max-width: 960px; margin: 0 auto; padding: 2rem 1.75rem 4rem; }

/* ── PAGE HEADER ── */
.pws-page-header { margin-bottom: 1.75rem; }
.pws-page-header h1 { font-size: 20px; font-weight: 700; color: var(--navy); display: flex; align-items: center; gap: 10px; margin-bottom: 4px; }
.pws-page-header h1 i { font-size: 22px; color: var(--blue); }
.pws-page-header p { font-size: 13px; color: var(--gray); }

/* ── SHARED COMPONENT STYLES ── */
.btn {
  font-family: 'IBM Plex Sans', sans-serif; font-size: .8rem; font-weight: 600;
  letter-spacing: .03em; padding: .45rem 1.1rem; border-radius: 4px; border: none;
  cursor: pointer; transition: all .15s; display: inline-flex; align-items: center; gap: .4rem;
}
.btn-primary  { background: var(--blue);  color: #fff; }
.btn-primary:hover  { background: #1f4a96; }
.btn-primary:disabled { background: var(--gray); cursor: not-allowed; }
.btn-navy  { background: var(--navy);  color: #fff; }
.btn-navy:hover  { background: #142d5c; }
.btn-outline  { background: transparent; color: var(--navy); border: 1.5px solid var(--navy); }
.btn-outline:hover  { background: var(--navy); color: #fff; }
.btn-success  { background: var(--green); color: #fff; }
.btn-success:hover  { background: #1e9450; }
.btn-warning  { background: var(--yellow); color: #fff; }
.btn-danger   { background: var(--red); color: #fff; }
.btn-danger:hover { background: #a93226; }
.btn-sm { font-size: .75rem; padding: .3rem .75rem; }

.section-card { background: #fff; border-radius: 8px; border: 0.5px solid var(--border); margin-bottom: 1rem; overflow: hidden; }
.section-head { background: var(--navy); color: #fff; padding: .6rem 1.2rem; font-size: .75rem; font-weight: 700; letter-spacing: .07em; text-transform: uppercase; display: flex; align-items: center; justify-content: space-between; }
.section-body { padding: 1rem 1.2rem; }

.field-group { display: flex; flex-direction: column; gap: .22rem; min-width: 0; }
.field-group label { font-size: .7rem; font-weight: 600; color: var(--gray); text-transform: uppercase; letter-spacing: .05em; }
.field-group input, .field-group select, .field-group textarea {
  border: 1.5px solid var(--border); border-radius: 3px; padding: .38rem .55rem; min-width: 0; width: 100%;
  font-family: 'IBM Plex Sans', sans-serif; font-size: .84rem; color: #222;
  background: #fff; transition: border-color .15s;
}
.field-group input:focus, .field-group select:focus, .field-group textarea:focus { outline: none; border-color: var(--blue); box-shadow: 0 0 0 3px rgba(43,93,173,.08); }
.field-group textarea { resize: vertical; min-height: 60px; }

.form-group { margin-bottom: 1rem; }
.form-group label { display: block; font-size: .78rem; font-weight: 600; color: var(--navy); margin-bottom: .35rem; text-transform: uppercase; letter-spacing: .04em; }
.form-group input, .form-group textarea, .form-group select {
  width: 100%; border: 1.5px solid var(--border); border-radius: 4px;
  padding: .55rem .75rem; font-family: 'IBM Plex Mono', monospace; font-size: .85rem;
  color: #222; transition: border-color .15s; background: #fff;
}
.form-group input:focus, .form-group textarea:focus, .form-group select:focus { outline: none; border-color: var(--blue); }
.form-hint { font-size: .74rem; color: var(--gray); margin-top: .35rem; line-height: 1.4; }

.grid-2 { display: grid; grid-template-columns: minmax(0,1fr) minmax(0,1fr); gap: .7rem 1.1rem; }
.grid-3 { display: grid; grid-template-columns: minmax(0,1fr) minmax(0,1fr) minmax(0,1fr); gap: .7rem 1.1rem; }
.grid-4 { display: grid; grid-template-columns: repeat(4,minmax(0,1fr)); gap: .7rem 1.1rem; }

.alert {
  padding: .7rem 1rem; border-radius: 4px; font-size: .82rem; font-weight: 500;
  margin-top: 1rem; display: none; line-height: 1.5;
}
.alert.error   { background: #fef0ef; color: var(--red);   border: 1px solid #f5c6c3; display: block; }
.alert.success { background: #edfaf3; color: var(--green); border: 1px solid #c3edd7; display: block; }
.alert.info    { background: #eef2fb; color: var(--navy);  border: 1px solid #c5d3ef; display: block; }
.alert.warning { background: #fef9ec; color: #7d5a00;     border: 1px solid #f5dfa0; display: block; }

.spinner { display: inline-block; width: 14px; height: 14px; border: 2px solid rgba(43,93,173,.2); border-top-color: var(--blue); border-radius: 50%; animation: spin .7s linear infinite; vertical-align: middle; margin-right: .4rem; }
@keyframes spin { to { transform: rotate(360deg); } }

.no-print { }
@media print {
  body { background: #fff !important; }
  .no-print { display: none !important; }
  .pws-topbar { display: none !important; }
  .pws-sidebar { display: none !important; }
  .pws-shell { display: block !important; }
  .pws-main { display: block !important; padding: 0 !important; }
  .pws-main-inner { padding: 0 !important; max-width: none !important; }
}
