/* AdminLS unified styles – dark, mobile-first */

:root {
  --ls-bg: #050914;
  --ls-surface: #0b1120;
  --ls-surface-soft: #020617;
  --ls-border: #1f2937;
  --ls-border-soft: rgba(148, 163, 184, 0.35);
  --ls-primary: #e78200;
  --ls-primary-soft: #ff9e2f;
  --ls-text: #e5e7eb;
  --ls-text-muted: #9ca3af;
  --ls-success-bg: rgba(22, 163, 74, 0.16);
  --ls-success-text: #bbf7d0;
  --ls-error-bg: rgba(185, 28, 28, 0.16);
  --ls-error-text: #fecaca;
  --ls-pill-bg: rgba(15, 23, 42, 0.9);
  --ls-radius-card: 0.9rem;
  --ls-radius-pill: 999px;
  --ls-radius-input: 0.55rem;
  --ls-shadow-card: 0 18px 40px rgba(0, 0, 0, 0.45);
}

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

html,
body {
  margin: 0;
  padding: 0;
  background: var(--ls-bg);
  color: var(--ls-text);
  font-family: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Arial, sans-serif;
}

/* Basic elements */

body {
  font-size: 14px;
  line-height: 1.45;
}

a {
  color: var(--ls-primary);
  text-decoration: none;
}

a:hover {
  text-decoration: underline;
}

h1,
h2,
h3 {
  margin: 0 0 0.35rem;
  font-weight: 600;
  color: var(--ls-text);
}

p {
  margin: 0 0 0.5rem;
  color: var(--ls-text-muted);
}

/* Layout shell matches layout.php */

.topbar {
  height: 56px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 16px;
  background: #111827;
  border-bottom: 1px solid #1f2937;
  position: sticky;
  top: 0;
  z-index: 10;
}

.topbar-title {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 15px;
  font-weight: 600;
}

.topbar-title-text {
  white-space: nowrap;
}

.topbar-actions form {
  display: inline;
}

.btn-link {
  background: none;
  border: none;
  color: #9ca3af;
  font-size: 14px;
  padding: 4px 8px;
  cursor: pointer;
}

.btn-link:hover {
  color: #e5e7eb;
}

/* Worker indicator */

#worker-indicator {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 22px;
  height: 22px;
  border-radius: 50%;
  border: 2px solid #374151;
  background: #111827;
  padding: 0;
}

#worker-indicator .worker-dot {
  width: 100%;
  height: 100%;
  border-radius: 50%;
  background: #333;
  display: block;
}

/* Page container */

.page {
  padding: 12px;
  max-width: 960px;
  margin: 0 auto;
}

@media (min-width: 768px) {
  .page {
    padding: 20px;
  }
}

/* Legacy .card support */

.card {
  background: var(--ls-surface);
  border-radius: var(--ls-radius-card);
  padding: 14px;
  margin-bottom: 14px;
  border: 1px solid var(--ls-border);
  box-shadow: var(--ls-shadow-card);
}

/* Flash / errors */

.flash {
  background: #065f46;
  color: #d1fae5;
  padding: 10px 12px;
  border-radius: 8px;
  margin-bottom: 12px;
  font-size: 13px;
}

.error {
  background: #7f1d1d;
  color: #fee2e2;
  padding: 10px 12px;
  border-radius: 8px;
  margin-bottom: 12px;
  font-size: 13px;
}

/* Buttons – generic */

.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  padding: 6px 12px;
  font-size: 13px;
  border: none;
  cursor: pointer;
}

.btn-primary {
  background: var(--ls-primary);
  color: #050505;
}

.btn-secondary {
  background: #1f2937;
  color: #e5e7eb;
}

/* LS design system styles (new AdminLS screens) */

.ls-card {
  background: var(--ls-surface);
  border-radius: var(--ls-radius-card);
  border: 1px solid var(--ls-border-soft);
  margin-bottom: 1rem;
  box-shadow: var(--ls-shadow-card);
}

.ls-card-inner {
  padding: 0.9rem 1rem;
}

@media (min-width: 768px) {
  .ls-card-inner {
    padding: 1.1rem 1.2rem;
  }
}

.ls-h1 {
  font-size: 1.2rem;
  font-weight: 600;
  color: var(--ls-text);
  margin: 0 0 0.25rem;
}

@media (min-width: 768px) {
  .ls-h1 {
    font-size: 1.4rem;
  }
}

.ls-h2-label {
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-size: 0.7rem;
  color: var(--ls-text-muted);
  margin-bottom: 0.15rem;
}

.ls-text-muted {
  font-size: 0.85rem;
  color: var(--ls-text-muted);
}

/* Pills / chips */

.ls-pill {
  display: inline-flex;
  align-items: center;
  padding: 0.15rem 0.55rem;
  border-radius: var(--ls-radius-pill);
  background: var(--ls-pill-bg);
  border: 1px solid rgba(148, 163, 184, 0.35);
  font-size: 0.75rem;
  color: var(--ls-text-muted);
  white-space: nowrap;
}

/* Form controls */

.ls-input,
.ls-select,
.ls-textarea {
  width: 100%;
  padding: 0.45rem 0.6rem;
  border-radius: var(--ls-radius-input);
  border: 1px solid var(--ls-border-soft);
  background: var(--ls-surface-soft);
  color: var(--ls-text);
  font-size: 0.9rem;
  outline: none;
}

.ls-input:focus,
.ls-select:focus,
.ls-textarea:focus {
  border-color: var(--ls-primary);
  box-shadow: 0 0 0 1px rgba(231, 130, 0, 0.35);
}

.ls-textarea {
  min-height: 90px;
  resize: vertical;
}

.ls-label {
  display: block;
  font-size: 0.85rem;
  margin-bottom: 0.55rem;
}

.ls-label > span,
.ls-label > .label-text {
  display: block;
  margin-bottom: 0.25rem;
  color: var(--ls-text-muted);
}

.ls-checkbox-row {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  font-size: 0.8rem;
  color: var(--ls-text-muted);
}

/* Buttons – LS variant */

.ls-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.3rem;
  border-radius: 999px;
  padding: 0.4rem 0.9rem;
  font-size: 0.85rem;
  font-weight: 500;
  cursor: pointer;
  border: 1px solid transparent;
  text-decoration: none;
}

.ls-btn-primary {
  background: var(--ls-primary);
  border-color: var(--ls-primary);
  color: #050505;
}

.ls-btn-primary:hover {
  background: var(--ls-primary-soft);
  border-color: var(--ls-primary-soft);
}

.ls-btn-outline {
  background: transparent;
  border-color: var(--ls-border-soft);
  color: var(--ls-text-muted);
}

.ls-btn-outline:hover {
  border-color: var(--ls-primary);
  color: var(--ls-primary-soft);
}

/* Simple flex/grid helpers */

.ls-flex-row {
  display: flex;
  flex-wrap: wrap;
  gap: 0.6rem;
}

.ls-flex-col {
  display: flex;
  flex-direction: column;
  gap: 0.6rem;
}

/* Clients list specifics */

.clients-header-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 0.75rem;
}

@media (max-width: 640px) {
  .clients-header-row {
    flex-direction: column;
    align-items: flex-start;
  }
}

.clients-list {
  display: flex;
  flex-direction: column;
  gap: 0.55rem;
  margin-top: 0.6rem;
}

.clients-item {
  border-radius: 0.7rem;
  border: 1px solid var(--ls-border-soft);
  padding: 0.55rem 0.8rem;
  background: rgba(15, 23, 42, 0.9);
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}

.clients-item-main {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 0.5rem;
}

.clients-item-name {
  font-weight: 600;
  font-size: 0.98rem;
}

.clients-item-contact {
  font-size: 0.8rem;
  color: var(--ls-text-muted);
}

.clients-pills {
  display: flex;
  flex-wrap: wrap;
  gap: 0.3rem;
}

/* Workday list */

.workday-section-title {
  font-size: 1rem;
  margin-bottom: 0.4rem;
}

.workday-list {
  display: flex;
  flex-direction: column;
  gap: 0.45rem;
  margin-top: 0.4rem;
}

.workday-item {
  border-radius: 0.7rem;
  border: 1px solid var(--ls-border-soft);
  padding: 0.5rem 0.7rem;
  background: rgba(15, 23, 42, 0.9);
}

.workday-item-title {
  font-size: 0.95rem;
  font-weight: 500;
}

.workday-item-meta {
  font-size: 0.8rem;
  color: var(--ls-text-muted);
}

/* Intake form bits */

.intake-form-layout {
  display: flex;
  flex-direction: column;
  gap: 0.6rem;
}

/* Small helpers */

.text-sm {
  font-size: 0.8rem;
}

.text-xs {
  font-size: 0.75rem;
}

.mt-sm {
  margin-top: 0.4rem;
}

.mt-md {
  margin-top: 0.75rem;
}

/* ----------------------------------------
   Legacy AdminLS "ls-*" view helpers
   ---------------------------------------- */

.ls-card {
  margin-top: 1rem;
  background: #111827;
  border-radius: 10px;
  border: 1px solid #1f2937;
}

.ls-card-inner {
  padding: 16px;
}

.ls-h1 {
  font-size: 1.3rem;
  margin: 0 0 .25rem;
  font-weight: 600;
}

.ls-h2-label {
  font-size: .8rem;
  text-transform: uppercase;
  letter-spacing: .08em;
  opacity: .7;
  margin-bottom: .1rem;
}

.ls-text-muted {
  color: #9ca3af;
}

/* Buttons */

.ls-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  padding: 6px 12px;
  font-size: 13px;
  border: none;
  cursor: pointer;
  text-decoration: none;
}

.ls-btn-primary {
  background: #e78200;
  color: #050505;
}

.ls-btn-outline {
  background: transparent;
  border: 1px solid #4b5563;
  color: #e5e7eb;
}

/* Inputs */

.ls-input,
.ls-select {
  width: 100%;
  border-radius: 8px;
  border: 1px solid #4b5563;
  background: #020617;
  color: #e5e7eb;
  padding: 6px 8px;
  font-size: .9rem;
}

.ls-input:focus,
.ls-select:focus {
  outline: 2px solid #e78200;
  outline-offset: 1px;
}

/* Checkbox row */

.ls-checkbox-row {
  display: inline-flex;
  align-items: center;
  gap: .35rem;
  cursor: pointer;
  font-size: .85rem;
}

/* Pills */

.ls-pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 2px 8px;
  border-radius: 999px;
  background: rgba(15,23,42,.9);
  border: 1px solid rgba(148,163,184,.5);
  font-size: .72rem;
}

/* SEO cockpit helpers (used in the SEO views) */

.seo-strip {
  display: flex;
  gap: .35rem;
  flex-wrap: wrap;
  font-size: .75rem;
}

.seo-dot {
  display: inline-block;
  width: 10px;
  height: 10px;
  border-radius: 999px;
}

.seo-dot--red    { background: #ef4444; }
.seo-dot--yellow { background: #eab308; }
.seo-dot--green  { background: #22c55e; }

/* ==========================================================
   AdminLS Shell v2 (non-breaking add-on)
   - Adds side nav + main surface shell
   - Does NOT remove old .topbar/.page/.flash etc.
   ========================================================== */

:root{
  --ls-nav-w: 280px;
  --ls-shell-bg: var(--ls-bg);
  --ls-shell-panel: #0b1120;
  --ls-shell-card: #0f172a;
  --ls-shell-border: var(--ls-border);
}

/* Topbar v2 */
.ls-topbar{
  height: 56px;
  display:flex;
  align-items:center;
  gap: 10px;
  padding: 0 12px;
  background: #111827;
  border-bottom: 1px solid #1f2937;
  position: sticky;
  top: 0;
  z-index: 20;
}

.ls-topbar-title{
  display:flex;
  align-items:center;
  gap: 10px;
  min-width: 0;
}

.ls-topbar-title-text{
  font-size: 15px;
  font-weight: 700;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.ls-topbar-actions{
  margin-left: auto;
  display:flex;
  align-items:center;
  gap: 10px;
}

.ls-iconbtn{
  width: 42px;
  height: 42px;
  border-radius: 12px;
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.10);
  color: var(--ls-text);
  display:flex;
  align-items:center;
  justify-content:center;
  cursor: pointer;
}

.ls-burger{
  width: 18px;
  height: 2px;
  background: var(--ls-text);
  position: relative;
  display:block;
  opacity: .9;
}
.ls-burger:before,
.ls-burger:after{
  content:"";
  position:absolute;
  left:0;
  width:18px;
  height:2px;
  background: var(--ls-text);
}
.ls-burger:before{ top:-6px; }
.ls-burger:after{ top: 6px; }

/* Worker indicator v2 maps to existing dot */
.ls-worker{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width: 22px;
  height: 22px;
  border-radius: 50%;
  border: 2px solid #374151;
  background: #111827;
}
.ls-worker-dot{
  width:100%;
  height:100%;
  border-radius:50%;
  background:#333;
  display:block;
}

/* Side nav */
.ls-nav{
  position: fixed;
  top: 0;
  left: 0;
  height: 100%;
  width: var(--ls-nav-w);
  background: var(--ls-shell-panel);
  border-right: 1px solid rgba(148, 163, 184, 0.20);
  transform: translateX(-102%);
  transition: transform .18s ease;
  z-index: 30;
  padding: 12px;
  display:flex;
  flex-direction:column;
}

.ls-nav.is-open{ transform: translateX(0); }

.ls-scrim{
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.55);
  z-index: 25;
}

.ls-nav-header{
  padding: 10px 10px 14px;
  border-bottom: 1px solid rgba(148, 163, 184, 0.18);
  margin-bottom: 10px;
}
.ls-nav-brand{ font-weight: 800; letter-spacing:.2px; }
.ls-nav-sub{ color: var(--ls-text-muted); font-size: 12px; margin-top: 4px; }

.ls-nav-links{
  display:flex;
  flex-direction:column;
  gap: 6px;
  padding: 10px 4px;
}
.ls-nav-link{
  display:block;
  padding: 10px 12px;
  border-radius: 12px;
  color: var(--ls-text);
  background: rgba(255,255,255,.03);
  border: 1px solid rgba(255,255,255,.06);
}
.ls-nav-link:hover{
  background: rgba(255,255,255,.06);
  text-decoration: none;
}

.ls-nav-footer{
  margin-top:auto;
  padding: 10px;
  border-top: 1px solid rgba(148, 163, 184, 0.18);
  color: var(--ls-text-muted);
  font-size: 12px;
}

/* Main content area */
.ls-main{
  padding: 12px;
  max-width: 1100px;
  margin: 0 auto;
}

@media (min-width: 980px){
  .ls-nav{ transform:none; }
  .ls-iconbtn{ display:none; }
  .ls-main{ margin-left: calc(var(--ls-nav-w) + 0px); }
}

.ls-surface{
  background: var(--ls-surface);
  border: 1px solid rgba(148, 163, 184, 0.20);
  border-radius: var(--ls-radius-card);
  box-shadow: var(--ls-shadow-card);
  padding: 14px;
}

/* Alerts reuse your existing colors */
.ls-alert{
  padding: 10px 12px;
  border-radius: 8px;
  margin: 12px 0;
  font-size: 13px;
  border: 1px solid rgba(148, 163, 184, 0.20);
}
.ls-alert--ok{ background: var(--ls-success-bg); color: var(--ls-success-text); }
.ls-alert--bad{ background: var(--ls-error-bg); color: var(--ls-error-text); }

/* Buttons v2 mapped onto existing .ls-btn variants */
.ls-btn--ghost{
  background: transparent;
  border: 1px solid rgba(148, 163, 184, 0.35);
  color: var(--ls-text-muted);
}
.ls-btn--ghost:hover{
  border-color: var(--ls-primary);
  color: var(--ls-primary-soft);
  text-decoration:none;
}