@import url("https://fonts.googleapis.com/css2?family=Manrope:wght@400;500;600;700;800&family=Sora:wght@500;600;700;800&display=swap");

:root {
  --bg: #f4f5f7;
  --card: #ffffff;
  --text: #1f2430;
  --muted: #5f6675;
  --primary: #3d4758;
  --primary-dark: #2c3442;
  --danger: #a23b3b;
  --border: #d8dde6;
}

* {
  box-sizing: border-box;
}

body {
  margin: 0;
  font-family: "Manrope", "Segoe UI", sans-serif;
  color: var(--text);
  background: var(--bg);
}

h1,
h2 {
  margin: 0;
  font-family: "Sora", "Manrope", sans-serif;
}

h3 {
  margin: 0;
  font-family: "Sora", "Manrope", sans-serif;
}

a {
  color: var(--primary-dark);
}

.muted {
  color: var(--muted);
}

.center {
  text-align: center;
}

.auth-body {
  min-height: 100vh;
  display: grid;
  place-items: center;
  padding: 16px;
}

.auth-card {
  width: min(460px, 100%);
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 16px;
  padding: 24px;
  box-shadow: 0 10px 24px rgba(24, 30, 41, 0.06);
}

.login-body {
  background:
    radial-gradient(circle at top, rgba(99, 102, 241, 0.18), transparent 30%),
    linear-gradient(180deg, #f8faff 0%, #eef2ff 50%, #f8fafc 100%);
}

.login-wrap {
  width: 100%;
  max-width: 430px;
}

.login-card {
  border-radius: 32px;
  border: 1px solid rgba(255, 255, 255, 0.72);
  background: rgba(255, 255, 255, 0.82);
  padding: 30px;
  box-shadow: 0 20px 60px rgba(99, 102, 241, 0.15);
  backdrop-filter: blur(10px);
  animation: login-fade-up 0.45s ease;
}

.login-back {
  display: inline-block;
  margin-bottom: 14px;
  color: #4f46e5;
  font-size: 13px;
  text-decoration: none;
}

.login-back:hover {
  text-decoration: underline;
}

.login-brand {
  margin-bottom: 18px;
  display: flex;
  align-items: center;
  gap: 10px;
}

.login-badge {
  display: grid;
  place-items: center;
  width: 48px;
  height: 48px;
  border-radius: 15px;
  color: #fff;
  font-weight: 700;
  background: linear-gradient(145deg, #4f46e5, #7c3aed);
  box-shadow: 0 10px 24px rgba(79, 70, 229, 0.35);
}

.login-brand h1 {
  margin: 0;
  font-size: 1.45rem;
  color: #0f172a;
}

.login-brand p {
  margin: 2px 0 0;
}

.login-intro {
  margin-bottom: 16px;
}

.login-intro h2 {
  margin: 0 0 4px;
  font-size: 1.2rem;
}

.login-intro p {
  margin: 0;
  line-height: 1.5;
}

.login-form {
  display: grid;
  gap: 12px;
}

.login-field label {
  margin: 0 0 6px;
  display: block;
  font-size: 14px;
  font-weight: 600;
  color: #334155;
}

.login-field input {
  width: 100%;
  height: 44px;
  border: 1px solid #d6dbe7;
  border-radius: 12px;
  padding: 0 14px;
  background: #fff;
  transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.login-field input:focus {
  outline: none;
  border-color: #6366f1;
  box-shadow: 0 0 0 3px rgba(99, 102, 241, 0.2);
}

.login-hint {
  margin: 6px 0 0;
  font-size: 12px;
  line-height: 1.4;
}

.login-password-row {
  margin-bottom: 6px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
}

.login-password-row label {
  margin: 0;
}

.login-forgot {
  color: #4f46e5;
  text-decoration: none;
  font-size: 12px;
}

.login-forgot:hover {
  text-decoration: underline;
}

.login-submit {
  width: 100%;
  height: 44px;
  border-radius: 12px;
  background: linear-gradient(90deg, #4f46e5, #7c3aed);
  color: #fff;
  font-weight: 700;
  border: 0;
  box-shadow: 0 10px 24px rgba(79, 70, 229, 0.28);
  transition: transform 0.2s ease, filter 0.2s ease;
}

.login-submit:hover {
  transform: translateY(-1px);
  filter: brightness(1.03);
}

.login-footer {
  margin: 16px 0 0;
  text-align: center;
  color: #64748b;
  font-size: 14px;
}

.login-footer a {
  color: #4f46e5;
  font-weight: 600;
  text-decoration: none;
}

.login-footer a:hover {
  text-decoration: underline;
}

.form-grid {
  display: grid;
  gap: 8px;
  margin-top: 16px;
}

input,
select,
textarea,
button {
  font: inherit;
}

input,
select,
textarea {
  width: 100%;
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 10px 12px;
  background: #fff;
}

label {
  display: block;
  margin-top: 10px;
  margin-bottom: 6px;
  font-weight: 600;
}

.group-tags,
.tag-selector {
  width: 100%;
  border: 1px solid var(--border);
  border-radius: 10px;
  background: #f8fbfd;
  padding: 10px;
  min-height: 52px;
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
}

.group-tag,
.tag-option {
  border: 1px solid #c8d9e2;
  border-radius: 999px;
  background: #eef4f8;
  color: #244056;
  padding: 7px 12px;
  font-size: 13px;
  font-weight: 600;
  line-height: 1.2;
}

.group-tag:hover,
.tag-option:hover {
  background: #e2ecf3;
}

.group-tag.active,
.tag-option.active {
  background: var(--primary);
  border-color: var(--primary);
  color: #fff;
}

.group-tag-empty,
.tag-empty {
  margin: 0;
  color: var(--muted);
  font-size: 13px;
}

button,
.link-btn {
  border: 0;
  border-radius: 10px;
  padding: 10px 14px;
  background: var(--primary);
  color: #fff;
  font-weight: 600;
  cursor: pointer;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

button:hover,
.link-btn:hover {
  background: var(--primary-dark);
}

button.secondary,
.link-btn.secondary {
  background: #f2f4f7;
  color: #2a3341;
  border: 1px solid var(--border);
}

button.secondary.stop-run-btn {
  background: #fff1f1;
  color: #b42318;
  border-color: #f5c2c7;
}

button.secondary.stop-run-btn:hover {
  background: #ffe2e2;
}

.alert.error {
  background: #fdeeed;
  color: var(--danger);
  border: 1px solid #f1c4c1;
  padding: 10px 12px;
  border-radius: 10px;
  margin-top: 12px;
}

.app-body {
  padding: 20px;
}

.app-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 16px;
  margin-bottom: 16px;
}

.top-nav-links {
  margin-top: 10px;
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.top-nav-links a {
  text-decoration: none;
  color: #2d3646;
  background: #f1f3f6;
  border: 1px solid #d7dde6;
  border-radius: 999px;
  padding: 6px 12px;
  font-size: 13px;
  font-weight: 600;
}

.top-nav-links a.active {
  background: var(--primary);
  color: #fff;
  border-color: var(--primary);
}

.home-layout {
  display: grid;
  gap: 14px;
}

.dash-body {
  background:
    radial-gradient(circle at top, rgba(99, 102, 241, 0.13), transparent 40%),
    #f8fafc;
}

.dash-layout {
  min-height: calc(100vh - 40px);
  display: grid;
  grid-template-columns: 280px 1fr;
  gap: 18px;
}

.dash-sidebar {
  border: 1px solid rgba(255, 255, 255, 0.78);
  border-radius: 26px;
  background: rgba(255, 255, 255, 0.82);
  box-shadow: 0 18px 48px rgba(79, 70, 229, 0.1);
  backdrop-filter: blur(10px);
  padding: 18px;
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.dash-brand {
  display: flex;
  align-items: center;
  gap: 10px;
}

.dash-brand-badge {
  width: 44px;
  height: 44px;
  border-radius: 14px;
  display: grid;
  place-items: center;
  color: #fff;
  font-weight: 700;
  background: linear-gradient(145deg, #4f46e5, #7c3aed);
  box-shadow: 0 10px 24px rgba(79, 70, 229, 0.3);
}

.dash-brand strong {
  display: block;
  font-family: "Sora", "Manrope", sans-serif;
  font-size: 18px;
}

.dash-brand p {
  margin: 2px 0 0;
  color: #64748b;
  font-size: 12px;
}

.dash-nav {
  display: grid;
  gap: 6px;
}

.dash-nav-group {
  display: grid;
  gap: 4px;
}

.dash-nav-link {
  display: block;
  text-decoration: none;
  padding: 10px 12px;
  border-radius: 12px;
  color: #334155;
  font-weight: 600;
  transition: background 0.2s ease, color 0.2s ease;
}

.dash-nav-link:hover {
  background: #f1f5f9;
}

.dash-nav-link.active {
  background: #eef2ff;
  color: #3730a3;
}

.dash-nav-sub-link {
  display: block;
  text-decoration: none;
  margin-left: 12px;
  padding: 8px 10px;
  border-radius: 10px;
  border: 1px solid #e2e8f0;
  background: #ffffff;
  color: #475569;
  font-weight: 600;
  font-size: 12px;
  transition: background 0.2s ease, color 0.2s ease, border-color 0.2s ease;
}

.dash-nav-sub-link:hover {
  background: #f8fafc;
  border-color: #cbd5e1;
  color: #1e293b;
}

.dash-nav-sub-link.active {
  background: #eef2ff;
  border-color: #c7d2fe;
  color: #3730a3;
}

.dash-account {
  margin-top: auto;
  padding-top: 14px;
  border-top: 1px solid #e2e8f0;
}

.dash-user-name {
  margin: 0;
  font-weight: 700;
  color: #0f172a;
  font-size: 14px;
}

.dash-user-mode,
.dash-company-name {
  margin: 3px 0 0;
  color: #64748b;
  font-size: 12px;
}

.dash-logout-btn {
  margin-top: 10px;
  border: 0;
  background: transparent;
  color: #dc2626;
  padding: 0;
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
}

.dash-logout-btn:hover {
  text-decoration: underline;
  background: transparent;
}

.dash-main {
  display: grid;
  gap: 16px;
}

.dash-header h1 {
  margin: 0;
  font-size: clamp(1.8rem, 3vw, 2.2rem);
  letter-spacing: -0.02em;
}

.dash-header p {
  margin: 6px 0 0;
  color: #64748b;
}

.dash-live-card {
  border-radius: 28px;
  background: linear-gradient(100deg, #4f46e5, #7c3aed);
  color: #fff;
  padding: 20px;
  box-shadow: 0 22px 50px rgba(79, 70, 229, 0.28);
}

.dash-live-kicker {
  margin: 0 0 8px;
  font-size: 12px;
  opacity: 0.82;
}

.dash-live-group h2 {
  margin: 0;
  color: #fff;
  font-size: 20px;
}

.dash-live-group p {
  margin: 4px 0 0;
  opacity: 0.86;
  font-size: 13px;
}

.dash-live-items {
  margin-top: 12px;
  display: grid;
  gap: 4px;
}

.dash-live-items p {
  margin: 0;
  font-size: 13px;
}

.muted-light {
  opacity: 0.72;
}

.dash-live-progress {
  margin-top: 12px;
}

.dash-live-progress-meta {
  display: flex;
  justify-content: space-between;
  font-size: 12px;
  opacity: 0.85;
  margin-bottom: 4px;
}

.dash-live-track {
  height: 8px;
  border-radius: 999px;
  overflow: hidden;
  background: rgba(255, 255, 255, 0.23);
}

.dash-live-fill {
  height: 100%;
  width: 67%;
  border-radius: 999px;
  background: #fff;
  animation: dash-fill-pulse 2.2s ease-in-out infinite;
}

.dash-live-summary {
  margin: 10px 0 0;
  font-size: 12px;
  opacity: 0.85;
}

.dash-actions-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}

.dash-action-card {
  text-decoration: none;
  color: inherit;
  border: 1px solid #e2e8f0;
  border-radius: 18px;
  padding: 16px;
  background: #fff;
  box-shadow: 0 8px 24px rgba(15, 23, 42, 0.06);
  transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease;
}

.dash-action-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 16px 30px rgba(15, 23, 42, 0.11);
  border-color: #c7d2fe;
}

.dash-action-card h3 {
  margin: 0 0 6px;
  font-size: 18px;
}

.dash-action-card p {
  margin: 0;
  color: #64748b;
  font-size: 14px;
  line-height: 1.5;
}

.dash-action-card span {
  display: inline-block;
  margin-top: 10px;
  color: #4338ca;
  font-weight: 700;
  font-size: 14px;
}

.dash-info-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

.dash-info-card {
  border-radius: 18px;
}

.dash-info-card h3 {
  margin: 0 0 8px;
}

.dash-info-card ul {
  margin: 0;
  padding-left: 16px;
  color: #64748b;
  line-height: 1.6;
  font-size: 14px;
}

.landing-body {
  max-width: 1320px;
  margin: 0 auto;
  background:
    radial-gradient(circle at top left, rgba(99, 102, 241, 0.14), transparent 34%),
    radial-gradient(circle at top right, rgba(56, 189, 248, 0.12), transparent 28%),
    linear-gradient(180deg, #f8faff 0%, #eef2ff 50%, #f8fafc 100%);
}

.landing-shell {
  display: grid;
  gap: 14px;
}

.landing-top {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  padding: 14px 16px;
  border: 1px solid rgba(255, 255, 255, 0.75);
  border-radius: 26px;
  background: rgba(255, 255, 255, 0.78);
  box-shadow: 0 16px 40px rgba(76, 78, 214, 0.12);
  backdrop-filter: blur(12px);
}

.landing-brand {
  display: flex;
  align-items: center;
  gap: 10px;
}

.landing-brand-copy {
  display: grid;
  gap: 2px;
}

.landing-brand strong {
  font-family: "Sora", "Manrope", sans-serif;
  font-size: 24px;
  letter-spacing: -0.01em;
}

.landing-brand span {
  color: #566074;
  font-size: 13px;
}

.lp-logo-badge {
  display: grid;
  place-items: center;
  width: 42px;
  height: 42px;
  border-radius: 14px;
  color: #fff;
  font-weight: 800;
  background: linear-gradient(145deg, #4f46e5, #7c3aed);
  box-shadow: 0 12px 28px rgba(79, 70, 229, 0.33);
}

.landing-auth-actions {
  display: flex;
  gap: 8px;
}

.landing-main {
  display: grid;
  gap: 14px;
}

.landing-hero-grid {
  display: grid;
  grid-template-columns: 1.2fr 0.8fr;
  gap: 14px;
}

.lp-hero-main {
  position: relative;
  overflow: hidden;
  display: grid;
  gap: 12px;
  padding: 22px;
  border: 1px solid rgba(255, 255, 255, 0.78);
  border-radius: 30px;
  background: rgba(255, 255, 255, 0.82);
  box-shadow: 0 24px 66px rgba(76, 78, 214, 0.16);
  backdrop-filter: blur(12px);
}

.lp-hero-main::before {
  content: "";
  position: absolute;
  inset: 0 auto auto 0;
  width: 100%;
  height: 4px;
  background: linear-gradient(90deg, #4f46e5, #8b5cf6, #38bdf8);
}

.lp-hero-main h1 {
  margin: 0;
  font-size: clamp(2rem, 4vw, 3.3rem);
  line-height: 1.15;
  letter-spacing: -0.02em;
  color: #111827;
}

.lp-hero-main .row {
  margin-top: 6px;
}

.lp-stats-grid {
  margin-top: 6px;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
}

.lp-stat-card {
  border: 1px solid rgba(255, 255, 255, 0.85);
  border-radius: 18px;
  padding: 12px;
  background: rgba(255, 255, 255, 0.84);
  box-shadow: 0 8px 24px rgba(15, 23, 42, 0.06);
}

.lp-stat-card strong {
  font-size: 1.35rem;
  line-height: 1;
  letter-spacing: -0.02em;
  color: #0f172a;
}

.lp-stat-card span {
  display: block;
  margin-top: 4px;
  font-size: 12px;
  color: #475569;
}

.lp-highlight-list {
  display: grid;
  gap: 8px;
}

.lp-highlight-card {
  border: 1px solid rgba(255, 255, 255, 0.88);
  border-radius: 18px;
  padding: 12px;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.9), rgba(244, 247, 255, 0.95));
  box-shadow: 0 10px 30px rgba(15, 23, 42, 0.07);
  transition: transform 0.25s ease, box-shadow 0.25s ease;
}

.lp-highlight-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 14px 34px rgba(15, 23, 42, 0.12);
}

.lp-highlight-card h3 {
  margin: 0 0 5px;
  font-size: 1rem;
  color: #111827;
}

.lp-highlight-card p {
  margin: 0;
  color: #475569;
  line-height: 1.55;
  font-size: 14px;
}

.lp-preview-card {
  position: relative;
  overflow: hidden;
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: 30px;
  padding: 18px;
  background: linear-gradient(170deg, #0f172a, #1e293b 55%, #111827);
  color: #fff;
  box-shadow: 0 26px 70px rgba(15, 23, 42, 0.36);
}

.lp-preview-card::before {
  content: "";
  position: absolute;
  inset: 0 auto auto 0;
  width: 100%;
  height: 4px;
  background: linear-gradient(90deg, #6366f1, #38bdf8, #34d399);
}

.lp-preview-head {
  display: flex;
  justify-content: space-between;
  gap: 10px;
}

.lp-preview-head h2 {
  margin-top: 6px;
  font-size: 1.48rem;
  color: #f8fafc;
}

.lp-preview-head p {
  margin: 6px 0 0;
  color: #cbd5e1;
  font-size: 13px;
}

.lp-preview-pill {
  display: inline-flex;
  align-items: center;
  border: 1px solid rgba(255, 255, 255, 0.16);
  background: rgba(255, 255, 255, 0.1);
  border-radius: 999px;
  padding: 4px 10px;
  font-size: 11px;
  font-weight: 700;
  color: #dbeafe;
}

.lp-preview-group {
  border: 1px solid rgba(255, 255, 255, 0.16);
  background: rgba(255, 255, 255, 0.11);
  border-radius: 14px;
  padding: 8px 10px;
  text-align: right;
  min-width: 112px;
}

.lp-preview-group small {
  display: block;
  color: #cbd5e1;
  font-size: 11px;
}

.lp-preview-group strong {
  font-size: 12px;
}

.lp-session-card {
  margin-top: 12px;
  border: 1px solid rgba(255, 255, 255, 0.14);
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.1);
  padding: 11px 12px;
  display: flex;
  justify-content: space-between;
  gap: 10px;
}

.lp-session-card strong {
  font-size: 14px;
}

.lp-session-card p {
  margin: 4px 0 0;
  color: #cbd5e1;
  font-size: 12px;
}

.lp-online-chip {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  border-radius: 999px;
  border: 1px solid rgba(52, 211, 153, 0.3);
  background: rgba(52, 211, 153, 0.12);
  color: #bbf7d0;
  font-size: 11px;
  font-weight: 700;
  padding: 5px 10px;
}

.lp-online-dot {
  width: 8px;
  height: 8px;
  border-radius: 999px;
  background: #6ee7b7;
  box-shadow: 0 0 0 rgba(110, 231, 183, 0.8);
  animation: pulse-online 1.8s infinite;
}

.lp-contact-list {
  margin-top: 12px;
  display: grid;
  gap: 8px;
}

.lp-contact-item {
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.08);
  padding: 10px 12px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  transition: transform 0.25s ease, background 0.25s ease;
}

.lp-contact-item:hover {
  transform: translateY(-1px);
  background: rgba(255, 255, 255, 0.14);
}

.lp-contact-item strong {
  font-size: 13px;
}

.lp-contact-item p {
  margin: 2px 0 0;
  color: #cbd5e1;
  font-size: 11px;
}

.lp-status-chip {
  white-space: nowrap;
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  font-size: 11px;
  font-weight: 700;
  padding: 5px 9px;
  border: 1px solid transparent;
}

.lp-status-chip.tone-success {
  background: rgba(16, 185, 129, 0.14);
  color: #a7f3d0;
  border-color: rgba(16, 185, 129, 0.28);
}

.lp-status-chip.tone-alert {
  background: rgba(245, 158, 11, 0.14);
  color: #fcd34d;
  border-color: rgba(245, 158, 11, 0.28);
}

.lp-status-chip.tone-info {
  background: rgba(56, 189, 248, 0.14);
  color: #bae6fd;
  border-color: rgba(56, 189, 248, 0.28);
}

.lp-status-chip.tone-error {
  background: rgba(244, 63, 94, 0.14);
  color: #fecdd3;
  border-color: rgba(244, 63, 94, 0.3);
}

.lp-progress-wrap {
  margin-top: 12px;
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.08);
  padding: 12px;
}

.lp-progress-meta {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 10px;
  font-size: 12px;
}

.lp-progress-meta span {
  color: #cbd5e1;
}

.lp-progress-track {
  margin-top: 8px;
  height: 10px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.12);
  overflow: hidden;
}

.lp-progress-fill {
  height: 100%;
  width: 40%;
  border-radius: 999px;
  background: linear-gradient(90deg, #6366f1, #8b5cf6, #34d399);
  box-shadow: 0 0 24px rgba(129, 140, 248, 0.5);
  animation: progress-slide 3.5s ease-in-out infinite alternate;
}

.lp-mini-stats {
  margin-top: 10px;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 7px;
}

.lp-mini-stats div {
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.09);
  padding: 8px;
  text-align: center;
}

.lp-mini-stats strong {
  display: block;
  font-size: 1rem;
}

.lp-mini-stats span {
  color: #cbd5e1;
  font-size: 11px;
}

.lp-info-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}

.lp-info-card {
  border-radius: 28px;
  border: 1px solid rgba(255, 255, 255, 0.78);
  background: rgba(255, 255, 255, 0.82);
  box-shadow: 0 18px 56px rgba(76, 78, 214, 0.1);
}

.lp-info-card h2 {
  margin-bottom: 14px;
}

.lp-step-list,
.lp-safe-list {
  display: grid;
  gap: 8px;
}

.lp-step-item {
  display: flex;
  gap: 10px;
  align-items: flex-start;
  border-radius: 16px;
  border: 1px solid #dfe5ff;
  background: linear-gradient(180deg, #ffffff, #f4f7ff);
  padding: 10px;
}

.lp-step-item span {
  display: grid;
  place-items: center;
  width: 28px;
  height: 28px;
  border-radius: 10px;
  background: #fff;
  border: 1px solid #d7dffa;
  font-weight: 700;
  font-size: 13px;
  color: #111827;
}

.lp-step-item p {
  margin: 0;
  color: #475569;
  line-height: 1.5;
}

.lp-safe-list p {
  margin: 0;
  border-radius: 16px;
  border: 1px solid #d7efea;
  background: linear-gradient(180deg, #ffffff, #f2fbf8);
  padding: 10px 12px;
  color: #475569;
  line-height: 1.5;
}

.lp-cta-section {
  display: grid;
  gap: 14px;
  grid-template-columns: 1.2fr 0.8fr;
  border-radius: 30px;
  border: 1px solid rgba(255, 255, 255, 0.8);
  background: rgba(255, 255, 255, 0.86);
  box-shadow: 0 20px 62px rgba(76, 78, 214, 0.12);
}

.lp-cta-kicker {
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  background: linear-gradient(90deg, #e0e7ff, #ede9fe);
  padding: 4px 10px;
  font-size: 11px;
  font-weight: 700;
  color: #4338ca;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.lp-cta-copy {
  display: grid;
  gap: 8px;
}

.lp-cta-box {
  display: grid;
  gap: 8px;
  align-content: center;
  border-radius: 22px;
  border: 1px solid #dfe6fb;
  background: linear-gradient(180deg, #ffffff, #f5f7ff);
  padding: 14px;
  box-shadow: 0 12px 36px rgba(76, 78, 214, 0.1);
}

.lp-cta-box p {
  margin: 4px 0 0;
  border: 1px dashed #c8d4fa;
  border-radius: 14px;
  padding: 10px;
  font-size: 13px;
  line-height: 1.5;
  color: #475569;
}

.reveal {
  opacity: 1;
  transform: none;
}

.js .reveal {
  opacity: 0;
  transform: translateY(20px);
  transition:
    opacity 0.6s ease,
    transform 0.6s ease;
}

.js .reveal.is-visible {
  opacity: 1;
  transform: none;
}

.js .reveal[data-delay="0.02"] {
  transition-delay: 0.02s;
}

.js .reveal[data-delay="0.08"] {
  transition-delay: 0.08s;
}

.js .reveal[data-delay="0.14"] {
  transition-delay: 0.14s;
}

@keyframes pulse-online {
  0% {
    box-shadow: 0 0 0 0 rgba(110, 231, 183, 0.75);
  }
  70% {
    box-shadow: 0 0 0 8px rgba(110, 231, 183, 0);
  }
  100% {
    box-shadow: 0 0 0 0 rgba(110, 231, 183, 0);
  }
}

@keyframes progress-slide {
  0% {
    width: 38%;
  }
  100% {
    width: 46%;
  }
}

@keyframes login-fade-up {
  from {
    opacity: 0;
    transform: translateY(10px);
  }
  to {
    opacity: 1;
    transform: none;
  }
}

@keyframes dash-fill-pulse {
  0% {
    opacity: 0.95;
  }
  50% {
    opacity: 0.72;
  }
  100% {
    opacity: 0.95;
  }
}

.setup-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 14px;
  max-width: 780px;
}

.company-summary-grid {
  margin-top: 10px;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 10px;
}

.summary-item {
  border: 1px solid #d4e3eb;
  border-radius: 12px;
  background: #f7fbfe;
  padding: 10px;
  display: grid;
  gap: 5px;
}

.summary-item strong {
  font-size: 13px;
  color: #2b4b60;
}

.summary-item span {
  font-size: 16px;
  font-weight: 700;
}

.full-home {
  gap: 16px;
}

.home-hero {
  background:
    radial-gradient(circle at top right, rgba(10, 122, 86, 0.12), transparent 40%),
    radial-gradient(circle at bottom left, rgba(13, 110, 180, 0.08), transparent 35%),
    #ffffff;
}

.marketing-hero {
  display: grid;
  grid-template-columns: 1.2fr 0.8fr;
  gap: 16px;
  align-items: stretch;
}

.hero-content {
  display: grid;
  gap: 10px;
}

.hero-kicker {
  margin: 0;
  display: inline-flex;
  width: fit-content;
  padding: 6px 10px;
  border-radius: 999px;
  background: #e7f4ee;
  border: 1px solid #bde1d0;
  color: #0f6245;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.02em;
}

.hero-kicker.neutral {
  background: #eef2f8;
  border-color: #ccd4e4;
  color: #2d3a4e;
}

.hero-content h2 {
  font-size: clamp(1.4rem, 2.6vw, 2rem);
  line-height: 1.25;
}

.hero-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.hero-side {
  border-left: 1px dashed #c8d7e1;
  padding-left: 12px;
}

.hero-stat-grid {
  display: grid;
  gap: 8px;
  height: 100%;
}

.hero-stat {
  background: #f5fafd;
  border: 1px solid #d5e3ec;
  border-radius: 12px;
  padding: 10px;
  display: grid;
  gap: 4px;
}

.hero-stat strong {
  color: #12374d;
  font-size: 14px;
}

.hero-stat span {
  color: #4d6678;
  font-size: 13px;
}

.home-badges {
  margin-top: 12px;
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.home-highlight-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 12px;
}

.highlight-box {
  border: 1px solid #d4e3eb;
  background: linear-gradient(180deg, #ffffff, #f7fbff);
}

.home-cards {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(290px, 1fr));
  gap: 14px;
}

.menu-cards {
  grid-template-columns: 1fr;
  max-width: 800px;
}

.menu-intro {
  max-width: 800px;
}

.feature-comparison .feature-card {
  position: relative;
  overflow: hidden;
}

.feature-pill {
  display: inline-flex;
  font-size: 12px;
  font-weight: 700;
  color: #3f4a5d;
  background: #eef1f6;
  border: 1px solid #d8deea;
  border-radius: 999px;
  padding: 5px 10px;
  margin-bottom: 8px;
}

.feature-card h3 {
  margin: 0 0 8px;
}

.feature-card .link-btn {
  margin-top: 8px;
}

.feature-card.featured {
  border-color: #92ccb2;
  box-shadow: 0 10px 34px rgba(7, 85, 61, 0.12);
}

.feature-list {
  margin: 10px 0 0;
  padding-left: 18px;
  color: #2a3c49;
  line-height: 1.5;
}

.how-it-works {
  border-color: #cbdce8;
  background: linear-gradient(180deg, #f8fbff, #ffffff);
}

.how-it-works h3 {
  margin-bottom: 10px;
}

.how-steps {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 10px;
}

.how-step {
  border: 1px solid #d2e0ea;
  border-radius: 10px;
  background: #ffffff;
  padding: 10px;
  display: flex;
  gap: 8px;
  align-items: flex-start;
}

.how-step strong {
  color: var(--primary-dark);
}

.app-grid {
  display: grid;
  gap: 14px;
}

.wizard {
  display: grid;
  gap: 14px;
}

.wizard-steps {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(105px, 1fr));
  gap: 8px;
}

.wizard-steps.locked .wizard-step:not([data-step-target="1"]) {
  display: none;
}

.wizard-step {
  border: 1px solid var(--border);
  background: #f6f7fa;
  color: #2f3a4b;
  border-radius: 12px;
  min-height: 64px;
  display: grid;
  place-items: center;
  gap: 2px;
  padding: 8px;
}

.wizard-step span {
  width: 26px;
  height: 26px;
  border-radius: 999px;
  border: 1px solid #b8cbd6;
  display: grid;
  place-items: center;
  font-size: 13px;
}

.wizard-step small {
  font-size: 12px;
}

.wizard-step.active {
  background: #3d4758;
  color: #fff;
  border-color: #3d4758;
}

.wizard-step.active span {
  border-color: rgba(255, 255, 255, 0.85);
}

.wizard-step.done {
  background: #e8edf5;
  border-color: #b9c4d6;
}

.card {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 14px;
  padding: 16px;
  box-shadow: 0 6px 18px rgba(19, 24, 33, 0.05);
}

.row {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.wizard-panel {
  position: relative;
}

.wizard-panel .wizard-tools {
  margin-top: 12px;
}

.wizard-panel .wizard-footer {
  position: sticky;
  bottom: 0;
  z-index: 8;
  margin: 16px -16px -16px;
  padding: 14px 16px 16px;
  background: #ffffff;
  border-top: 1px solid #d8e3ea;
  border-radius: 0 0 14px 14px;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 12px;
}

.wizard-panel .wizard-footer button,
.wizard-panel .wizard-footer .link-btn {
  min-height: 50px;
  border-radius: 14px;
  padding: 0 28px;
  font-size: 16px;
  font-weight: 700;
}

.wizard-panel .wizard-footer button.secondary,
.wizard-panel .wizard-footer .link-btn.secondary {
  background: #f8fafc;
  color: #475569;
  border: 1px solid #d2dbe8;
}

.wizard-panel .wizard-footer button.secondary:hover,
.wizard-panel .wizard-footer .link-btn.secondary:hover {
  background: #f1f5f9;
}

.wizard-panel .wizard-footer button:not(.secondary),
.wizard-panel .wizard-footer .link-btn:not(.secondary) {
  background: linear-gradient(180deg, #6447f5 0%, #4f46e5 100%);
  border: 1px solid #4f46e5;
  color: #ffffff;
  box-shadow: 0 6px 14px rgba(79, 70, 229, 0.34);
}

.wizard-panel .wizard-footer button:not(.secondary):hover,
.wizard-panel .wizard-footer .link-btn:not(.secondary):hover {
  background: linear-gradient(180deg, #5740de 0%, #4338ca 100%);
}

.inline-field {
  display: grid;
  gap: 6px;
  min-width: 220px;
  flex: 1 1 260px;
  font-weight: 600;
  font-size: 13px;
  color: #2f4658;
}

.company-note {
  margin: 10px 0;
  line-height: 1.45;
}

.company-commercial .row,
.company-governance .row {
  margin-top: 10px;
}

.gap-top {
  margin-top: 12px;
}

.status-line {
  margin: 10px 0;
}

.guide-text {
  line-height: 1.5;
  margin-top: 8px;
}

.wa-guide-list {
  margin: 8px 0 0 0;
  padding-left: 20px;
  color: #2b3c49;
  line-height: 1.55;
}

.wa-guide-state {
  margin: 12px 0 0;
  padding: 10px 12px;
  border-radius: 10px;
  border: 1px solid #d5dde8;
  background: #f3f6fa;
  color: #334155;
  font-weight: 600;
  font-size: 14px;
}

.connect-step-shell {
  display: grid;
  gap: 14px;
}

.connect-page-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 14px;
  border: 1px solid #d7dde8;
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.85);
  box-shadow: 0 8px 22px rgba(15, 23, 42, 0.08);
  padding: 14px 18px;
}

.connect-page-header h1 {
  margin: 0;
  font-size: 1.18rem;
}

.connect-page-header p {
  margin: 3px 0 0;
  font-size: 13px;
  color: #64748b;
}

.connect-page-user {
  display: flex;
  align-items: center;
  gap: 14px;
}

.connect-page-user strong {
  display: block;
  text-align: right;
  font-size: 15px;
}

.connect-page-user small {
  display: block;
  text-align: right;
  color: #64748b;
  font-size: 12px;
}

.connect-page-logout {
  border: 0;
  background: transparent;
  color: #dc2626;
  font-size: 13px;
  font-weight: 600;
  padding: 0;
  cursor: pointer;
}

.connect-page-logout:hover {
  text-decoration: underline;
  background: transparent;
}

.connect-page .wizard-steps {
  display: flex;
  align-items: center;
  gap: 14px;
  width: 100%;
}

.connect-page .wizard-step {
  min-height: 48px;
  border-radius: 14px;
  flex: 0 0 auto;
  min-width: 168px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 10px 18px;
  border: 1px solid #d0d7e3;
  background: #ffffff;
  color: #0f172a;
  box-shadow: 0 1px 0 rgba(255, 255, 255, 0.8) inset;
}

.connect-page .wizard-step.step-extra {
  display: none !important;
}

.connect-page .wizard-step.hidden:not(.step-extra) {
  display: inline-flex !important;
}

.connect-page .wizard-step span {
  width: auto;
  height: auto;
  border: 0;
  display: inline;
  font-size: 24px;
  font-weight: 800;
  line-height: 1;
}

.connect-page .wizard-step small {
  font-size: 14px;
  font-weight: 800;
  line-height: 1;
}

.connect-page .wizard-step.active {
  background: #4f46e5;
  border-color: #4f46e5;
  color: #fff;
}

.connect-page .wizard-step.done {
  background: #ffffff;
  border-color: #d0d7e3;
  color: #0f172a;
}

.connect-page .wizard-step.done span {
  color: #0f172a;
}

.connect-step-line {
  flex: 1 1 auto;
  min-width: 36px;
  height: 2px;
  background: #c1cada;
  border-radius: 999px;
}

.connect-page .wizard-steps.locked .wizard-step[data-step-target="2"],
.connect-page .wizard-steps.locked .wizard-step[data-step-target="3"],
.connect-page .wizard-steps.locked .wizard-step[data-step-target="4"] {
  display: inline-flex !important;
}

.connect-top-grid {
  display: grid;
  grid-template-columns: 1.05fr 0.95fr;
  gap: 14px;
}

.connect-panel {
  border: 1px solid #d8e1ee;
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.88);
  padding: 18px;
  box-shadow: 0 10px 26px rgba(15, 23, 42, 0.07);
}

.connect-title {
  margin-bottom: 8px;
}

.connect-tips {
  margin-top: 14px;
  display: grid;
  gap: 10px;
}

.connect-tip {
  display: flex;
  gap: 10px;
  align-items: flex-start;
}

.connect-tip p {
  margin: 3px 0 0;
  color: #334155;
  line-height: 1.5;
}

.connect-tip-index {
  width: 30px;
  height: 30px;
  border-radius: 999px;
  display: grid;
  place-items: center;
  background: #4f46e5;
  color: #fff;
  font-weight: 700;
  font-size: 13px;
  box-shadow: 0 8px 18px rgba(79, 70, 229, 0.28);
  flex: 0 0 auto;
}

.connect-status-box {
  margin-top: 16px;
  border: 1px solid #fde68a;
  background: #fffbeb;
  border-radius: 12px;
  padding: 12px;
}

.connect-status-label {
  margin: 0;
  color: #a16207;
  font-size: 12px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.03em;
}

.connect-status-value {
  margin: 6px 0 0;
  color: #92400e;
  font-size: 16px;
  font-weight: 700;
}

.connect-status-box .status-line {
  margin: 8px 0 0;
  color: #7c2d12;
}

.wa-status-error-note {
  color: #af2c2c;
  font-size: 13px;
}

.connect-qr-panel {
  display: grid;
  align-content: center;
  justify-items: center;
}

.connect-qr-title {
  margin: 0;
  font-size: 16px;
  font-weight: 700;
  color: #334155;
}

.connect-qr-stage {
  margin-top: 14px;
  width: 100%;
  max-width: 390px;
  min-height: 380px;
  border-radius: 14px;
  border: 1px solid #d8e2f0;
  background: #f8fafc;
  box-shadow: inset 0 1px 14px rgba(15, 23, 42, 0.08);
  display: grid;
  place-items: center;
  padding: 16px;
}

.connect-qr-stage #qr-image {
  width: 100%;
  max-width: 340px;
  aspect-ratio: 1 / 1;
  object-fit: contain;
}

.connect-qr-stage .qr-placeholder {
  color: #64748b;
  text-align: center;
  font-weight: 700;
}

.connect-qr-note {
  margin: 12px 0 0;
  color: #64748b;
  font-size: 13px;
  font-weight: 700;
}

.connect-bottom-preview {
  border-radius: 18px;
  background: #0f172a;
  color: #f8fafc;
  padding: 16px;
  box-shadow: 0 18px 42px rgba(15, 23, 42, 0.35);
}

.connect-bottom-preview h3 {
  margin: 0 0 10px;
  color: #f8fafc;
}

.connect-bottom-grid {
  display: grid;
  grid-template-columns: 0.8fr 1.2fr;
  gap: 12px;
}

.connect-meta-cards {
  display: grid;
  gap: 8px;
}

.connect-meta-cards article {
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.08);
  padding: 10px;
}

.connect-meta-cards small {
  display: block;
  color: #cbd5e1;
  font-size: 11px;
}

.connect-meta-cards strong {
  display: block;
  margin-top: 3px;
  font-size: 15px;
}

.connect-sample-progress-meta {
  display: flex;
  justify-content: space-between;
  font-size: 11px;
  color: #cbd5e1;
  margin-bottom: 4px;
}

.connect-sample-track {
  height: 8px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.16);
  overflow: hidden;
}

.connect-sample-fill {
  height: 100%;
  width: 50%;
  border-radius: 999px;
  background: #818cf8;
  animation: dash-fill-pulse 2s ease-in-out infinite;
}

.connect-sample-list {
  margin-top: 10px;
  display: grid;
  gap: 7px;
}

.connect-sample-list div {
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: 10px;
  background: rgba(255, 255, 255, 0.06);
  padding: 9px 10px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 10px;
}

.connect-sample-list b {
  font-size: 12px;
}

.connect-sample-list .tone-ok {
  color: #86efac;
}

.connect-sample-list .tone-alert {
  color: #fcd34d;
}

.connect-sample-list .tone-info {
  color: #7dd3fc;
}

.after-qr-panel {
  border: 1px solid rgba(255, 255, 255, 0.7);
  border-radius: 28px;
  background: rgba(255, 255, 255, 0.86);
  box-shadow: 0 16px 38px rgba(79, 70, 229, 0.08);
}

.after-qr-top {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 14px;
}

.after-qr-kicker {
  margin: 0;
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  border: 1px solid #d5ddf3;
  background: #eef2ff;
  color: #4338ca;
  padding: 5px 10px;
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.after-qr-top h2 {
  margin-top: 8px;
  font-size: clamp(1.6rem, 2.7vw, 2rem);
}

.after-qr-back {
  flex: 0 0 auto;
}

.after-qr-stack {
  margin-top: 14px;
  display: grid;
  gap: 14px;
}

.after-qr-block {
  border: 1px solid #dde3f0;
  border-radius: 22px;
  background: linear-gradient(180deg, #fbfcff, #f6f8ff);
  padding: 16px;
}

.after-qr-block-head {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  margin-bottom: 12px;
}

.after-qr-block-head h3 {
  margin: 2px 0 0;
  font-size: 1.1rem;
}

.after-qr-block-head p {
  margin: 4px 0 0;
  font-size: 13px;
}

.after-qr-icon {
  width: 40px;
  height: 40px;
  border-radius: 14px;
  display: grid;
  place-items: center;
  background: #e5e7ff;
  color: #4338ca;
  font-weight: 800;
}

.after-qr-search-wrap {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 8px;
  align-items: center;
}

.after-qr-search-wrap input {
  margin: 0;
  border-radius: 14px;
  min-height: 44px;
}

.after-qr-search-wrap .secondary {
  min-height: 44px;
  border-radius: 12px;
}

#step-panel-2 .after-qr-group-list {
  margin-top: 10px;
  border: 0;
  background: transparent;
  padding: 0;
  min-height: 0;
  display: grid;
  gap: 10px;
  max-height: 360px;
  overflow-y: auto;
  padding-right: 4px;
}

#step-panel-2 .after-qr-group-list::-webkit-scrollbar {
  width: 8px;
}

#step-panel-2 .after-qr-group-list::-webkit-scrollbar-track {
  background: #edf2f8;
  border-radius: 999px;
}

#step-panel-2 .after-qr-group-list::-webkit-scrollbar-thumb {
  background: #c5d0df;
  border-radius: 999px;
}

#step-panel-2 .after-qr-group-list .tag-option {
  width: 100%;
  border-radius: 16px;
  border: 1px solid #c9d7f4;
  background: #f8faff;
  color: #1e293b;
  padding: 14px 16px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  font-size: 14px;
  text-align: left;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.5);
  transition: border-color 0.2s ease, background-color 0.2s ease, transform 0.2s ease;
}

#step-panel-2 .after-qr-group-list .tag-option .after-qr-group-copy {
  display: grid;
  gap: 4px;
  min-width: 0;
}

#step-panel-2 .after-qr-group-list .tag-option .after-qr-group-copy strong {
  font-size: 16px;
  font-weight: 700;
  color: #0f172a;
  line-height: 1.25;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

#step-panel-2 .after-qr-group-list .tag-option .after-qr-group-copy small {
  font-size: 13px;
  line-height: 1.2;
  color: #64748b;
}

#step-panel-2 .after-qr-group-list .tag-option:hover {
  border-color: #b4c6ef;
  background: #f0f5ff;
}

#step-panel-2 .after-qr-group-list .tag-option.active {
  border-color: #8ca7e9;
  background: #e2e8fa;
  color: #1f2a44;
}

#step-panel-2 .after-qr-group-list .tag-option::after {
  content: none;
}

#step-panel-2 .after-qr-group-list .tag-option .after-qr-group-check {
  width: 22px;
  height: 22px;
  border-radius: 999px;
  border: 2px solid #4f46e5;
  background: #f8faff;
  color: #4f46e5;
  font-size: 12px;
  font-weight: 900;
  line-height: 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 auto;
  opacity: 0;
  transform: scale(0.85);
  transition: opacity 0.2s ease, transform 0.2s ease;
}

#step-panel-2 .after-qr-group-list .tag-option.active .after-qr-group-check {
  opacity: 1;
  transform: scale(1);
}

#step-panel-2 .after-qr-group-list .tag-empty {
  border: 1px dashed #cfd8e8;
  border-radius: 14px;
  background: #ffffff;
  padding: 12px;
}

.after-qr-card {
  border: 1px solid #d9e0ee;
  border-radius: 18px;
  background: #ffffff;
  padding: 14px;
}

.after-qr-card + .after-qr-card {
  margin-top: 12px;
}

.after-qr-card-title {
  margin: 0 0 8px;
  font-size: 14px;
  font-weight: 800;
  color: #0f172a;
}

.after-qr-dropzone {
  border-radius: 16px;
  background: #f8fafc;
  border: 1px dashed #c7d2e6;
}

.after-qr-detected-grid {
  margin-top: 12px;
  display: grid;
  gap: 10px;
  grid-template-columns: 1.2fr 0.8fr;
}

.after-qr-detected-card,
.after-qr-safe-card {
  border: 1px solid #d9e0ee;
  border-radius: 16px;
  background: #ffffff;
  padding: 12px;
}

.after-qr-detected-grid > :only-child {
  grid-column: 1 / -1;
}

.after-qr-detected-list {
  display: grid;
  gap: 8px;
  max-height: 340px;
  overflow-y: auto;
  padding-right: 4px;
}

.after-qr-detected-list::-webkit-scrollbar {
  width: 8px;
}

.after-qr-detected-list::-webkit-scrollbar-track {
  background: #edf2f8;
  border-radius: 999px;
}

.after-qr-detected-list::-webkit-scrollbar-thumb {
  background: #c5d0df;
  border-radius: 999px;
}

.after-qr-detected-item {
  border: 1px solid #e2e8f0;
  border-radius: 12px;
  background: #f3f6fb;
  padding: 9px 10px;
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  align-items: center;
  gap: 10px;
  cursor: pointer;
  transition: border-color 0.2s ease, background 0.2s ease, box-shadow 0.2s ease;
}

.after-qr-detected-item:hover {
  border-color: #c7d2fe;
}

.after-qr-detected-item.is-selected {
  border-color: #4f46e5;
  background: #eef2ff;
  box-shadow: 0 0 0 1px rgba(79, 70, 229, 0.16) inset;
}

.after-qr-detected-item strong {
  display: block;
  font-size: 13px;
  color: #1e293b;
}

.after-qr-detected-item span {
  display: block;
  margin-top: 2px;
  font-size: 12px;
  color: #64748b;
}

.message-contact-select-indicator {
  width: 20px;
  height: 20px;
  border-radius: 999px;
  border: 1px solid #cbd5e1;
  background: #ffffff;
  display: inline-grid;
  place-items: center;
  box-sizing: border-box;
  align-self: center;
}

.message-contact-select-indicator-check {
  width: 8px;
  height: 5px;
  border-left: 2px solid transparent;
  border-bottom: 2px solid transparent;
  transform: rotate(-45deg);
  margin-top: -1px;
}

.after-qr-detected-item.is-selected .message-contact-select-indicator,
.message-contact-select-indicator.is-selected {
  border-color: #4f46e5;
  background: #4f46e5;
}

.after-qr-detected-item.is-selected .message-contact-select-indicator-check,
.message-contact-select-indicator.is-selected .message-contact-select-indicator-check {
  border-left-color: #ffffff;
  border-bottom-color: #ffffff;
}

.message-contact-info {
  min-width: 0;
}

.message-contact-badges {
  margin-top: 6px;
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.message-extra-chip {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  border-radius: 999px;
  border: 1px solid #d6deef;
  background: #ffffff;
  color: #334155;
  padding: 4px 8px;
  font-size: 11px;
  line-height: 1.2;
}

.message-extra-chip b {
  font-weight: 800;
  color: #1e293b;
}

.detected-contact-remove {
  appearance: none;
  border: 1px solid #fecdd3;
  border-radius: 10px;
  background: #fff1f2;
  color: #be123c;
  font-size: 12px;
  font-weight: 800;
  line-height: 1;
  padding: 8px 10px;
  cursor: pointer;
  transition: background-color 0.2s ease, border-color 0.2s ease, transform 0.15s ease;
}

.detected-contact-remove:hover {
  background: #ffe4e6;
  border-color: #fda4af;
}

.detected-contact-remove:active {
  transform: translateY(1px);
}

.after-qr-detected-pill {
  border-radius: 999px;
  padding: 4px 8px;
  font-size: 11px;
  font-weight: 700;
  border: 1px solid transparent;
}

.after-qr-detected-pill.ok {
  background: #ecfdf3;
  border-color: #a7f3d0;
  color: #047857;
}

.after-qr-detected-pill.error {
  background: #fff1f2;
  border-color: #fecdd3;
  color: #be123c;
}

.after-qr-detected-loading {
  border: 1px dashed #cfd8e8;
  border-radius: 12px;
  background: #f8fafc;
  min-height: 72px;
  padding: 14px;
  display: flex;
  align-items: center;
  gap: 10px;
}

.message-contact-selection-row {
  display: flex;
  gap: 10px;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 8px;
}

.message-detected-filters {
  margin-bottom: 10px;
  display: grid;
  gap: 8px;
}

.message-detected-filters input,
.message-detected-filters select {
  margin: 0;
  min-height: 40px;
  border-radius: 10px;
}

.message-detected-filters-row {
  display: grid;
  gap: 8px;
  grid-template-columns: auto minmax(180px, 1fr) auto;
  align-items: center;
}

.message-detected-filters-row label {
  font-size: 12px;
  font-weight: 700;
  color: #475569;
}

.message-sort-buttons {
  display: flex;
  gap: 6px;
}

.message-sort-buttons button.secondary {
  min-height: 40px;
  min-width: 44px;
  padding: 0 10px;
  font-size: 1rem;
}

.message-sort-buttons button.secondary.active {
  background: #eef2ff;
  border-color: #c7d2fe;
  color: #3730a3;
}

.message-detected-filters .muted {
  margin: 0;
}

.message-contact-selection-row .muted {
  margin: 0;
}

.message-contact-selection-actions {
  display: flex;
  gap: 8px;
}

.message-contact-selection-actions button.secondary {
  min-height: 34px;
  padding: 7px 10px;
  font-size: 12px;
}

.after-qr-loader {
  width: 16px;
  height: 16px;
  border-radius: 50%;
  border: 2px solid #d7deef;
  border-top-color: #4f46e5;
  animation: after-qr-spin 0.8s linear infinite;
}

@keyframes after-qr-spin {
  to {
    transform: rotate(360deg);
  }
}

.after-qr-safe-card {
  background: #eef2ff;
  border-color: #d6dcff;
}

.after-qr-safe-title {
  margin: 0 0 10px;
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 18px;
  font-weight: 800;
  color: #4f46e5;
}

.after-qr-safe-icon {
  width: 18px;
  height: 18px;
  border-radius: 7px;
  border: 1px solid #c7d2fe;
  background: #e0e7ff;
  color: #4f46e5;
  font-size: 11px;
  font-weight: 800;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.after-qr-safe-toggle {
  margin-top: 4px;
  display: flex;
  align-items: flex-start;
  gap: 8px;
  border-radius: 12px;
  border: 1px solid #d5dbef;
  background: #ffffff;
  padding: 14px;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.65);
}

.after-qr-safe-toggle input {
  margin-top: 2px;
  width: 16px;
  height: 16px;
}

.after-qr-safe-toggle span {
  display: grid;
  gap: 2px;
  font-size: 13px;
  line-height: 1.5;
  color: #334155;
}

.after-qr-safe-toggle span strong {
  font-size: 14px;
  color: #1e293b;
}

.after-qr-safe-toggle span small {
  font-size: 14px;
  color: #475569;
}

.message-stage-panel {
  border: 1px solid rgba(255, 255, 255, 0.7);
  border-radius: 28px;
  background: rgba(255, 255, 255, 0.88);
  box-shadow: 0 16px 38px rgba(79, 70, 229, 0.08);
  animation: message-stage-fade 0.35s ease;
}

@keyframes message-stage-fade {
  from {
    opacity: 0;
    transform: translateY(6px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.message-stage-top h2 {
  margin: 0;
  font-size: clamp(1.7rem, 2.7vw, 2.2rem);
}

.message-stage-kicker {
  margin: 0 0 8px;
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  border: 1px solid #d5ddf3;
  background: #eef2ff;
  color: #4338ca;
  padding: 5px 10px;
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.message-stage-top .guide-text {
  margin-top: 8px;
  max-width: 920px;
  line-height: 1.7;
}

.message-stage-grid {
  margin-top: 14px;
  display: grid;
  gap: 14px;
  grid-template-columns: minmax(0, 1.15fr) minmax(0, 0.85fr);
}

.message-stage-main {
  display: grid;
  gap: 14px;
}

.message-stage-card {
  border: 1px solid #dde3f0;
  border-radius: 24px;
  background: linear-gradient(180deg, #fbfcff, #f6f8ff);
  padding: 16px;
}

.message-stage-card-head {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  margin-bottom: 12px;
}

.message-stage-card-head h3 {
  margin: 2px 0 0;
  font-size: 1.1rem;
}

.message-stage-card-head p {
  margin: 4px 0 0;
  line-height: 1.5;
}

.message-stage-icon {
  width: 34px;
  height: 34px;
  border-radius: 11px;
  border: 1px solid #c7d2fe;
  background: #e0e7ff;
  color: #4f46e5;
  font-size: 13px;
  font-weight: 800;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 auto;
}

.message-var-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 10px;
}

.message-var-chip {
  border: 1px solid #c7d2fe;
  border-radius: 999px;
  background: #eef2ff;
  color: #4338ca;
  font-size: 12px;
  font-weight: 700;
  padding: 7px 11px;
  cursor: pointer;
}

.message-var-chip:hover {
  background: #e0e7ff;
}

.message-stage-course {
  margin: 0 0 10px;
}

.message-stage-help {
  margin: 8px 0 0;
  font-size: 14px;
}

.message-remetente-grid {
  display: grid;
  gap: 12px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.message-remetente-box {
  border: 1px solid #dfe7ef;
  border-radius: 16px;
  background: #ffffff;
  padding: 12px;
}

.message-remetente-box label {
  margin-top: 0;
}

.message-remetente-status {
  border-color: #b9e8d3;
  background: #ecfdf5;
}

.message-remetente-status-title {
  margin: 0 0 6px;
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 14px;
  font-weight: 800;
  color: #0f766e;
}

.message-remetente-status-check {
  width: 18px;
  height: 18px;
  border-radius: 999px;
  border: 1px solid #86efac;
  background: #dcfce7;
  color: #0f766e;
  font-size: 12px;
  font-weight: 800;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.message-remetente-phone {
  margin: 0 0 6px;
  font-size: 14px;
  color: #334155;
}

.message-remetente-phone strong {
  color: #0f172a;
}

.message-remetente-status .muted {
  margin: 0;
}

.message-config-grid {
  display: grid;
  gap: 12px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.message-config-box {
  border: 1px solid #dfe7ef;
  border-radius: 16px;
  background: #ffffff;
  padding: 12px;
}

.message-config-box label {
  margin-top: 0;
}

.message-config-box p {
  margin: 8px 0 0;
}

.message-safe-box {
  border-color: #c7d2fe;
  background: #eef2ff;
}

.message-safe-toggle {
  margin: 0;
  display: flex;
  align-items: flex-start;
  gap: 8px;
}

.message-safe-toggle input {
  margin-top: 2px;
  width: 16px;
  height: 16px;
}

.message-safe-toggle span {
  display: grid;
  gap: 2px;
}

.message-safe-toggle span strong {
  font-size: 14px;
  color: #1e293b;
}

.message-safe-toggle span small {
  font-size: 14px;
  color: #475569;
}

.message-report-section {
  margin-top: 14px;
  border-top: 1px solid #dbe4ef;
  padding-top: 14px;
}

.message-report-section label {
  margin-top: 8px;
}

.message-report-tags {
  margin-top: 8px;
  max-height: 170px;
  overflow: auto;
}

.message-stage-aside {
  display: grid;
  gap: 14px;
  align-content: start;
}

.message-preview-card {
  border: 1px solid #0f1f4a;
  border-radius: 24px;
  background: #0b1733;
  color: #f8fafc;
  padding: 20px;
  box-shadow: 0 14px 28px rgba(15, 23, 42, 0.22);
}

.message-preview-head h3 {
  display: flex;
  align-items: center;
  gap: 8px;
  margin: 0;
}

.message-preview-head p {
  margin: 10px 0 0;
  color: #cbd5e1;
  line-height: 1.6;
}

.message-preview-title-icon {
  width: 18px;
  height: 18px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: #c9d6f2;
  font-size: 14px;
}

.message-preview-shell {
  margin-top: 14px;
  border-radius: 22px;
  background: #0f1938;
  border: 1px solid rgba(148, 163, 184, 0.24);
  padding: 16px;
}

.message-preview-label {
  margin: 0 0 10px;
  color: #9fb0cc;
  font-size: 14px;
}

.message-preview-card .message-preview-body {
  min-height: 220px;
  border-radius: 22px;
  border: 1px solid rgba(20, 184, 166, 0.22);
  background: #0b4b54;
  color: #e7f9ff;
  padding: 16px 18px;
  line-height: 1.9;
  white-space: pre-wrap;
}

.message-preview-card-compact {
  padding: 16px;
}

.message-preview-card-compact .message-preview-shell {
  margin-top: 10px;
  border-radius: 16px;
  padding: 12px;
}

.message-preview-card-compact .message-preview-body {
  min-height: 150px;
  border-radius: 16px;
  padding: 12px 14px;
  line-height: 1.7;
}

.message-checklist-card {
  border: 1px solid #d7dfea;
  border-radius: 24px;
  background: #ffffff;
  padding: 20px;
}

.message-report-side-card {
  display: grid;
  gap: 12px;
}

.message-report-side-card > h3 {
  margin: 0;
}

.message-report-side-card > p.muted {
  margin: 0;
}

.message-report-side-card .review-report-config {
  margin-top: 6px;
}

.message-report-side-card .review-report-tags {
  max-height: 240px;
}

.message-checklist-card h3 {
  margin: 0;
}

.message-checklist-items {
  margin-top: 12px;
  display: grid;
  gap: 10px;
}

.message-checklist-items > div {
  border-radius: 14px;
  background: #f1f5f9;
  border: 1px solid #e2e8f0;
  padding: 12px 14px;
  font-size: 14px;
  line-height: 1.6;
  color: #334155;
}

.review-stage-panel {
  border: 1px solid rgba(255, 255, 255, 0.7);
  border-radius: 28px;
  background: rgba(255, 255, 255, 0.88);
  box-shadow: 0 16px 38px rgba(79, 70, 229, 0.08);
}

.review-stage-kicker {
  margin: 0 0 8px;
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  border: 1px solid #d5ddf3;
  background: #eef2ff;
  color: #4338ca;
  padding: 5px 10px;
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.review-stage-top h2 {
  margin: 0;
  font-size: clamp(1.7rem, 2.7vw, 2.2rem);
}

.review-stage-top .guide-text {
  margin-top: 8px;
  max-width: 920px;
  line-height: 1.7;
}

.review-stage-grid {
  margin-top: 16px;
  display: grid;
  gap: 16px;
  grid-template-columns: minmax(0, 1.15fr) minmax(0, 0.85fr);
  align-items: stretch;
}

.review-stage-main {
  display: grid;
  gap: 16px;
}

.review-stage-card {
  border: 1px solid #dde3f0;
  border-radius: 28px;
  background: linear-gradient(180deg, #fbfcff, #f6f8ff);
  padding: 20px;
}

.review-stage-card-head {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  margin-bottom: 14px;
}

.review-stage-card-head h3 {
  margin: 0;
  font-size: 1.18rem;
}

.review-stage-card-head p {
  margin: 4px 0 0;
  line-height: 1.6;
}

.review-stage-icon {
  width: 40px;
  height: 40px;
  border-radius: 14px;
  border: 1px solid #c7d2fe;
  background: #e0e7ff;
  color: #4f46e5;
  font-size: 15px;
  font-weight: 800;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 auto;
}

.review-checklist-grid {
  margin: 0;
  display: grid;
  gap: 12px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.review-checklist-grid .checklist-item {
  margin: 0;
  border-radius: 16px;
  border: 1px solid #d8e2ec;
  background: #f8fbff;
  padding: 14px;
  font-size: 14px;
  line-height: 1.55;
}

.review-validation-icon {
  width: 20px;
  height: 20px;
  border-radius: 999px;
  border: 1px solid #cbd5e1;
  background: #ffffff;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-right: 8px;
  font-size: 12px;
  vertical-align: middle;
}

.review-checklist-grid .checklist-item.ok .review-validation-icon {
  border-color: #86efac;
  background: #dcfce7;
  color: #166534;
}

.review-checklist-grid .checklist-item.pending .review-validation-icon {
  border-color: #f9d38d;
  background: #fef3c7;
  color: #92400e;
}

.review-checklist-grid .checklist-item.ok {
  border-color: #b7e4cf;
  background: #ecfdf3;
  color: #166534;
}

.review-checklist-grid .checklist-item.pending {
  border-color: #f3d6a1;
  background: #fff7e6;
  color: #92400e;
}

.review-report-card {
  border-color: #c7d2fe;
  background: linear-gradient(180deg, #f5f7ff, #eef2ff);
  min-height: 520px;
  display: flex;
  flex-direction: column;
}

.review-report-mode-grid {
  display: grid;
  gap: 12px;
  grid-template-columns: minmax(0, 1fr);
}

.review-report-option {
  width: 100%;
  text-align: left;
  border: 1px solid #c7d2fe;
  border-radius: 18px;
  background: #ffffff;
  padding: 12px 14px;
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  grid-template-areas:
    "icon copy"
    "icon copy";
  align-items: center;
  column-gap: 10px;
  row-gap: 0;
  min-height: 64px;
  cursor: pointer;
  box-shadow: 0 2px 8px rgba(79, 70, 229, 0.08);
}

.review-report-option-icon {
  grid-area: icon;
  width: 20px;
  height: 20px;
  border-radius: 8px;
  border: 1px solid #c7d2fe;
  background: #eef2ff;
  color: #4338ca;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 11px;
}

.review-report-option-copy {
  grid-area: copy;
  display: grid;
  gap: 2px;
  min-width: 0;
}

.review-report-option strong {
  margin: 0;
  font-size: 14px;
  color: #3730a3;
  line-height: 1.35;
}

.review-report-option small {
  margin: 0;
  font-size: 13px;
  line-height: 1.5;
  color: #475569;
}

.review-report-option:hover {
  background: #ffffff;
  border-color: #c7d2fe;
  box-shadow: none;
}

.review-report-option.active {
  border-color: #4f46e5;
  background: #f8faff;
  box-shadow: 0 0 0 2px rgba(79, 70, 229, 0.18), 0 2px 8px rgba(79, 70, 229, 0.1);
}

.review-report-option.active:hover {
  background: #f8faff;
  border-color: #4f46e5;
  box-shadow: 0 0 0 2px rgba(79, 70, 229, 0.18), 0 2px 8px rgba(79, 70, 229, 0.1);
}

.review-report-configurator {
  border: 1px solid #d6deea;
  border-radius: 18px;
  background: #fbfdff;
  padding: 14px;
  display: grid;
  gap: 10px;
}

.review-report-configurator.collapsed .review-report-configurator-body {
  display: none;
}

.review-report-configurator-head h4 {
  margin: 0;
  font-size: 16px;
  color: #0f172a;
}

.review-report-configurator-head p {
  margin: 4px 0 0;
  font-size: 13px;
  line-height: 1.5;
}

.review-report-config-grid {
  display: grid;
  gap: 10px;
  grid-template-columns: minmax(0, 1fr);
}

.review-report-config-block {
  border: 1px solid #e2e8f0;
  border-radius: 14px;
  background: #ffffff;
  padding: 10px 12px;
  display: grid;
  gap: 8px;
}

.review-report-preview-block {
  grid-column: 1 / -1;
}

.review-report-fixed-block,
.review-report-detected-block {
  width: 100%;
}

.review-report-config-block h5 {
  margin: 0;
  font-size: 13px;
  color: #334155;
}

.review-report-block-subtitle {
  margin: -2px 0 0;
  font-size: 12px;
  line-height: 1.45;
}

.review-report-fixed-fields {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: flex-start;
}

.review-report-fixed-chip {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  height: 34px;
  width: auto;
  min-width: 0;
  border-radius: 999px;
  border: 1px solid #c7d2fe;
  background: #eef2ff;
  color: #3730a3;
  font-size: 12px;
  font-weight: 700;
  line-height: 1;
  white-space: nowrap;
  padding: 0 12px;
}

.review-report-detected-fields {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: flex-start;
  align-content: flex-start;
  min-height: 92px;
  max-height: 248px;
  overflow-x: hidden;
  overflow-y: auto;
  padding-right: 4px;
}

.review-report-detected-chip {
  border: 1px solid #d2d9e6;
  border-radius: 999px;
  background: #ffffff;
  color: #334155;
  padding: 7px 11px;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  cursor: pointer;
  white-space: nowrap;
  transition: border-color 0.2s ease, background-color 0.2s ease, color 0.2s ease;
}

.review-report-detected-chip:hover {
  border-color: #b8c4da;
  background: #f8fafc;
}

.review-report-detected-chip.active {
  border-color: #4f46e5;
  background: #eef2ff;
  color: #312e81;
}

.review-report-detected-chip-label {
  font-size: 12px;
  font-weight: 700;
  line-height: 1;
}

.review-report-detected-chip-meta {
  margin: 0;
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  border: 1px solid #d7deea;
  background: #f8fafc;
  color: #64748b;
  font-size: 11px;
  font-weight: 700;
  line-height: 1;
  padding: 3px 7px;
}

.review-report-detected-chip.active .review-report-detected-chip-meta {
  border-color: #c7d2fe;
  background: #ffffff;
  color: #4338ca;
}

.review-report-preview-sample {
  border-radius: 12px;
  border: 1px solid #d7dee9;
  background: #f8fafc;
  color: #1e293b;
  font-size: 13px;
  line-height: 1.55;
  padding: 10px;
}

.review-report-selected-summary {
  margin: 0;
  font-size: 12px;
}

.review-report-config {
  margin-top: 14px;
  border-top: 1px solid #dbe4ef;
  padding-top: 14px;
  display: grid;
  gap: 8px;
}

.review-report-config label {
  margin-top: 8px;
}

.review-report-edit-config {
  margin-top: 6px;
}

.review-report-search-wrap {
  margin-top: 4px;
  grid-template-columns: 1fr auto;
  gap: 8px;
}

.review-report-search-wrap input {
  min-height: 42px;
}

.review-report-search-wrap .secondary {
  min-height: 42px;
  padding: 0 14px;
  font-size: 13px;
}

.review-report-tags {
  margin-top: 8px;
  max-height: 280px;
  overflow: auto;
  display: grid;
  gap: 8px;
  border: 0;
  background: transparent;
  padding: 0 4px 0 0;
  min-height: 0;
}

#step-panel-7 .review-report-tags .tag-option {
  width: 100%;
  text-align: left;
  border-radius: 14px;
  border: 1px solid #c9d7f4;
  background: #f8faff;
  padding: 11px 13px;
  color: #1e293b;
  display: flex;
  align-items: center;
  gap: 10px;
  justify-content: space-between;
  font-size: 14px;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.45);
  transition: border-color 0.2s ease, background-color 0.2s ease;
}

#step-panel-7 .review-report-tags .tag-option:hover {
  border-color: #b4c6ef;
  background: #f0f5ff;
}

#step-panel-7 .review-report-tags .tag-option.active {
  border-color: #8ca7e9;
  background: #e2e8fa;
  color: #1f2a44;
}

#step-panel-7 .review-report-tags .tag-option .after-qr-group-copy {
  display: grid;
  gap: 3px;
  min-width: 0;
}

#step-panel-7 .review-report-tags .tag-option .after-qr-group-copy strong {
  font-size: 14px;
  font-weight: 700;
  color: #0f172a;
  line-height: 1.25;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

#step-panel-7 .review-report-tags .tag-option .after-qr-group-copy small {
  font-size: 12px;
  line-height: 1.2;
  color: #64748b;
}

#step-panel-7 .review-report-tags .tag-option .after-qr-group-check {
  width: 22px;
  height: 22px;
  border-radius: 999px;
  border: 2px solid #4f46e5;
  background: #f8faff;
  color: #4f46e5;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 auto;
  font-size: 12px;
  font-weight: 900;
  opacity: 0;
  transform: scale(0.9);
  transition: all 0.2s ease;
}

#step-panel-7 .review-report-tags .tag-option.active .after-qr-group-check {
  opacity: 1;
  transform: scale(1);
  background: #e0e7ff;
}

#message-report-group-tags .tag-option {
  width: 100%;
  text-align: left;
  border-radius: 14px;
  border: 1px solid #c9d7f4;
  background: #f8faff;
  padding: 11px 13px;
  color: #1e293b;
  display: flex;
  align-items: center;
  gap: 10px;
  justify-content: space-between;
  font-size: 14px;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.45);
  transition: border-color 0.2s ease, background-color 0.2s ease;
}

#message-report-group-tags .tag-option:hover {
  border-color: #b4c6ef;
  background: #f0f5ff;
}

#message-report-group-tags .tag-option.active {
  border-color: #8ca7e9;
  background: #e2e8fa;
  color: #1f2a44;
}

#message-report-group-tags .tag-option .after-qr-group-copy {
  display: grid;
  gap: 3px;
  min-width: 0;
}

#message-report-group-tags .tag-option .after-qr-group-copy strong {
  font-size: 14px;
  font-weight: 700;
  color: #0f172a;
  line-height: 1.25;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

#message-report-group-tags .tag-option .after-qr-group-copy small {
  font-size: 12px;
  line-height: 1.2;
  color: #64748b;
}

#message-report-group-tags .tag-option .after-qr-group-check {
  width: 22px;
  height: 22px;
  border-radius: 999px;
  border: 2px solid #4f46e5;
  background: #f8faff;
  color: #4f46e5;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 auto;
  font-size: 12px;
  font-weight: 900;
  opacity: 0;
  transform: scale(0.9);
  transition: all 0.2s ease;
}

#message-report-group-tags .tag-option.active .after-qr-group-check {
  opacity: 1;
  transform: scale(1);
  background: #e0e7ff;
}

.review-stage-aside {
  display: grid;
  gap: 16px;
  align-content: start;
}

.review-summary-card {
  border: 1px solid #0f1f4a;
  border-radius: 28px;
  background: #0b1733;
  color: #f8fafc;
  padding: 20px;
  box-shadow: 0 14px 28px rgba(15, 23, 42, 0.22);
}

.review-summary-card h3 {
  margin: 0;
}

.review-summary-card p {
  margin: 8px 0 0;
  color: #cbd5e1;
  line-height: 1.6;
}

.review-summary-card .usage-projection {
  color: #cbd5e1;
}

.review-summary-box {
  margin-top: 12px;
  border-radius: 18px;
  border: 1px solid rgba(148, 163, 184, 0.3);
  background: rgba(15, 23, 42, 0.5);
  color: #e2e8f0;
  line-height: 1.7;
  display: grid;
  gap: 8px;
}

.review-summary-item {
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.08);
  border: 1px solid rgba(148, 163, 184, 0.22);
  padding: 10px 12px;
  display: grid;
  gap: 2px;
}

.review-summary-item small {
  font-size: 11px;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: #cbd5e1;
}

.review-summary-item strong {
  font-size: 14px;
  color: #ffffff;
}

.review-summary-box strong {
  color: #ffffff;
}

.review-confirm-card {
  border: 1px solid #d7dfea;
  border-radius: 28px;
  background: #ffffff;
  padding: 20px;
}

.review-confirm-card h3 {
  margin: 0;
}

.review-confirm-grid {
  margin-top: 10px;
  gap: 10px;
}

.review-confirm-grid .check-item {
  border-radius: 16px;
  background: #f8fafc;
  border: 1px solid #e2e8f0;
  padding: 12px 14px;
}

.review-check-card span {
  display: grid;
  gap: 3px;
}

.review-check-card span strong {
  font-size: 14px;
  color: #0f172a;
}

.review-check-card span small {
  font-size: 14px;
  line-height: 1.55;
  color: #334155;
}

.review-run-monitor {
  margin-top: 16px;
  border: 1px solid #d8e3ea;
  border-radius: 22px;
  background: #ffffff;
  padding: 16px;
}

/* Pre-flight SaaS review layout */
.review-stage-panel {
  border: 1px solid rgba(255, 255, 255, 0.72);
  border-radius: 28px;
  background: rgba(255, 255, 255, 0.9);
  box-shadow: 0 16px 38px rgba(15, 23, 42, 0.08);
}

.review-stage-panel .review-stage-top {
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(0, 0.9fr);
  gap: 16px;
  align-items: stretch;
}

.review-stage-panel .guide-text {
  margin-top: 8px;
  line-height: 1.6;
}

.review-decision-card {
  border-radius: 20px;
  border: 1px solid #dbe3ee;
  background: #f8fafc;
  padding: 14px;
  display: grid;
  align-content: center;
  gap: 6px;
}

.review-decision-card strong {
  color: #0f172a;
  font-size: 1rem;
}

.review-decision-card p {
  margin: 0;
  font-size: 13px;
  line-height: 1.45;
}

.review-decision-card.success {
  border-color: #86efac;
  background: #ecfdf3;
}

.review-decision-card.warning {
  border-color: #fcd34d;
  background: #fffbeb;
}

.review-decision-card.error,
.review-decision-card.pending {
  border-color: #fecaca;
  background: #fef2f2;
}

.review-decision-badge {
  width: fit-content;
  border-radius: 999px;
  padding: 4px 10px;
  font-size: 10px;
  font-weight: 800;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  border: 1px solid transparent;
}

.review-decision-badge.success {
  background: #dcfce7;
  border-color: #86efac;
  color: #166534;
}

.review-decision-badge.warning {
  background: #fef3c7;
  border-color: #fcd34d;
  color: #92400e;
}

.review-decision-badge.error,
.review-decision-badge.pending {
  background: #fee2e2;
  border-color: #fca5a5;
  color: #991b1b;
}

.review-preflight-grid {
  margin-top: 16px;
  display: grid;
  gap: 16px;
  grid-template-columns: minmax(0, 1.1fr) minmax(0, 0.9fr);
  align-items: stretch;
}

.review-left-column,
.review-right-column {
  min-width: 0;
  display: flex;
}

.review-right-column {
  flex-direction: column;
  gap: 16px;
  align-items: stretch;
}

.review-right-column > * {
  width: 100%;
}

.review-flow-card {
  width: 100%;
  border: 1px solid #dde3f0;
  border-radius: 24px;
  background: linear-gradient(180deg, #fcfdff, #f7faff);
  padding: 16px;
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.review-flow-section {
  display: grid;
  gap: 12px;
}

.review-flow-head h3 {
  margin: 0;
  font-size: 1.05rem;
}

.review-flow-head p {
  margin: 4px 0 0;
  font-size: 13px;
}

.review-flow-divider {
  height: 1px;
  background: #e2e8f0;
}

.review-checklist-list {
  margin: 0;
  display: grid;
  gap: 8px;
}

.review-checklist-list .checklist-item {
  margin: 0;
  border-radius: 14px;
  border: 1px solid #e2e8f0;
  background: #f8fafc;
  padding: 12px;
  line-height: 1.5;
}

.review-checklist-list .checklist-item strong {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 14px;
}

.review-checklist-list .checklist-item p {
  margin: 5px 0 0;
  font-size: 13px;
}

.review-checklist-list .checklist-item.tone-success {
  border-color: #a7f3d0;
  background: #ecfdf3;
  color: #166534;
}

.review-checklist-list .checklist-item.tone-warning {
  border-color: #fcd34d;
  background: #fffbeb;
  color: #92400e;
}

.review-checklist-list .checklist-item.tone-error {
  border-color: #fecaca;
  background: #fef2f2;
  color: #991b1b;
}

.review-checklist-list .checklist-item .review-validation-icon {
  margin: 0;
}

.review-checklist-list .checklist-item.tone-success .review-validation-icon {
  border-color: #86efac;
  background: #dcfce7;
  color: #166534;
}

.review-checklist-list .checklist-item.tone-warning .review-validation-icon {
  border-color: #fcd34d;
  background: #fef3c7;
  color: #92400e;
}

.review-checklist-list .checklist-item.tone-error .review-validation-icon {
  border-color: #fca5a5;
  background: #fee2e2;
  color: #991b1b;
}

.review-report-mode-grid {
  display: grid;
  gap: 10px;
  grid-template-columns: minmax(0, 1fr);
}

.review-report-option {
  border-radius: 14px;
  padding: 12px;
}

.review-confirm-grid {
  margin-top: 0;
  gap: 8px;
}

.review-confirm-grid .check-item {
  border-radius: 14px;
  padding: 11px 12px;
}

.review-flow-footer {
  margin-top: auto;
  padding-top: 12px;
  border-top: 1px solid #e2e8f0;
  display: flex;
  gap: 10px;
  justify-content: flex-end;
}

.review-flow-footer button {
  min-width: 170px;
  min-height: 48px;
  border-radius: 12px;
}

.review-flow-footer #btn-start-run {
  background: linear-gradient(90deg, #4f46e5, #7c3aed);
  color: #ffffff;
  font-weight: 700;
  box-shadow: 0 10px 22px rgba(79, 70, 229, 0.24);
}

.review-flow-footer #btn-start-run:disabled {
  opacity: 0.52;
  cursor: not-allowed;
  box-shadow: none;
}

.review-flow-footer #btn-start-run:disabled:hover {
  background: linear-gradient(90deg, #4f46e5, #7c3aed);
}

.review-summary-sticky {
  width: 100%;
  height: 100%;
  min-height: 100%;
  position: sticky;
  top: 12px;
}

.execution-stage-panel {
  border: 1px solid rgba(255, 255, 255, 0.72);
  border-radius: 28px;
  background: rgba(255, 255, 255, 0.9);
  box-shadow: 0 16px 38px rgba(79, 70, 229, 0.08);
}

.execution-stage-top {
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(0, 0.9fr);
  gap: 16px;
  align-items: center;
}

.execution-stage-top h2 {
  margin: 10px 0 0;
  font-size: clamp(1.8rem, 2.8vw, 2.3rem);
}

.execution-stage-top .guide-text {
  margin-top: 8px;
  line-height: 1.7;
  max-width: 900px;
}

.execution-badge {
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  padding: 5px 12px;
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.execution-badge.running {
  border: 1px solid #d5ddf3;
  background: #eef2ff;
  color: #4338ca;
}

.execution-badge.completed {
  border: 1px solid #b7e4cf;
  background: #ecfdf3;
  color: #166534;
}

.execution-badge.paused {
  border: 1px solid #f5d9a8;
  background: #fff8e7;
  color: #9a5b08;
}

.execution-status-card {
  border-radius: 28px;
  border: 1px solid #c7d2fe;
  background: rgba(238, 242, 255, 0.78);
  padding: 16px;
}

.execution-status-card.running {
  border-color: #c7d2fe;
  background: rgba(238, 242, 255, 0.78);
}

.execution-status-card.completed {
  border-color: #b7e4cf;
  background: rgba(236, 253, 243, 0.86);
}

.execution-status-card.paused {
  border-color: #f5d9a8;
  background: rgba(255, 248, 231, 0.9);
}

.execution-status-meta {
  margin-bottom: 8px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  font-size: 14px;
}

.execution-status-label {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: #334155;
  font-weight: 700;
}

.execution-status-icon {
  display: inline-flex;
  width: 18px;
  justify-content: center;
  color: #4f46e5;
}

.execution-status-card.completed .execution-status-icon {
  color: #059669;
}

.execution-status-card.paused .execution-status-icon {
  color: #b56d11;
}

.execution-progress-bar {
  height: 12px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.8);
}

.execution-status-card.running #progress-fill {
  background: linear-gradient(90deg, #4f46e5, #7c3aed);
  animation: execution-progress-pulse 1.3s ease-in-out infinite;
}

.execution-status-card.completed #progress-fill {
  background: linear-gradient(90deg, #10b981, #14b8a6);
  animation: none;
}

.execution-status-card.paused #progress-fill {
  background: linear-gradient(90deg, #f59e0b, #f97316);
  animation: none;
}

@keyframes execution-progress-pulse {
  0%,
  100% {
    filter: brightness(1);
  }
  50% {
    filter: brightness(1.08);
  }
}

.execution-progress-text {
  margin: 10px 0 0;
  font-size: 13px;
}

.execution-stats-grid {
  margin-top: 16px;
  display: grid;
  gap: 12px;
  grid-template-columns: repeat(6, minmax(0, 1fr));
}

.execution-stat-card {
  border-radius: 18px;
  border: 1px solid #dbe3ee;
  background: #f8fafc;
  padding: 12px;
  display: grid;
  gap: 4px;
}

.execution-stat-card small {
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: #64748b;
  font-weight: 700;
}

.execution-stat-card strong {
  font-size: 1.5rem;
  color: #0f172a;
  line-height: 1.2;
}

.execution-main-grid {
  margin-top: 16px;
  display: grid;
  grid-template-columns: minmax(0, 1.15fr) minmax(0, 0.85fr);
  gap: 16px;
  align-items: stretch;
}

.execution-log-card {
  border-radius: 28px;
  border: 1px solid #dbe3ee;
  background: #f8fafc;
  padding: 16px;
  height: clamp(520px, calc(100vh - 300px), 760px);
  min-height: 520px;
  max-height: 760px;
  display: flex;
  flex-direction: column;
  overflow: hidden;
}

.execution-log-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

.execution-log-head h3 {
  margin: 0;
}

.execution-log-head p {
  margin: 6px 0 0;
  line-height: 1.6;
}

.execution-live-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  min-height: 38px;
  min-width: 92px;
  padding: 0 14px;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  font-weight: 800;
  color: #ffffff;
  white-space: nowrap;
}

.execution-live-badge.running {
  background: linear-gradient(90deg, #0f9f63, #0b8d59);
  box-shadow: 0 0 0 0 rgba(15, 159, 99, 0.35);
  animation: execution-live-badge-pulse 1.2s ease-in-out infinite;
}

.execution-live-badge.completed {
  background: #059669;
}

.execution-live-badge.paused {
  background: #b56d11;
}

@keyframes execution-live-badge-pulse {
  0% {
    filter: brightness(0.95);
    box-shadow: 0 0 0 0 rgba(15, 159, 99, 0.4);
  }
  50% {
    filter: brightness(1.06);
    box-shadow: 0 0 0 8px rgba(15, 159, 99, 0);
  }
  100% {
    filter: brightness(0.95);
    box-shadow: 0 0 0 0 rgba(15, 159, 99, 0);
  }
}

.execution-log-list {
  margin-top: 12px;
  display: grid;
  gap: 10px;
  flex: 1 1 auto;
  min-height: 0;
  max-height: 100%;
  overflow-y: auto;
  overflow-x: hidden;
  padding-right: 4px;
  align-content: start;
}

.execution-log-list::-webkit-scrollbar {
  width: 8px;
}

.execution-log-list::-webkit-scrollbar-track {
  background: #edf2f8;
  border-radius: 999px;
}

.execution-log-list::-webkit-scrollbar-thumb {
  background: #c5d0df;
  border-radius: 999px;
}

.execution-log-item {
  border-radius: 16px;
  border: 1px solid #d7deeb;
  background: #ffffff;
  padding: 12px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.execution-log-item-main {
  display: flex;
  align-items: center;
  gap: 10px;
  min-width: 0;
}

.execution-log-icon {
  width: 20px;
  height: 20px;
  border-radius: 999px;
  border: 1px solid currentColor;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-weight: 800;
  line-height: 1;
  flex: 0 0 auto;
  margin-top: 0;
}

.execution-log-copy {
  min-width: 0;
}

.execution-log-copy strong {
  display: block;
  font-size: 14px;
}

.execution-log-copy p {
  margin: 4px 0 0;
  font-size: 14px;
  line-height: 1.5;
}

.execution-log-tone {
  margin-top: 2px;
  font-size: 11px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  opacity: 0.8;
  white-space: nowrap;
}

.execution-log-item.tone-success {
  border-color: #a7f3d0;
  background: #ecfdf3;
  color: #047857;
}

.execution-log-item.tone-warning {
  border-color: #fcd34d;
  background: #fff7e6;
  color: #8c5a11;
}

.execution-log-item.tone-info {
  border-color: #bae6fd;
  background: #eff9ff;
  color: #0c4a6e;
}

.execution-log-item.tone-error {
  border-color: #fecdd3;
  background: #fff1f2;
  color: #be123c;
}

.execution-log-item.tone-pending {
  border-color: #cbd5e1;
  background: #f8fafc;
  color: #334155;
}

.execution-log-item.is-pending {
  animation: dash-fill-pulse 1.8s ease-in-out infinite;
}

.execution-log-item.tone-current {
  border-color: #86efac;
  background: #ecfdf3;
  color: #166534;
}

.execution-log-item.is-current {
  animation: execution-current-row-pulse 1.4s ease-in-out infinite;
}

@keyframes execution-current-row-pulse {
  0%,
  100% {
    filter: brightness(1);
  }
  50% {
    filter: brightness(1.04);
  }
}

.execution-side-stack {
  display: grid;
  gap: 16px;
  align-content: start;
}

.execution-summary-card {
  border: 1px solid #0f1f4a;
  border-radius: 28px;
  background: #0b1733;
  color: #f8fafc;
  padding: 20px;
  box-shadow: 0 14px 28px rgba(15, 23, 42, 0.22);
}

.execution-summary-card h3 {
  margin: 0;
}

.execution-summary-card p {
  margin: 8px 0 0;
  color: #cbd5e1;
  line-height: 1.6;
}

.execution-summary-items {
  margin-top: 12px;
  display: grid;
  gap: 8px;
}

.execution-summary-item {
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.08);
  border: 1px solid rgba(148, 163, 184, 0.22);
  padding: 10px 12px;
  display: grid;
  gap: 2px;
}

.execution-summary-item small {
  font-size: 11px;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: #cbd5e1;
  font-weight: 700;
}

.execution-summary-item strong {
  color: #ffffff;
  font-size: 14px;
}

.execution-report-card {
  border: 1px solid #c7d2fe;
  border-radius: 28px;
  background: linear-gradient(180deg, #f5f7ff, #eef2ff);
  padding: 20px;
}

.execution-report-card h3 {
  margin: 0;
}

.execution-report-card p {
  margin: 8px 0 0;
  line-height: 1.6;
}

.execution-report-actions {
  margin-top: 12px;
  display: grid;
  gap: 10px;
}

.execution-report-actions .link-btn,
.execution-report-actions button {
  width: 100%;
  justify-content: flex-start;
  text-align: left;
  border-radius: 16px;
  min-height: 52px;
  padding: 12px 14px;
  background: #ffffff;
  color: #0f172a;
  border: 1px solid #c7d2fe;
  box-shadow: 0 2px 8px rgba(79, 70, 229, 0.08);
}

.execution-report-actions .link-btn:hover,
.execution-report-actions button:hover {
  border-color: #8ca7e9;
  background: #f8faff;
}

.execution-report-actions button:disabled {
  opacity: 0.55;
  cursor: not-allowed;
}

.execution-report-actions button:disabled:hover {
  border-color: #c7d2fe;
  background: #ffffff;
}

.execution-stage-panel #btn-new-run {
  background: linear-gradient(90deg, #4f46e5, #7c3aed);
  color: #ffffff;
  box-shadow: 0 10px 24px rgba(79, 70, 229, 0.28);
}

.execution-stage-panel #btn-new-run:disabled {
  opacity: 0.6;
  box-shadow: none;
  cursor: not-allowed;
}

.execution-stage-panel #btn-new-run:not(:disabled):hover {
  filter: brightness(1.02);
}

.session-recovery-overlay {
  position: fixed;
  inset: 0;
  z-index: 2200;
  background: rgba(15, 23, 42, 0.58);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px;
  backdrop-filter: blur(2px);
}

.session-recovery-card {
  width: min(900px, 100%);
  border-radius: 28px;
  border: 1px solid #dbe3ee;
  background: #ffffff;
  box-shadow: 0 28px 60px rgba(15, 23, 42, 0.24);
  padding: 24px;
  display: grid;
  gap: 18px;
}

.session-recovery-head h3 {
  margin: 6px 0 0;
  font-size: clamp(1.4rem, 2.2vw, 1.8rem);
}

.session-recovery-head p {
  margin: 8px 0 0;
}

.session-recovery-kicker {
  display: inline-flex;
  border-radius: 999px;
  padding: 4px 10px;
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  background: #eef2ff;
  color: #4338ca;
}

.session-recovery-step {
  margin-top: 8px;
  font-size: 13px;
}

.session-recovery-body {
  display: grid;
  grid-template-columns: minmax(0, 0.95fr) minmax(0, 1.05fr);
  gap: 16px;
  align-items: center;
}

.session-recovery-qr {
  border: 1px solid #dbe3ee;
  border-radius: 22px;
  background: #f8fafc;
  min-height: 290px;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 14px;
}

.session-recovery-qr img {
  width: min(260px, 100%);
  height: auto;
  border-radius: 14px;
  background: #ffffff;
}

.session-recovery-qr p {
  margin: 0;
  text-align: center;
  line-height: 1.6;
}

.session-recovery-actions {
  display: grid;
  gap: 10px;
}

.session-recovery-actions button {
  min-height: 48px;
}

.review-box {
  border: 1px solid var(--border);
  border-radius: 10px;
  background: #f7fafc;
  padding: 12px;
  line-height: 1.5;
}

.review-summary-card .review-summary-box {
  border: 1px solid rgba(148, 163, 184, 0.3);
  border-radius: 18px;
  background: rgba(15, 23, 42, 0.5);
  color: #e2e8f0;
  padding: 12px;
}

.preview-title {
  margin: 12px 0 8px;
  font-weight: 700;
}

.preview-message {
  border: 1px solid var(--border);
  border-radius: 10px;
  background: #f7fafc;
  padding: 12px;
  line-height: 1.6;
  white-space: pre-wrap;
}

.dropzone {
  border: 2px dashed #b7c9d6;
  background: #f7fbfe;
  border-radius: 12px;
  padding: 18px;
  text-align: center;
}

.dropzone.drag-over {
  border-color: #3f926f;
  background: #ecf7f1;
}

.hidden-file-input {
  position: absolute;
  left: -9999px;
  width: 1px;
  height: 1px;
  opacity: 0;
}

.qr-wrapper {
  margin: 10px 0;
  min-height: 200px;
  display: grid;
  place-items: center;
  border: 1px dashed var(--border);
  border-radius: 12px;
  background: #f9fcfa;
}

.qr-wrapper.prominent {
  min-height: 320px;
  border: 2px dashed #8cbfa8;
  background: radial-gradient(circle at center, #f8fdf9 0%, #eef8f3 80%);
}

.qr-wrapper.hero-qr {
  min-height: 420px;
  padding: 18px;
}

#qr-image {
  max-width: 240px;
  width: 100%;
  display: none;
}

.qr-wrapper.prominent #qr-image {
  max-width: 320px;
}

.qr-placeholder {
  margin: 0;
  color: #2d4d3f;
  font-size: 16px;
  font-weight: 700;
  text-align: center;
}

.wizard-panel.qr-focus {
  border-color: #94ccb0;
  box-shadow: 0 0 0 3px rgba(10, 122, 86, 0.08), 0 18px 34px rgba(7, 85, 61, 0.12);
}

.progress-bar {
  width: 100%;
  height: 12px;
  border-radius: 999px;
  overflow: hidden;
  background: #e7ecef;
}

#progress-fill {
  height: 100%;
  width: 0%;
  background: linear-gradient(90deg, #0a7a56, #42b082);
  transition: width 0.2s ease;
}

.counters {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 10px;
}

.counter {
  background: #f2f6f9;
  border: 1px solid var(--border);
  border-radius: 999px;
  padding: 4px 10px;
  font-size: 13px;
}

.counter.status-success,
.status-chip.status-success {
  background: #e9f8ef;
  border-color: #a7ddbb;
  color: #0f6c3b;
}

.counter.status-warning,
.status-chip.status-warning {
  background: #fff6e8;
  border-color: #f0d6a2;
  color: #8c5a11;
}

.counter.status-error,
.status-chip.status-error {
  background: #fdeeee;
  border-color: #efc0c0;
  color: #a43131;
}

.counter.status-neutral,
.status-chip.status-neutral {
  background: #eef3f8;
  border-color: #d4dee8;
  color: #345066;
}

.checklist-list {
  list-style: none;
  margin: 0 0 12px;
  padding: 0;
  display: grid;
  gap: 8px;
}

.checklist-item {
  border-radius: 10px;
  border: 1px solid #d5e2eb;
  background: #f8fbfd;
  padding: 10px 12px;
  font-size: 14px;
}

.checklist-item strong {
  display: block;
  margin: 0;
  font-size: 15px;
}

.checklist-item p {
  margin: 6px 0 0;
  font-size: 13px;
  line-height: 1.55;
  color: inherit;
}

.checklist-item.ok {
  border-color: #9fd4b5;
  background: #ecf8f1;
  color: #145f3f;
}

.checklist-item.pending {
  border-color: #efd4a4;
  background: #fff9ef;
  color: #7b5618;
}

.compliance-grid {
  display: grid;
  gap: 8px;
  margin-top: 12px;
}

.check-item {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  border: 1px solid #d6e1ea;
  border-radius: 10px;
  background: #f9fcff;
  padding: 9px 10px;
  font-size: 14px;
}

.check-item input {
  margin-top: 2px;
  width: 16px;
  height: 16px;
}

.check-item.optional {
  border-style: dashed;
}

.usage-projection {
  margin-top: 10px;
  font-size: 13px;
}

.sticky-progress {
  position: sticky;
  top: 8px;
  z-index: 4;
}

.results-cards {
  display: none;
  margin-top: 10px;
  gap: 10px;
}

.result-card {
  border: 1px solid var(--border);
  border-radius: 12px;
  background: #ffffff;
  padding: 10px;
  display: grid;
  gap: 6px;
}

.result-card h4 {
  margin: 0;
  font-size: 15px;
}

.result-meta {
  color: #486173;
  font-size: 13px;
}

.status-chip {
  width: fit-content;
  border-radius: 999px;
  border: 1px solid var(--border);
  padding: 4px 8px;
  font-size: 12px;
  font-weight: 700;
}

.table-wrapper {
  overflow: auto;
  margin-top: 12px;
  max-height: 340px;
  border: 1px solid var(--border);
  border-radius: 10px;
}

.table-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  align-items: center;
}

.table-actions select {
  max-width: 130px;
}

.role-chip {
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  padding: 4px 9px;
  border: 1px solid #ccd9e3;
  background: #eef4f8;
  font-size: 12px;
  font-weight: 700;
}

.role-chip.role-owner {
  border-color: #8cc8ae;
  background: #e8f7ef;
  color: #0f6545;
}

.role-chip.role-admin {
  border-color: #98bfe2;
  background: #edf5fc;
  color: #245a86;
}

.role-chip.role-operador {
  border-color: #d3dde6;
  background: #f5f8fb;
  color: #445a6b;
}

table {
  width: 100%;
  border-collapse: collapse;
  min-width: 760px;
}

th,
td {
  padding: 8px 10px;
  border-bottom: 1px solid var(--border);
  text-align: left;
  font-size: 14px;
}

th {
  background: #f2f6fa;
  position: sticky;
  top: 0;
}

.hidden {
  display: none !important;
}

.history-main,
.company-main,
.company-setup-main {
  align-content: start;
}

.history-kicker,
.company-kicker {
  margin: 0 0 6px;
  display: inline-flex;
  width: fit-content;
  padding: 6px 12px;
  border-radius: 999px;
  border: 1px solid #cdd8ff;
  background: #eef2ff;
  color: #3730a3;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.03em;
  text-transform: uppercase;
}

.history-kpi-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
}

.history-kpi-card {
  border-radius: 18px;
  padding: 14px;
  border: 1px solid #dbe3f1;
  box-shadow: 0 8px 24px rgba(15, 23, 42, 0.06);
  background:
    radial-gradient(circle at top right, rgba(99, 102, 241, 0.12), transparent 40%),
    #ffffff;
}

.history-kpi-label {
  margin: 0;
  color: #64748b;
  font-size: 13px;
  font-weight: 600;
}

.history-kpi-value {
  margin: 8px 0 0;
  color: #0f172a;
  font-family: "Sora", "Manrope", sans-serif;
  font-size: clamp(1.35rem, 2.2vw, 1.7rem);
  font-weight: 700;
  line-height: 1.1;
}

.history-card {
  border-radius: 20px;
  border-color: #dbe3f1;
}

.history-card-head,
.company-card-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 10px;
}

.history-card-head h2,
.company-card-head h2,
.company-card-head h3 {
  margin: 0;
}

.history-card-pill {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 10px;
  border-radius: 999px;
  border: 1px solid #d4dffc;
  background: #eff3ff;
  color: #3f4bb8;
  font-size: 12px;
  font-weight: 700;
  line-height: 1;
  white-space: nowrap;
}

.history-live-chip {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  padding: 6px 10px;
  border-radius: 999px;
  border: 1px solid #bde2c7;
  background: #ecfdf3;
  color: #11643e;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.02em;
}

.history-live-dot {
  width: 8px;
  height: 8px;
  border-radius: 999px;
  background: #16a34a;
  box-shadow: 0 0 0 0 rgba(22, 163, 74, 0.5);
  animation: history-live-pulse 1.5s ease-in-out infinite;
}

.history-table-wrapper {
  max-height: 360px;
  border-radius: 12px;
}

.history-status-chip {
  display: inline-flex;
  align-items: center;
  border: 1px solid #ced8e4;
  background: #f1f5f9;
  color: #334155;
  border-radius: 999px;
  padding: 4px 10px;
  font-size: 12px;
  font-weight: 700;
  line-height: 1.2;
  white-space: nowrap;
}

.history-yes {
  border-color: #bce2cb;
  background: #ecfdf3;
  color: #11643e;
}

.history-no {
  border-color: #d6dee7;
  background: #f8fafc;
  color: #475569;
}

.history-run-status-running,
.history-run-status-open {
  border-color: #bfd6ff;
  background: #eef4ff;
  color: #1d4ed8;
}

.history-run-status-completed,
.history-run-status-success {
  border-color: #bce2cb;
  background: #ecfdf3;
  color: #11643e;
}

.history-run-status-failed,
.history-run-status-error,
.history-run-status-interrupted,
.history-run-status-cancelled {
  border-color: #f2c9c9;
  background: #fff1f1;
  color: #b42318;
}

.history-run-status-paused_waiting_qr {
  border-color: #f5d9a8;
  background: #fff7e8;
  color: #9a5800;
}

.history-final-status-adicionado,
.history-internal-status-added_success {
  border-color: #bce2cb;
  background: #ecfdf3;
  color: #11643e;
}

.history-final-status-ja_no_grupo,
.history-internal-status-already_in_group,
.history-internal-status-skipped_already_processed {
  border-color: #f5d9a8;
  background: #fff7e8;
  color: #9a5800;
}

.history-final-status-convite_enviado,
.history-internal-status-invite_sent {
  border-color: #bfd6ff;
  background: #eef4ff;
  color: #1d4ed8;
}

.history-final-status-numero_invalido,
.history-final-status-nao_existe_whatsapp,
.history-final-status-falha,
.history-internal-status-invalid_number,
.history-internal-status-not_on_whatsapp,
.history-internal-status-add_failed,
.history-internal-status-invite_failed {
  border-color: #f2c9c9;
  background: #fff1f1;
  color: #b42318;
}

.history-internal-status-invite_skipped_safe_mode {
  border-color: #ddd4fe;
  background: #f5f3ff;
  color: #5b21b6;
}

.company-main {
  gap: 14px;
}

.company-team-main {
  gap: 12px;
}

.company-admin-main {
  gap: 14px;
}

.company-team-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.22fr) minmax(320px, 0.78fr);
  gap: 12px;
  align-items: start;
}

.team-main-stack,
.team-context-stack {
  display: grid;
  gap: 12px;
  align-content: start;
}

.team-header-card {
  border: 1px solid rgba(255, 255, 255, 0.7);
  border-radius: 20px;
  background: rgba(255, 255, 255, 0.82);
  box-shadow: 0 10px 28px rgba(15, 23, 42, 0.08);
  backdrop-filter: blur(8px);
  padding: 18px 20px;
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 16px;
}

.team-header-card h1 {
  margin: 10px 0 0;
  font-size: clamp(1.8rem, 3vw, 2.2rem);
}

.team-header-card .muted {
  margin: 8px 0 0;
  max-width: 680px;
}

.team-header-right {
  display: flex;
  align-items: center;
  gap: 14px;
}

.team-header-actor {
  text-align: right;
}

.team-header-actor-name {
  margin: 0;
  font-weight: 800;
  color: #0f172a;
}

.team-summary-head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 12px;
}

.team-summary-head h2 {
  margin: 0;
  font-size: 1.6rem;
}

.team-summary-head .muted {
  margin: 6px 0 0;
}

.team-summary-card,
.team-members-card,
.team-permissions-card {
  border-radius: 20px;
  border-color: #dbe3f1;
}

.team-members-card {
  box-shadow: 0 14px 30px rgba(15, 23, 42, 0.09);
}

.team-members-head h2 {
  margin: 0;
  font-size: 1.8rem;
}

.team-members-head .muted {
  margin: 6px 0 0;
}

.team-member-form-grid {
  margin-top: 12px;
  display: grid;
  gap: 10px;
  grid-template-columns: minmax(0, 1fr) 220px 180px;
  align-items: end;
}

.team-member-form-grid label {
  margin-top: 0;
}

.team-member-submit {
  display: flex;
}

.team-member-submit button {
  width: 100%;
  border-radius: 14px;
  background: #0f172a;
}

.team-member-submit button:hover {
  background: #1e293b;
}

.team-members-card .table-wrapper {
  margin-top: 12px;
}

.team-members-table {
  border-radius: 14px;
}

.team-members-table th {
  text-transform: uppercase;
  letter-spacing: 0.05em;
  font-size: 11px;
  color: #64748b;
  font-weight: 700;
}

.team-permissions-list {
  margin-top: 8px;
  display: grid;
  gap: 8px;
  color: #475569;
  line-height: 1.5;
  font-size: 14px;
}

.team-permissions-list p {
  margin: 0;
  padding: 10px 12px;
  border-radius: 12px;
  border: 1px solid #e2e8f0;
  background: #f8fafc;
}

.team-plan-card {
  border-radius: 22px;
  background: #0f172a;
  border: 1px solid #1e293b;
  color: #e2e8f0;
  box-shadow: 0 16px 34px rgba(15, 23, 42, 0.28);
}

.team-plan-card h3 {
  margin: 0;
  color: #ffffff;
}

.team-plan-card .muted,
.team-plan-card .company-note {
  color: #94a3b8;
}

.team-plan-grid {
  margin-top: 10px;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.team-plan-grid > div {
  padding: 10px;
  border-radius: 12px;
  border: 1px solid rgba(148, 163, 184, 0.25);
  background: rgba(30, 41, 59, 0.65);
}

.team-plan-label {
  margin: 0;
  font-size: 12px;
  color: #94a3b8;
}

.team-plan-value {
  margin: 6px 0 0;
  font-size: 15px;
  font-weight: 700;
  color: #f8fafc;
}

.team-context-stack {
  position: sticky;
  top: 8px;
}

.team-admin-link {
  margin-top: 8px;
  width: 100%;
}

.team-admin-open-btn {
  margin-top: 8px;
  width: 100%;
  background: #ffffff;
  color: #0f172a;
  border-radius: 14px;
  font-weight: 700;
}

.team-admin-open-btn:hover {
  background: #f1f5f9;
}

.history-card-pill.account-status-active {
  border-color: #bce2cb;
  background: #ecfdf3;
  color: #11643e;
}

.history-card-pill.account-status-readonly {
  border-color: #f5d9a8;
  background: #fff7e8;
  color: #9a5800;
}

.team-admin-locked {
  margin: 10px 0 0;
  font-size: 13px;
}

.team-scope-card {
  border-radius: 20px;
  border-color: #dbe3f1;
}

.team-scope-card h3 {
  margin: 0;
}

.team-scope-card .muted {
  margin: 6px 0 0;
}

.team-scope-list {
  margin-top: 12px;
  display: grid;
  gap: 8px;
}

.team-scope-list p {
  margin: 0;
  border: 1px solid #e2e8f0;
  background: #f8fafc;
  border-radius: 12px;
  padding: 10px 12px;
  color: #475569;
  line-height: 1.45;
  font-size: 14px;
}

.admin-premium-body {
  background:
    radial-gradient(circle at top, rgba(99, 102, 241, 0.12), transparent 38%),
    linear-gradient(180deg, #f8fafc 0%, #eef2ff 52%, #f8fafc 100%);
}

.admin-premium-shell {
  max-width: 1280px;
  margin: 0 auto;
  padding: 6px 4px;
}

.admin-premium-header {
  margin-bottom: 16px;
  border: 1px solid rgba(255, 255, 255, 0.7);
  border-radius: 24px;
  background: rgba(255, 255, 255, 0.84);
  box-shadow: 0 10px 30px rgba(15, 23, 42, 0.08);
  backdrop-filter: blur(8px);
  padding: 22px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 18px;
}

.admin-premium-badge {
  margin: 0;
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  background: #eef2ff;
  color: #4338ca;
  border: 1px solid #c7d2fe;
  padding: 6px 12px;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  font-size: 11px;
  font-weight: 800;
}

.admin-premium-header h1 {
  margin: 10px 0 0;
  font-size: clamp(1.8rem, 3vw, 2.25rem);
  letter-spacing: -0.02em;
}

.admin-premium-header .muted {
  margin: 8px 0 0;
  max-width: 740px;
}

.admin-premium-header-right {
  display: flex;
  align-items: center;
  gap: 16px;
}

.admin-premium-back {
  min-height: 44px;
  border-radius: 14px;
  border: 1px solid #cbd5e1;
  padding: 0 16px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
  font-weight: 700;
  color: #334155;
  background: #ffffff;
}

.admin-premium-back:hover {
  background: #f8fafc;
}

.admin-premium-actor {
  text-align: right;
}

.admin-premium-actor-name {
  margin: 0;
  font-weight: 800;
  color: #0f172a;
}

.admin-top-summary {
  margin-bottom: 16px;
  border: 1px solid rgba(255, 255, 255, 0.7);
  border-radius: 24px;
  background: rgba(255, 255, 255, 0.86);
  box-shadow: 0 10px 28px rgba(15, 23, 42, 0.08);
  backdrop-filter: blur(8px);
  padding: 20px;
}

.admin-top-summary-head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 16px;
}

.admin-top-summary-head h2 {
  margin: 0;
  font-size: 1.75rem;
  letter-spacing: -0.02em;
}

.admin-top-summary-head .muted {
  margin: 6px 0 0;
}

.admin-status-pill {
  border-radius: 999px;
  border: 1px solid #bbf7d0;
  background: #ecfdf3;
  color: #15803d;
  padding: 8px 14px;
  font-weight: 800;
  white-space: nowrap;
  font-size: 0.92rem;
}

.admin-top-summary-grid {
  margin-top: 14px;
  display: grid;
  gap: 12px;
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.admin-top-kpi {
  border: 1px solid #e2e8f0;
  border-radius: 16px;
  background: rgba(248, 250, 252, 0.86);
  padding: 12px;
}

.admin-top-kpi-label {
  margin: 0;
  font-size: 11px;
  color: #64748b;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  font-weight: 800;
}

.admin-top-kpi-value {
  margin: 8px 0 0;
  color: #0f172a;
  font-size: 1.18rem;
  font-weight: 800;
}

.admin-premium-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(320px, 0.8fr);
  gap: 16px;
  align-items: start;
}

.admin-main-stack,
.admin-context-stack {
  display: grid;
  gap: 16px;
  align-content: start;
}

.admin-context-stack {
  position: sticky;
  top: 10px;
}

.admin-premium-card {
  border-radius: 24px;
  border-color: rgba(255, 255, 255, 0.72);
  background: rgba(255, 255, 255, 0.85);
  box-shadow: 0 10px 26px rgba(15, 23, 42, 0.08);
  backdrop-filter: blur(8px);
  padding: 20px;
}

.admin-section-head {
  display: block;
}

.admin-section-head h2,
.admin-section-head h3 {
  margin: 8px 0 0;
  letter-spacing: -0.01em;
}

.admin-section-head .muted {
  margin: 6px 0 0;
}

.admin-section-icon {
  margin: 0;
  width: 40px;
  height: 40px;
  border-radius: 14px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: #e0e7ff;
  color: #4338ca;
  border: 1px solid #c7d2fe;
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 0.04em;
}

.admin-duo-grid {
  margin-top: 12px;
  display: grid;
  gap: 12px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.admin-plan-feature-grid {
  margin-top: 12px;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.admin-feature-item {
  border: 1px solid #e2e8f0;
  border-radius: 16px;
  background: #ffffff;
  padding: 12px;
}

.admin-feature-item-highlight {
  border-color: #bfdbfe;
  background: #eef2ff;
}

.admin-feature-label {
  margin: 0;
  color: #64748b;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  font-size: 11px;
  font-weight: 700;
}

.admin-feature-value {
  margin: 8px 0 0;
  color: #0f172a;
  font-size: 1.18rem;
  line-height: 1.1;
  font-weight: 800;
}

.admin-feature-item .muted {
  margin: 8px 0 0;
}

.admin-callout-rule {
  margin-top: 12px;
  border-radius: 16px;
  border: 1px solid #fde68a;
  background: #fff7e8;
  padding: 12px;
  color: #92400e;
}

.admin-callout-rule strong {
  display: block;
  color: #9a5800;
}

.admin-callout-rule p {
  margin: 6px 0 0;
  line-height: 1.5;
}

.admin-action-row {
  margin-top: 12px;
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: flex-end;
}

.admin-action-row .inline-field {
  min-width: 260px;
  flex: 1 1 340px;
}

.admin-action-row .inline-field input,
.admin-action-row .inline-field select,
.admin-audit-inputs input {
  width: 100%;
}

.admin-audit-inputs input {
  flex: 1 1 260px;
}

.admin-limits-grid {
  margin-top: 10px;
}

.admin-governance-grid {
  margin-top: 10px;
  display: grid;
  gap: 10px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.admin-summary-dark {
  border-radius: 24px;
  background: #0f172a;
  color: #e2e8f0;
  border: 1px solid #1e293b;
  box-shadow: 0 16px 32px rgba(15, 23, 42, 0.3);
  padding: 20px;
}

.admin-summary-dark h2 {
  margin: 0;
  color: #ffffff;
}

.admin-summary-dark p {
  margin: 8px 0 0;
  color: #cbd5e1;
  font-size: 14px;
  line-height: 1.5;
}

.admin-summary-items {
  margin-top: 12px;
  display: grid;
  gap: 8px;
}

.admin-summary-items article {
  border-radius: 14px;
  border: 1px solid rgba(148, 163, 184, 0.26);
  background: rgba(30, 41, 59, 0.72);
  padding: 10px;
  display: grid;
  gap: 4px;
}

.admin-summary-items span {
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: #94a3b8;
  font-weight: 700;
}

.admin-summary-items strong {
  color: #f8fafc;
  font-size: 14px;
  line-height: 1.4;
}

.admin-model-list {
  margin-top: 10px;
  display: grid;
  gap: 8px;
}

.admin-model-list p {
  margin: 0;
  padding: 10px 12px;
  border: 1px solid #e2e8f0;
  background: #f8fafc;
  border-radius: 12px;
  color: #475569;
  font-size: 14px;
  line-height: 1.45;
}

.admin-warning-card {
  border-radius: 24px;
  border: 1px solid #f5d9a8;
  background: #fff7e8;
  box-shadow: 0 10px 24px rgba(154, 88, 0, 0.14);
  padding: 16px;
}

.admin-warning-card h3 {
  margin: 0;
  color: #9a5800;
}

.admin-warning-card p {
  margin: 8px 0 0;
  color: #92400e;
  font-size: 14px;
  line-height: 1.55;
}

.admin-jump-btn {
  min-height: 46px;
  border-radius: 16px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
  color: #ffffff;
  font-weight: 800;
  background: linear-gradient(90deg, #4f46e5, #7c3aed);
  box-shadow: 0 10px 22px rgba(79, 70, 229, 0.28);
}

.admin-jump-btn:hover {
  filter: brightness(1.03);
}

.admin-v2-body {
  background:
    radial-gradient(circle at top, rgba(99, 102, 241, 0.12), transparent 38%),
    linear-gradient(180deg, #f8fafc 0%, #eef2ff 52%, #f8fafc 100%);
}

.admin-v2-shell {
  max-width: 1280px;
  margin: 0 auto;
  padding: 8px 6px 18px;
}

.admin-v2-header {
  border: 1px solid rgba(255, 255, 255, 0.7);
  border-radius: 24px;
  background: rgba(255, 255, 255, 0.84);
  box-shadow: 0 10px 30px rgba(15, 23, 42, 0.08);
  backdrop-filter: blur(8px);
  padding: 22px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 18px;
}

.admin-v2-kicker {
  margin: 0;
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  background: #eef2ff;
  color: #4338ca;
  border: 1px solid #c7d2fe;
  padding: 6px 12px;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  font-size: 11px;
  font-weight: 800;
}

.admin-v2-header h1 {
  margin: 10px 0 0;
  font-size: clamp(1.85rem, 3vw, 2.25rem);
  letter-spacing: -0.02em;
}

.admin-v2-subtitle {
  margin: 8px 0 0;
  max-width: 760px;
  color: #64748b;
}

.admin-v2-header-right {
  display: flex;
  align-items: center;
  gap: 18px;
}

.admin-v2-back {
  min-height: 44px;
  border-radius: 12px;
  border: 1px solid #d5deef;
  padding: 0 16px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  text-decoration: none;
  font-weight: 700;
  color: #334155;
  background: #ffffff;
}

.admin-v2-back-icon {
  width: 16px;
  height: 16px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.admin-v2-back:hover {
  background: #f8fafc;
}

.admin-v2-user {
  text-align: right;
}

.admin-v2-user-name {
  margin: 0;
  display: inline-flex;
  align-items: center;
  justify-content: flex-end;
  gap: 6px;
  color: #0f172a;
  font-weight: 800;
}

.admin-v2-crown {
  color: #4f46e5;
  width: 18px;
  height: 18px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.admin-v2-user-role {
  margin: 3px 0 0;
  color: #64748b;
  text-transform: capitalize;
}

.admin-v2-summary {
  margin-top: 16px;
  border: 1px solid rgba(255, 255, 255, 0.7);
  border-radius: 24px;
  background: rgba(255, 255, 255, 0.86);
  box-shadow: 0 10px 28px rgba(15, 23, 42, 0.08);
  backdrop-filter: blur(8px);
  padding: 20px;
}

.admin-v2-summary-head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 16px;
}

.admin-v2-summary-head h2 {
  margin: 0;
  font-size: 1.75rem;
  letter-spacing: -0.02em;
}

.admin-v2-status-pill {
  border-radius: 999px;
  border: 1px solid #bbf7d0;
  background: #ecfdf3;
  color: #15803d;
  padding: 8px 14px;
  font-size: 0.92rem;
  font-weight: 800;
  white-space: nowrap;
}

.admin-v2-status-pill.is-delinquent {
  border-color: #fecaca;
  background: #fef2f2;
  color: #b91c1c;
}

.admin-v2-muted {
  color: #64748b;
}

.admin-v2-summary-grid {
  margin-top: 14px;
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
}

.admin-v2-summary-card {
  border: 1px solid #e2e8f0;
  border-radius: 16px;
  background: rgba(248, 250, 252, 0.86);
  padding: 12px;
}

.admin-v2-label {
  margin: 0;
  font-size: 11px;
  color: #64748b;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  font-weight: 800;
}

.admin-v2-value {
  margin: 8px 0 0;
  color: #0f172a;
  font-size: 1.18rem;
  font-weight: 800;
}

.admin-v2-grid {
  margin-top: 16px;
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(320px, 0.8fr);
  gap: 16px;
  align-items: start;
}

.admin-v2-main,
.admin-v2-side {
  display: grid;
  gap: 16px;
  align-content: start;
}

.admin-v2-side {
  position: sticky;
  top: 10px;
}

.admin-v2-grid-single {
  grid-template-columns: 1fr;
}

.admin-v2-card {
  border: 1px solid rgba(255, 255, 255, 0.72);
  border-radius: 24px;
  background: rgba(255, 255, 255, 0.86);
  box-shadow: 0 10px 26px rgba(15, 23, 42, 0.08);
  backdrop-filter: blur(8px);
  padding: 20px;
}

.admin-v2-card h3 {
  margin: 0;
  color: #0f172a;
  letter-spacing: -0.01em;
}

.admin-v2-card-head {
  display: flex;
  gap: 12px;
  align-items: flex-start;
}

.admin-v2-card-head .admin-v2-muted {
  margin: 6px 0 0;
}

.admin-v2-icon-chip {
  width: 42px;
  height: 42px;
  border-radius: 13px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: #e0e7ff;
  color: #4338ca;
  border: 1px solid #c7d2fe;
  flex-shrink: 0;
}

.admin-v2-icon-svg {
  width: 19px;
  height: 19px;
}

.admin-v2-two-cols {
  margin-top: 12px;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

.admin-v2-feature-card {
  border: 1px solid #e2e8f0;
  border-radius: 16px;
  background: #ffffff;
  padding: 12px;
}

.admin-v2-feature-highlight {
  border-color: #bfdbfe;
  background: #eef2ff;
}

.admin-v2-feature-title {
  margin: 8px 0 0;
  color: #0f172a;
  font-size: 1.1rem;
  font-weight: 800;
}

.admin-v2-feature-card .admin-v2-muted {
  margin: 8px 0 0;
}

.admin-v2-rule {
  margin-top: 12px;
  border: 1px solid #fde68a;
  border-radius: 16px;
  background: #fff7e8;
  padding: 12px;
  color: #92400e;
}

.admin-v2-rule strong {
  display: block;
  color: #9a5800;
}

.admin-v2-rule p {
  margin: 6px 0 0;
  line-height: 1.5;
}

.admin-v2-actions {
  margin-top: 12px;
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: flex-end;
}

.admin-v2-actions input,
.admin-v2-actions select {
  width: 100%;
}

.admin-v2-field {
  min-width: 260px;
  flex: 1 1 340px;
}

.admin-v2-actions > button {
  min-height: 50px;
  border-radius: 13px;
  font-size: 1.01rem;
  font-weight: 700;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 0 22px;
  line-height: 1;
}

.admin-v2-actions > button:not(.secondary) {
  border: none;
  background: linear-gradient(90deg, #4f46e5, #7c3aed);
  box-shadow: 0 10px 22px rgba(79, 70, 229, 0.28);
  color: #ffffff;
  font-weight: 800;
}

.admin-v2-actions > button:not(.secondary):hover {
  filter: brightness(1.03);
}

.admin-v2-actions > button.secondary {
  border: 1px solid #dbe3f1;
  background: #ffffff;
  color: #334155;
  box-shadow: none;
}

.admin-v2-actions > button.secondary:hover {
  background: #f8fafc;
}

.admin-v2-advanced {
  margin-top: 12px;
  border: 1px dashed #cbd5e1;
  border-radius: 14px;
  padding: 10px;
  background: rgba(248, 250, 252, 0.8);
}

.admin-v2-advanced summary {
  cursor: pointer;
  color: #334155;
  font-weight: 700;
}

.admin-v2-note {
  margin-top: 10px;
}

.admin-v2-finance-list {
  margin-top: 14px;
  display: grid;
  gap: 10px;
}

.admin-v2-finance-item {
  border: 1px solid #dbe3f1;
  border-radius: 16px;
  background: rgba(248, 250, 252, 0.86);
  padding: 14px;
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: center;
}

.admin-v2-finance-ref {
  margin: 0;
  color: #0f172a;
  font-size: 1.68rem;
  font-weight: 700;
}

.admin-v2-finance-desc {
  margin: 6px 0 0;
  color: #64748b;
}

.admin-v2-finance-right {
  text-align: right;
}

.admin-v2-finance-amount {
  margin: 0;
  color: #0f172a;
  font-size: 1.12rem;
  font-weight: 700;
}

.admin-v2-finance-status {
  margin: 6px 0 0;
  color: #64748b;
  font-weight: 700;
}

.admin-v2-finance-status.is-paid {
  color: #047857;
}

.admin-v2-dark-card {
  border-radius: 24px;
  background: #0f172a;
  border: 1px solid #1e293b;
  box-shadow: 0 16px 32px rgba(15, 23, 42, 0.3);
  padding: 20px;
  color: #e2e8f0;
}

.admin-v2-dark-card h3 {
  margin: 0;
  color: #ffffff;
  font-size: 1.7rem;
  letter-spacing: -0.02em;
}

.admin-v2-dark-card p {
  margin: 8px 0 0;
  color: #cbd5e1;
  line-height: 1.5;
}

.admin-v2-dark-list {
  margin-top: 12px;
  display: grid;
  gap: 8px;
}

.admin-v2-dark-list article {
  border-radius: 14px;
  border: 1px solid rgba(148, 163, 184, 0.26);
  background: rgba(30, 41, 59, 0.72);
  padding: 10px;
  display: grid;
  gap: 4px;
}

.admin-v2-dark-list span {
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: #94a3b8;
  font-weight: 700;
}

.admin-v2-dark-list strong {
  color: #f8fafc;
  font-size: 14px;
}

.admin-v2-side-head {
  display: flex;
  gap: 12px;
  align-items: flex-start;
}

.admin-v2-side-icon {
  width: 40px;
  height: 40px;
  border-radius: 14px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: rgba(255, 255, 255, 0.08);
  color: #ffffff;
  border: 1px solid rgba(148, 163, 184, 0.32);
  flex-shrink: 0;
}

.admin-v2-info-list {
  margin-top: 10px;
  display: grid;
  gap: 8px;
}

.admin-v2-info-list p {
  margin: 0;
  border: 1px solid #e2e8f0;
  border-radius: 12px;
  background: #f8fafc;
  padding: 10px 12px;
  color: #475569;
  line-height: 1.45;
}

.admin-v2-warning-card {
  border-radius: 24px;
  border: 1px solid #f5d9a8;
  background: #fff7e8;
  box-shadow: 0 10px 24px rgba(154, 88, 0, 0.14);
  padding: 16px;
}

.admin-v2-warning-card h3 {
  margin: 0;
  color: #9a5800;
}

.admin-v2-warning-card p {
  margin: 8px 0 0;
  color: #92400e;
  line-height: 1.55;
}

.admin-v2-primary-link {
  width: 100%;
  margin-top: 16px;
  min-height: 44px;
  border-radius: 16px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
  color: #ffffff;
  font-weight: 800;
  background: linear-gradient(90deg, #4f46e5, #7c3aed);
  box-shadow: 0 10px 22px rgba(79, 70, 229, 0.28);
  gap: 8px;
}

.admin-v2-primary-link:hover {
  filter: brightness(1.03);
}

.admin-v2-link-arrow {
  width: 16px;
  height: 16px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.admin-v2-retention-points {
  margin-top: 12px;
}

.admin-v2-btn-icon {
  width: 16px;
  height: 16px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: #4f46e5;
}

.admin-v2-btn-icon .admin-v2-icon-svg,
.admin-v2-back-icon .admin-v2-icon-svg,
.admin-v2-link-arrow .admin-v2-icon-svg {
  width: 16px;
  height: 16px;
}

.admin-v2-modal-open {
  overflow: hidden;
}

.admin-v2-modal {
  position: fixed;
  inset: 0;
  z-index: 1200;
  display: grid;
  place-items: center;
  padding: 18px;
}

.admin-v2-modal.hidden {
  display: none;
}

.admin-v2-modal-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(15, 23, 42, 0.56);
  backdrop-filter: blur(3px);
}

.admin-v2-modal-card {
  position: relative;
  width: min(880px, 100%);
  border: 1px solid rgba(255, 255, 255, 0.72);
  border-radius: 26px;
  background: rgba(255, 255, 255, 0.95);
  box-shadow: 0 28px 70px rgba(15, 23, 42, 0.26);
  padding: 20px;
  display: grid;
  gap: 14px;
}

.admin-v2-modal-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}

.admin-v2-modal-head h2 {
  margin: 10px 0 0;
  font-size: clamp(1.4rem, 3vw, 1.85rem);
  letter-spacing: -0.02em;
  color: #0f172a;
}

.admin-v2-modal-head .admin-v2-muted {
  margin: 8px 0 0;
}

.admin-v2-modal-close {
  min-height: 40px;
  border-radius: 12px;
  border: 1px solid #d5deef;
  background: #ffffff;
  color: #334155;
  font-weight: 700;
  padding: 0 14px;
}

.admin-v2-modal-close:hover:not(:disabled) {
  background: #f8fafc;
}

.admin-v2-modal-close:disabled {
  opacity: 0.65;
  cursor: not-allowed;
}

.admin-v2-plan-options {
  display: grid;
  gap: 12px;
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.admin-v2-plan-option {
  position: relative;
  display: grid;
  gap: 10px;
  border-radius: 18px;
  border: 1px solid #dbe3f1;
  background: #ffffff;
  padding: 14px;
  cursor: pointer;
  transition: border-color 0.2s ease, box-shadow 0.2s ease, transform 0.2s ease;
}

.admin-v2-plan-option:hover {
  border-color: #a5b4fc;
  transform: translateY(-1px);
}

.admin-v2-plan-option.is-current {
  cursor: not-allowed;
  border-color: #cbd5e1;
  background: #f8fafc;
  opacity: 0.9;
}

.admin-v2-plan-option.is-current:hover {
  border-color: #cbd5e1;
  transform: none;
}

.admin-v2-plan-option.is-selected {
  border-color: #6366f1;
  background: #eef2ff;
  box-shadow: 0 0 0 3px rgba(99, 102, 241, 0.18);
}

.admin-v2-plan-option input {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}

.admin-v2-plan-option-head {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 8px;
  flex-wrap: wrap;
}

.admin-v2-plan-option-head strong {
  font-size: 1.06rem;
  color: #0f172a;
}

.admin-v2-plan-option-head small {
  color: #475569;
  font-size: 0.88rem;
  font-weight: 700;
}

.admin-v2-plan-current-badge {
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  padding: 4px 9px;
  font-size: 0.72rem;
  font-style: normal;
  font-weight: 800;
  letter-spacing: 0.02em;
  color: #1d4ed8;
  border: 1px solid #bfdbfe;
  background: #eff6ff;
}

.admin-v2-plan-option-body {
  display: grid;
  gap: 6px;
}

.admin-v2-plan-option-body span {
  border-radius: 10px;
  border: 1px solid #e2e8f0;
  background: #f8fafc;
  padding: 8px 10px;
  color: #475569;
  font-size: 0.85rem;
  line-height: 1.3;
}

.admin-v2-modal-feedback {
  margin: 0;
  border: 1px solid #fca5a5;
  border-radius: 12px;
  background: #fef2f2;
  color: #b42318;
  padding: 10px 12px;
  font-size: 0.92rem;
  font-weight: 700;
}

.admin-v2-modal-feedback.is-error {
  border-color: #fca5a5;
  background: #fef2f2;
  color: #b42318;
}

.admin-v2-modal-footer {
  display: flex;
  justify-content: flex-end;
  align-items: center;
  gap: 10px;
}

.admin-v2-modal-footer > button {
  min-height: 46px;
  border-radius: 13px;
  padding: 0 18px;
  font-weight: 700;
}

.admin-v2-modal-footer > button:not(.secondary) {
  border: none;
  background: linear-gradient(90deg, #4f46e5, #7c3aed);
  color: #ffffff;
  box-shadow: 0 10px 22px rgba(79, 70, 229, 0.28);
}

.admin-v2-modal-footer > button:not(.secondary):hover:not(:disabled) {
  filter: brightness(1.03);
}

.admin-v2-modal-footer > button:disabled {
  opacity: 0.65;
  cursor: not-allowed;
}

.admin-v2-toast-container {
  position: fixed;
  top: 16px;
  right: 16px;
  z-index: 1300;
  display: grid;
  gap: 10px;
  pointer-events: none;
}

.admin-v2-toast {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  min-width: min(360px, calc(100vw - 32px));
  max-width: min(420px, calc(100vw - 32px));
  border: 1px solid #bbf7d0;
  border-radius: 14px;
  background: #ecfdf3;
  color: #11643e;
  padding: 12px 14px;
  font-size: 0.93rem;
  font-weight: 700;
  box-shadow: 0 16px 38px rgba(15, 23, 42, 0.18);
  opacity: 0;
  transform: translateY(-10px);
  transition: opacity 0.2s ease, transform 0.2s ease;
}

.admin-v2-toast::before {
  content: "";
  width: 10px;
  height: 10px;
  border-radius: 999px;
  background: #16a34a;
  box-shadow: 0 0 0 4px rgba(22, 163, 74, 0.18);
  flex-shrink: 0;
}

.admin-v2-toast.is-visible {
  opacity: 1;
  transform: translateY(0);
}

.admin-v2-toast.is-hiding {
  opacity: 0;
  transform: translateY(-10px);
}

.company-admin-grid,
.company-bottom-grid {
  display: grid;
  gap: 12px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.company-strong-card {
  border-radius: 20px;
  border-color: #dbe3f1;
  background:
    radial-gradient(circle at top right, rgba(99, 102, 241, 0.1), transparent 42%),
    #ffffff;
}

.company-row-compact {
  align-items: center;
}

.company-row-compact input {
  flex: 1 1 280px;
}

.company-divider {
  margin: 12px 0;
  border-top: 1px dashed #d5dce8;
}

.company-table-wrapper {
  max-height: 320px;
  border-radius: 12px;
}

.company-members .company-table-wrapper {
  max-height: 380px;
}

.company-note {
  margin: 10px 0;
  line-height: 1.45;
}

.company-setup-main {
  gap: 12px;
}

.company-setup-hero {
  border-radius: 24px;
  border: 1px solid #d8e2f2;
  background:
    radial-gradient(circle at top right, rgba(99, 102, 241, 0.12), transparent 45%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(248, 250, 255, 0.95));
  padding: 20px;
  box-shadow: 0 14px 28px rgba(79, 70, 229, 0.1);
}

.company-setup-hero h1 {
  margin: 0;
}

.company-setup-hero p:last-child {
  margin-bottom: 0;
}

.company-setup-intro {
  border-radius: 18px;
  border-color: #dbe3f1;
}

.company-setup-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

.company-setup-card {
  border-radius: 18px;
  border-color: #dbe3f1;
}

@keyframes history-live-pulse {
  0% {
    box-shadow: 0 0 0 0 rgba(22, 163, 74, 0.5);
  }
  70% {
    box-shadow: 0 0 0 9px rgba(22, 163, 74, 0);
  }
  100% {
    box-shadow: 0 0 0 0 rgba(22, 163, 74, 0);
  }
}

@media (max-width: 860px) {
  .app-header {
    flex-direction: column;
  }

  .dash-layout {
    grid-template-columns: 1fr;
    gap: 12px;
  }

  .dash-sidebar {
    border-radius: 18px;
  }

  .dash-nav {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 6px;
  }

  .dash-actions-grid,
  .dash-info-grid {
    grid-template-columns: 1fr;
  }

  .history-kpi-grid,
  .company-team-grid,
  .company-admin-grid,
  .admin-premium-grid,
  .admin-v2-grid,
  .admin-v2-summary-grid,
  .admin-v2-two-cols,
  .admin-top-summary-grid,
  .admin-plan-feature-grid,
  .admin-duo-grid,
  .admin-governance-grid,
  .company-bottom-grid,
  .team-plan-grid,
  .company-setup-grid {
    grid-template-columns: 1fr;
  }

  .history-card-head,
  .company-card-head {
    flex-direction: column;
    align-items: flex-start;
  }

  .history-table-wrapper,
  .company-table-wrapper {
    max-height: 300px;
  }

  .admin-premium-header {
    flex-direction: column;
    align-items: flex-start;
  }

  .admin-v2-header {
    flex-direction: column;
    align-items: flex-start;
  }

  .admin-premium-header-right {
    width: 100%;
    justify-content: space-between;
  }

  .admin-v2-header-right {
    width: 100%;
    justify-content: space-between;
  }

  .admin-top-summary-head {
    flex-direction: column;
  }

  .admin-context-stack {
    position: static;
  }

  .admin-v2-summary-head {
    flex-direction: column;
  }

  .admin-v2-side {
    position: static;
  }

  .admin-action-row {
    flex-direction: column;
    align-items: stretch;
  }

  .admin-action-row .inline-field {
    min-width: 0;
    flex: 1 1 auto;
  }

  .admin-v2-actions {
    flex-direction: column;
    align-items: stretch;
  }

  .admin-v2-field {
    min-width: 0;
    flex: 1 1 auto;
  }

  .admin-v2-finance-item {
    flex-direction: column;
    align-items: flex-start;
  }

  .admin-v2-finance-right {
    text-align: left;
  }

  .admin-v2-modal {
    padding: 12px;
  }

  .admin-v2-modal-card {
    padding: 14px;
    border-radius: 20px;
  }

  .admin-v2-plan-options {
    grid-template-columns: 1fr;
  }

  .admin-v2-modal-footer {
    flex-direction: column-reverse;
    align-items: stretch;
  }

  .admin-v2-modal-footer > button {
    width: 100%;
  }

  .admin-v2-toast-container {
    top: 12px;
    right: 12px;
  }

  .team-header-card {
    flex-direction: column;
  }

  .team-header-right {
    width: 100%;
    justify-content: space-between;
  }

  .team-member-form-grid {
    grid-template-columns: 1fr;
  }

  .team-context-stack {
    position: static;
  }

  .login-card {
    border-radius: 24px;
    padding: 22px;
  }

  .landing-top {
    flex-direction: column;
    align-items: flex-start;
  }

  .landing-auth-actions {
    width: 100%;
  }

  .landing-auth-actions .link-btn {
    flex: 1 1 calc(50% - 6px);
  }

  .landing-hero-grid,
  .lp-info-grid,
  .lp-cta-section {
    grid-template-columns: 1fr;
  }

  .lp-preview-head {
    flex-direction: column;
  }

  .lp-preview-group {
    text-align: left;
  }

  .lp-stats-grid {
    grid-template-columns: 1fr;
  }

  .marketing-hero {
    grid-template-columns: 1fr;
  }

  .hero-side {
    border-left: 0;
    border-top: 1px dashed #c8d7e1;
    padding-left: 0;
    padding-top: 10px;
  }

  .wizard-steps {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .connect-top-grid,
  .connect-bottom-grid {
    grid-template-columns: 1fr;
  }

  .connect-page-header {
    flex-direction: column;
    align-items: flex-start;
  }

  .connect-page-user {
    width: 100%;
    justify-content: space-between;
  }

  .connect-page-user strong,
  .connect-page-user small {
    text-align: left;
  }

  .connect-page .wizard-steps {
    display: grid;
    grid-template-columns: 1fr;
    gap: 8px;
  }

  .connect-page .wizard-step {
    min-width: 0;
    width: 100%;
    justify-content: flex-start;
  }

  .connect-page .connect-step-line {
    display: none;
  }

  .connect-qr-stage {
    min-height: 300px;
  }

  .after-qr-top {
    flex-direction: column;
  }

  .after-qr-back {
    width: 100%;
  }

  .after-qr-search-wrap {
    grid-template-columns: 1fr;
  }

  .after-qr-search-wrap .secondary {
    width: 100%;
  }

  .after-qr-detected-grid {
    grid-template-columns: 1fr;
  }

  .after-qr-detected-list {
    max-height: 280px;
  }

  .message-stage-grid {
    grid-template-columns: 1fr;
  }

  .message-remetente-grid,
  .message-config-grid {
    grid-template-columns: 1fr;
  }

  .message-report-tags {
    max-height: 220px;
  }

  .review-stage-panel .review-stage-top {
    grid-template-columns: 1fr;
  }

  .review-preflight-grid {
    grid-template-columns: 1fr;
  }

  .review-report-mode-grid {
    grid-template-columns: 1fr;
  }

  .review-report-config-grid {
    grid-template-columns: 1fr;
  }

  .review-report-tags {
    max-height: 220px;
    display: grid;
    overflow-y: auto;
    overflow-x: hidden;
    white-space: normal;
  }

  .review-stage-card,
  .review-summary-card,
  .review-confirm-card,
  .review-flow-card {
    padding: 16px;
    border-radius: 22px;
  }

  .review-report-card {
    min-height: auto;
  }

  .review-run-monitor {
    padding: 14px;
  }

  .review-summary-sticky {
    position: static;
  }

  .review-flow-footer {
    flex-direction: row;
    gap: 8px;
  }

  .review-flow-footer button {
    flex: 1 1 calc(50% - 4px);
    min-width: 0;
  }

  .execution-stage-top {
    grid-template-columns: 1fr;
  }

  .execution-stats-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .execution-main-grid {
    grid-template-columns: 1fr;
  }

  .execution-log-card,
  .execution-summary-card,
  .execution-report-card {
    padding: 16px;
    border-radius: 22px;
  }

  .execution-log-card {
    height: auto;
    min-height: auto;
    max-height: none;
  }

  .execution-log-list {
    max-height: 300px;
  }

  .session-recovery-overlay {
    padding: 14px;
  }

  .session-recovery-card {
    border-radius: 22px;
    padding: 16px;
  }

  .session-recovery-body {
    grid-template-columns: 1fr;
  }

  .session-recovery-qr {
    min-height: 220px;
  }

  .after-qr-safe-title {
    font-size: 16px;
  }

  #step-panel-2 .after-qr-group-list {
    max-height: 300px;
  }

  .wizard-panel .wizard-footer {
    margin-left: -16px;
    margin-right: -16px;
    margin-bottom: -16px;
    padding-top: 12px;
    padding-bottom: 14px;
  }

  .wizard-panel .wizard-footer button,
  .wizard-panel .wizard-footer .link-btn {
    flex: 1 1 calc(50% - 8px);
  }

  .tag-selector {
    flex-wrap: nowrap;
    overflow-x: auto;
    white-space: nowrap;
  }

  .results-cards {
    display: grid;
  }

  .wizard .table-wrapper {
    display: none;
  }
}

/* ========= Empresa e Equipe (Espelho Premium) ========= */
.company-premium-body {
  margin: 0;
  min-height: 100vh;
  color: #1e293b;
  background:
    radial-gradient(circle at top, rgba(99, 102, 241, 0.12), transparent 38%),
    linear-gradient(180deg, #f8fafc 0%, #eef2ff 52%, #f8fafc 100%);
}

.company-premium-wrap {
  width: min(1120px, calc(100% - 40px));
  margin: 24px auto 34px;
}

.company-premium-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
  margin-bottom: 16px;
  padding: 18px 22px;
  border-radius: 18px;
  border: 1px solid rgba(255, 255, 255, 0.7);
  background: rgba(255, 255, 255, 0.82);
  box-shadow: 0 8px 24px rgba(15, 23, 42, 0.08);
  backdrop-filter: blur(8px);
}

.company-premium-kicker {
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  background: #eef2ff;
  color: #4338ca;
  padding: 6px 11px;
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 0.05em;
  text-transform: uppercase;
}

.company-premium-header h1 {
  margin: 10px 0 0;
  font-size: clamp(1.75rem, 3vw, 2.15rem);
  line-height: 1.12;
}

.company-premium-header .muted {
  margin: 8px 0 0;
  max-width: 640px;
}

.company-premium-header-right {
  display: flex;
  align-items: center;
  gap: 16px;
}

.company-premium-back {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  height: 42px;
  border-radius: 12px;
  border: 1px solid #d5deef;
  background: #fff;
  color: #334155;
  font-weight: 700;
  text-decoration: none;
  padding: 0 16px;
}

.company-premium-back:hover {
  background: #f8fafc;
}

.company-premium-user {
  text-align: right;
}

.company-premium-user-name {
  margin: 0;
  font-weight: 700;
}

.company-premium-user .muted {
  margin: 2px 0 0;
}

.company-premium-summary {
  border-radius: 24px;
  border: 1px solid rgba(255, 255, 255, 0.7);
  background: rgba(255, 255, 255, 0.85);
  box-shadow: 0 10px 26px rgba(15, 23, 42, 0.08);
  backdrop-filter: blur(8px);
  padding: 20px;
  margin-bottom: 16px;
}

.company-premium-summary-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  margin-bottom: 14px;
}

.company-premium-summary-head h2 {
  margin: 0;
  font-size: 1.38rem;
}

.company-premium-summary-head .muted {
  margin: 6px 0 0;
}

.company-premium-status-pill {
  border-radius: 999px;
  border: 1px solid #bbf7d0;
  background: #f0fdf4;
  color: #15803d;
  font-size: 0.84rem;
  font-weight: 700;
  padding: 7px 12px;
}

.company-premium-status-pill.account-status-active {
  border-color: #bbf7d0;
  background: #f0fdf4;
  color: #15803d;
}

.company-premium-status-pill.account-status-readonly {
  border-color: #fcd34d;
  background: #fffbeb;
  color: #a16207;
}

.company-premium-summary-grid {
  display: grid;
  gap: 12px;
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.company-premium-summary-card {
  border-radius: 16px;
  border: 1px solid #dce3ef;
  background: rgba(248, 250, 252, 0.86);
  padding: 14px;
}

.company-premium-summary-label {
  color: #64748b;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  font-weight: 700;
}

.company-premium-summary-value {
  margin-top: 6px;
  font-weight: 800;
  color: #0f172a;
  font-size: 1.04rem;
}

.company-premium-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(300px, 0.8fr);
  gap: 16px;
  align-items: stretch;
}

.company-premium-main,
.company-premium-side {
  display: flex;
  flex-direction: column;
  gap: 16px;
  justify-content: flex-start;
  height: 100%;
}

.company-premium-members-card {
  display: flex;
  flex-direction: column;
  flex: 1 1 auto;
  min-height: 0;
}

.company-premium-card {
  border-radius: 24px;
  border: 1px solid rgba(255, 255, 255, 0.7);
  background: rgba(255, 255, 255, 0.85);
  box-shadow: 0 10px 26px rgba(15, 23, 42, 0.08);
  backdrop-filter: blur(8px);
  padding: 20px;
}

.company-premium-card h2,
.company-premium-card h3 {
  margin: 0;
}

.company-premium-card-head .muted {
  margin: 6px 0 0;
}

.company-premium-member-form {
  margin: 14px 0 8px;
  display: grid;
  grid-template-columns: minmax(0, 1fr) 220px 170px;
  gap: 12px;
}

.company-premium-member-form label {
  display: block;
  margin-bottom: 6px;
  font-size: 0.86rem;
  font-weight: 700;
  color: #334155;
}

.company-premium-member-form input,
.company-premium-member-form select {
  width: 100%;
  height: 46px;
  border-radius: 14px;
  border: 1px solid #dbe3f1;
  background: #fff;
  padding: 0 12px;
  font-size: 0.95rem;
  color: #0f172a;
}

.company-premium-member-form input:focus,
.company-premium-member-form select:focus {
  outline: none;
  border-color: #a5b4fc;
  box-shadow: 0 0 0 3px rgba(129, 140, 248, 0.16);
}

.company-premium-member-submit {
  display: flex;
  align-items: flex-end;
}

.company-premium-member-submit button {
  width: 100%;
  height: 46px;
  border: none;
  border-radius: 14px;
  background: linear-gradient(90deg, #4f46e5, #7c3aed);
  color: #fff;
  font-weight: 700;
  cursor: pointer;
  box-shadow: 0 8px 20px rgba(79, 70, 229, 0.25);
}

.company-premium-member-submit button:hover {
  filter: brightness(1.02);
}

.company-premium-table-wrap {
  margin-top: 10px;
  border-radius: 16px;
  border: 1px solid #dbe3f1;
  overflow: auto;
  background: #fff;
}

.company-premium-members-card .company-premium-table-wrap {
  flex: 1 1 auto;
  min-height: 180px;
  max-height: clamp(240px, 44vh, 560px);
}

.company-premium-table {
  width: 100%;
  border-collapse: collapse;
  min-width: 700px;
}

.company-premium-table thead th {
  background: #f8fafc;
  color: #64748b;
  font-size: 11px;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  font-weight: 800;
  text-align: left;
  border-bottom: 1px solid #e2e8f0;
  padding: 11px 14px;
}

.company-premium-table tbody td {
  padding: 12px 14px;
  border-bottom: 1px solid #f1f5f9;
  vertical-align: middle;
}

.company-premium-table tbody tr:last-child td {
  border-bottom: 0;
}

.company-premium-permissions-head .muted {
  margin: 6px 0 0;
}

.company-premium-permissions-list {
  margin-top: 12px;
  display: grid;
  gap: 10px;
}

.company-premium-permission-item {
  border-radius: 14px;
  border: 1px solid #dbe3f1;
  background: rgba(248, 250, 252, 0.86);
  padding: 12px;
}

.company-premium-permission-item strong {
  display: block;
  font-size: 0.97rem;
}

.company-premium-permission-item p {
  margin: 4px 0 0;
  color: #475569;
}

.company-premium-plan-card {
  border-radius: 24px;
  border: 1px solid #1e293b;
  background: #0f172a;
  color: #e2e8f0;
  box-shadow: 0 16px 32px rgba(15, 23, 42, 0.3);
  padding: 20px;
}

.company-premium-plan-card h2 {
  margin: 0;
  color: #fff;
  font-size: 1.45rem;
}

.company-premium-plan-card .muted,
.company-premium-plan-card .company-premium-readonly-reason {
  color: #94a3b8;
}

.company-premium-plan-grid {
  margin-top: 12px;
  display: grid;
  gap: 10px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.company-premium-plan-grid > div {
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.08);
  padding: 11px;
}

.company-premium-plan-label {
  margin: 0;
  color: #cbd5e1;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  font-weight: 700;
}

.company-premium-plan-value {
  margin: 6px 0 0;
  color: #fff;
  font-size: 1rem;
  font-weight: 800;
}

.company-premium-plan-note {
  margin-top: 12px;
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.09);
  color: #e2e8f0;
  padding: 12px;
  line-height: 1.45;
}

.company-premium-readonly-reason {
  margin-top: 10px;
}

.company-premium-admin-btn {
  margin-top: 12px;
  width: 100%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 44px;
  border-radius: 14px;
  text-decoration: none;
  font-weight: 700;
  border: 1px solid rgba(255, 255, 255, 0.2);
  background: #ffffff;
  color: #0f172a;
}

.company-premium-admin-btn:hover {
  background: #f8fafc;
}

.company-premium-admin-locked {
  margin-top: 12px;
}

.company-premium-danger-card {
  border-color: #fecaca;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.95), rgba(254, 242, 242, 0.9));
}

.company-premium-danger-card .muted {
  margin: 8px 0 0;
}

.company-premium-danger-list {
  margin-top: 10px;
  display: grid;
  gap: 8px;
}

.company-premium-danger-list p {
  margin: 0;
  border-radius: 12px;
  border: 1px solid #fecaca;
  background: #fff7f7;
  color: #7f1d1d;
  padding: 11px;
}

.company-premium-danger-card label {
  display: block;
  margin-top: 12px;
  margin-bottom: 6px;
  font-size: 0.86rem;
  font-weight: 700;
  color: #7f1d1d;
}

.company-premium-danger-card input {
  width: 100%;
  height: 44px;
  border-radius: 12px;
  border: 1px solid #fca5a5;
  background: #fff;
  padding: 0 12px;
  font-size: 0.94rem;
  color: #0f172a;
}

.company-premium-danger-card input:focus {
  outline: none;
  border-color: #ef4444;
  box-shadow: 0 0 0 3px rgba(239, 68, 68, 0.16);
}

.company-premium-delete-btn {
  margin-top: 10px;
  width: 100%;
  min-height: 44px;
  border: 1px solid #ef4444;
  border-radius: 12px;
  background: #dc2626;
  color: #fff;
  font-weight: 700;
  cursor: pointer;
}

.company-premium-delete-btn:hover:not(:disabled) {
  background: #b91c1c;
}

.company-premium-delete-btn:disabled {
  opacity: 0.55;
  cursor: not-allowed;
}

.company-premium-scope-list {
  margin-top: 10px;
  display: grid;
  gap: 8px;
}

.company-premium-scope-list p {
  margin: 0;
  border-radius: 12px;
  background: #f8fafc;
  padding: 11px;
  color: #334155;
}

.table-role-chip {
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  background: #eef2ff;
  color: #4338ca;
  font-size: 12px;
  font-weight: 700;
  padding: 5px 10px;
}

.table-status-chip {
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 700;
  padding: 5px 10px;
}

.table-status-active {
  color: #047857;
  background: #ecfdf5;
}

.table-status-pending {
  color: #a16207;
  background: #fefce8;
}

.table-row-actions {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}

.table-link-action {
  appearance: none;
  border: none;
  background: transparent;
  color: #475569;
  font-size: 0.88rem;
  font-weight: 700;
  cursor: pointer;
  padding: 0;
}

.table-link-action:hover {
  color: #0f172a;
}

.table-link-action.remove {
  color: #e11d48;
}

.table-link-action.remove:hover {
  color: #be123c;
}

@media (max-width: 1080px) {
  .company-premium-grid {
    grid-template-columns: 1fr;
  }

  .company-premium-side {
    position: static;
  }

  .company-premium-main,
  .company-premium-side {
    justify-content: flex-start;
    height: auto;
  }

  .company-premium-members-card {
    flex: 0 0 auto;
  }

  .company-premium-members-card .company-premium-table-wrap {
    max-height: 360px;
  }
}

@media (max-width: 860px) {
  .company-premium-wrap {
    width: min(1120px, calc(100% - 20px));
    margin-top: 12px;
  }

  .company-premium-header,
  .company-premium-summary,
  .company-premium-card,
  .company-premium-plan-card {
    padding: 14px;
  }

  .company-premium-header {
    flex-direction: column;
    align-items: stretch;
  }

  .company-premium-header-right {
    justify-content: space-between;
  }

  .company-premium-summary-grid {
    grid-template-columns: 1fr;
  }

  .company-premium-member-form {
    grid-template-columns: 1fr;
  }

  .company-premium-plan-grid {
    grid-template-columns: 1fr;
  }
}

/* ========= Platform Admin ========= */
.platform-admin-body {
  margin: 0;
  min-height: 100vh;
  color: #1e293b;
  background:
    radial-gradient(circle at top, rgba(99, 102, 241, 0.12), transparent 38%),
    linear-gradient(180deg, #f8fafc 0%, #eef2ff 52%, #f8fafc 100%);
}

.platform-admin-wrap {
  width: min(1240px, calc(100% - 34px));
  margin: 18px auto 30px;
}

.platform-admin-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  border-radius: 18px;
  border: 1px solid rgba(255, 255, 255, 0.72);
  background: rgba(255, 255, 255, 0.84);
  box-shadow: 0 10px 28px rgba(15, 23, 42, 0.09);
  backdrop-filter: blur(8px);
  padding: 18px 22px;
}

.platform-admin-kicker {
  margin: 0;
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  background: #eef2ff;
  color: #4338ca;
  padding: 6px 10px;
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 0.05em;
  text-transform: uppercase;
}

.platform-admin-header h1 {
  margin: 8px 0 0;
  font-size: clamp(1.86rem, 3vw, 2.4rem);
  line-height: 1.1;
}

.platform-admin-header .muted {
  margin: 8px 0 0;
}

.platform-admin-header-right {
  display: flex;
  align-items: center;
  gap: 16px;
}

.platform-admin-back {
  min-height: 42px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 12px;
  border: 1px solid #d7e0f1;
  background: #fff;
  color: #334155;
  font-weight: 700;
  padding: 0 16px;
  text-decoration: none;
}

.platform-admin-back:hover {
  background: #f8fafc;
}

.platform-admin-user-name {
  margin: 0;
  text-align: right;
  font-weight: 800;
}

.platform-admin-user .muted {
  margin: 2px 0 0;
  text-align: right;
}

.platform-admin-summary {
  margin-top: 14px;
  display: grid;
  gap: 10px;
  grid-template-columns: repeat(6, minmax(0, 1fr));
}

.platform-admin-summary-card {
  border-radius: 14px;
  border: 1px solid #dbe3f1;
  background: rgba(255, 255, 255, 0.86);
  padding: 12px;
  box-shadow: 0 7px 20px rgba(15, 23, 42, 0.06);
}

.platform-admin-summary-label {
  margin: 0;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: #64748b;
  font-weight: 800;
}

.platform-admin-summary-card strong {
  display: block;
  margin-top: 7px;
  font-size: 1.22rem;
  color: #0f172a;
}

.platform-admin-grid {
  margin-top: 14px;
  display: grid;
  gap: 14px;
  grid-template-columns: minmax(0, 1.25fr) minmax(360px, 0.75fr);
  align-items: start;
}

.platform-admin-main,
.platform-admin-side {
  display: grid;
  gap: 14px;
}

.platform-admin-side {
  position: sticky;
  top: 14px;
}

.platform-admin-card {
  border-radius: 18px;
  border: 1px solid rgba(255, 255, 255, 0.74);
  background: rgba(255, 255, 255, 0.86);
  box-shadow: 0 8px 24px rgba(15, 23, 42, 0.08);
  padding: 16px;
}

.platform-admin-card-strong {
  border-color: #d4dcf0;
  background:
    radial-gradient(circle at top right, rgba(99, 102, 241, 0.12), transparent 44%),
    rgba(255, 255, 255, 0.88);
}

.platform-admin-card h2,
.platform-admin-card h3 {
  margin: 0;
}

.platform-admin-card .muted {
  margin: 7px 0 0;
}

.platform-admin-card-head {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 14px;
  margin-bottom: 10px;
}

.platform-admin-inline {
  display: flex;
  align-items: center;
  gap: 8px;
  min-width: 340px;
}

.platform-admin-inline input {
  height: 40px;
}

.platform-admin-inline button {
  min-height: 40px;
  white-space: nowrap;
}

.platform-admin-card label {
  display: block;
  margin-top: 10px;
  margin-bottom: 6px;
  font-size: 0.86rem;
  font-weight: 700;
  color: #334155;
}

.platform-admin-card input,
.platform-admin-card select,
.platform-admin-card textarea {
  width: 100%;
  border: 1px solid #dbe3f1;
  border-radius: 12px;
  background: #fff;
  color: #0f172a;
  padding: 10px 12px;
}

.platform-admin-card textarea {
  resize: vertical;
  min-height: 84px;
}

.platform-admin-card input:focus,
.platform-admin-card select:focus,
.platform-admin-card textarea:focus {
  outline: none;
  border-color: #a5b4fc;
  box-shadow: 0 0 0 3px rgba(129, 140, 248, 0.14);
}

.platform-admin-checkbox {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-top: 10px;
  font-size: 0.92rem;
}

.platform-admin-checkbox input {
  width: 16px;
  height: 16px;
  margin: 0;
  border-radius: 4px;
  padding: 0;
}

.platform-admin-actions {
  margin-top: 12px;
  display: grid;
  gap: 8px;
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.platform-admin-actions button {
  min-height: 42px;
  border-radius: 12px;
}

.platform-admin-actions .danger {
  background: #dc2626;
  border: 1px solid #dc2626;
}

.platform-admin-actions .danger:hover {
  background: #b91c1c;
}

.platform-admin-table-wrap {
  border-radius: 14px;
  border: 1px solid #dbe3f1;
  background: #fff;
  overflow: auto;
  max-height: 400px;
}

.platform-admin-table-wrap.compact {
  max-height: 220px;
}

.platform-admin-table {
  width: 100%;
  min-width: 760px;
  border-collapse: collapse;
}

.platform-admin-table.compact {
  min-width: 0;
}

.platform-admin-table thead th {
  background: #f8fafc;
  color: #64748b;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  font-weight: 800;
  text-align: left;
  border-bottom: 1px solid #e2e8f0;
  padding: 10px 11px;
}

.platform-admin-table tbody td {
  border-bottom: 1px solid #f1f5f9;
  padding: 10px 11px;
  vertical-align: top;
}

.platform-admin-table tbody tr:last-child td {
  border-bottom: 0;
}

.platform-admin-table tbody tr.is-selected {
  background: #eef2ff;
}

.platform-admin-table tbody tr:hover {
  background: #f8fafc;
  cursor: pointer;
}

.platform-admin-toast-container {
  position: fixed;
  top: 14px;
  right: 14px;
  z-index: 2100;
  display: grid;
  gap: 8px;
}

.platform-admin-toast {
  min-width: 260px;
  max-width: min(420px, calc(100vw - 28px));
  border-radius: 11px;
  border: 1px solid #c7d2fe;
  background: #eef2ff;
  color: #3730a3;
  font-size: 0.92rem;
  font-weight: 700;
  padding: 10px 12px;
  box-shadow: 0 10px 24px rgba(79, 70, 229, 0.18);
  opacity: 0;
  transform: translateY(-9px);
  transition: opacity 0.2s ease, transform 0.2s ease;
}

.platform-admin-toast.is-error {
  border-color: #fecaca;
  background: #fff1f2;
  color: #be123c;
}

.platform-admin-toast.is-visible {
  opacity: 1;
  transform: translateY(0);
}

.platform-admin-toast.is-hiding {
  opacity: 0;
  transform: translateY(-9px);
}

@media (max-width: 1160px) {
  .platform-admin-summary {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .platform-admin-grid {
    grid-template-columns: 1fr;
  }

  .platform-admin-side {
    position: static;
  }
}

@media (max-width: 860px) {
  .platform-admin-wrap {
    width: min(1240px, calc(100% - 18px));
  }

  .platform-admin-header {
    flex-direction: column;
    align-items: stretch;
  }

  .platform-admin-header-right {
    justify-content: space-between;
  }

  .platform-admin-user-name,
  .platform-admin-user .muted {
    text-align: left;
  }

  .platform-admin-summary {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .platform-admin-card-head {
    flex-direction: column;
    align-items: stretch;
  }

  .platform-admin-inline {
    min-width: 0;
    width: 100%;
    flex-direction: column;
    align-items: stretch;
  }

  .platform-admin-actions {
    grid-template-columns: 1fr;
  }
}

/* ========= Super Admin (Espelho Premium) ========= */
.sa-body {
  margin: 0;
  min-height: 100vh;
  color: #1e293b;
  background:
    radial-gradient(circle at top, rgba(99, 102, 241, 0.12), transparent 38%),
    linear-gradient(180deg, #f8fafc 0%, #eef2ff 52%, #f8fafc 100%);
}

.sa-shell {
  width: min(1240px, calc(100% - 38px));
  margin: 16px auto 28px;
}

.sa-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 18px;
  padding: 18px 22px;
  border-radius: 22px;
  border: 1px solid rgba(255, 255, 255, 0.72);
  background: rgba(255, 255, 255, 0.84);
  box-shadow: 0 10px 28px rgba(15, 23, 42, 0.09);
  backdrop-filter: blur(10px);
}

.sa-kicker {
  margin: 0;
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  background: #eef2ff;
  color: #4338ca;
  padding: 6px 12px;
  font-size: 11px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.sa-header h1 {
  margin: 10px 0 0;
  font-size: clamp(1.9rem, 3.1vw, 2.55rem);
  line-height: 1.08;
}

.sa-subtitle {
  margin: 8px 0 0;
  color: #64748b;
  max-width: 640px;
}

.sa-header-right {
  display: flex;
  align-items: center;
  gap: 16px;
}

.sa-back-btn {
  min-height: 42px;
  border-radius: 12px;
  border: 1px solid #d7e0f1;
  background: #fff;
  color: #334155;
  padding: 0 16px;
  font-weight: 700;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  text-decoration: none;
}

.sa-back-btn:hover {
  background: #f8fafc;
}

.sa-user-info {
  text-align: right;
}

.sa-user-name {
  margin: 0;
  font-weight: 800;
}

.sa-user-role {
  margin: 2px 0 0;
  color: #64748b;
  font-size: 0.86rem;
}

.sa-sections-grid {
  margin-top: 14px;
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
}

.sa-section-card {
  border-radius: 22px;
  border: 1px solid rgba(255, 255, 255, 0.75);
  background: rgba(255, 255, 255, 0.86);
  box-shadow: 0 8px 24px rgba(15, 23, 42, 0.07);
  padding: 14px;
}

.sa-section-card h2 {
  margin: 9px 0 0;
  font-size: 1.05rem;
}

.sa-section-card p {
  margin: 6px 0 0;
  color: #64748b;
  line-height: 1.5;
  font-size: 0.92rem;
}

.sa-section-icon {
  width: 44px;
  height: 44px;
  border-radius: 14px;
  display: grid;
  place-items: center;
  color: #4f46e5;
  background: #e0e7ff;
}

.sa-section-icon svg {
  width: 20px;
  height: 20px;
}

.sa-section-icon.small {
  width: 40px;
  height: 40px;
  border-radius: 12px;
}

.sa-content-grid {
  margin-top: 14px;
  display: grid;
  gap: 14px;
  grid-template-columns: minmax(0, 1.25fr) minmax(0, 0.75fr);
  align-items: start;
}

.sa-left-col,
.sa-right-col {
  display: grid;
  gap: 14px;
}

.sa-right-col {
  position: sticky;
  top: 14px;
}

.sa-panel {
  border-radius: 22px;
  border: 1px solid rgba(255, 255, 255, 0.72);
  background: rgba(255, 255, 255, 0.86);
  box-shadow: 0 8px 24px rgba(15, 23, 42, 0.08);
  padding: 16px;
}

.sa-panel-head {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 12px;
}

.sa-panel h2,
.sa-panel h3 {
  margin: 0;
}

.sa-panel-head p,
.sa-card-title-wrap p {
  margin: 6px 0 0;
  color: #64748b;
}

.sa-btn-primary,
.sa-btn-ghost,
.sa-btn-danger,
.sa-user-card-actions button {
  min-height: 42px;
  border-radius: 12px;
  padding: 0 14px;
  font-weight: 700;
}

.sa-btn-primary {
  border: none;
  color: #fff;
  background: linear-gradient(90deg, #4f46e5, #7c3aed);
  box-shadow: 0 10px 24px rgba(79, 70, 229, 0.24);
}

.sa-btn-primary:hover {
  filter: brightness(1.02);
}

.sa-btn-ghost {
  border: 1px solid #dbe3f1;
  background: #fff;
  color: #334155;
}

.sa-btn-ghost:hover {
  background: #f8fafc;
}

.sa-btn-danger {
  border: 1px solid #dc2626;
  background: #dc2626;
  color: #fff;
}

.sa-btn-danger:hover {
  background: #b91c1c;
}

.sa-companies-toolbar {
  display: grid;
  gap: 10px;
  grid-template-columns: minmax(0, 1fr) 170px 190px;
  margin-bottom: 12px;
}

.sa-search-wrap {
  display: flex;
  align-items: center;
  gap: 8px;
  border-radius: 14px;
  border: 1px solid #dbe3f1;
  background: #fff;
  padding: 0 12px;
  min-height: 42px;
}

.sa-search-wrap svg {
  width: 15px;
  height: 15px;
  color: #94a3b8;
  flex-shrink: 0;
}

.sa-search-wrap input,
.sa-user-actions-toolbar input,
.sa-panel select,
.sa-panel textarea,
.sa-panel input {
  width: 100%;
  border: 1px solid #dbe3f1;
  border-radius: 12px;
  background: #fff;
  color: #0f172a;
}

.sa-search-wrap input {
  border: none;
  border-radius: 0;
  padding: 0;
  min-height: 20px;
}

.sa-search-wrap input:focus {
  outline: none;
}

.sa-user-actions-toolbar input,
.sa-panel select,
.sa-panel input {
  min-height: 42px;
  padding: 0 12px;
}

.sa-panel textarea {
  min-height: 90px;
  resize: vertical;
  padding: 10px 12px;
}

.sa-user-actions-toolbar input:focus,
.sa-panel select:focus,
.sa-panel input:focus,
.sa-panel textarea:focus {
  outline: none;
  border-color: #a5b4fc;
  box-shadow: 0 0 0 3px rgba(129, 140, 248, 0.14);
}

.sa-table-grid-head {
  display: grid;
  grid-template-columns: 1.2fr 1fr 0.7fr 0.7fr 0.7fr 0.7fr 0.38fr;
  gap: 10px;
  border-radius: 12px 12px 0 0;
  border: 1px solid #dbe3f1;
  border-bottom: 1px solid #e2e8f0;
  background: #f8fafc;
  padding: 10px 12px;
  color: #64748b;
  font-size: 11px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.sa-table-grid-body {
  border: 1px solid #dbe3f1;
  border-top: none;
  border-radius: 0 0 12px 12px;
  background: #fff;
  overflow: auto;
  max-height: 410px;
}

.sa-empty-row {
  padding: 16px;
  color: #64748b;
}

.sa-company-row {
  display: grid;
  grid-template-columns: 1.2fr 1fr 0.7fr 0.7fr 0.7fr 0.7fr 0.38fr;
  gap: 10px;
  align-items: center;
  padding: 12px;
  border-bottom: 1px solid #f1f5f9;
  font-size: 0.92rem;
}

.sa-company-row:last-child {
  border-bottom: none;
}

.sa-company-row.is-selected {
  background: #eef2ff;
}

.sa-company-row:hover {
  background: #f8fafc;
  cursor: pointer;
}

.sa-company-row strong {
  display: block;
  color: #0f172a;
}

.sa-company-row small {
  display: block;
  margin-top: 3px;
  color: #64748b;
}

.sa-row-menu-btn {
  border: none;
  background: transparent;
  color: #64748b;
  width: 32px;
  height: 32px;
  border-radius: 10px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
}

.sa-row-menu-btn:hover {
  background: #f1f5f9;
}

.sa-chip {
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  padding: 5px 10px;
  font-size: 11px;
  font-weight: 800;
}

.sa-chip.indigo {
  background: #eef2ff;
  color: #4338ca;
}

.sa-chip.success {
  background: #ecfdf5;
  color: #047857;
}

.sa-chip.danger {
  background: #fff1f2;
  color: #be123c;
}

.sa-bottom-grid {
  display: grid;
  gap: 14px;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
}

.sa-card-title-wrap {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  margin-bottom: 10px;
}

.sa-user-actions-toolbar {
  display: grid;
  gap: 10px;
  grid-template-columns: minmax(0, 1fr) 120px;
}

.sa-users-list {
  margin-top: 10px;
  display: grid;
  gap: 10px;
  max-height: 420px;
  overflow: auto;
}

.sa-user-empty {
  color: #64748b;
  padding: 8px 0;
}

.sa-user-card {
  border-radius: 14px;
  border: 1px solid #dbe3f1;
  background: #f8fafc;
  padding: 12px;
}

.sa-user-card-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 10px;
}

.sa-user-card-name {
  margin: 0;
  font-weight: 800;
  color: #0f172a;
}

.sa-user-card-email {
  margin: 4px 0 0;
  color: #475569;
}

.sa-user-card-company {
  margin: 5px 0 0;
  color: #64748b;
  font-size: 0.83rem;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.sa-user-card-meta p {
  margin: 0;
  text-align: right;
  font-weight: 800;
}

.sa-user-card-meta small {
  display: block;
  margin-top: 3px;
  text-align: right;
  font-size: 0.82rem;
  font-weight: 700;
}

.sa-user-card-meta small.ok {
  color: #047857;
}

.sa-user-card-meta small.warn {
  color: #a16207;
}

.sa-user-card-actions {
  margin-top: 10px;
  display: grid;
  gap: 8px;
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.sa-user-card-actions button {
  border: 1px solid #dbe3f1;
  background: #fff;
  color: #334155;
}

.sa-user-card-actions button:hover {
  background: #f8fafc;
}

.sa-user-card-actions button.danger {
  border-color: #fecaca;
  background: #fff1f2;
  color: #be123c;
}

.sa-user-card-actions button.danger:hover {
  background: #ffe4e6;
}

.sa-panel label {
  display: block;
  margin-top: 10px;
  margin-bottom: 6px;
  color: #334155;
  font-size: 0.86rem;
  font-weight: 700;
}

.sa-duo-grid {
  display: grid;
  gap: 10px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.sa-actions-grid {
  margin-top: 10px;
  display: grid;
  gap: 8px;
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.sa-summary-card {
  border-radius: 22px;
  background: #0f172a;
  color: #e2e8f0;
  box-shadow: 0 16px 34px rgba(15, 23, 42, 0.3);
  padding: 16px;
}

.sa-summary-card h2 {
  margin: 0;
  color: #fff;
  font-size: 1.5rem;
}

.sa-summary-card p {
  margin: 6px 0 0;
  color: #94a3b8;
}

.sa-summary-list {
  margin-top: 12px;
  display: grid;
  gap: 10px;
}

.sa-summary-item {
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.1);
  padding: 11px 12px;
}

.sa-summary-item span {
  display: block;
  color: #cbd5e1;
  font-size: 0.8rem;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  font-weight: 700;
}

.sa-summary-item strong {
  display: block;
  margin-top: 5px;
  color: #fff;
  font-size: 1.12rem;
}

.sa-quick-actions {
  display: grid;
  gap: 8px;
  margin-top: 10px;
}

.sa-quick-btn {
  width: 100%;
  min-height: 44px;
  border-radius: 12px;
  border: 1px solid #dbe3f1;
  background: #f8fafc;
  color: #334155;
  font-weight: 700;
  display: inline-flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 12px;
  cursor: pointer;
}

.sa-quick-btn:hover {
  background: #fff;
}

.sa-warning-panel {
  border-color: #fcd34d;
  background: #fffbeb;
}

.sa-warning-head {
  display: flex;
  align-items: center;
  gap: 8px;
}

.sa-warning-head h3 {
  margin: 0;
}

.sa-warning-head svg {
  width: 16px;
  height: 16px;
  color: #b45309;
}

.sa-warning-panel p {
  margin: 8px 0 0;
  color: #7c2d12;
  line-height: 1.55;
}

.sa-mini-table-wrap {
  border-radius: 12px;
  border: 1px solid #dbe3f1;
  background: #fff;
  overflow: auto;
  max-height: 340px;
  margin-top: 10px;
}

.sa-mini-table {
  width: 100%;
  min-width: 420px;
  border-collapse: collapse;
}

.sa-mini-table th {
  text-align: left;
  font-size: 11px;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: #64748b;
  background: #f8fafc;
  padding: 10px 11px;
  border-bottom: 1px solid #e2e8f0;
}

.sa-mini-table td {
  padding: 10px 11px;
  border-bottom: 1px solid #f1f5f9;
  color: #334155;
}

.sa-mini-table tr:last-child td {
  border-bottom: none;
}

.sa-toast-container {
  position: fixed;
  top: 14px;
  right: 14px;
  z-index: 2200;
  display: grid;
  gap: 8px;
}

.sa-toast {
  min-width: 260px;
  max-width: min(420px, calc(100vw - 28px));
  border-radius: 11px;
  border: 1px solid #c7d2fe;
  background: #eef2ff;
  color: #3730a3;
  font-size: 0.92rem;
  font-weight: 700;
  padding: 10px 12px;
  box-shadow: 0 10px 24px rgba(79, 70, 229, 0.18);
  opacity: 0;
  transform: translateY(-9px);
  transition: opacity 0.2s ease, transform 0.2s ease;
}

.sa-toast.is-error {
  border-color: #fecaca;
  background: #fff1f2;
  color: #be123c;
}

.sa-toast.is-visible {
  opacity: 1;
  transform: translateY(0);
}

.sa-toast.is-hiding {
  opacity: 0;
  transform: translateY(-9px);
}

@media (max-width: 1160px) {
  .sa-sections-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .sa-content-grid {
    grid-template-columns: 1fr;
  }

  .sa-right-col {
    position: static;
  }
}

@media (max-width: 900px) {
  .sa-shell {
    width: min(1240px, calc(100% - 18px));
  }

  .sa-header {
    flex-direction: column;
    align-items: stretch;
  }

  .sa-header-right {
    justify-content: space-between;
  }

  .sa-user-info {
    text-align: left;
  }

  .sa-companies-toolbar,
  .sa-user-actions-toolbar,
  .sa-bottom-grid,
  .sa-duo-grid,
  .sa-actions-grid,
  .sa-user-card-actions {
    grid-template-columns: 1fr;
  }

  .sa-table-grid-head,
  .sa-company-row {
    grid-template-columns: 1fr 1fr;
  }
}

/* ========= Super Admin Ajustes de Fluxo (Stack + Modal) ========= */
.sa-content-grid {
  grid-template-columns: 1fr;
}

.sa-bottom-grid {
  grid-template-columns: 1fr;
}

.sa-right-col {
  position: static;
}

.sa-summary-card {
  border: 1px solid rgba(255, 255, 255, 0.72);
  background: rgba(255, 255, 255, 0.86);
  color: #1e293b;
  box-shadow: 0 8px 24px rgba(15, 23, 42, 0.08);
}

.sa-summary-card h2 {
  color: #0f172a;
}

.sa-summary-card p {
  color: #64748b;
}

.sa-summary-item {
  border: 1px solid #dbe3f1;
  background: #f8fafc;
}

.sa-summary-item span {
  color: #64748b;
}

.sa-summary-item strong {
  color: #0f172a;
}

.sa-modal {
  position: fixed;
  inset: 0;
  z-index: 2300;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 16px;
  background: rgba(15, 23, 42, 0.38);
}

.sa-modal.hidden {
  display: none;
}

.sa-modal-card {
  width: min(560px, 100%);
  border-radius: 18px;
  border: 1px solid #dbe3f1;
  background: #ffffff;
  box-shadow: 0 22px 45px rgba(15, 23, 42, 0.25);
  overflow: hidden;
}

.sa-modal-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding: 14px 16px;
  border-bottom: 1px solid #e2e8f0;
}

.sa-modal-head h3 {
  margin: 0;
  color: #0f172a;
}

.sa-modal-close {
  border: 1px solid #dbe3f1;
  background: #f8fafc;
  color: #334155;
  width: 34px;
  height: 34px;
  border-radius: 10px;
  font-weight: 700;
  font-size: 1.1rem;
  line-height: 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
}

.sa-modal-close:hover {
  background: #eef2f7;
}

.sa-modal-body {
  padding: 14px 16px;
  display: grid;
  gap: 10px;
}

.sa-modal-body p {
  margin: 0;
  color: #475569;
}

.sa-modal-body label {
  margin: 0;
  display: grid;
  gap: 6px;
  color: #334155;
  font-weight: 700;
  font-size: 0.9rem;
}

.sa-modal-body input,
.sa-modal-body select,
.sa-modal-body textarea {
  width: 100%;
  min-height: 42px;
  border-radius: 12px;
  border: 1px solid #dbe3f1;
  background: #fff;
  color: #0f172a;
  padding: 10px 12px;
}

.sa-modal-body textarea {
  min-height: 84px;
  resize: vertical;
}

.sa-modal-body input:focus,
.sa-modal-body select:focus,
.sa-modal-body textarea:focus {
  outline: none;
  border-color: #a5b4fc;
  box-shadow: 0 0 0 3px rgba(129, 140, 248, 0.14);
}

.sa-modal-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.sa-modal-muted {
  padding: 10px 12px;
  border: 1px solid #e2e8f0;
  background: #f8fafc;
  border-radius: 12px;
}

.sa-modal-actions {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 10px;
  padding: 12px 16px 16px;
  border-top: 1px solid #e2e8f0;
}

.sa-modal-actions .sa-btn-primary,
.sa-modal-actions .sa-btn-ghost,
.sa-modal-actions .sa-btn-danger {
  min-height: 40px;
}

.sa-modal-actions .sa-btn-danger {
  background: #dc2626;
  border-color: #dc2626;
  color: #fff;
}

.sa-modal-actions .sa-btn-danger:hover {
  background: #b91c1c;
}

@media (max-width: 900px) {
  .sa-modal-grid {
    grid-template-columns: 1fr;
  }
}

.message-wizard {
  max-width: 1220px;
}

.message-top-grid {
  display: grid;
  gap: 16px;
  grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
}

.message-top-card,
.message-panel {
  border: 1px solid #d9deeb;
  border-radius: 18px;
  background: #ffffff;
  padding: 18px;
}

.message-top-card h2,
.message-panel h2 {
  margin-bottom: 6px;
}

.message-main-grid {
  display: grid;
  gap: 16px;
  grid-template-columns: repeat(auto-fit, minmax(360px, 1fr));
}

.message-execution-grid {
  display: grid;
  gap: 16px;
  grid-template-columns: 1fr;
}

.message-meta-row {
  display: grid;
  gap: 12px;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
}

.message-template-row {
  display: grid;
  gap: 10px;
  grid-template-columns: 1fr auto;
  align-items: center;
}

.message-profile-summary-grid {
  margin-top: 12px;
  display: grid;
  gap: 10px;
  grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
}

.message-profile-summary-grid article {
  border: 1px solid #d9e0ee;
  border-radius: 12px;
  background: #f8fafc;
  padding: 10px 12px;
  display: grid;
  gap: 2px;
}

.message-profile-summary-grid small {
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: #64748b;
  font-weight: 700;
}

.message-profile-summary-grid strong {
  font-size: 14px;
  color: #1f2937;
}

.message-filter-card {
  border: 1px solid #d9e0ee;
  border-radius: 14px;
  background: #f8fafc;
  padding: 12px;
  display: grid;
  gap: 10px;
}

.message-filter-modes {
  display: grid;
  gap: 8px;
}

.message-filter-mode {
  display: flex;
  align-items: center;
  gap: 8px;
  border: 1px solid #d6deef;
  border-radius: 12px;
  background: #ffffff;
  padding: 10px 12px;
  color: #1e293b;
  font-size: 13px;
  font-weight: 700;
  cursor: pointer;
}

.message-filter-mode input {
  margin: 0;
  width: 16px;
  height: 16px;
  accent-color: #4f46e5;
}

.message-filter-range {
  display: grid;
  grid-template-columns: auto 1fr auto 1fr;
  gap: 8px;
  align-items: center;
}

.message-filter-range label {
  font-size: 11px;
  font-weight: 800;
  color: #64748b;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.message-filter-range input {
  margin: 0;
  min-height: 42px;
  border-radius: 12px;
  text-align: center;
  font-size: 1rem;
  font-weight: 800;
  text-transform: uppercase;
}

.message-filter-range input:disabled {
  background: #eef2f7;
  color: #94a3b8;
  cursor: not-allowed;
}

.message-field-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.message-field-chip {
  border: 1px solid #d6deef;
  border-radius: 999px;
  background: #ffffff;
  color: #334155;
  font-size: 12px;
  font-weight: 700;
  padding: 6px 10px;
  cursor: pointer;
  transition: border-color 0.2s ease, background 0.2s ease, color 0.2s ease;
}

.message-field-chip:hover {
  border-color: #94a3b8;
}

.message-field-chip.active {
  border-color: #4f46e5;
  background: #eef2ff;
  color: #3730a3;
}

.message-template-extra-wrap {
  margin-top: 12px;
  border: 1px solid #d9e0ee;
  border-radius: 14px;
  background: #f8fafc;
  padding: 10px;
}

.message-template-extra-vars {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 8px;
}

.message-check-inline {
  margin-top: 10px;
}

.message-detected-list {
  max-height: 320px;
  overflow: auto;
}

.message-panel-dark {
  background: #0a183e;
  border-color: #0a183e;
  color: #ffffff;
}

.message-panel-dark .muted,
.message-panel-dark .status-line,
.message-panel-dark small {
  color: #c8d3f2;
}

.counter-item {
  border: 1px solid #d9deeb;
  border-radius: 14px;
  padding: 10px 12px;
  background: #f8fafc;
  display: grid;
  gap: 2px;
}

.counter-item small {
  color: #64748b;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.02em;
  font-size: 11px;
}

.counter-item strong {
  font-family: "Sora", "Manrope", sans-serif;
  font-size: 1.25rem;
}

.message-panel-dark .counter-item {
  background: #1f2d55;
  border-color: #334276;
  color: #ffffff;
}

.message-panel-dark .counter-item small {
  color: #c8d3f2;
}

.message-run-logs {
  flex: 1 1 auto;
  min-height: 0;
  max-height: none;
  overflow-y: auto;
  overflow-x: hidden;
}

.message-run-logs .execution-log-item-main {
  align-items: center;
}

.message-run-logs .execution-log-icon {
  font-size: 12px;
  line-height: 1;
}

.message-toast-root {
  position: fixed;
  top: 16px;
  right: 16px;
  z-index: 12000;
  display: grid;
  gap: 8px;
}

.message-toast {
  min-width: 260px;
  max-width: 420px;
  padding: 12px 14px;
  border-radius: 12px;
  border: 1px solid #d9deeb;
  background: #ffffff;
  color: #1f2430;
  box-shadow: 0 10px 28px rgba(15, 23, 42, 0.14);
  transition: opacity 0.2s ease, transform 0.2s ease;
}

.message-toast.success {
  border-color: #8fd0ad;
}

.message-toast.error {
  border-color: #f4b4b4;
}

.message-toast.hide {
  opacity: 0;
  transform: translateY(-6px);
}

.meta-form-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 8px;
}

.meta-form-grid input,
.meta-form-grid select,
.meta-form-grid textarea {
  width: 100%;
}

.meta-conv-layout {
  align-items: flex-start;
  gap: 16px;
}

.meta-conv-list-col {
  min-width: 320px;
  max-width: 420px;
  flex: 1 1 320px;
}

.meta-conv-main-col {
  min-width: 420px;
  flex: 2 1 520px;
}

.meta-conv-item-btn {
  display: block;
  width: 100%;
  text-align: left;
  margin-bottom: 8px;
}

.meta-msg-item {
  border: 1px solid #d9deeb;
  border-radius: 12px;
  padding: 10px 12px;
  margin-bottom: 8px;
  background: #ffffff;
}

.meta-msg-chip {
  display: inline-block;
  font-size: 12px;
  border-radius: 999px;
  padding: 2px 8px;
  margin-right: 8px;
}

.meta-msg-chip.inbound {
  background: #e8f4ff;
  color: #195c9f;
}

.meta-msg-chip.outbound {
  background: #ecf8ef;
  color: #236c3e;
}

@media (max-width: 640px) {
  .message-filter-range {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .message-detected-filters-row {
    grid-template-columns: 1fr;
  }

  .message-contact-selection-row {
    flex-direction: column;
    align-items: stretch;
  }

  .message-contact-selection-actions {
    justify-content: flex-start;
  }
}

/* ========= Meta WhatsApp Exact Layout ========= */
.meta-exact-body {
  margin: 0;
  min-height: 100vh;
  padding: 0;
  font-family: "Manrope", "Segoe UI", sans-serif;
  color: #0f172a;
  background: #f1f5f9;
}

.meta-exact-layout {
  min-height: 100vh;
  display: flex;
}

.meta-exact-sidebar {
  width: 288px;
  border-right: 1px solid #e2e8f0;
  background: #ffffff;
  padding: 24px 20px;
  display: flex;
  flex-direction: column;
  gap: 18px;
}

.meta-exact-brand {
  display: flex;
  align-items: center;
  gap: 12px;
}

.meta-exact-brand-icon {
  width: 44px;
  height: 44px;
  border-radius: 14px;
  background: #2563eb;
  color: #ffffff;
  font-weight: 800;
  display: grid;
  place-items: center;
  box-shadow: 0 10px 24px rgba(37, 99, 235, 0.3);
}

.meta-exact-brand h1 {
  margin: 0;
  font-size: 1.12rem;
  font-weight: 900;
  letter-spacing: -0.02em;
}

.meta-exact-brand p {
  margin: 2px 0 0;
  font-size: 12px;
  color: #64748b;
  font-weight: 600;
}

.meta-exact-menu {
  display: grid;
  gap: 8px;
}

.meta-exact-menu-item {
  text-decoration: none;
  border-radius: 14px;
  padding: 11px 13px;
  font-size: 14px;
  font-weight: 800;
  color: #475569;
  border: 1px solid transparent;
  transition: background 0.2s ease, color 0.2s ease, border-color 0.2s ease;
}

.meta-exact-menu-item:hover {
  background: #f8fafc;
  border-color: #e2e8f0;
  color: #0f172a;
}

.meta-exact-menu-item.active {
  background: #2563eb;
  border-color: #2563eb;
  color: #ffffff;
  box-shadow: 0 14px 24px rgba(37, 99, 235, 0.24);
}

.meta-exact-safe-card {
  margin-top: 4px;
  border-radius: 18px;
  background: #020617;
  color: #e2e8f0;
  padding: 16px;
}

.meta-exact-safe-card h2 {
  margin: 0;
  font-size: 14px;
  font-weight: 900;
}

.meta-exact-safe-card p {
  margin: 8px 0 0;
  font-size: 12px;
  line-height: 1.55;
  color: #cbd5e1;
}

.meta-exact-back-links {
  margin-top: auto;
  display: grid;
  gap: 6px;
}

.meta-exact-back-links a {
  text-decoration: none;
  color: #334155;
  font-weight: 700;
  font-size: 13px;
}

.meta-exact-main {
  flex: 1;
  min-width: 0;
  overflow: hidden;
}

.meta-exact-header {
  position: sticky;
  top: 0;
  z-index: 20;
  border-bottom: 1px solid #e2e8f0;
  background: rgba(255, 255, 255, 0.92);
  backdrop-filter: blur(10px);
  padding: 18px 24px;
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 14px;
}

.meta-exact-company {
  margin: 0 0 4px;
  color: #2563eb;
  font-size: 11px;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.meta-exact-header h2 {
  margin: 0;
  font-size: 2rem;
  line-height: 1.1;
  letter-spacing: -0.02em;
  font-weight: 900;
}

.meta-exact-header p {
  margin: 8px 0 0;
  color: #64748b;
  font-size: 14px;
}

.meta-exact-user-box {
  display: flex;
  align-items: center;
  gap: 10px;
}

.meta-exact-bell {
  width: 42px;
  height: 42px;
  border-radius: 14px;
  border: 1px solid #dbe3ef;
  background: #ffffff;
  position: relative;
}

.meta-exact-bell::after {
  content: "";
  position: absolute;
  right: 10px;
  top: 10px;
  width: 8px;
  height: 8px;
  border-radius: 999px;
  background: #ef4444;
  box-shadow: 0 0 0 2px #ffffff;
}

.meta-exact-user-badge {
  width: 38px;
  height: 38px;
  border-radius: 12px;
  background: #0f172a;
  color: #ffffff;
  font-size: 13px;
  font-weight: 800;
  display: grid;
  place-items: center;
}

.meta-exact-user-info {
  display: grid;
  gap: 2px;
}

.meta-exact-user-info strong {
  font-size: 13px;
  line-height: 1;
}

.meta-exact-user-info span {
  font-size: 12px;
  color: #64748b;
}

.meta-exact-logout {
  border: 1px solid #e2e8f0;
  background: #ffffff;
  color: #334155;
  border-radius: 12px;
  padding: 8px 12px;
  font-size: 12px;
  font-weight: 700;
  cursor: pointer;
}

.meta-exact-scroll {
  height: calc(100vh - 112px);
  overflow-y: auto;
  padding: 20px 24px;
}

.meta-exact-summary-grid {
  display: grid;
  gap: 14px;
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.meta-exact-summary-card {
  border-radius: 24px;
  border: 1px solid #dbe3ef;
  background: #ffffff;
  box-shadow: 0 8px 24px rgba(15, 23, 42, 0.06);
  padding: 18px;
}

.meta-exact-summary-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
}

.meta-exact-summary-head p {
  margin: 0;
  font-size: 13px;
  font-weight: 800;
  color: #64748b;
}

.meta-exact-summary-card h3 {
  margin: 10px 0 0;
  font-size: 1.4rem;
  font-weight: 900;
  letter-spacing: -0.02em;
}

.meta-exact-summary-card > p {
  margin: 8px 0 0;
  font-size: 13px;
  line-height: 1.45;
  color: #64748b;
}

.meta-ui-status-pill {
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  padding: 4px 10px;
  font-size: 11px;
  font-weight: 900;
  border: 1px solid transparent;
}

.meta-ui-status-pill.success {
  background: #ecfdf3;
  border-color: #a7f3d0;
  color: #047857;
}

.meta-ui-status-pill.warning {
  background: #fffbeb;
  border-color: #fde68a;
  color: #b45309;
}

.meta-ui-status-pill.danger {
  background: #fef2f2;
  border-color: #fecaca;
  color: #b91c1c;
}

.meta-ui-status-pill.info {
  background: #eff6ff;
  border-color: #bfdbfe;
  color: #1d4ed8;
}

.meta-ui-status-pill.neutral {
  background: #f1f5f9;
  border-color: #dbe3ef;
  color: #334155;
}

.meta-exact-main-grid {
  margin-top: 18px;
  display: grid;
  gap: 16px;
  grid-template-columns: minmax(0, 1.06fr) minmax(330px, 0.94fr);
}

.meta-exact-panel {
  border-radius: 24px;
  border: 1px solid #dbe3ef;
  background: #ffffff;
  box-shadow: 0 8px 24px rgba(15, 23, 42, 0.06);
  padding: 18px;
}

.meta-exact-panel-head {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: flex-start;
}

.meta-exact-panel-head.compact {
  margin-bottom: 12px;
}

.meta-exact-chip {
  margin: 0 0 8px;
  display: inline-flex;
  border-radius: 999px;
  background: #eff6ff;
  border: 1px solid #bfdbfe;
  color: #1d4ed8;
  font-size: 11px;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  padding: 5px 10px;
}

.meta-exact-panel-head h3 {
  margin: 0;
  font-size: 1.24rem;
  letter-spacing: -0.02em;
  font-weight: 900;
}

.meta-exact-panel-head p {
  margin: 6px 0 0;
  font-size: 13px;
  color: #64748b;
  line-height: 1.5;
}

.meta-exact-dark-btn {
  border: 1px solid #0f172a;
  background: #0f172a;
  color: #ffffff;
  border-radius: 14px;
  padding: 11px 14px;
  font-size: 13px;
  font-weight: 800;
  cursor: pointer;
}

.meta-exact-dark-btn:hover {
  background: #1e293b;
}

.meta-exact-status-line {
  margin: 12px 0 0;
  font-size: 13px;
  color: #334155;
}

.meta-exact-validation {
  margin: 8px 0 0;
  border: 1px solid #fecaca;
  background: #fef2f2;
  border-radius: 12px;
  color: #b91c1c;
  font-size: 12px;
  font-weight: 700;
  padding: 8px 10px;
}

.meta-exact-form-grid {
  margin-top: 14px;
  display: grid;
  gap: 12px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.meta-exact-field {
  display: grid;
  gap: 6px;
}

.meta-exact-field span {
  font-size: 13px;
  font-weight: 800;
  color: #334155;
}

.meta-exact-field input,
.meta-exact-field textarea,
.meta-exact-template-send input,
.meta-exact-template-send select {
  width: 100%;
  border-radius: 14px;
  border: 1px solid #dbe3ef;
  background: #f8fafc;
  color: #0f172a;
  padding: 11px 12px;
  font-size: 13px;
  font-weight: 700;
  outline: none;
  transition: border-color 0.2s ease, box-shadow 0.2s ease, background 0.2s ease;
}

.meta-exact-field textarea {
  resize: vertical;
}

.meta-exact-field input:focus,
.meta-exact-field textarea:focus,
.meta-exact-template-send input:focus,
.meta-exact-template-send select:focus,
.meta-exact-search-row input:focus,
.meta-exact-reply-box input:focus,
.meta-exact-reply-box textarea:focus {
  border-color: #3b82f6;
  background: #ffffff;
  box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.16);
}

.meta-exact-field-full {
  grid-column: 1 / -1;
}

.meta-exact-input-row {
  display: flex;
  align-items: center;
  gap: 8px;
}

.meta-exact-eye-btn {
  border: 1px solid #dbe3ef;
  background: #ffffff;
  color: #475569;
  border-radius: 12px;
  min-width: 72px;
  padding: 8px 10px;
  font-size: 12px;
  font-weight: 800;
  cursor: pointer;
}

.meta-exact-eye-btn:hover {
  background: #f1f5f9;
}

.meta-exact-panel-foot {
  margin-top: 14px;
  border-top: 1px solid #e2e8f0;
  background: #f8fafc;
  border-radius: 16px;
  padding: 12px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.meta-exact-panel-foot strong {
  font-size: 13px;
}

.meta-exact-panel-foot p {
  margin: 4px 0 0;
  font-size: 12px;
  color: #64748b;
}

.meta-exact-foot-actions {
  display: flex;
  align-items: center;
  gap: 8px;
}

.meta-exact-foot-actions button,
.meta-exact-success-btn,
.meta-exact-reply-box button,
.meta-exact-template-send button {
  border-radius: 14px;
  padding: 10px 13px;
  font-size: 13px;
  font-weight: 800;
  border: 1px solid #2563eb;
  background: #2563eb;
  color: #ffffff;
  cursor: pointer;
}

.meta-exact-foot-actions button.secondary,
.meta-exact-template-send button.secondary,
.meta-exact-code-wrap button.secondary,
.meta-exact-search-row button.secondary {
  border-color: #dbe3ef;
  background: #ffffff;
  color: #334155;
}

.meta-exact-foot-actions button.secondary:hover,
.meta-exact-template-send button.secondary:hover,
.meta-exact-code-wrap button.secondary:hover,
.meta-exact-search-row button.secondary:hover {
  background: #f8fafc;
}

.meta-exact-success-btn {
  margin-top: 10px;
  width: 100%;
  background: #059669;
  border-color: #059669;
}

.meta-exact-success-btn:hover {
  background: #047857;
}

.meta-exact-side-stack {
  display: grid;
  gap: 16px;
}

.meta-exact-code-wrap {
  border-radius: 16px;
  border: 1px solid #dbe3ef;
  background: #f8fafc;
  padding: 12px;
}

.meta-exact-code-wrap > p {
  margin: 0 0 8px;
  font-size: 11px;
  font-weight: 900;
  color: #64748b;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

.meta-exact-code-wrap > div {
  display: flex;
  align-items: center;
  gap: 8px;
}

.meta-exact-code-wrap code {
  display: block;
  flex: 1 1 auto;
  min-width: 0;
  font-size: 12px;
  font-weight: 700;
  color: #334155;
  word-break: break-all;
}

.meta-exact-mini-grid {
  margin-top: 10px;
  display: grid;
  gap: 8px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.meta-exact-mini-grid > div {
  border-radius: 14px;
  padding: 10px;
  background: #eff6ff;
  border: 1px solid #bfdbfe;
}

.meta-exact-mini-grid strong {
  display: block;
  font-size: 13px;
  font-weight: 900;
  color: #1e3a8a;
}

.meta-exact-mini-grid small {
  font-size: 11px;
  font-weight: 700;
  color: #334155;
}

.meta-exact-chat-grid {
  margin-top: 16px;
  display: grid;
  gap: 16px;
  grid-template-columns: 0.9fr 1.1fr;
}

.meta-exact-search-row {
  display: grid;
  gap: 8px;
  grid-template-columns: 1fr auto;
  margin-bottom: 10px;
}

.meta-exact-search-row input,
.meta-exact-reply-box input,
.meta-exact-reply-box textarea {
  border-radius: 14px;
  border: 1px solid #dbe3ef;
  background: #f8fafc;
  padding: 11px 12px;
  font-size: 13px;
  font-weight: 700;
  outline: none;
}

.meta-exact-conversation-list {
  border-top: 1px solid #eef2f7;
}

.meta-exact-conversation-item {
  width: 100%;
  text-align: left;
  border: 0;
  border-bottom: 1px solid #f1f5f9;
  background: #ffffff;
  padding: 12px 8px;
  cursor: pointer;
}

.meta-exact-conversation-item:hover {
  background: #f8fafc;
}

.meta-exact-conversation-item.active {
  background: #eff6ff;
}

.meta-exact-conversation-top {
  display: flex;
  justify-content: space-between;
  gap: 8px;
  align-items: center;
}

.meta-exact-conversation-top strong {
  font-size: 13px;
  font-weight: 900;
  color: #0f172a;
}

.meta-exact-conversation-top span,
.meta-exact-conversation-item small {
  font-size: 11px;
  color: #94a3b8;
  font-weight: 700;
}

.meta-exact-conversation-item p {
  margin: 7px 0 0;
  font-size: 12px;
  color: #475569;
  line-height: 1.45;
}

.meta-exact-chat-head {
  display: flex;
  justify-content: space-between;
  gap: 10px;
  align-items: flex-start;
  padding-bottom: 10px;
  border-bottom: 1px solid #e2e8f0;
}

.meta-exact-chat-head h3 {
  margin: 0;
  font-size: 1.1rem;
  font-weight: 900;
}

.meta-exact-chat-head p {
  margin: 4px 0 0;
  color: #64748b;
  font-size: 13px;
}

.meta-exact-messages {
  margin-top: 10px;
  min-height: 380px;
  max-height: 470px;
  overflow-y: auto;
  background: linear-gradient(180deg, #f8fafc, #ffffff);
  border-radius: 16px;
  padding: 12px;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.meta-exact-message {
  max-width: 82%;
  border-radius: 18px;
  padding: 10px 12px;
  box-shadow: 0 4px 10px rgba(15, 23, 42, 0.08);
}

.meta-exact-message p {
  margin: 0;
  font-size: 13px;
  line-height: 1.52;
}

.meta-exact-message small {
  display: block;
  margin-top: 6px;
  font-size: 11px;
  font-weight: 700;
}

.meta-exact-message.inbound {
  align-self: flex-start;
  background: #ffffff;
  border: 1px solid #dbe3ef;
  color: #0f172a;
}

.meta-exact-message.inbound small {
  color: #64748b;
}

.meta-exact-message.outbound {
  align-self: flex-end;
  background: #2563eb;
  color: #ffffff;
}

.meta-exact-message.outbound small {
  color: #dbeafe;
}

.meta-exact-reply-box {
  margin-top: 12px;
  display: grid;
  gap: 8px;
}

.meta-exact-bottom-grid {
  margin-top: 16px;
  display: grid;
  gap: 16px;
  grid-template-columns: 1fr 0.9fr;
}

.meta-exact-template-send {
  display: grid;
  gap: 8px;
  grid-template-columns: 1fr 110px 1fr auto;
  margin-bottom: 10px;
}

.meta-exact-table-wrap {
  overflow: auto;
  border-radius: 14px;
  border: 1px solid #dbe3ef;
}

.meta-exact-table {
  width: 100%;
  border-collapse: collapse;
  background: #ffffff;
  font-size: 13px;
}

.meta-exact-table thead {
  background: #f8fafc;
}

.meta-exact-table th,
.meta-exact-table td {
  text-align: left;
  padding: 10px 11px;
  border-bottom: 1px solid #eef2f7;
}

.meta-exact-table th {
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: #64748b;
  font-weight: 900;
}

.meta-ui-table-status {
  display: inline-flex;
  border-radius: 999px;
  padding: 3px 9px;
  font-size: 11px;
  font-weight: 900;
}

.meta-ui-table-status.success {
  background: #ecfdf3;
  color: #047857;
  border: 1px solid #a7f3d0;
}

.meta-ui-table-status.warning {
  background: #fffbeb;
  color: #b45309;
  border: 1px solid #fde68a;
}

.meta-exact-audit-list {
  display: grid;
  gap: 10px;
}

.meta-exact-audit-item {
  border: 1px solid #dbe3ef;
  border-radius: 14px;
  background: #f8fafc;
  padding: 11px;
}

.meta-exact-audit-item strong {
  font-size: 13px;
  font-weight: 900;
}

.meta-exact-audit-item p {
  margin: 6px 0 0;
  font-size: 12px;
  color: #475569;
}

.meta-exact-audit-item small {
  display: block;
  margin-top: 7px;
  font-size: 11px;
  color: #94a3b8;
  font-weight: 700;
}

.meta-exact-alert {
  margin-top: 16px;
  border-radius: 18px;
  border: 1px solid #fde68a;
  background: #fffbeb;
  padding: 13px;
}

.meta-exact-alert strong {
  display: block;
  font-size: 13px;
  color: #92400e;
}

.meta-exact-alert p {
  margin: 8px 0 0;
  font-size: 13px;
  color: #b45309;
  line-height: 1.5;
}

.meta-exact-link-chip {
  text-decoration: none;
  font-size: 12px;
  font-weight: 800;
  color: #1d4ed8;
  border: 1px solid #bfdbfe;
  background: #eff6ff;
  padding: 6px 10px;
  border-radius: 999px;
}

.meta-exact-link-chip:hover {
  background: #dbeafe;
}

.meta-exact-template-send button:hover,
.meta-exact-reply-box button:hover,
.meta-exact-foot-actions button:hover {
  filter: brightness(0.96);
}

.meta-exact-template-send button.secondary:hover,
.meta-exact-foot-actions button.secondary:hover {
  filter: none;
}

@media (max-width: 1360px) {
  .meta-exact-summary-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .meta-exact-main-grid,
  .meta-exact-chat-grid,
  .meta-exact-bottom-grid {
    grid-template-columns: 1fr;
  }

  .meta-exact-template-send {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 1024px) {
  .meta-exact-layout {
    flex-direction: column;
  }

  .meta-exact-sidebar {
    width: 100%;
    border-right: 0;
    border-bottom: 1px solid #e2e8f0;
  }

  .meta-exact-menu {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .meta-exact-scroll {
    height: auto;
  }
}

@media (max-width: 760px) {
  .meta-exact-header {
    flex-direction: column;
  }

  .meta-exact-user-box {
    width: 100%;
    justify-content: flex-start;
    flex-wrap: wrap;
  }

  .meta-exact-summary-grid,
  .meta-exact-form-grid {
    grid-template-columns: 1fr;
  }

  .meta-exact-panel-foot {
    flex-direction: column;
    align-items: stretch;
  }

  .meta-exact-foot-actions {
    width: 100%;
    display: grid;
    grid-template-columns: 1fr;
  }

  .meta-exact-search-row {
    grid-template-columns: 1fr;
  }
}

.meta-exact-template-send-gap {
  margin-top: 10px;
}

.skip-link {
  position: absolute;
  left: 12px;
  top: -44px;
  z-index: 1000;
  background: #0f172a;
  color: #ffffff;
  padding: 10px 12px;
  border-radius: 10px;
  text-decoration: none;
  font-weight: 700;
}

.skip-link:focus {
  top: 12px;
}

.privacy-wrap {
  width: min(900px, 100%);
  padding: 16px;
}

.privacy-card {
  border-radius: 24px;
  border-color: rgba(255, 255, 255, 0.75);
  background: rgba(255, 255, 255, 0.9);
  padding: 30px;
}

.privacy-card h1 {
  margin: 0 0 14px;
  font-size: clamp(1.45rem, 2.2vw, 2rem);
  color: #0f172a;
}

.privacy-card p {
  margin: 0 0 14px;
  color: #334155;
  line-height: 1.7;
}

.privacy-card p:last-child {
  margin-bottom: 0;
}

.privacy-list {
  margin: 0 0 14px 18px;
  padding: 0;
  color: #334155;
  line-height: 1.7;
}

.privacy-list li {
  margin-bottom: 6px;
}

.privacy-card a {
  color: #4f46e5;
  font-weight: 700;
}

.landing-legal {
  margin-top: 14px;
  text-align: center;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}

.landing-legal a {
  color: #475569;
  font-weight: 700;
  text-decoration: none;
}

.landing-legal a:hover {
  text-decoration: underline;
}

.login-legal {
  margin-top: 8px;
  font-size: 13px;
}

