:root {
  --bg: #f5f8fb;
  --card: rgba(255,255,255,0.94);
  --text: #12222f;
  --muted: #5e7281;
  --primary: #0F6391;
  --primary-dark: #0b4d71;
  --accent: #F7DB1F;
  --accent-dark: #d5b600;
  --success: #188a45;
  --danger: #c53b32;
  --warning: #c69300;
  --border: rgba(15,99,145,0.16);
  --shadow: 0 18px 50px rgba(15,99,145,0.12);
  --sidebar-start: var(--primary);
  --sidebar-end: var(--primary-dark);
}

* { box-sizing: border-box; }
body { margin: 0; font-family: Inter, Arial, sans-serif; background: radial-gradient(circle at top left, #edf5fa 0, #f8fbfd 42%, #f5f8fb 100%); color: var(--text); }
.hidden { display: none !important; }
.top-space { margin-top: 12px; }
.full-width { width: 100%; }
.overlay { min-height: 100vh; display: flex; align-items: center; justify-content: center; padding: 24px; background: radial-gradient(circle at top, #e7f2f9, #eef6fb 50%, #f7fafc 100%); }
.login-card { width: min(420px, 100%); }

.login-overlay { background: radial-gradient(circle at top left, rgba(15,99,145,.16), transparent 32%), radial-gradient(circle at bottom right, rgba(247,219,31,.18), transparent 28%), linear-gradient(135deg, #f4f9fc 0%, #edf5fa 45%, #f8fbfd 100%); }
.login-shell { width:min(1100px,100%); display:grid; grid-template-columns: 1.1fr 420px; gap:24px; align-items:stretch; }
.login-aside { padding:42px 36px; border-radius:32px; background: linear-gradient(145deg, rgba(15,99,145,.96), rgba(11,77,113,.92)); color:#fff; box-shadow: 0 22px 60px rgba(15,99,145,.20); position:relative; overflow:hidden; }
.login-aside::after { content:''; position:absolute; right:-50px; bottom:-50px; width:220px; height:220px; background: radial-gradient(circle, rgba(247,219,31,.45), transparent 70%); }
.login-brand-badge { display:inline-flex; padding:10px 16px; border-radius:999px; background:rgba(255,255,255,.12); font-size:12px; font-weight:800; text-transform:uppercase; letter-spacing:.08em; margin-bottom:20px; }
.login-aside h1 { font-size:48px; line-height:1.02; margin:0 0 14px; letter-spacing:-.03em; }
.login-lead { max-width:640px; color:rgba(255,255,255,.86); font-size:18px; line-height:1.6; margin-bottom:28px; }
.login-points { display:grid; gap:16px; margin-top:24px; }
.login-point { display:flex; gap:14px; align-items:flex-start; padding:14px 16px; border-radius:18px; background:rgba(255,255,255,.08); backdrop-filter: blur(6px); }
.login-point span { width:12px; height:12px; border-radius:999px; margin-top:6px; background:var(--accent); box-shadow:0 0 0 4px rgba(247,219,31,.18); }
.login-point strong { display:block; margin-bottom:4px; }
.login-point small { color:rgba(255,255,255,.82); font-size:13px; line-height:1.4; }
.login-panel { align-self:center; }
.login-card { width:100%; }
.login-panel h2 { margin:0 0 8px; font-size:34px; letter-spacing:-.02em; }
.login-mark { width:72px; height:72px; border-radius:22px; display:flex; align-items:center; justify-content:center; background:rgba(247,219,31,.20); color:#fff; font-size:28px; font-weight:900; letter-spacing:-.04em; margin-bottom:18px; border:1px solid rgba(255,255,255,.14); }
.login-contact-box { margin-top:18px; padding:16px 18px; border-radius:18px; background:rgba(15,99,145,.06); border:1px solid rgba(15,99,145,.12); display:grid; gap:8px; }
.login-contact-box strong { font-size:14px; }
.login-contact-box a { color:var(--primary); font-weight:800; text-decoration:none; }
.login-contact-box small { color:var(--muted); line-height:1.45; }
.nav-app-icon { width:54px; height:54px; border-radius:16px; background:linear-gradient(135deg, rgba(247,219,31,.95), rgba(255,241,140,.92)); color:#0F6391; display:flex; align-items:center; justify-content:center; font-size:20px; font-weight:900; box-shadow:0 12px 24px rgba(247,219,31,.18); flex:0 0 54px; }
.center-switch label { color: rgba(255,255,255,.86); }

.login-form-grid label { display:block; margin-bottom:6px; color:var(--muted); font-size:13px; font-weight:700; }
.login-submit { margin-top:8px; width:100%; padding:14px 18px; font-size:15px; }
.neutral-note { border-left-color: var(--primary); background: rgba(15,99,145,.08); }
.soft-separator { border:0; height:1px; background:rgba(15,99,145,.12); margin:18px 0; }

.error-text { color: var(--danger); }
.app-shell { display: grid; grid-template-columns: 260px 1fr; min-height: 100vh; }
.sidebar { background: linear-gradient(180deg, var(--sidebar-start) 0%, var(--sidebar-end) 100%); color: white; padding: 24px; display: flex; flex-direction: column; gap: 12px; box-shadow: inset -1px 0 0 rgba(255,255,255,0.08); }
.sidebar h1 { margin: 0; font-size: 28px; }
.eyebrow { text-transform: uppercase; letter-spacing: .08em; font-size: 12px; opacity: .75; margin: 0 0 8px; }
.nav-btn { width: 100%; padding: 14px 16px; border: 0; border-radius: 16px; background: rgba(255,255,255,0.08); color: white; cursor: pointer; text-align: left; font-weight: 700; backdrop-filter: blur(6px); }
.nav-btn.active { background: linear-gradient(135deg, var(--accent) 0%, #ffe867 100%); color: #12222f; box-shadow: 0 10px 22px rgba(247,219,31,.30); }
.sidebar-footer { margin-top: auto; }
.content { padding: 28px; }
.tab { display: none; }
.tab.active { display: block; }
.brand-row { display: flex; align-items: center; gap: 12px; }
.brand-logo { width: 54px; height: 54px; object-fit: contain; border-radius: 12px; background: white; padding: 4px; }
.card { background: var(--card); border: 1px solid var(--border); backdrop-filter: blur(14px); border-radius: 24px; padding: 22px; box-shadow: var(--shadow); margin-bottom: 16px; }
.hero-card { padding: 26px; position: relative; overflow: hidden; }
.hero-card::after { content: ''; position: absolute; inset: auto -30px -30px auto; width: 160px; height: 160px; background: radial-gradient(circle, rgba(247,219,31,.30), transparent 70%); }
.hero-strip { display:flex; gap:10px; flex-wrap:wrap; margin: 0 0 16px; }
.hero-pill { padding: 10px 14px; border-radius: 999px; background: rgba(247,219,31,.25); color: #7f6900; font-weight: 700; }
.hero-pill.alt { background: rgba(15,99,145,.10); color: var(--primary); }
.hero-top, .section-header { display: flex; justify-content: space-between; align-items: start; gap: 12px; }
.hero-actions, .row, .inline-search { display: flex; gap: 12px; align-items: end; flex-wrap: wrap; }
.inline-field { display: flex; flex-direction: column; gap: 6px; min-width: 180px; }
.inline-field.grow, .grow { flex: 1; }
.field-stack { display: grid; gap: 12px; }
.checkbox-line { display: flex; gap: 8px; align-items: center; font-weight: 600; }
.subtle { color: var(--muted); }
.status-text { color: var(--muted); margin-top: 14px; }
.grid.two { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.checkin-layout { max-width: 1200px; }
.member-card { min-height: 136px; border: 1px dashed rgba(15,99,145,.24); border-radius: 20px; padding: 18px; background: linear-gradient(180deg, rgba(255,255,255,.98), rgba(240,247,252,.95)); }
.member-card.empty { color: var(--muted); display: flex; align-items: center; }
.member-name { font-size: 28px; font-weight: 900; margin-bottom: 10px; letter-spacing: -0.02em; }
.member-meta { color: var(--muted); display: grid; gap: 4px; }
.search-results { margin-top: 12px; border: 1px solid var(--border); border-radius: 16px; overflow: hidden; background: white; }
.search-item { padding: 12px 14px; border-bottom: 1px solid var(--border); cursor: pointer; }
.search-item:last-child { border-bottom: 0; }
.search-item:hover { background: rgba(15,99,145,.06); }
.status-badge { display: inline-flex; align-items: center; padding: 8px 12px; border-radius: 999px; font-size: 12px; font-weight: 700; }
.status-badge.neutral { background: rgba(15,99,145,.10); color: var(--primary); }
.status-badge.success { background: #dcfce7; color: #166534; }
.status-badge.error { background: #fee2e2; color: #991b1b; }
.status-badge.warning { background: #ffedd5; color: #9a3412; }
button, input, select, textarea { padding: 12px 14px; border-radius: 14px; border: 1px solid var(--border); font: inherit; }
button { background: linear-gradient(135deg, var(--primary) 0%, var(--primary-dark) 100%); color: white; border: 0; cursor: pointer; font-weight: 800; box-shadow: 0 10px 18px rgba(15,99,145,.22); }
button:hover { filter: brightness(1.03); transform: translateY(-1px); }
button.secondary { background: rgba(15,99,145,.08); color: var(--primary); box-shadow: none; }
button.primary.big { padding: 14px 18px; font-size: 16px; }
input, select, textarea { width: 100%; background: rgba(255,255,255,.96); border-color: rgba(15,99,145,.18); }
textarea { min-height: 90px; resize: vertical; }
.form-grid { display: grid; gap: 12px; }
.form-grid.two-cols { grid-template-columns: 1fr 1fr; }
.form-grid .full-span { grid-column: 1 / -1; }
table { width: 100%; border-collapse: collapse; }
th, td { padding: 11px 10px; border-bottom: 1px solid var(--border); text-align: left; }
tr.clickable:hover { background: #f0f4ff; cursor: pointer; }
.empty-row { color: var(--muted); text-align: center; }
.uid-row { display: grid; grid-template-columns: minmax(180px, 1fr) auto auto; gap: 10px; align-items: center; }
.stats-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 12px; }
.stat-box { padding: 16px; border: 1px solid var(--border); border-radius: 16px; background: #f8fbff; }
.stat-box span { display: block; color: var(--muted); margin-bottom: 6px; }
.stat-box strong { font-size: 28px; }
.settings-logo { max-width: 220px; max-height: 120px; object-fit: contain; border: 1px solid var(--border); border-radius: 14px; background: white; padding: 8px; }
.logo-preview-wrap { display: flex; align-items: center; justify-content: center; }
code { display: inline-block; background: #eef3fb; padding: 6px 10px; border-radius: 8px; margin-top: 6px; }
@media (max-width: 960px) {
  .app-shell { grid-template-columns: 1fr; }
  .sidebar { display: flex; flex-wrap: wrap; align-items: center; }
  .grid.two, .form-grid.two-cols, .login-shell { grid-template-columns: 1fr; }
  .uid-row { grid-template-columns: 1fr; }
  .login-aside { padding:28px 24px; }
  .login-aside h1 { font-size:34px; }
}

.field-help { color: var(--muted); font-size: 13px; margin-top: -4px; }
.section-kicker { text-transform: uppercase; letter-spacing: .08em; font-size: 12px; color: var(--primary); font-weight: 800; margin-bottom: 8px; }
thead th { font-size: 12px; text-transform: uppercase; letter-spacing: .04em; color: var(--muted); }
tr.clickable:hover { background: rgba(15,99,145,.06); }

.actions-cell { display:flex; gap:8px; flex-wrap:wrap; }
.mini-btn { padding:8px 10px; border-radius:10px; font-size:13px; }
.settings-note { border-left:4px solid var(--accent); padding:12px 14px; background: rgba(247,219,31,.12); border-radius:12px; }


.logo-preview-wrap.compact{justify-content:flex-start;margin-top:10px}.center-logo-block{display:grid;gap:10px}.center-logo-block .settings-logo{max-height:72px;max-width:220px;object-fit:contain;border-radius:10px;border:1px solid rgba(15,99,145,.12);background:#fff;padding:8px}


/* Clean brand layout: center logo only */
.login-logo-only { display:flex; align-items:center; justify-content:center; padding:32px; }
.login-center-logo { width:min(360px, 80%); max-height:260px; object-fit:contain; filter: drop-shadow(0 20px 40px rgba(0,0,0,.12)); }
.login-brand-badge, .login-mark, .nav-app-icon { display:none !important; }
.brand-row { display:flex; align-items:center; gap:12px; }
.brand-logo { width:62px; height:62px; object-fit:contain; border-radius:14px; background:#fff; padding:6px; }
@media (max-width: 960px) { .login-logo-only { min-height:180px; } .login-center-logo { width:min(260px, 72%); max-height:180px; } }


/* Restored login descriptive panel without generic app icon */
.login-logo-only {
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 24px;
}

.login-logo-wrap {
  display: flex;
  justify-content: center;
  align-items: center;
}

.login-copy-box {
  position: relative;
  z-index: 1;
}

.login-logo-only .login-center-logo {
  width: 132px;
  height: 132px;
  object-fit: contain;
  border-radius: 24px;
  background: rgba(255,255,255,.96);
  padding: 14px;
  box-shadow: 0 18px 38px rgba(0,0,0,.14);
}

.login-logo-only .login-brand-badge {
  display: inline-flex;
  padding: 10px 16px;
  border-radius: 999px;
  background: rgba(255,255,255,.14);
  font-size: 12px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .08em;
  margin-bottom: 18px;
}

.login-logo-only h1 {
  margin: 0;
  font-size: 44px;
  line-height: 1.04;
  color: #fff;
}

.login-logo-only .login-lead {
  margin: 14px 0 0;
  font-size: 18px;
  line-height: 1.55;
  color: rgba(255,255,255,.88);
  max-width: 640px;
}

.login-logo-only .login-points {
  display: grid;
  gap: 14px;
  margin-top: 24px;
}

.login-logo-only .login-point {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  padding: 14px 16px;
  border-radius: 18px;
  background: rgba(255,255,255,.12);
  backdrop-filter: blur(4px);
}

.login-logo-only .login-point span {
  width: 12px;
  height: 12px;
  margin-top: 6px;
  border-radius: 999px;
  background: var(--accent, #F7DB1F);
  flex: 0 0 auto;
  box-shadow: 0 0 0 4px rgba(247,219,31,.18);
}

.login-logo-only .login-point strong {
  display: block;
  color: #fff;
  font-size: 15px;
  margin-bottom: 4px;
}

.login-logo-only .login-point small {
  display: block;
  color: rgba(255,255,255,.82);
  font-size: 13px;
  line-height: 1.45;
}

@media (max-width: 960px) {
  .login-logo-only {
    gap: 18px;
  }
  .login-logo-only h1 {
    font-size: 34px;
  }
  .login-logo-only .login-lead {
    font-size: 16px;
  }
}
