:root {
  --bg: #f4f6fb;
  --card: #ffffff;
  --text: #111827;
  --muted: #64748b;
  --line: #e2e8f0;
  --soft: #f8fafc;
  --primary: #d71920;
  --primary-dark: #a90f15;
  --blue: #101a6b;
  --blue-dark: #080d38;
  --purple: #32135f;
  --danger: #b91c1c;
  --success: #15803d;
  --warning: #b45309;
  --shadow: 0 22px 70px rgba(15, 23, 42, .12);
  --shadow-soft: 0 12px 35px rgba(15, 23, 42, .08);
  --radius: 22px;
  font-family: Arial, Helvetica, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; color: var(--text); background: var(--bg); }
a { color: inherit; text-decoration: none; }
img { max-width: 100%; display: block; }
input, select, textarea, button { font: inherit; }
button { cursor: pointer; }

.public-body {
  min-height: 100vh;
  background:
    radial-gradient(circle at 9% 7%, rgba(215, 25, 32, .14), transparent 26%),
    radial-gradient(circle at 90% 0%, rgba(16, 26, 107, .18), transparent 30%),
    linear-gradient(180deg, #ffffff 0%, #f4f6fb 38%, #eef2ff 100%);
}
.ce-body::before {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  background-image:
    linear-gradient(135deg, rgba(16,26,107,.05) 25%, transparent 25%),
    linear-gradient(315deg, rgba(215,25,32,.05) 25%, transparent 25%);
  background-position: 0 0, 18px 18px;
  background-size: 36px 36px;
  opacity: .32;
}

.site-header {
  position: sticky;
  top: 0;
  z-index: 20;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 16px;
  padding: 12px clamp(16px, 4vw, 56px);
  background: rgba(255,255,255,.90);
  border-bottom: 1px solid rgba(226,232,240,.8);
  backdrop-filter: blur(12px);
}
.site-brand { display: inline-flex; align-items: center; gap: 12px; }
.site-brand img { width: 48px; height: 48px; object-fit: contain; }
.site-brand strong { display: block; color: var(--blue); text-transform: uppercase; letter-spacing: .03em; font-size: 16px; }
.site-brand small { display: block; color: var(--muted); font-size: 12px; margin-top: 1px; }
.site-contact { font-size: 13px; font-weight: 800; color: var(--blue); background: #eef2ff; border: 1px solid #dbeafe; padding: 9px 12px; border-radius: 999px; }

.public-wrap { max-width: 1040px; margin: 0 auto; padding: 28px 16px 56px; position: relative; }
.public-wrap.wide { max-width: 1180px; }
.ce-hero {
  display: grid;
  grid-template-columns: minmax(0, .96fr) minmax(420px, 1.04fr);
  gap: 22px;
  align-items: stretch;
  margin: 12px 0 22px;
}
.hero-copy, .hero-visual, .hero-card, .form-section, .card, .success-card, .detail-card, .table-card {
  background: rgba(255,255,255,.94);
  border: 1px solid rgba(226,232,240,.92);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
}
.hero-copy {
  padding: clamp(24px, 4vw, 44px);
  position: relative;
  overflow: hidden;
}
.hero-copy::after {
  content: "";
  position: absolute;
  width: 230px; height: 230px; right: -80px; bottom: -80px;
  background: linear-gradient(135deg, rgba(215,25,32,.16), rgba(16,26,107,.12));
  border-radius: 52px;
  transform: rotate(25deg);
}
.hero-badge {
  display: inline-flex;
  align-items: center;
  padding: 8px 12px;
  border-radius: 999px;
  background: #fff1f2;
  color: var(--primary-dark);
  border: 1px solid #fecdd3;
  font-weight: 900;
  font-size: 13px;
  margin-bottom: 14px;
}
.hero-copy h1 {
  margin: 0;
  color: var(--blue-dark);
  font-size: clamp(32px, 5vw, 54px);
  line-height: .98;
  letter-spacing: -.05em;
  text-transform: uppercase;
}
.lead, .hero-copy p { color: #475569; font-size: 16px; line-height: 1.7; }
.hero-info-grid {
  display: grid;
  gap: 10px;
  margin-top: 22px;
  position: relative;
  z-index: 1;
}
.hero-info-grid div {
  padding: 13px 14px;
  border-radius: 16px;
  border: 1px solid #e5e7eb;
  background: linear-gradient(180deg, #ffffff, #f8fafc);
}
.hero-info-grid strong { display: block; color: var(--primary-dark); font-size: 12px; letter-spacing: .08em; text-transform: uppercase; }
.hero-info-grid span { display: block; margin-top: 2px; color: #334155; font-weight: 700; }
.hero-visual {
  overflow: hidden;
  position: relative;
  min-height: 420px;
  background: linear-gradient(135deg, var(--purple), var(--blue-dark));
}
.hero-banner-img {
  width: 100%; height: 100%; object-fit: cover; object-position: center;
  min-height: 420px;
}
.hero-visual::after {
  content: ""; position: absolute; inset: 0;
  background: linear-gradient(180deg, rgba(8,13,56,.04), rgba(8,13,56,.42));
}
.office-card {
  position: absolute;
  right: 18px; bottom: 18px; left: 18px;
  z-index: 2;
  display: grid;
  grid-template-columns: 74px 1fr;
  gap: 12px;
  align-items: center;
  padding: 12px;
  border-radius: 20px;
  background: rgba(255,255,255,.92);
  box-shadow: 0 18px 45px rgba(0,0,0,.20);
}
.office-card img { width: 74px; height: 74px; object-fit: cover; border-radius: 16px; }
.office-card strong { display: block; color: var(--blue-dark); }
.office-card span { display: block; color: var(--muted); font-size: 13px; margin-top: 3px; }

.hero-card { padding: 30px; margin-bottom: 18px; overflow: hidden; position: relative; }
.hero-card h1 { margin: 0 0 10px; font-size: clamp(28px, 5vw, 44px); color: var(--blue-dark); }
.hero-contact { margin-top: 16px; padding: 11px 13px; background: #f8fafc; border-radius: 14px; color: #334155; font-weight: 700; }

.registration-form { display: grid; gap: 18px; }
.form-section { padding: clamp(18px, 3vw, 28px); }
.official-section { position: relative; overflow: hidden; }
.official-section::before {
  content: "";
  position: absolute;
  left: 0; top: 0; bottom: 0;
  width: 5px;
  background: linear-gradient(180deg, var(--primary), var(--blue));
}
.compact-section { padding: 18px 24px; }
.section-title-row {
  display: flex;
  gap: 14px;
  align-items: flex-start;
  margin-bottom: 18px;
}
.section-letter {
  flex: 0 0 auto;
  display: inline-grid;
  place-items: center;
  width: 42px; height: 42px;
  border-radius: 14px;
  background: linear-gradient(135deg, var(--primary), var(--blue));
  color: #fff;
  font-weight: 900;
  box-shadow: 0 12px 28px rgba(16,26,107,.20);
}
.form-section h2 { margin: 0; color: var(--blue-dark); font-size: 22px; text-transform: uppercase; letter-spacing: -.02em; }
.form-section h3 { margin: 18px 0 10px; color: var(--blue); font-size: 16px; }
.section-title-row p { margin: 4px 0 0; color: var(--muted); }
.form-grid { display: grid; gap: 14px; }
.form-grid.two { grid-template-columns: repeat(2, minmax(0,1fr)); }
.form-grid .full, label.full { grid-column: 1 / -1; }
label { display: grid; gap: 7px; color: #334155; font-weight: 800; }
label span, .form-section h3 span, .signature-title span { color: var(--primary); }
input, select, textarea {
  width: 100%;
  border: 1px solid #dbe3ee;
  border-radius: 14px;
  padding: 12px 13px;
  background: #fff;
  color: var(--text);
  outline: none;
  transition: .16s ease;
}
textarea { resize: vertical; min-height: 96px; }
input:focus, select:focus, textarea:focus {
  border-color: rgba(16,26,107,.65);
  box-shadow: 0 0 0 4px rgba(16,26,107,.10);
}
small, .muted { color: var(--muted); font-weight: 500; }
.choice-grid { display: grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap: 10px; }
.choice-card {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 13px 14px;
  border: 1px solid #e2e8f0;
  border-radius: 16px;
  background: #fff;
  cursor: pointer;
  transition: .16s ease;
  min-height: 50px;
}
.choice-card:hover { transform: translateY(-1px); box-shadow: var(--shadow-soft); border-color: #cbd5e1; }
.choice-card input { width: 18px; height: 18px; accent-color: var(--primary); flex: 0 0 auto; }
.choice-card span { color: #1f2937; font-weight: 900; }
.other-class-field { margin-top: 12px; }
.statement-box {
  padding: 16px;
  border-radius: 18px;
  background: linear-gradient(180deg, #f8fafc, #ffffff);
  border: 1px solid var(--line);
}
.official-statement p { margin-top: 0; color: #334155; line-height: 1.65; }
.official-statement ol { margin-top: 0; color: #334155; line-height: 1.65; }
.checkbox-line { display: flex; grid-template-columns: none; flex-direction: row; align-items: flex-start; gap: 10px; margin-top: 10px; font-weight: 700; color: #334155; }
.checkbox-line input { width: 18px; height: 18px; margin-top: 2px; accent-color: var(--primary); }
.signature-area { margin-top: 16px; }
.signature-pad {
  margin-top: 12px;
  border: 1px dashed #cbd5e1;
  background: #fff;
  border-radius: 18px;
  padding: 12px;
}
.signature-title { font-weight: 900; color: var(--blue); margin-bottom: 8px; }
.signature-pad canvas {
  display: block;
  width: 100%;
  height: 170px;
  background: linear-gradient(180deg, #fff, #f8fafc);
  border: 1px solid #e2e8f0;
  border-radius: 14px;
  touch-action: none;
}
.note-panel {
  padding: 14px 16px;
  background: #fff7ed;
  border: 1px solid #fed7aa;
  border-radius: 16px;
  color: #7c2d12;
  margin-bottom: 14px;
}
.note-panel ol { margin: 6px 0 0 18px; padding: 0; line-height: 1.6; }
.captcha-section label { max-width: 440px; }
.submit-area { text-align: center; padding: 10px 0 0; }
.ce-submit { padding-bottom: 28px; }

.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  border: 1px solid #dbe3ee;
  background: #fff;
  color: #1f2937;
  padding: 10px 14px;
  border-radius: 13px;
  font-weight: 900;
  text-decoration: none;
  transition: .16s ease;
}
.btn:hover { transform: translateY(-1px); box-shadow: var(--shadow-soft); }
.btn.primary { border-color: transparent; color: #fff; background: linear-gradient(135deg, var(--primary), var(--blue)); }
.btn.danger { background: #fee2e2; color: #991b1b; border-color: #fecaca; }
.btn.light { background: #f8fafc; }
.btn.large { font-size: 17px; padding: 14px 26px; border-radius: 16px; }
.btn.small { padding: 7px 10px; font-size: 13px; margin-top: 9px; }
.alert { border-radius: 16px; padding: 14px 16px; font-weight: 800; margin-bottom: 14px; box-shadow: var(--shadow-soft); }
.alert-error { background: #fef2f2; border: 1px solid #fecaca; color: #991b1b; }
.alert-success { background: #ecfdf5; border: 1px solid #bbf7d0; color: #166534; }
.danger-text { color: var(--danger); }

.success-wrap { max-width: 640px; margin: 0 auto; min-height: 100vh; display: grid; place-items: center; padding: 24px; position: relative; }
.success-card { width: 100%; padding: 34px; text-align: center; }
.success-logo { width: 86px; height: 86px; object-fit: contain; margin: 0 auto 8px; }
.success-icon { width: 64px; height: 64px; border-radius: 50%; display: grid; place-items: center; color: #fff; background: linear-gradient(135deg, #16a34a, #15803d); margin: 0 auto 12px; font-size: 36px; font-weight: 900; }
.success-card h1 { margin: 0 0 8px; color: var(--blue-dark); }
.registration-number { display: inline-block; margin: 14px 0; padding: 12px 18px; border-radius: 14px; background: #eef2ff; color: var(--blue); font-size: 22px; font-weight: 900; letter-spacing: .04em; }
.actions { display: flex; gap: 8px; flex-wrap: wrap; align-items: center; }
.actions.center { justify-content: center; }

.login-wrap { max-width: 980px; margin: 0 auto; min-height: 100vh; display: grid; place-items: center; padding: 24px; position: relative; }
.branded-login { grid-template-columns: minmax(0, .9fr) minmax(360px, .65fr); gap: 18px; }
.login-visual { position: relative; min-height: 520px; border-radius: var(--radius); overflow: hidden; box-shadow: var(--shadow); color: #fff; background: var(--blue-dark); }
.login-visual > img { width: 100%; height: 100%; object-fit: cover; min-height: 520px; filter: brightness(.82); }
.login-visual > div { position: absolute; inset: auto 24px 24px 24px; background: rgba(8,13,56,.74); border: 1px solid rgba(255,255,255,.18); border-radius: 20px; padding: 20px; backdrop-filter: blur(10px); }
.login-logo { width: 74px; height: 74px; object-fit: contain; background: #fff; border-radius: 18px; padding: 6px; }
.login-visual h1 { margin: 12px 0 2px; font-size: 36px; text-transform: uppercase; }
.login-card { width: 100%; padding: 28px; }
.login-card h1 { margin: 0 0 6px; color: var(--blue-dark); }
.install-wrap { max-width: 760px; margin: 0 auto; min-height: 100vh; display: grid; place-items: center; padding: 24px; }

.admin-body { background: #f4f6fb; }
.admin-topbar {
  position: sticky; top: 0; z-index: 30;
  display: flex; align-items: center; justify-content: space-between; gap: 16px;
  padding: 14px clamp(16px, 4vw, 34px);
  background: rgba(255,255,255,.95);
  border-bottom: 1px solid var(--line);
  box-shadow: 0 10px 30px rgba(15,23,42,.06);
  backdrop-filter: blur(12px);
}
.admin-brand-wrap { display: flex; align-items: center; gap: 12px; }
.admin-brand-wrap img { width: 46px; height: 46px; object-fit: contain; }
.admin-brand { color: var(--blue-dark); text-transform: uppercase; font-weight: 950; letter-spacing: .03em; }
.admin-subtitle { color: var(--muted); font-size: 13px; margin-top: 1px; }
.admin-nav { display: flex; gap: 8px; flex-wrap: wrap; }
.admin-nav a { padding: 9px 12px; border: 1px solid var(--line); border-radius: 12px; background: #fff; color: #334155; font-weight: 900; }
.admin-nav a:hover { color: #fff; background: linear-gradient(135deg, var(--primary), var(--blue)); border-color: transparent; }
.admin-main { max-width: 1180px; margin: 0 auto; padding: 26px 16px 56px; }
.admin-section { display: grid; gap: 18px; }
.section-head { display: flex; justify-content: space-between; gap: 16px; align-items: center; }
.section-head h1 { margin: 0; color: var(--blue-dark); font-size: 30px; letter-spacing: -.03em; }
.stats-grid { display: grid; grid-template-columns: repeat(4, minmax(0,1fr)); gap: 12px; }
.stat-card { padding: 18px; background: #fff; border: 1px solid var(--line); border-radius: 18px; box-shadow: var(--shadow-soft); }
.stat-card strong { display: block; color: var(--blue); font-size: 30px; }
.stat-card span { color: var(--muted); font-weight: 800; }
.filter-bar { display: grid; grid-template-columns: 1fr 220px auto; gap: 10px; align-items: end; }
.table-card { overflow: hidden; }
.table-responsive, .table-card { overflow-x: auto; }
.admin-table { width: 100%; border-collapse: collapse; min-width: 850px; }
.admin-table th, .admin-table td { padding: 13px 12px; border-bottom: 1px solid var(--line); text-align: left; vertical-align: top; }
.admin-table th { background: #f8fafc; color: #334155; font-size: 13px; text-transform: uppercase; letter-spacing: .04em; }
.empty { text-align: center !important; color: var(--muted); padding: 30px !important; }
.actions-cell { white-space: nowrap; }
.status-pill { display: inline-flex; align-items: center; padding: 5px 9px; border-radius: 999px; background: #f1f5f9; color: #334155; font-weight: 900; font-size: 12px; }
.status-baru { background:#dbeafe; color:#1d4ed8; }
.status-dihubungi, .status-sudah-konfirmasi { background:#fef3c7; color:#92400e; }
.status-sudah-bayar, .status-aktif-belajar { background:#dcfce7; color:#166534; }
.status-batal { background:#fee2e2; color:#991b1b; }
.pagination { display: flex; gap: 6px; margin-top: 16px; flex-wrap: wrap; }
.pagination a { padding: 8px 12px; background: #fff; border: 1px solid var(--line); border-radius: 10px; font-weight: 900; }
.pagination a.active { background: linear-gradient(135deg, var(--primary), var(--blue)); color: #fff; border-color: transparent; }
.detail-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 16px; }
.detail-grid.two-columns { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.detail-card { padding: 20px; }
.detail-card h2 { margin: 0 0 12px; color: var(--blue-dark); }
dl { display: grid; grid-template-columns: 170px 1fr; gap: 8px 14px; }
dt { color: var(--muted); font-weight: 900; }
dd { margin: 0; }
.inline-form { display: flex; gap: 8px; align-items: center; flex-wrap: wrap; }
.inline-form.mini { display: inline-flex; }
.add-master-form { margin-bottom: 12px; }
.sort-input { max-width: 90px; }
.signature-preview-row { display: grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap: 10px; }
.signature-preview-row img { width: 100%; max-height: 130px; object-fit: contain; background: #fff; border: 1px solid var(--line); border-radius: 12px; }
.file-list { padding-left: 18px; }
.compact-table { min-width: 520px; }
.admin-edit-form { display: grid; gap: 18px; }
.card { padding: 22px; }
.horizontal { display: flex; gap: 8px; flex-wrap: wrap; }

@media (max-width: 1020px) {
  .ce-hero, .branded-login { grid-template-columns: 1fr; }
  .hero-visual, .hero-banner-img { min-height: 340px; }
  .login-visual, .login-visual > img { min-height: 360px; }
}
@media (max-width: 900px) {
  .form-grid.two, .detail-grid, .detail-grid.two-columns { grid-template-columns: 1fr; }
  .choice-grid { grid-template-columns: repeat(2, minmax(0,1fr)); }
  .stats-grid { grid-template-columns: repeat(2, minmax(0,1fr)); }
  .filter-bar { grid-template-columns: 1fr; }
  .section-head, .admin-topbar, .site-header { align-items: flex-start; flex-direction: column; }
  dl { grid-template-columns: 1fr; }
}
@media (max-width: 560px) {
  .public-wrap { padding: 16px 12px 42px; }
  .choice-grid { grid-template-columns: 1fr; }
  .hero-copy, .form-section, .success-card, .login-card { padding: 18px; }
  .hero-copy h1 { font-size: 30px; }
  .signature-pad canvas { height: 150px; }
  .site-contact { width: 100%; border-radius: 14px; }
  .office-card { grid-template-columns: 58px 1fr; }
  .office-card img { width: 58px; height: 58px; }
}

/* V1.3 - Success payment instructions */
.payment-card {
  margin: 20px auto 0;
  padding: 18px;
  border: 1px solid rgba(15,23,42,.10);
  border-radius: 22px;
  background: linear-gradient(180deg, rgba(255,255,255,.94), rgba(248,250,252,.94));
  box-shadow: 0 18px 45px rgba(15,23,42,.08);
  text-align: left;
}
.payment-card h2 {
  margin: 0 0 12px;
  color: var(--blue-dark);
  font-size: 19px;
  text-align: center;
}
.bank-list {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}
.bank-item {
  display: grid;
  grid-template-columns: 72px 1fr;
  gap: 10px;
  align-items: center;
  padding: 11px;
  border: 1px solid rgba(15,23,42,.08);
  border-radius: 16px;
  background: #fff;
}
.bank-item img {
  width: 72px;
  height: 42px;
  object-fit: contain;
  border-radius: 9px;
  background: #fff;
}
.bank-item strong,
.bank-item span,
.bank-item small {
  display: block;
}
.bank-item strong {
  color: var(--blue-dark);
  font-size: 15px;
}
.bank-item span {
  margin-top: 2px;
  font-size: 17px;
  font-weight: 900;
  letter-spacing: .02em;
  color: #111827;
}
.bank-item small {
  margin-top: 2px;
  color: var(--muted);
  font-weight: 700;
}
.success-actions {
  gap: 10px;
  flex-wrap: wrap;
}
.btn.secondary {
  background: #fff;
  color: var(--blue-dark);
  border: 1px solid rgba(15,23,42,.12);
}
@media (max-width: 720px) {
  .bank-list { grid-template-columns: 1fr; }
  .bank-item { grid-template-columns: 68px 1fr; }
  .success-actions .btn { width: 100%; justify-content: center; }
}

/* V1.5 security hardening: logout memakai POST + CSRF, tetap tampil seperti link nav */
.logout-form{margin:0;display:inline-flex;align-items:center}
.logout-form button{border:0;background:transparent;color:inherit;font:inherit;cursor:pointer;padding:0.55rem 0.75rem;border-radius:999px}
.logout-form button:hover{background:rgba(255,255,255,.12)}
.btn.danger,.danger{background:#fee2e2!important;color:#991b1b!important;border-color:#fecaca!important}
.btn.danger:hover,.danger:hover{background:#fecaca!important}

/* V1.7 - WhatsApp/Fonnte settings */
.admin-form-wide label{display:block;margin-bottom:12px;font-weight:800;color:#111827}
.admin-form-wide input[type="text"],
.admin-form-wide input[type="password"],
.admin-form-wide input:not([type]),
.admin-form-wide textarea{width:100%;margin-top:7px;border:1px solid rgba(15,23,42,.14);border-radius:14px;padding:12px 13px;font:inherit;background:#fff;color:#111827}
.admin-form-wide textarea{resize:vertical;line-height:1.55;min-height:110px}
.checkline{display:flex!important;gap:10px;align-items:flex-start;padding:10px 12px;border:1px solid rgba(15,23,42,.08);border-radius:14px;background:#f8fafc;font-weight:800}
.checkline input{margin-top:3px;transform:scale(1.1)}
.hint-box{padding:14px;border:1px dashed rgba(30,64,175,.25);border-radius:16px;background:#eff6ff;color:#1e3a8a;line-height:1.7}
.hint-box code{background:#fff;border:1px solid rgba(30,64,175,.15);border-radius:8px;padding:2px 6px;color:#1d4ed8;font-weight:800}
.soft-divider{border:0;border-top:1px solid rgba(15,23,42,.10);margin:22px 0}
.mini-table-wrap{max-height:520px;overflow:auto}
.wa-log-list{list-style:none;margin:0;padding:0;display:grid;gap:10px}
.wa-log-list li{padding:12px;border:1px solid rgba(15,23,42,.09);border-radius:14px;background:#f8fafc}
.status-batal{background:#fee2e2!important;color:#991b1b!important;border-color:#fecaca!important}
@media (max-width: 900px){.admin-form-wide textarea{min-height:120px}}

/* V1.8 - Premium WhatsApp admin UI patch */
.wa-page{gap:22px}.wa-hero{position:relative;overflow:hidden;display:flex;justify-content:space-between;align-items:stretch;gap:22px;padding:30px;border:1px solid rgba(226,232,240,.9);border-radius:28px;background:linear-gradient(135deg,#ffffff 0%,#f8fafc 42%,#eef2ff 100%);box-shadow:0 24px 70px rgba(15,23,42,.09)}.wa-hero:before{content:"";position:absolute;right:-80px;top:-100px;width:280px;height:280px;border-radius:80px;background:linear-gradient(135deg,rgba(34,197,94,.14),rgba(16,26,107,.10));transform:rotate(24deg)}.wa-hero>*{position:relative;z-index:1}.wa-kicker{display:inline-flex;padding:7px 11px;border-radius:999px;background:#dcfce7;color:#166534;border:1px solid #bbf7d0;font-size:12px;font-weight:950;text-transform:uppercase;letter-spacing:.08em}.wa-hero h1{margin:10px 0 8px;color:var(--blue-dark);font-size:clamp(34px,4vw,52px);line-height:.95;letter-spacing:-.055em}.wa-hero p{max-width:720px;margin:0;color:#52647c;font-size:16px;line-height:1.65;font-weight:600}.wa-status-panel{min-width:270px;display:grid;grid-template-columns:1fr;gap:10px}.wa-status-item{padding:16px;border-radius:20px;border:1px solid rgba(15,23,42,.08);background:rgba(255,255,255,.78);box-shadow:0 12px 34px rgba(15,23,42,.06)}.wa-status-item span{display:block;color:var(--muted);font-size:12px;font-weight:900;text-transform:uppercase;letter-spacing:.08em}.wa-status-item strong{display:block;margin-top:5px;color:#0f172a;font-size:18px}.wa-status-item.is-on{border-color:rgba(34,197,94,.25);background:linear-gradient(180deg,#f0fdf4,#fff)}.wa-status-item.is-on strong{color:#166534}.wa-status-item.is-off{border-color:rgba(239,68,68,.18);background:linear-gradient(180deg,#fff7ed,#fff)}.wa-status-item.is-off strong{color:#9f1239}.wa-layout{display:grid;grid-template-columns:minmax(0,1.2fr) 420px;gap:22px;align-items:start}.wa-card{border:1px solid rgba(226,232,240,.95);border-radius:26px;background:rgba(255,255,255,.96);box-shadow:0 22px 65px rgba(15,23,42,.10);overflow:hidden}.wa-main-card{padding:0}.wa-card-head{display:flex;justify-content:space-between;align-items:flex-start;gap:14px;padding:24px 26px 18px;border-bottom:1px solid rgba(226,232,240,.85);background:linear-gradient(180deg,#fff,#f8fafc)}.wa-card-head.compact{padding:22px 22px 16px}.wa-card-head h2{margin:0;color:var(--blue-dark);font-size:26px;line-height:1.05;letter-spacing:-.035em}.wa-card-head p{margin:7px 0 0;color:#64748b;font-weight:600;line-height:1.55}.wa-form{padding:24px 26px 26px;display:grid;gap:18px}.compact-form{padding:20px 22px 22px}.wa-toggle-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.wa-toggle-card{position:relative;display:grid!important;grid-template-columns:46px 1fr;gap:12px;align-items:flex-start;margin:0!important;padding:16px;border:1px solid rgba(15,23,42,.08);border-radius:20px;background:#f8fafc;color:#0f172a;transition:.18s ease}.wa-toggle-card:hover{transform:translateY(-1px);box-shadow:0 16px 34px rgba(15,23,42,.08);border-color:rgba(16,26,107,.18)}.wa-toggle-card input{position:absolute;opacity:0;pointer-events:none}.wa-toggle-card strong{display:block;font-size:15px;line-height:1.25;color:#0f172a}.wa-toggle-card small{display:block;margin-top:4px;font-size:12px;line-height:1.4;color:#64748b;font-weight:650}.wa-toggle-ui{position:relative;width:46px;height:28px;border-radius:999px;background:#cbd5e1;box-shadow:inset 0 0 0 1px rgba(15,23,42,.08);transition:.18s ease}.wa-toggle-ui:after{content:"";position:absolute;top:4px;left:4px;width:20px;height:20px;border-radius:999px;background:#fff;box-shadow:0 3px 10px rgba(15,23,42,.18);transition:.18s ease}.wa-toggle-card input:checked+.wa-toggle-ui{background:linear-gradient(135deg,#22c55e,#16a34a)}.wa-toggle-card input:checked+.wa-toggle-ui:after{left:22px}.danger-toggle input:checked+.wa-toggle-ui{background:linear-gradient(135deg,#ef4444,#b91c1c)}.wa-fieldset{display:grid;gap:12px;padding:18px;border:1px solid rgba(15,23,42,.08);border-radius:22px;background:#fff}.wa-fieldset.two{grid-template-columns:repeat(2,minmax(0,1fr))}.wa-fieldset h3{margin:0;color:var(--blue-dark);font-size:17px}.wa-field{display:grid!important;gap:8px;margin:0!important;color:#0f172a;font-weight:900}.wa-field input,.wa-field textarea{width:100%;margin:0!important;border:1px solid #dbe3ee;border-radius:16px;padding:13px 14px;background:#fff;color:#111827;font:inherit;font-weight:700;outline:none}.wa-field textarea{font-weight:650;line-height:1.58;resize:vertical;min-height:130px}.textarea-pair textarea{min-height:280px}.wa-field input:focus,.wa-field textarea:focus{border-color:rgba(16,26,107,.55);box-shadow:0 0 0 4px rgba(16,26,107,.09)}.wa-field small{color:#64748b;font-weight:650}.wa-hint{padding:16px;border-radius:20px;border:1px dashed rgba(16,26,107,.22);background:linear-gradient(180deg,#eff6ff,#f8fafc);color:#1e3a8a;line-height:1.65}.wa-hint strong{display:block;margin-bottom:8px}.wa-hint div{display:flex;gap:7px;flex-wrap:wrap}.wa-hint code{display:inline-flex;padding:4px 7px;border:1px solid rgba(30,64,175,.14);border-radius:9px;background:#fff;color:#1d4ed8;font-weight:900;font-size:12px}.wa-save-btn{min-height:52px;border-radius:17px;font-size:16px}.wa-side{display:grid;gap:22px;position:sticky;top:92px}.wa-full-btn{width:100%;justify-content:center;min-height:48px;border-radius:16px;background:#fff;border:1px solid #dbe3ee;color:var(--blue-dark);font-weight:950}.wa-full-btn:hover{background:linear-gradient(135deg,var(--primary),var(--blue));color:#fff;border-color:transparent}.wa-empty-log{margin:20px 22px 24px;padding:18px;border-radius:18px;background:#f8fafc;color:#64748b;font-weight:700;text-align:center}.wa-log-stack{padding:16px;display:grid;gap:10px;max-height:490px;overflow:auto}.wa-log-item{display:flex;justify-content:space-between;gap:12px;align-items:flex-start;padding:14px;border:1px solid rgba(15,23,42,.08);border-radius:18px;background:#f8fafc}.wa-log-item strong{display:block;color:#0f172a}.wa-log-item span,.wa-log-item small{display:block;margin-top:3px;color:#64748b;font-size:12px;font-weight:700}.wa-pill{flex:0 0 auto;font-style:normal;border-radius:999px;padding:6px 9px;font-size:11px;font-weight:950;text-transform:uppercase;letter-spacing:.04em}.wa-pill.ok{background:#dcfce7;color:#166534;border:1px solid #bbf7d0}.wa-pill.fail{background:#fee2e2;color:#991b1b;border:1px solid #fecaca}@media(max-width:1100px){.wa-layout{grid-template-columns:1fr}.wa-side{position:static}.wa-status-panel{min-width:0;width:100%;grid-template-columns:repeat(2,minmax(0,1fr))}.wa-hero{flex-direction:column}}@media(max-width:760px){.wa-hero{padding:22px;border-radius:22px}.wa-toggle-grid,.wa-fieldset.two,.wa-status-panel{grid-template-columns:1fr}.wa-card-head,.wa-card-head.compact,.wa-form,.compact-form{padding-left:18px;padding-right:18px}.wa-card{border-radius:22px}.textarea-pair textarea{min-height:220px}}
