/* ===============================================
   ACCORD LAW CONSULT PRUC — Practice Portal v2
   Navy + Gold + White — Professional Legal Theme
   =============================================== */

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

:root {
  --navy:       #0e2547;
  --navy-light: #163770;
  --navy-dim:   rgba(14,37,71,0.08);
  --gold:       #c9a84c;
  --gold-light: #e2c070;
  --gold-dim:   rgba(201,168,76,0.15);

  --white:      #ffffff;
  --bg:         #f4f6fa;
  --surface:    #ffffff;
  --raised:     #f9fafb;
  --border:     #dde3ee;
  --border2:    #c8d0e0;

  --text:       #1a2640;
  --text2:      #4a5568;
  --text3:      #8a95a8;

  --green:      #2f9e5b;
  --green-dim:  rgba(47,158,91,0.12);
  --red:        #d94f4f;
  --red-dim:    rgba(217,79,79,0.1);
  --amber:      #e07d2a;
  --amber-dim:  rgba(224,125,42,0.12);
  --blue:       #2d6fcc;
  --blue-dim:   rgba(45,111,204,0.1);

  --sidebar-w:  260px;
  --topbar-h:   60px;
  --radius:     8px;
  --radius-lg:  12px;
  --shadow:     0 2px 12px rgba(14,37,71,0.1);
  --shadow-lg:  0 8px 40px rgba(14,37,71,0.18);
}

html, body {
  height: 100%;
  font-family: 'Source Sans 3', sans-serif;
  font-size: 14px;
  background: var(--bg);
  color: var(--text);
  -webkit-font-smoothing: antialiased;
}

/* ============ LOGIN ============ */
#login-screen {
  position: fixed; inset: 0;
  display: flex; align-items: center; justify-content: center;
  background: var(--navy);
  z-index: 9000;
}

.login-overlay {
  position: absolute; inset: 0;
  background: url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23c9a84c' fill-opacity='0.04'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");
}

.login-box {
  position: relative;
  width: 440px;
  background: var(--white);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-lg);
  padding: 2.5rem;
  animation: slideUp 0.5s ease;
}

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

.login-logo-wrap {
  text-align: center;
  margin-bottom: 1rem;
}

.login-logo-img {
  max-width: 300px;
  width: 100%;
  height: auto;
}

.login-tagline {
  text-align: center;
  font-size: 0.7rem;
  font-weight: 600;
  letter-spacing: 0.18em;
  color: var(--navy);
  margin-bottom: 1.25rem;
  background: var(--gold-dim);
  padding: 0.4rem;
  border-radius: 4px;
}

.login-divider {
  height: 2px;
  background: linear-gradient(90deg, transparent, var(--gold), transparent);
  margin-bottom: 1.5rem;
}

.btn-login {
  width: 100%;
  padding: 0.875rem;
  background: var(--navy);
  color: var(--gold);
  border: none;
  border-radius: var(--radius);
  font-family: 'Source Sans 3', sans-serif;
  font-size: 0.95rem;
  font-weight: 600;
  letter-spacing: 0.06em;
  cursor: pointer;
  transition: background 0.2s, transform 0.1s;
  margin-top: 0.5rem;
}
.btn-login:hover { background: var(--navy-light); transform: translateY(-1px); }

.login-foot {
  text-align: center;
  font-size: 0.72rem;
  color: var(--text3);
  margin-top: 1.25rem;
  line-height: 1.6;
}

.pw-wrap { position: relative; }
.pw-wrap input { padding-right: 2.5rem !important; }
.pw-toggle {
  position: absolute; right: 0.6rem; top: 50%; transform: translateY(-50%);
  background: none; border: none; cursor: pointer; font-size: 0.9rem; color: var(--text3);
}

/* ============ LAYOUT ============ */
#app {
  display: flex;
  height: 100vh;
  overflow: hidden;
}
#app.hidden, .hidden { display: none !important; }

/* ============ SIDEBAR ============ */
.sidebar {
  width: var(--sidebar-w);
  background: var(--navy);
  display: flex;
  flex-direction: column;
  flex-shrink: 0;
  overflow: hidden;
  transition: transform 0.3s;
  z-index: 100;
}

.sb-brand {
  padding: 1.25rem 1.25rem 0.75rem;
  border-bottom: 1px solid rgba(255,255,255,0.08);
}

.sb-logo {
  width: 100%;
  max-width: 180px;
  height: auto;
  filter: brightness(0) invert(1); /* white version */
}

.sb-nav {
  flex: 1;
  overflow-y: auto;
  padding: 0.5rem 0;
  scrollbar-width: thin;
  scrollbar-color: rgba(255,255,255,0.1) transparent;
}

.sb-label {
  padding: 0.9rem 1.25rem 0.3rem;
  font-size: 0.6rem;
  font-weight: 700;
  letter-spacing: 0.16em;
  color: rgba(201,168,76,0.6);
  text-transform: uppercase;
}

.sb-item {
  display: flex;
  align-items: center;
  gap: 0.6rem;
  padding: 0.55rem 1.25rem;
  color: rgba(255,255,255,0.65);
  cursor: pointer;
  font-size: 0.875rem;
  border-left: 3px solid transparent;
  transition: all 0.15s;
  text-decoration: none;
}
.sb-item:hover { background: rgba(255,255,255,0.06); color: #fff; }
.sb-item.active {
  background: var(--gold-dim);
  color: var(--gold);
  border-left-color: var(--gold);
  font-weight: 600;
}
.sb-ico { width: 1.1rem; text-align: center; font-size: 0.85rem; }

.sb-footer {
  padding: 1rem 1.25rem;
  border-top: 1px solid rgba(255,255,255,0.08);
  display: flex;
  align-items: center;
  gap: 0.75rem;
}

.sb-user-av {
  width: 34px; height: 34px;
  background: var(--gold-dim);
  border: 1.5px solid var(--gold);
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: 0.72rem; font-weight: 700;
  color: var(--gold); flex-shrink: 0;
}
.sb-user-info { flex: 1; overflow: hidden; }
.sb-user-info div:first-child { font-size: 0.82rem; color: #fff; font-weight: 600; }
.sb-user-info div:last-child  { font-size: 0.7rem; color: rgba(255,255,255,0.45); }
.sb-logout {
  background: none; border: none; color: rgba(255,255,255,0.35);
  cursor: pointer; font-size: 1.1rem; transition: color 0.2s; padding: 4px;
}
.sb-logout:hover { color: var(--red); }

/* ============ MAIN ============ */
.main-wrap {
  flex: 1; display: flex; flex-direction: column; overflow: hidden;
}

/* TOPBAR */
.topbar {
  height: var(--topbar-h);
  background: var(--white);
  border-bottom: 1px solid var(--border);
  display: flex; align-items: center; justify-content: space-between;
  padding: 0 1.5rem;
  flex-shrink: 0;
  box-shadow: 0 1px 4px rgba(14,37,71,0.06);
}
.tb-left { display: flex; align-items: center; gap: 1rem; }
.ham { background: none; border: none; font-size: 1.1rem; color: var(--text2); cursor: pointer; padding: 4px; border-radius: 4px; }
.ham:hover { background: var(--bg); }
.tb-bc {
  font-family: 'Playfair Display', serif;
  font-size: 1.05rem;
  color: var(--navy);
  font-weight: 600;
}
.tb-right { display: flex; align-items: center; gap: 1rem; }
.tb-clock { font-family: 'Source Code Pro', monospace; font-size: 0.78rem; color: var(--text3); }
.tb-notif { cursor: pointer; position: relative; font-size: 1.1rem; }
.notif-badge {
  position: absolute; top: -4px; right: -4px;
  background: var(--red); color: #fff;
  border-radius: 50%; width: 16px; height: 16px;
  font-size: 0.58rem; display: flex; align-items: center; justify-content: center;
}
.tb-search input {
  background: var(--bg);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 0.4rem 0.875rem;
  font-family: 'Source Sans 3', sans-serif;
  font-size: 0.82rem;
  width: 200px;
  outline: none;
  transition: border-color 0.2s;
  color: var(--text);
}
.tb-search input:focus { border-color: var(--navy); }

.search-drop {
  position: fixed; top: 64px; right: 1.5rem;
  width: 320px; max-height: 320px; overflow-y: auto;
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  box-shadow: var(--shadow-lg);
  z-index: 500;
}
.search-item {
  padding: 0.6rem 1rem;
  border-bottom: 1px solid var(--border);
  cursor: pointer;
  font-size: 0.83rem;
}
.search-item:hover { background: var(--bg); }
.search-item-type { font-size: 0.68rem; color: var(--text3); text-transform: uppercase; }

/* SCROLL AREA */
.scroll-area {
  flex: 1; overflow-y: auto;
  scrollbar-width: thin;
  scrollbar-color: var(--border2) transparent;
}

/* ============ SECTIONS ============ */
.sec { display: none; padding: 1.75rem 2rem 3rem; }
.sec.active { display: block; }

.sec-hdr {
  display: flex; justify-content: space-between; align-items: flex-start;
  margin-bottom: 1.5rem; flex-wrap: wrap; gap: 1rem;
}

.sec-title {
  font-family: 'Playfair Display', serif;
  font-size: 1.85rem;
  font-weight: 700;
  color: var(--navy);
  line-height: 1.2;
}
.sec-title em { color: var(--gold); font-style: italic; }
.sec-sub { color: var(--text3); font-size: 0.85rem; margin-top: 0.2rem; }

.hdr-actions { display: flex; gap: 0.75rem; }

/* ============ KPI CARDS ============ */
.kpi-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
  gap: 1rem; margin-bottom: 1.5rem;
}

.kpi-card {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 1.25rem;
  cursor: pointer;
  transition: all 0.2s;
  border-top: 3px solid var(--border);
}
.kpi-card:hover { box-shadow: var(--shadow); transform: translateY(-2px); border-top-color: var(--navy); }
.kpi-card.accent { border-top-color: var(--amber); }
.kpi-card.success { border-top-color: var(--green); }
.kpi-icon { font-size: 1.2rem; margin-bottom: 0.5rem; }
.kpi-num {
  font-family: 'Playfair Display', serif;
  font-size: 1.75rem; font-weight: 700;
  color: var(--navy); line-height: 1;
}
.kpi-card.accent .kpi-num { color: var(--amber); }
.kpi-card.success .kpi-num { color: var(--green); }
.kpi-lbl { font-size: 0.72rem; color: var(--text3); text-transform: uppercase; letter-spacing: 0.07em; margin-top: 0.35rem; }

/* ============ DASHBOARD PANELS ============ */
.dash-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1rem;
}
.dash-panel {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  overflow: hidden;
}
.dash-panel.span2 { grid-column: span 2; }

.panel-hdr {
  display: flex; justify-content: space-between; align-items: center;
  padding: 0.875rem 1.25rem;
  border-bottom: 1px solid var(--border);
  background: var(--raised);
}
.panel-hdr h3 {
  font-family: 'Playfair Display', serif;
  font-size: 0.95rem; font-weight: 600; color: var(--navy);
}
.panel-list { padding: 0; }
.pitem {
  padding: 0.65rem 1.25rem;
  border-bottom: 1px solid var(--border);
  font-size: 0.825rem;
  cursor: pointer; transition: background 0.15s;
}
.pitem:last-child { border-bottom: none; }
.pitem:hover { background: var(--bg); }
.pitem-title { font-weight: 500; color: var(--text); }
.pitem-sub { color: var(--text3); font-size: 0.75rem; margin-top: 0.1rem; }

.activity-feed { padding: 0; }
.activity-item {
  display: flex; align-items: flex-start; gap: 0.75rem;
  padding: 0.6rem 1.25rem;
  border-bottom: 1px solid var(--border);
  font-size: 0.825rem;
}
.activity-item:last-child { border-bottom: none; }
.act-dot {
  width: 8px; height: 8px;
  background: var(--gold); border-radius: 50%; flex-shrink: 0; margin-top: 0.3rem;
}
.act-text { flex: 1; color: var(--text2); }
.act-time { font-size: 0.72rem; color: var(--text3); white-space: nowrap; }

/* ============ BUTTONS ============ */
.btn-1 {
  background: var(--navy);
  color: var(--gold);
  border: none;
  border-radius: var(--radius);
  padding: 0.6rem 1.25rem;
  font-family: 'Source Sans 3', sans-serif;
  font-size: 0.875rem; font-weight: 600;
  cursor: pointer; transition: all 0.2s; white-space: nowrap;
}
.btn-1:hover { background: var(--navy-light); transform: translateY(-1px); }

.btn-2 {
  background: var(--white);
  color: var(--navy);
  border: 1px solid var(--border2);
  border-radius: var(--radius);
  padding: 0.6rem 1.25rem;
  font-family: 'Source Sans 3', sans-serif;
  font-size: 0.875rem; font-weight: 500;
  cursor: pointer; transition: all 0.2s; white-space: nowrap;
}
.btn-2:hover { border-color: var(--navy); color: var(--navy); }

.btn-xs {
  background: none; border: 1px solid var(--border);
  border-radius: 6px; padding: 0.25rem 0.65rem;
  font-size: 0.75rem; color: var(--text3); cursor: pointer;
  transition: all 0.2s;
}
.btn-xs:hover { border-color: var(--navy); color: var(--navy); }

.btn-sm { padding: 0.4rem 0.9rem; font-size: 0.82rem; }

.btn-icon {
  background: none; border: none; cursor: pointer;
  color: var(--text3); font-size: 0.875rem;
  padding: 3px 5px; border-radius: 4px; transition: color 0.2s;
}
.btn-icon:hover { color: var(--navy); }
.btn-icon.danger:hover { color: var(--red); }

.btn-danger-sm {
  background: var(--red-dim); color: var(--red);
  border: 1px solid rgba(217,79,79,0.3);
  border-radius: var(--radius); padding: 0.6rem 1.25rem;
  font-size: 0.875rem; font-weight: 500; cursor: pointer;
  transition: all 0.2s;
}
.btn-danger-sm:hover { background: var(--red); color: #fff; }

/* ============ FORMS ============ */
.form-group {
  display: flex; flex-direction: column; gap: 0.35rem; flex: 1;
  margin-bottom: 0.1rem;
}
.form-group label {
  font-size: 0.73rem; font-weight: 600; color: var(--text2);
  text-transform: uppercase; letter-spacing: 0.06em;
}
.form-group input,
.form-group select,
.form-group textarea {
  background: var(--white);
  border: 1px solid var(--border2);
  border-radius: var(--radius);
  padding: 0.6rem 0.875rem;
  color: var(--text);
  font-family: 'Source Sans 3', sans-serif;
  font-size: 0.875rem;
  outline: none;
  transition: border-color 0.2s, box-shadow 0.2s;
  width: 100%;
}
.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus {
  border-color: var(--navy);
  box-shadow: 0 0 0 3px rgba(14,37,71,0.1);
}
.form-row { display: flex; gap: 1rem; flex-wrap: wrap; }
.form-row .form-group { min-width: 160px; }

/* ============ TOOLBAR ============ */
.toolbar {
  display: flex; gap: 0.75rem; align-items: center;
  flex-wrap: wrap; margin-bottom: 1rem;
}
.tb-search-in {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 0.55rem 1rem;
  font-family: 'Source Sans 3', sans-serif;
  font-size: 0.875rem; color: var(--text);
  min-width: 220px; outline: none;
  transition: border-color 0.2s;
}
.tb-search-in:focus { border-color: var(--navy); }
.tb-select {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 0.55rem 1rem;
  font-family: 'Source Sans 3', sans-serif;
  font-size: 0.875rem; color: var(--text);
  outline: none; cursor: pointer;
}

/* ============ TABLE ============ */
.table-card {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  overflow: hidden; overflow-x: auto;
}
.data-tbl { width: 100%; border-collapse: collapse; }
.data-tbl thead tr { background: var(--navy); }
.data-tbl th {
  padding: 0.75rem 1rem;
  text-align: left;
  font-size: 0.68rem; font-weight: 600;
  letter-spacing: 0.1em; text-transform: uppercase;
  color: var(--gold); white-space: nowrap;
}
.data-tbl td {
  padding: 0.8rem 1rem;
  border-bottom: 1px solid var(--border);
  font-size: 0.85rem; color: var(--text);
  vertical-align: middle;
}
.data-tbl tbody tr:last-child td { border-bottom: none; }
.data-tbl tbody tr:hover { background: var(--bg); }
.empty-row {
  text-align: center; color: var(--text3);
  padding: 2.5rem !important; font-style: italic;
}
.empty-note { padding: 1rem 1.25rem; color: var(--text3); font-style: italic; font-size: 0.85rem; }
.empty-full {
  text-align: center; padding: 4rem 2rem;
  color: var(--text3); font-style: italic; font-size: 0.9rem;
}

/* ============ BADGES ============ */
.badge {
  display: inline-block; padding: 0.2rem 0.6rem;
  border-radius: 999px; font-size: 0.67rem; font-weight: 700;
  letter-spacing: 0.07em; text-transform: uppercase;
}
.badge-active   { background: var(--green-dim); color: var(--green); }
.badge-pending  { background: var(--amber-dim); color: var(--amber); }
.badge-closed   { background: rgba(138,149,168,0.15); color: var(--text3); }
.badge-paid     { background: var(--green-dim); color: var(--green); }
.badge-unpaid   { background: var(--red-dim);   color: var(--red); }
.badge-partial  { background: var(--blue-dim);  color: var(--blue); }
.badge-overdue  { background: var(--red-dim);   color: var(--red); border: 1px solid rgba(217,79,79,0.3); }
.badge-hearing  { background: var(--navy-dim);  color: var(--navy); }
.badge-deadline { background: var(--red-dim);   color: var(--red); }
.badge-meeting  { background: var(--blue-dim);  color: var(--blue); }

/* ============ CASES GRID ============ */
.cases-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  gap: 1rem;
}
.case-card {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 1.25rem;
  transition: all 0.2s;
  border-left: 4px solid var(--border);
}
.case-card:hover { box-shadow: var(--shadow); transform: translateY(-2px); }
.case-card.status-active  { border-left-color: var(--green); }
.case-card.status-pending { border-left-color: var(--amber); }
.case-card.status-closed  { border-left-color: var(--text3); }

.cc-hdr { display: flex; justify-content: space-between; align-items: flex-start; margin-bottom: 0.75rem; }
.cc-title {
  font-family: 'Playfair Display', serif;
  font-size: 0.95rem; font-weight: 600; color: var(--navy);
  flex: 1; margin-right: 0.5rem; line-height: 1.3;
}
.cc-meta { display: flex; flex-direction: column; gap: 0.25rem; margin-top: 0.25rem; }
.cc-row { display: flex; gap: 0.5rem; font-size: 0.775rem; color: var(--text3); }
.cc-row strong { color: var(--text2); font-weight: 500; }

.cc-progress { margin-top: 0.875rem; }
.cc-prog-lbl { display: flex; justify-content: space-between; font-size: 0.72rem; color: var(--text3); margin-bottom: 0.3rem; }
.prog-bar { height: 5px; background: var(--bg); border-radius: 3px; overflow: hidden; }
.prog-fill { height: 100%; background: linear-gradient(90deg, var(--navy), var(--gold)); border-radius: 3px; transition: width 0.4s; }
.prog-slider { width: 100%; margin-top: 6px; accent-color: var(--navy); background: transparent; cursor: pointer; }

.cc-actions { display: flex; gap: 0.35rem; margin-top: 0.875rem; justify-content: flex-end; align-items: center; }

/* ============ BILLING SUMMARY ============ */
.bill-summary {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(170px, 1fr));
  gap: 1rem; margin-bottom: 1.25rem;
}
.bill-card {
  background: var(--white); border: 1px solid var(--border);
  border-radius: var(--radius-lg); padding: 1.25rem 1.5rem;
}
.bill-card.warn  { border-color: rgba(224,125,42,0.3); }
.bill-card.success { border-color: rgba(47,158,91,0.3); }
.bill-lbl { font-size: 0.7rem; text-transform: uppercase; letter-spacing: 0.1em; color: var(--text3); margin-bottom: 0.4rem; }
.bill-val {
  font-family: 'Playfair Display', serif;
  font-size: 1.5rem; font-weight: 700; color: var(--navy);
}
.bill-card.warn .bill-val { color: var(--amber); }
.bill-card.success .bill-val { color: var(--green); }
.warn-text { color: var(--red) !important; }

/* ============ INVOICE ITEMS ============ */
.inv-items-section { margin: 1rem 0; }
.inv-items-section > label {
  display: block; font-size: 0.73rem; font-weight: 600;
  color: var(--text2); text-transform: uppercase; letter-spacing: 0.06em; margin-bottom: 0.5rem;
}
.inv-row {
  display: grid;
  grid-template-columns: 1fr 70px 150px 100px 28px;
  gap: 0.5rem; align-items: center; margin-bottom: 0.5rem;
}
.inv-row input {
  background: var(--white); border: 1px solid var(--border2);
  border-radius: var(--radius); padding: 0.5rem 0.7rem;
  color: var(--text); font-family: 'Source Sans 3', sans-serif;
  font-size: 0.85rem; outline: none; width: 100%;
  transition: border-color 0.2s;
}
.inv-row input:focus { border-color: var(--navy); }
.irow-total {
  font-family: 'Source Code Pro', monospace;
  font-size: 0.82rem; color: var(--navy); text-align: right; white-space: nowrap;
}
.rm-item {
  background: none; border: none; cursor: pointer;
  color: var(--text3); font-size: 0.85rem; border-radius: 4px; padding: 4px;
  transition: color 0.2s;
}
.rm-item:hover { color: var(--red); }
.btn-add-row {
  background: none; border: 1px dashed var(--border2);
  border-radius: var(--radius); padding: 0.5rem 1rem;
  color: var(--text3); font-size: 0.8rem; cursor: pointer;
  width: 100%; transition: all 0.2s;
}
.btn-add-row:hover { border-color: var(--navy); color: var(--navy); }
.inv-totals { border-top: 1px solid var(--border); padding-top: 0.75rem; margin-top: 0.75rem; }
.itrow { display: flex; justify-content: space-between; padding: 0.3rem 0; font-size: 0.85rem; color: var(--text2); }
.itrow.grand {
  border-top: 2px solid var(--navy); margin-top: 0.35rem; padding-top: 0.6rem;
  font-family: 'Playfair Display', serif;
  font-size: 1.1rem; font-weight: 700; color: var(--navy);
}

/* ============ CALENDAR ============ */
.cal-layout { display: grid; grid-template-columns: 1fr 280px; gap: 1rem; }
.cal-main {
  background: var(--white); border: 1px solid var(--border);
  border-radius: var(--radius-lg); overflow: hidden;
}
.cal-nav-bar {
  display: flex; align-items: center; justify-content: space-between;
  padding: 1rem 1.25rem; border-bottom: 1px solid var(--border);
  background: var(--raised);
}
.cal-nav-bar h3 {
  font-family: 'Playfair Display', serif;
  font-size: 1.1rem; font-weight: 700; color: var(--navy);
}
.cal-grid {
  display: grid; grid-template-columns: repeat(7, 1fr);
}
.cal-dh {
  text-align: center; padding: 0.6rem;
  font-size: 0.68rem; font-weight: 700; letter-spacing: 0.08em;
  text-transform: uppercase; color: var(--navy);
  background: var(--navy-dim);
  border-bottom: 1px solid var(--border);
}
.cal-day {
  min-height: 70px; border: 0.5px solid var(--border);
  padding: 0.4rem; cursor: pointer; transition: background 0.15s;
}
.cal-day:hover { background: var(--bg); }
.cal-day.today { background: var(--gold-dim); }
.cal-day.today .cal-dn { color: var(--navy); font-weight: 700; }
.cal-day.other { opacity: 0.35; }
.cal-dn { font-size: 0.78rem; font-weight: 500; color: var(--text2); }
.cal-ev {
  display: block; width: 100%; padding: 1px 4px;
  border-radius: 3px; font-size: 0.58rem; font-weight: 600;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
  margin-top: 2px;
}
.cal-ev.hearing  { background: var(--navy-dim); color: var(--navy); }
.cal-ev.deadline { background: var(--red-dim);  color: var(--red); }
.cal-ev.meeting  { background: var(--blue-dim); color: var(--blue); }
.cal-ev.other    { background: var(--gold-dim); color: var(--amber); }

.cal-side {
  background: var(--white); border: 1px solid var(--border);
  border-radius: var(--radius-lg); overflow: hidden;
}
.events-list { max-height: 500px; overflow-y: auto; }
.ev-item {
  padding: 0.75rem 1.25rem; border-bottom: 1px solid var(--border);
  cursor: pointer; transition: background 0.15s;
}
.ev-item:last-child { border-bottom: none; }
.ev-item:hover { background: var(--bg); }
.ev-item-title { font-size: 0.83rem; font-weight: 600; color: var(--text); }
.ev-item-meta { font-size: 0.73rem; color: var(--text3); margin-top: 0.2rem; }

/* ============ TASKS ============ */
.task-cols { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1rem; }
.task-col {
  background: var(--white); border: 1px solid var(--border);
  border-radius: var(--radius-lg); overflow: hidden;
}
.task-col-hdr {
  padding: 0.75rem 1.25rem;
  font-size: 0.82rem; font-weight: 700;
  border-bottom: 1px solid var(--border);
  background: var(--raised); color: var(--text);
}
.task-col-body { padding: 0.5rem; }
.task-item {
  background: var(--bg); border: 1px solid var(--border);
  border-radius: var(--radius); padding: 0.75rem;
  margin-bottom: 0.5rem; cursor: pointer;
  transition: box-shadow 0.15s;
}
.task-item:hover { box-shadow: var(--shadow); }
.task-item-title { font-size: 0.83rem; font-weight: 600; color: var(--text); }
.task-item-meta { font-size: 0.73rem; color: var(--text3); margin-top: 0.2rem; }
.task-item-actions { display: flex; gap: 0.35rem; margin-top: 0.5rem; }

/* ============ STAFF ============ */
.staff-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: 1rem;
}
.staff-card {
  background: var(--white); border: 1px solid var(--border);
  border-radius: var(--radius-lg); padding: 1.5rem;
  text-align: center;
}
.staff-av {
  width: 56px; height: 56px;
  background: var(--navy); color: var(--gold);
  border-radius: 50%; display: flex; align-items: center; justify-content: center;
  font-size: 1.1rem; font-weight: 700; margin: 0 auto 1rem;
}
.staff-name { font-family: 'Playfair Display', serif; font-size: 1rem; font-weight: 600; color: var(--navy); }
.staff-role { font-size: 0.8rem; color: var(--text3); margin-top: 0.2rem; }
.staff-email { font-size: 0.78rem; color: var(--blue); margin-top: 0.35rem; }

/* ============ SETTINGS ============ */
.settings-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
  gap: 1.25rem;
}
.settings-panel {
  background: var(--white); border: 1px solid var(--border);
  border-radius: var(--radius-lg); padding: 1.5rem;
  display: flex; flex-direction: column; gap: 0.875rem;
}
.settings-panel h3 {
  font-family: 'Playfair Display', serif;
  font-size: 1rem; font-weight: 700; color: var(--navy);
  padding-bottom: 0.5rem; border-bottom: 2px solid var(--gold-dim);
}
.settings-info { font-size: 0.82rem; color: var(--text3); line-height: 1.7; }
.gcal-status {
  font-size: 0.8rem; padding: 0.6rem; border-radius: 6px; margin-top: 0.25rem;
}
.gcal-status.ok  { background: var(--green-dim); color: var(--green); }
.gcal-status.err { background: var(--red-dim); color: var(--red); }
.gcal-info {
  background: var(--bg); border: 1px solid var(--border);
  border-radius: var(--radius); padding: 1rem;
  font-size: 0.78rem; color: var(--text2); line-height: 2;
}
.gcal-info a { color: var(--blue); }
.toggle-row {
  display: flex; justify-content: space-between; align-items: center;
  padding: 0.4rem 0; border-bottom: 1px solid var(--border); font-size: 0.85rem;
}
.toggle-row input { width: auto; cursor: pointer; }

/* ============ REPORTS ============ */
.report-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); gap: 1.25rem; }
.report-card {
  background: var(--white); border: 1px solid var(--border);
  border-radius: var(--radius-lg); overflow: hidden;
}
.report-card h3 {
  font-family: 'Playfair Display', serif;
  font-size: 0.95rem; font-weight: 700; color: var(--navy);
  padding: 1rem 1.25rem; border-bottom: 1px solid var(--border);
  background: var(--raised);
}
.rpt-body { padding: 1rem 1.25rem; }
.rpt-row {
  display: flex; justify-content: space-between; align-items: center;
  padding: 0.5rem 0; border-bottom: 1px solid var(--border); font-size: 0.85rem;
}
.rpt-row:last-child { border-bottom: none; }
.rpt-label { color: var(--text2); }
.rpt-val { font-weight: 600; color: var(--navy); font-family: 'Source Code Pro', monospace; font-size: 0.82rem; }
.rpt-bar { height: 6px; background: var(--bg); border-radius: 3px; margin-top: 0.25rem; }
.rpt-bar-fill { height: 100%; background: var(--navy); border-radius: 3px; }

/* ============ MODALS ============ */
.modal-bg {
  position: fixed; inset: 0;
  background: rgba(14,37,71,0.6);
  backdrop-filter: blur(3px);
  display: none; align-items: center; justify-content: center;
  z-index: 800; padding: 1rem;
}
.modal-bg.open { display: flex; animation: fadeIn 0.2s ease; }

@keyframes fadeIn { from { opacity: 0; } to { opacity: 1; } }

.modal {
  background: var(--white);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-lg);
  width: 100%; max-width: 540px;
  max-height: 90vh; overflow-y: auto;
  animation: slideUp 0.25s ease;
  scrollbar-width: thin;
}
.modal.modal-lg { max-width: 760px; }

.modal-hdr {
  display: flex; justify-content: space-between; align-items: center;
  padding: 1.25rem 1.5rem;
  border-bottom: 1px solid var(--border);
  background: var(--navy);
  position: sticky; top: 0; z-index: 1;
}
.modal-hdr h2 {
  font-family: 'Playfair Display', serif;
  font-size: 1.2rem; font-weight: 700; color: var(--gold);
}
.modal-hdr button {
  background: none; border: none; color: rgba(255,255,255,0.5);
  font-size: 1.1rem; cursor: pointer; border-radius: 4px; padding: 4px 8px;
  transition: color 0.2s;
}
.modal-hdr button:hover { color: #fff; }

.modal-body {
  padding: 1.5rem;
  display: flex; flex-direction: column; gap: 1rem;
}
.modal-ftr {
  padding: 1rem 1.5rem;
  border-top: 1px solid var(--border);
  display: flex; justify-content: flex-end; gap: 0.75rem;
  position: sticky; bottom: 0; background: var(--white);
}

/* ============ DOCUMENTS / PRINT ============ */
.doc-view { font-size: 0.9rem; }

.doc-letterhead {
  display: flex; justify-content: space-between; align-items: flex-start;
  margin-bottom: 1.5rem; padding-bottom: 1.25rem;
  border-bottom: 3px double var(--border2);
}
.doc-firm-logo { max-width: 220px; height: auto; }
.doc-firm-contact { text-align: right; font-size: 0.78rem; color: var(--text2); line-height: 1.8; }
.doc-title-row {
  display: flex; justify-content: space-between; align-items: flex-start;
  margin-bottom: 1.5rem;
}
.doc-type-label {
  font-family: 'Playfair Display', serif;
  font-size: 2rem; font-weight: 700; color: var(--navy); letter-spacing: 0.04em;
}
.doc-number { font-family: 'Source Code Pro', monospace; font-size: 0.9rem; color: var(--gold); font-weight: 600; }
.doc-parties { display: grid; grid-template-columns: 1fr 1fr; gap: 1.5rem; margin-bottom: 1.25rem; }
.doc-party-lbl { font-size: 0.68rem; text-transform: uppercase; letter-spacing: 0.1em; color: var(--text3); margin-bottom: 0.3rem; }
.doc-party-name { font-weight: 700; font-size: 1rem; color: var(--navy); }
.doc-party-det { font-size: 0.8rem; color: var(--text2); line-height: 1.7; }
.doc-dates { display: flex; gap: 2rem; margin-bottom: 1.5rem; }
.doc-date-lbl { font-size: 0.68rem; text-transform: uppercase; letter-spacing: 0.1em; color: var(--text3); }
.doc-date-val { font-weight: 600; color: var(--text); margin-top: 0.15rem; }

.doc-table { width: 100%; border-collapse: collapse; margin-bottom: 1.25rem; }
.doc-table th {
  background: var(--navy); color: var(--gold);
  padding: 0.6rem 0.875rem;
  text-align: left; font-size: 0.68rem; text-transform: uppercase; letter-spacing: 0.1em;
}
.doc-table td { padding: 0.7rem 0.875rem; border-bottom: 1px solid var(--border); font-size: 0.85rem; }
.doc-totals { margin-left: auto; width: 260px; }
.doc-tot-row { display: flex; justify-content: space-between; padding: 0.3rem 0; font-size: 0.85rem; color: var(--text2); }
.doc-tot-row.grand {
  border-top: 2px solid var(--navy); padding-top: 0.6rem; margin-top: 0.35rem;
  font-family: 'Playfair Display', serif; font-size: 1.05rem; font-weight: 700; color: var(--navy);
}
.doc-footer { margin-top: 2rem; padding-top: 1rem; border-top: 1px solid var(--border); font-size: 0.78rem; color: var(--text2); line-height: 1.8; }
.doc-stamp {
  text-align: right; margin-top: 1.5rem;
}
.doc-stamp-box {
  display: inline-block; border: 2.5px solid;
  border-radius: 4px; padding: 0.75rem 1.5rem;
  font-family: 'Playfair Display', serif;
  font-size: 1.1rem; font-weight: 700;
}

/* ============ TOAST ============ */
.toast {
  position: fixed; bottom: 1.5rem; right: 1.5rem;
  background: var(--navy); color: var(--gold);
  border-radius: var(--radius); padding: 0.75rem 1.25rem;
  font-size: 0.875rem; font-weight: 500;
  z-index: 9999; box-shadow: var(--shadow-lg);
  transform: translateY(20px); opacity: 0; pointer-events: none;
  transition: all 0.3s ease; max-width: 350px;
  border-left: 4px solid var(--gold);
}
.toast.show { transform: translateY(0); opacity: 1; }
.toast.success { border-left-color: var(--green); }
.toast.error   { border-left-color: var(--red); }

/* ============ PRINT ============ */
@media print {
  body { background: white; font-size: 12px; }
  .sidebar, .topbar, .scroll-area > .sec:not(.active),
  .tb-right, .ham, .modal-ftr, .no-print { display: none !important; }
  .modal-bg { position: static; background: none; display: block !important; padding: 0; }
  .modal { max-width: 100%; box-shadow: none; border: none; max-height: none; overflow: visible; }
  .modal-hdr { background: var(--navy); -webkit-print-color-adjust: exact; print-color-adjust: exact; }
  :root { --navy: #0e2547; --gold: #c9a84c; }
}

/* ============ RESPONSIVE ============ */
@media (max-width: 800px) {
  .sidebar {
    position: fixed; top: 0; left: 0; bottom: 0;
    transform: translateX(-100%); z-index: 200;
  }
  .sidebar.open { transform: translateX(0); box-shadow: 5px 0 20px rgba(0,0,0,0.3); }
  .dash-grid { grid-template-columns: 1fr; }
  .dash-panel.span2 { grid-column: span 1; }
  .cal-layout { grid-template-columns: 1fr; }
  .task-cols { grid-template-columns: 1fr; }
  .inv-row { grid-template-columns: 1fr 60px 120px 80px 28px; }
  .sec { padding: 1rem; }
}

/* ============ SCROLLBAR ============ */
::-webkit-scrollbar { width: 6px; height: 6px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: var(--border2); border-radius: 3px; }
::-webkit-scrollbar-thumb:hover { background: var(--text3); }

/* ============================================================
   ACCORD LAW v3 — Additional Styles
   ============================================================ */

/* ── GBA Fee Reference Bar ── */
.fee-ref-bar {
  display:flex; align-items:center; gap:.75rem;
  background:var(--navy-dim); border:1px solid rgba(14,37,71,0.15);
  border-radius:var(--radius); padding:.6rem 1rem;
  font-size:.82rem; color:var(--navy); font-weight:600;
  flex-wrap:wrap;
}
.fee-ref-bar select {
  flex:1; background:var(--white); border:1px solid var(--border2);
  border-radius:var(--radius); padding:.45rem .75rem;
  font-size:.82rem; outline:none; min-width:200px;
  color:var(--text);
}

/* ── Fee Scale Section ── */
.fee-scale-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(300px,1fr)); gap:1rem; }
.fee-scale-card {
  background:var(--white); border:1px solid var(--border);
  border-radius:var(--radius-lg); overflow:hidden;
}
.fee-scale-card-hdr {
  background:var(--navy); color:var(--gold);
  padding:.75rem 1.25rem; font-weight:700; font-size:.88rem;
  font-family:'Playfair Display',serif;
}
.fee-scale-card-body { padding:1rem 1.25rem; }
.fee-row { display:flex; justify-content:space-between; align-items:flex-start; padding:.4rem 0; border-bottom:1px solid var(--border); font-size:.82rem; gap:.5rem; }
.fee-row:last-child { border-bottom:none; }
.fee-row-label { color:var(--text2); flex:1; }
.fee-row-val { font-weight:700; color:var(--navy); font-family:'Source Code Pro',monospace; font-size:.78rem; text-align:right; }

/* ── Fee Calculator Result ── */
.fee-calc-result {
  background:var(--navy-dim); border:1px solid rgba(14,37,71,0.2);
  border-radius:var(--radius-lg); padding:1.25rem;
  font-size:.88rem; min-height:80px;
}
.calc-min { color:var(--green); font-weight:700; font-size:1rem; }
.calc-max { color:var(--amber); font-weight:700; font-size:1rem; }
.calc-note { color:var(--text3); font-size:.78rem; margin-top:.5rem; }

/* ── File Label ── */
.file-label-preview {
  border:2px dashed var(--border2); border-radius:var(--radius-lg);
  background:var(--white); padding:1rem; min-height:120px;
}
.file-label {
  width:100%; font-family:'Playfair Display',serif;
  border:3px solid var(--navy); padding:0;
  background:#fff; color:#000;
}
.fl-top-bar {
  background:var(--navy); color:var(--gold);
  text-align:center; padding:.5rem;
  font-size:.7rem; font-weight:700; letter-spacing:.15em; text-transform:uppercase;
}
.fl-logo-row {
  display:flex; align-items:center; justify-content:center;
  gap:1.5rem; padding:1rem 1.5rem; border-bottom:2px solid var(--navy);
}
.fl-logo { max-height:70px; max-width:200px; object-fit:contain; }
.fl-firm-block { text-align:left; }
.fl-firm-name { font-family:'Playfair Display',serif; font-size:1rem; font-weight:700; color:var(--navy); }
.fl-firm-tag { font-size:.62rem; color:#444; line-height:1.5; }
.fl-court-banner {
  background:var(--gold); text-align:center; padding:.4rem .5rem;
  font-family:'Playfair Display',serif; font-size:.95rem; font-weight:700; color:var(--navy);
  text-transform:uppercase; letter-spacing:.08em;
}
.fl-body { padding:1rem 1.5rem; }
.fl-suit { text-align:center; margin-bottom:.75rem; }
.fl-suit-num { font-family:'Source Code Pro',monospace; font-size:1rem; font-weight:700; color:var(--navy); }
.fl-suit-year { font-size:.82rem; color:#555; }
.fl-parties { margin-bottom:.75rem; }
.fl-party-row { display:flex; gap:.75rem; align-items:flex-start; padding:.35rem 0; border-bottom:1px solid #ddd; font-size:.85rem; }
.fl-party-role { width:100px; font-weight:700; color:var(--navy); font-size:.72rem; text-transform:uppercase; letter-spacing:.06em; flex-shrink:0; }
.fl-party-name { color:#000; font-weight:600; }
.fl-meta { display:grid; grid-template-columns:1fr 1fr; gap:.5rem; margin-bottom:.75rem; }
.fl-meta-item { }
.fl-meta-lbl { font-size:.62rem; text-transform:uppercase; letter-spacing:.08em; color:#666; }
.fl-meta-val { font-size:.82rem; font-weight:600; color:#000; }
.fl-bottom-bar {
  background:var(--navy); color:rgba(255,255,255,0.7);
  text-align:center; padding:.35rem;
  font-size:.6rem; letter-spacing:.1em;
}

/* ── Print ── */
@media print {
  /* Hide everything except the print overlay */
  body > * { display:none !important; }
  #print-overlay { display:block !important; }
  #print-overlay { position:fixed; inset:0; background:white; z-index:99999; }
  #print-content { padding:0; }
  
  /* File label specific */
  .file-label { border:2px solid #000; }
  .fl-top-bar { background:#000 !important; color:#c9a84c !important; -webkit-print-color-adjust:exact; print-color-adjust:exact; }
  .fl-court-banner { background:#c9a84c !important; -webkit-print-color-adjust:exact; print-color-adjust:exact; }
  .fl-bottom-bar { background:#000 !important; -webkit-print-color-adjust:exact; print-color-adjust:exact; }
  
  /* Doc styles for invoice/receipt print */
  .doc-letterhead, .doc-table thead { -webkit-print-color-adjust:exact; print-color-adjust:exact; }
  .modal-hdr { background:#0e2547 !important; color:#c9a84c !important; -webkit-print-color-adjust:exact; print-color-adjust:exact; }
  
  @page { size:A4; margin:10mm; }
}

/* ── Reminder list ── */
.reminder-item {
  display:flex; align-items:flex-start; gap:.75rem;
  background:var(--bg); border:1px solid var(--border);
  border-radius:var(--radius); padding:.75rem 1rem; margin-bottom:.5rem;
}
.reminder-item input[type="checkbox"] { margin-top:3px; flex-shrink:0; }
.reminder-item-body { flex:1; }
.reminder-item-title { font-weight:600; font-size:.85rem; color:var(--text); }
.reminder-item-meta { font-size:.75rem; color:var(--text3); margin-top:.2rem; }
.reminder-phone { font-family:'Source Code Pro',monospace; font-size:.78rem; color:var(--blue); }

/* ── Representative fields indicator ── */
#rep-fields { border-left:3px solid var(--gold) !important; }

/* ── Access level badge ── */
.access-badge { font-size:.62rem; }
.access-admin    { background:var(--navy-dim); color:var(--navy); }
.access-lawyer   { background:var(--blue-dim); color:var(--blue); }
.access-calendar { background:var(--gold-dim); color:var(--amber); }
.access-readonly { background:rgba(138,149,168,0.15); color:var(--text3); }

/* ── Dashboard logo ── */
#dash-logo {
  max-height: 90px;
  width: auto;
  object-fit: contain;
  flex-shrink: 0;
  filter: drop-shadow(0 2px 8px rgba(14,37,71,0.1));
  transition: transform 0.2s;
}
#dash-logo:hover { transform: scale(1.03); }

@media (max-width: 600px) {
  #dash-logo { max-height: 60px; }
}

/* ── Sidebar avatar — initials only (no image overlay) ── */
#sb-av { position: relative; overflow: hidden; }
#sb-av-text { font-size: .72rem; font-weight: 700; }


/* ===== ENHANCEMENT PATCH ===== */

.login-help {
  margin-top: .9rem;
  font-size: .76rem;
  color: var(--text3);
  line-height: 1.6;
  text-align: center;
}

:focus-visible {
  outline: 3px solid rgba(45,111,204,.24);
  outline-offset: 2px;
}

.sec.active {
  animation: secFade .32s ease;
}

@keyframes secFade {
  from { opacity: 0; transform: translateY(8px); }
  to { opacity: 1; transform: translateY(0); }
}

.kpi-card, .dash-panel, .case-card, .staff-card, .settings-panel, .table-card, .report-card {
  transition: transform .22s ease, box-shadow .22s ease, border-color .22s ease, opacity .22s ease;
}

.kpi-card:hover, .dash-panel:hover, .case-card:hover, .staff-card:hover, .settings-panel:hover, .table-card:hover, .report-card:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow);
}

.topbar-utilities {
  display: flex;
  align-items: center;
  gap: .5rem;
}

.utility-btn {
  border: 1px solid var(--border);
  background: var(--white);
  color: var(--navy);
  border-radius: 999px;
  padding: .42rem .8rem;
  font-size: .78rem;
  font-weight: 600;
  cursor: pointer;
  transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}
.utility-btn:hover {
  transform: translateY(-1px);
  border-color: var(--navy-light);
  box-shadow: 0 6px 16px rgba(14,37,71,.1);
}
.utility-btn.active {
  background: var(--navy);
  color: var(--gold);
  border-color: var(--navy);
}

.settings-shell {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}
.settings-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: .65rem;
  margin-bottom: .5rem;
}
.settings-tab {
  border: 1px solid var(--border);
  background: var(--white);
  border-radius: 999px;
  padding: .6rem 1rem;
  font-size: .8rem;
  font-weight: 700;
  letter-spacing: .02em;
  color: var(--navy);
  cursor: pointer;
}
.settings-tab.active {
  background: var(--navy);
  color: var(--gold);
  border-color: var(--navy);
  box-shadow: var(--shadow);
}
.settings-panel[hidden] { display: none !important; }
.settings-panel.tab-animate { animation: secFade .24s ease; }

.privacy-mode .mono,
.privacy-mode .staff-email,
.privacy-mode .reminder-phone,
.privacy-mode td:nth-child(3),
.privacy-mode td:nth-child(4),
.privacy-mode td:nth-child(5),
.privacy-mode td:nth-child(7),
.privacy-mode .bill-val,
.privacy-mode .kpi-num,
.privacy-mode .doc-party-det,
.privacy-mode .doc-number {
  filter: blur(6px);
  user-select: none;
}

.lock-screen {
  position: fixed;
  inset: 0;
  background: rgba(14,37,71,.82);
  backdrop-filter: blur(8px);
  display: none;
  align-items: center;
  justify-content: center;
  z-index: 9500;
  padding: 1rem;
}
.lock-screen.open { display: flex; }
.lock-card {
  width: min(420px, 100%);
  background: var(--white);
  border-radius: 18px;
  box-shadow: var(--shadow-lg);
  padding: 1.6rem;
}
.lock-card h3 {
  font-family: 'Playfair Display', serif;
  color: var(--navy);
  font-size: 1.45rem;
  margin-bottom: .4rem;
}
.lock-card p {
  color: var(--text3);
  line-height: 1.7;
  margin-bottom: 1rem;
}

.modal.force-modal {
  max-width: 480px;
}
.force-note {
  background: linear-gradient(135deg, rgba(45,111,204,.08), rgba(201,168,76,.12));
  border: 1px solid rgba(45,111,204,.15);
  border-radius: 12px;
  padding: .9rem 1rem;
  font-size: .85rem;
  color: var(--navy);
  line-height: 1.7;
}
.password-rules {
  list-style: none;
  display: grid;
  gap: .35rem;
  font-size: .78rem;
  color: var(--text3);
}
.password-rules li.ok { color: var(--green); font-weight: 600; }
.password-rules li.bad { color: var(--red); }
.strength-bar {
  height: 8px;
  background: var(--bg);
  border-radius: 999px;
  overflow: hidden;
  margin-top: .45rem;
}
.strength-bar > span {
  display: block;
  height: 100%;
  width: 0;
  background: var(--amber);
  transition: width .2s ease;
}
.gcal-status.warn {
  background: var(--amber-dim);
  color: var(--amber);
}
.inline-note {
  font-size: .76rem;
  color: var(--text3);
  line-height: 1.6;
}

@media (max-width: 800px) {
  .topbar-utilities { display: none; }
  .settings-tabs { overflow-x: auto; flex-wrap: nowrap; padding-bottom: .25rem; }
}

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration: .01ms !important; animation-iteration-count: 1 !important; transition-duration: .01ms !important; scroll-behavior: auto !important; }
}
