/* ============================================================
   SAAS LAYER — scanmenu.id
   Dibangun di atas design-system.css (token sama, komponen baru)
   ============================================================ */

/* ── App Shell (Super Admin & Owner) ──────────────────────── */
.saas-shell {
  display: grid;
  grid-template-columns: 240px 1fr;
  min-height: 100vh;
}
@media (max-width: 768px) {
  .saas-shell { grid-template-columns: 1fr; }
  .saas-sidebar { display: none; }
  .saas-sidebar.open { display: flex; position: fixed; inset: 0; z-index: 500; }
}

.saas-sidebar {
  background: var(--bg-surface);
  border-right: 1px solid var(--border-subtle);
  padding: var(--space-6) var(--space-4);
  display: flex; flex-direction: column; gap: var(--space-2);
}
.saas-logo {
  font-family: var(--font-display); font-weight: 800; font-size: 18px;
  color: var(--text-primary); margin-bottom: var(--space-8);
  display: flex; align-items: center; gap: var(--space-2);
}
.saas-logo span { color: var(--brand-primary); }
.saas-nav-item {
  display: flex; align-items: center; gap: var(--space-3);
  padding: 10px var(--space-3); border-radius: var(--radius-md);
  color: var(--text-secondary); font-size: 14px; font-weight: 500;
  cursor: pointer; transition: all var(--transition-fast); text-decoration: none;
}
.saas-nav-item:hover { background: var(--bg-elevated); color: var(--text-primary); }
.saas-nav-item.active { background: var(--bg-card); color: var(--text-primary); border: 1px solid var(--border-brand); }
.saas-nav-bottom { margin-top: auto; }

.saas-main {
  padding: var(--space-8);
  max-width: 1200px; width: 100%;
}
.saas-topbar {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: var(--space-8);
}

/* ── Stat cards ───────────────────────────────────────────── */
.stat-grid {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: var(--space-4); margin-bottom: var(--space-8);
}
.stat-card {
  background: var(--bg-card); border: 1px solid var(--border-subtle);
  border-radius: var(--radius-lg); padding: var(--space-5);
}
.stat-card .stat-label { color: var(--text-tertiary); font-size: 12px; font-weight: 600; letter-spacing: 0.04em; text-transform: uppercase; }
.stat-card .stat-value { font-family: var(--font-display); font-size: 28px; font-weight: 800; margin-top: var(--space-2); }

/* ── Table ────────────────────────────────────────────────── */
.saas-table-wrap {
  background: var(--bg-card); border: 1px solid var(--border-subtle);
  border-radius: var(--radius-lg); overflow: hidden;
}
table.saas-table { width: 100%; border-collapse: collapse; font-size: 14px; }
table.saas-table th {
  text-align: left; padding: var(--space-3) var(--space-4);
  background: var(--bg-elevated); color: var(--text-tertiary);
  font-size: 11px; font-weight: 600; letter-spacing: 0.05em; text-transform: uppercase;
  border-bottom: 1px solid var(--border-subtle);
}
table.saas-table td {
  padding: var(--space-4); border-bottom: 1px solid var(--border-subtle);
  color: var(--text-primary); vertical-align: middle;
}
table.saas-table tr:last-child td { border-bottom: none; }
table.saas-table tr:hover td { background: var(--bg-hover); }

/* ── Status pills (resto) ────────────────────────────────────── */
.pill { display: inline-flex; align-items: center; gap: 5px; padding: 4px 10px; border-radius: var(--radius-full); font-size: 11px; font-weight: 700; letter-spacing: 0.03em; text-transform: uppercase; }
.pill-active { background: var(--success-bg); color: var(--success); border: 1px solid rgba(16,185,129,0.25); }
.pill-pending { background: var(--warning-bg); color: var(--warning); border: 1px solid rgba(245,158,11,0.25); }
.pill-suspended { background: var(--danger-bg); color: var(--danger); border: 1px solid rgba(239,68,68,0.25); }
.pill-plan { background: rgba(255,107,53,0.12); color: var(--brand-primary); border: 1px solid var(--border-brand); }

/* ── Subscription card (Owner dashboard) ─────────────────── */
.sub-card {
  background: linear-gradient(135deg, var(--bg-elevated), var(--bg-card));
  border: 1px solid var(--border-default); border-radius: var(--radius-xl);
  padding: var(--space-8); margin-bottom: var(--space-8);
  display: flex; align-items: center; justify-content: space-between; gap: var(--space-6); flex-wrap: wrap;
}
.sub-card.suspended { border-color: rgba(239,68,68,0.4); background: linear-gradient(135deg, rgba(239,68,68,0.08), var(--bg-card)); }
.sub-card-title { font-family: var(--font-display); font-size: 22px; font-weight: 800; }
.sub-card-meta { color: var(--text-secondary); font-size: 14px; margin-top: var(--space-2); }

/* ── Locked overlay (resto suspended) ─────────────────────── */
.locked-banner {
  display: flex; align-items: center; gap: var(--space-3);
  background: var(--danger-bg); border: 1px solid rgba(239,68,68,0.3);
  border-radius: var(--radius-lg); padding: var(--space-4) var(--space-5);
  margin-bottom: var(--space-6); color: var(--text-primary); font-size: 14px;
}

/* ── Quick links grid (Owner) ─────────────────────────────── */
.quick-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap: var(--space-4); }
.quick-link {
  background: var(--bg-card); border: 1px solid var(--border-subtle); border-radius: var(--radius-lg);
  padding: var(--space-6); text-decoration: none; color: var(--text-primary);
  display: flex; flex-direction: column; gap: var(--space-2);
  transition: all var(--transition-fast);
}
.quick-link:hover { border-color: var(--border-brand); transform: translateY(-2px); box-shadow: var(--shadow-md); }
.quick-link .quick-icon { font-size: 26px; }
.quick-link .quick-title { font-weight: 700; font-size: 15px; }
.quick-link .quick-desc { font-size: 12px; color: var(--text-tertiary); }
.quick-link.disabled { opacity: 0.4; pointer-events: none; }

/* ── Landing page ─────────────────────────────────────────── */
.landing-nav {
  display: flex; align-items: center; justify-content: space-between;
  padding: var(--space-5) var(--space-8); max-width: 1200px; margin: 0 auto;
}
.landing-hero {
  max-width: 1200px; margin: 0 auto; padding: var(--space-12) var(--space-8) var(--space-10);
  display: grid; grid-template-columns: 1.1fr 0.9fr; gap: var(--space-10); align-items: center;
}
@media (max-width: 860px) { .landing-hero { grid-template-columns: 1fr; padding-top: var(--space-8); } }
.hero-eyebrow { color: var(--brand-primary); font-weight: 700; font-size: 13px; letter-spacing: 0.06em; text-transform: uppercase; margin-bottom: var(--space-4); }
.hero-title { font-family: var(--font-display); font-size: clamp(32px, 5vw, 52px); font-weight: 800; letter-spacing: -0.03em; line-height: 1.08; }
.hero-sub { color: var(--text-secondary); font-size: 17px; margin: var(--space-5) 0 var(--space-8); max-width: 480px; line-height: 1.6; }
.hero-cta-row { display: flex; gap: var(--space-3); flex-wrap: wrap; }
.hero-mock {
  background: var(--bg-card); border: 1px solid var(--border-default); border-radius: var(--radius-xl);
  padding: var(--space-6); box-shadow: var(--shadow-lg); position: relative;
}
.hero-mock-row { display: flex; align-items: center; justify-content: space-between; padding: var(--space-3) 0; border-bottom: 1px solid var(--border-subtle); }
.hero-mock-row:last-child { border-bottom: none; }

.landing-section { max-width: 1200px; margin: 0 auto; padding: var(--space-10) var(--space-8); }
.section-title { font-family: var(--font-display); font-size: clamp(24px, 3vw, 34px); font-weight: 800; letter-spacing: -0.02em; margin-bottom: var(--space-3); }
.section-sub { color: var(--text-secondary); font-size: 15px; max-width: 560px; margin-bottom: var(--space-8); }
.feature-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: var(--space-5); }
.feature-card { background: var(--bg-card); border: 1px solid var(--border-subtle); border-radius: var(--radius-lg); padding: var(--space-6); }
.feature-card .f-icon { font-size: 24px; margin-bottom: var(--space-3); }
.feature-card .f-title { font-weight: 700; margin-bottom: var(--space-2); }
.feature-card .f-desc { color: var(--text-tertiary); font-size: 13px; line-height: 1.6; }

.plan-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); gap: var(--space-5); }
.plan-card { background: var(--bg-card); border: 1px solid var(--border-subtle); border-radius: var(--radius-xl); padding: var(--space-8); position: relative; }
.plan-card.featured { border-color: var(--border-brand); background: linear-gradient(180deg, rgba(255,107,53,0.06), var(--bg-card)); }
.plan-card .plan-tag { position: absolute; top: -12px; right: var(--space-6); background: var(--brand-primary); color: white; font-size: 11px; font-weight: 700; padding: 4px 12px; border-radius: var(--radius-full); }
.plan-name { font-weight: 700; font-size: 16px; color: var(--text-secondary); }
.plan-price { font-family: var(--font-display); font-size: 36px; font-weight: 800; margin: var(--space-3) 0; }
.plan-price span { font-size: 14px; color: var(--text-tertiary); font-weight: 500; }
.plan-features { margin: var(--space-6) 0; display: flex; flex-direction: column; gap: var(--space-3); font-size: 13px; color: var(--text-secondary); }

.landing-footer { text-align: center; padding: var(--space-10) var(--space-8); color: var(--text-tertiary); font-size: 13px; border-top: 1px solid var(--border-subtle); margin-top: var(--space-10); }

/* ── Auth screens (login) ─────────────────────────────────── */
.auth-screen { min-height: 100vh; display: flex; align-items: center; justify-content: center; padding: var(--space-6); }
.auth-card { width: 100%; max-width: 380px; background: var(--bg-card); border: 1px solid var(--border-subtle); border-radius: var(--radius-xl); padding: var(--space-8); }
.auth-logo { text-align: center; margin-bottom: var(--space-6); font-family: var(--font-display); font-weight: 800; font-size: 20px; }
.auth-logo span { color: var(--brand-primary); }
.auth-error { background: var(--danger-bg); color: var(--danger); border: 1px solid rgba(239,68,68,0.25); border-radius: var(--radius-md); padding: var(--space-3); font-size: 13px; margin-top: var(--space-4); display: none; }
.auth-error.show { display: block; }
