:root {
  --bg: #f6f8fb;
  --surface: #ffffff;
  --surface-soft: #f1f5f9;
  --text: #0f172a;
  --muted: #475569;
  --line: #dbe4f0;
  --primary: #0f4c81;
  --primary-2: #0b6aa8;
  --dark: #0b1220;
  --success: #0f9f6e;
  --warning: #d97706;
  --gray: #64748b;
  --shadow: 0 16px 42px rgba(15, 23, 42, 0.08);
  --radius: 22px;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: 'Inter', sans-serif;
  background: var(--bg);
  color: var(--text);
}

a { color: inherit; text-decoration: none; }
.container { width: min(1440px, calc(100% - 36px)); margin: 0 auto; }
.section { padding: 76px 0; }
.section-soft { background: linear-gradient(180deg, #f8fbff 0%, #f1f5fb 100%); }
.section-dark { padding: 76px 0; background: linear-gradient(135deg, #0b1220, #123559); color: #fff; }
.eyebrow {
  display: inline-block;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--primary-2);
  margin-bottom: 14px;
}
.section-dark .eyebrow { color: #9ad7ff; }
.section-head { text-align: center; max-width: 760px; margin: 0 auto 34px; }
.section-head h2 { font-size: 36px; margin: 0 0 12px; }
.section-head p { margin: 0; color: var(--muted); line-height: 1.7; }
.section-head-row {
  display: flex; justify-content: space-between; align-items: end; gap: 20px; max-width: 100%; text-align: left;
}

.site-header {
  position: sticky; top: 0; z-index: 50;
  background: rgba(255,255,255,.88); backdrop-filter: blur(14px);
  border-bottom: 1px solid rgba(219,228,240,.8);
}
.nav-wrap {
  display: grid;
  grid-template-columns: 320px minmax(0, 1fr) 230px;
  align-items: center;
  gap: 24px;
  min-height: 108px;
}
.brand {
  display: flex;
  align-items: center;
  gap: 16px;
  min-width: 0;
}
.brand-logo-only { display:flex; align-items:center; }
.brand-logo {
  width: min(100%, 300px);
  height: auto;
  display: block;
  object-fit: contain;
}
.brand-meta { min-width: 0; }
.brand strong, .sidebar-brand strong { display: block; font-size: 17px; line-height: 1.2; }
.brand span, .sidebar-brand span { color: var(--muted); font-size: 13px; line-height: 1.45; }
.brand-meta span { display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; max-width: 240px; }
.brand-badge {
  width: 48px; height: 48px; border-radius: 16px;
  display: grid; place-items: center; background: var(--dark); color: white; font-weight: 800;
  box-shadow: var(--shadow);
}
.main-nav {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  flex-wrap: nowrap;
  min-width: 0;
}
.main-nav > * { flex: 0 1 auto; }
.main-nav a {
  font-size: 15px;
  color: var(--muted);
  font-weight: 700;
  white-space: nowrap;
  letter-spacing: -.01em;
}
.main-nav a:hover { color: var(--text); }
.nav-actions { display: flex; gap: 10px; justify-content: flex-end; white-space: nowrap; }
.nav-actions .btn { padding: 12px 16px; min-height: 46px; }

.hero {
  padding: 86px 0 72px;
  background:
    radial-gradient(circle at top left, rgba(14,165,233,.15), transparent 28%),
    radial-gradient(circle at 90% 10%, rgba(15,23,42,.08), transparent 24%),
    linear-gradient(180deg, #fbfdff 0%, #f4f8fd 100%);
}
.hero-grid { display: grid; grid-template-columns: 1.15fr .85fr; gap: 30px; align-items: center; }
.hero h1 { margin: 0 0 16px; font-size: 58px; line-height: 1.04; letter-spacing: -.03em; }
.hero p { max-width: 700px; color: var(--muted); line-height: 1.8; font-size: 17px; }
.hero-actions { display: flex; gap: 12px; flex-wrap: wrap; margin: 28px 0 24px; }
.hero-stats { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 14px; }
.stat-card {
  background: var(--surface); border: 1px solid var(--line); border-radius: var(--radius); padding: 20px;
  box-shadow: var(--shadow);
}
.stat-card strong { display: block; font-size: 28px; margin-bottom: 6px; }
.stat-card span { color: var(--muted); font-size: 14px; }
.stat-card{min-height:132px;display:flex;flex-direction:column;justify-content:center}
.faq-grid .card{height:100%}
.hero-panel, .card {
  background: var(--surface); border: 1px solid var(--line); border-radius: 26px; padding: 28px; box-shadow: var(--shadow);
}
.hero-panel h3, .card h2, .card h3 { margin-top: 0; }
.check-list { padding-left: 18px; margin: 0; }
.check-list li { margin-bottom: 12px; color: var(--muted); }

.grid { display: grid; gap: 18px; }
.grid-2 { grid-template-columns: repeat(2, 1fr); }
.grid-3 { grid-template-columns: repeat(3, 1fr); }
.grid-4 { grid-template-columns: repeat(4, minmax(0, 1fr)); }
.grid-5 { grid-template-columns: repeat(5, minmax(0, 1fr)); }
.card p { color: var(--muted); line-height: 1.7; }
.promo-box {
  background: #e8f6ff; border: 1px solid #b5e0f8; border-radius: 18px; padding: 16px 18px;
  color: var(--primary); font-weight: 600;
}
.promo-box strong { display: inline-block; margin: 0 6px; text-decoration: line-through; color: #52738e; }
.promo-box span { color: #0a7f54; font-size: 20px; font-weight: 800; }
.course-card h3 { min-height: 62px; }
.course-meta { color: var(--muted); font-size: 14px; margin-bottom: 14px; }
.course-price { display: flex; justify-content: space-between; align-items: center; gap: 16px; margin-top: 18px; }
.course-price strong { font-size: 24px; }
.mentor-card strong { display: inline-block; margin-top: 14px; font-size: 24px; }
.testimonial p { font-style: italic; }
.course-cover{width:100%;height:190px;object-fit:cover;border-radius:18px;margin-bottom:18px;border:1px solid var(--line);background:#eef4f9}
.course-card{height:100%;display:flex;flex-direction:column}
.course-card p{flex:1}
.course-card h3{margin-bottom:10px}

.verify-wrap { display: grid; grid-template-columns: 1.1fr .9fr; gap: 30px; align-items: center; }
.verify-panel {
  background: rgba(255,255,255,.08); border: 1px solid rgba(255,255,255,.15); border-radius: 24px; padding: 24px;
}
.verify-panel label { display: block; margin-bottom: 8px; font-weight: 600; }
.verify-panel input, .form-grid input, .form-grid textarea {
  width: 100%; border-radius: 16px; border: 1px solid var(--line); padding: 14px 16px; font: inherit;
  background: white; color: var(--text);
}
.verify-result {
  margin-top: 14px; min-height: 72px; border-radius: 18px; background: rgba(255,255,255,.08); padding: 14px; font-size: 14px;
}
.verify-result.valid { background: rgba(16, 185, 129, .16); border: 1px solid rgba(16,185,129,.35); }
.verify-result.invalid { background: rgba(239, 68, 68, .16); border: 1px solid rgba(239,68,68,.35); }
.contact-card p { margin: 12px 0; }
.muted { color: var(--gray); }

.site-footer { background: #0e1628; color: #d4deea; padding: 28px 0; }
.footer-wrap { display: flex; justify-content: space-between; gap: 22px; align-items: center; }
.footer-links { display: flex; gap: 18px; flex-wrap: wrap; }
.footer-links a { color: #e5eef8; }

.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  border-radius: 14px; padding: 13px 18px; font-size: 14px; font-weight: 700;
  border: 1px solid transparent; cursor: pointer; transition: .2s ease;
}
.btn:hover { transform: translateY(-1px); }
.btn-light { background: white; border-color: var(--line); }
.btn-dark { background: var(--dark); color: white; }
.btn-primary { background: linear-gradient(135deg, var(--primary), var(--primary-2)); color: white; }
.btn-secondary { background: #eaf5ff; color: var(--primary); border-color: #b9dcfa; }
.btn-danger { background: #fee2e2; color: #b91c1c; border-color: #fecaca; }
.btn-block { width: 100%; }

.panel-body { background: #eef4f9; }
.panel-layout { display: grid; grid-template-columns: 280px 1fr; min-height: 100vh; }
.sidebar {
  background: #0d1525; color: white; padding: 26px 20px; border-right: 1px solid rgba(255,255,255,.06);
}
.sidebar-brand { display: flex; gap: 14px; align-items: center; margin-bottom: 28px; }
.sidebar-nav { display: grid; gap: 8px; }
.sidebar-nav a {
  color: #c7d1df; padding: 12px 14px; border-radius: 14px; font-size: 14px; font-weight: 600;
}
.sidebar-nav a.active, .sidebar-nav a:hover { background: rgba(255,255,255,.08); color: white; }
.panel-main { padding: 26px; }
.panel-topbar {
  display: flex; justify-content: space-between; gap: 18px; align-items: center; margin-bottom: 18px;
}
.panel-topbar h1 { margin: 0 0 6px; }
.panel-topbar p { margin: 0; color: var(--muted); }
.panel-section-gap { margin-top: 18px; }
.panel-stat { padding: 24px; }
.panel-stat strong { display: block; font-size: 30px; margin-bottom: 6px; }
.panel-stat span { color: var(--muted); }
.list-rows { display: grid; gap: 12px; }
.list-row {
  display: flex; justify-content: space-between; gap: 16px; align-items: center;
  border: 1px solid var(--line); background: #fbfdff; border-radius: 16px; padding: 14px 16px;
}
.badge {
  display: inline-flex; align-items: center; justify-content: center;
  border-radius: 999px; padding: 8px 12px; font-size: 12px; font-weight: 700;
}
.badge-success { background: rgba(16,185,129,.12); color: #047857; }
.badge-warning { background: rgba(245,158,11,.12); color: #b45309; }
.badge-muted { background: rgba(100,116,139,.12); color: #475569; }
.form-grid { display: grid; gap: 12px; }
.form-grid textarea { min-height: 120px; resize: vertical; }
.message-box { display: grid; gap: 10px; }
.message {
  border-radius: 16px; padding: 14px 16px; line-height: 1.6; font-size: 14px;
}
.message.admin { background: #eef6ff; border: 1px solid #c7def5; }
.message.member { background: #f4f8f2; border: 1px solid #d7ead0; }
.card-head-inline { display: flex; justify-content: space-between; align-items: start; gap: 18px; }
.grant-layout { margin-top: 18px; align-items: start; }
.member-summary { background: #f8fbff; border: 1px solid var(--line); border-radius: 18px; padding: 18px; }
.permission-card {
  background: #f8fbff; border: 1px solid var(--line); border-radius: 18px; padding: 18px; margin-bottom: 16px;
}
.permission-card label { display: block; margin-bottom: 10px; color: var(--muted); }

@media (max-width: 1360px) {
  .container { width: min(1380px, calc(100% - 28px)); }
  .nav-wrap { grid-template-columns: 280px minmax(0, 1fr) 210px; gap: 18px; }
  .brand-logo { width: min(100%, 260px); }
  .main-nav { gap: 12px; }
  .main-nav a { font-size: 14px; }
  .nav-actions .btn { padding: 11px 14px; }
}

@media (max-width: 1180px) {
  .nav-wrap { grid-template-columns: 250px minmax(0, 1fr) 190px; gap: 14px; }
  .brand-logo { width: min(100%, 235px); }
  .main-nav { gap: 10px; }
  .main-nav a { font-size: 13px; }
  .nav-actions .btn { padding: 10px 12px; font-size: 13px; }
}

@media (max-width: 1100px) {
  .main-nav { display: none; }
  .nav-wrap { display: flex; align-items: center; justify-content: space-between; min-height: 88px; }
  .hero-grid, .verify-wrap, .grid-4 { grid-template-columns: 1fr 1fr; }
  .grid-3, .grid-5 { grid-template-columns: 1fr 1fr; }
  .hero-stats { grid-template-columns: repeat(2, minmax(0,1fr)); }
  .section-head-row { flex-direction: column; align-items: start; }
}

@media (max-width: 820px) {
  .hero h1 { font-size: 42px; }
  .hero-grid, .verify-wrap, .grid-3, .grid-2, .grid-4, .grid-5, .panel-layout { grid-template-columns: 1fr; }
  .nav-wrap, .footer-wrap, .panel-topbar { flex-direction: column; align-items: stretch; }
  .brand { align-items: flex-start; }
  .brand-logo { width: min(100%, 270px); }
  .brand-meta span { max-width: none; }
  .site-header .header-logo { width: 64px; height: 64px; }
  .hero-stats { grid-template-columns: 1fr; }
  .panel-main { padding: 16px; }
  .sidebar { padding-bottom: 12px; }
}


.table-wrap{overflow:auto}
.table{width:100%;border-collapse:collapse}
.table th,.table td{padding:12px 14px;border-bottom:1px solid var(--line);text-align:left;font-size:14px}
.table th{background:#f8fbff;font-size:13px;text-transform:uppercase;letter-spacing:.06em;color:var(--gray)}
.alert{padding:14px 16px;border-radius:16px;margin:0 0 16px;border:1px solid transparent}
.alert-success{background:#ecfdf5;border-color:#a7f3d0;color:#166534}
.alert-error{background:#fef2f2;border-color:#fecaca;color:#991b1b}
.alert-info{background:#eff6ff;border-color:#bfdbfe;color:#1d4ed8}
.kpi-row{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.auth-wrap{max-width:520px;margin:40px auto}
.content-card{background:#fff;border:1px solid var(--line);border-radius:26px;padding:28px;box-shadow:var(--shadow)}
.content-card h1,.content-card h2,.content-card h3{margin-top:0}
.content-card .wysiwyg{line-height:1.8;color:var(--muted)}
.content-card .wysiwyg h1,.content-card .wysiwyg h2,.content-card .wysiwyg h3,.content-card .wysiwyg h4{color:var(--text);margin-top:24px}
.content-card .wysiwyg p{margin:0 0 14px}
.content-card .wysiwyg ul,.content-card .wysiwyg ol{padding-left:20px}
.page-hero{padding:52px 0;background:linear-gradient(180deg,#fbfdff 0%, #f4f8fd 100%)}
.page-hero h1{margin:0 0 8px;font-size:42px}
.page-hero p{margin:0;color:var(--muted)}
.form-row{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
.form-grid select{width:100%;border-radius:16px;border:1px solid var(--line);padding:14px 16px;font:inherit;background:white;color:var(--text)}
.form-grid button,.inline-form button{appearance:none}
.inline-form{display:flex;gap:8px;flex-wrap:wrap}
.kv-list{display:grid;gap:10px}
.kv-list div{display:flex;justify-content:space-between;gap:18px;padding:12px 0;border-bottom:1px solid var(--line)}
.stat-pill{display:inline-flex;padding:8px 12px;background:#eff6ff;border:1px solid #bfdbfe;border-radius:999px;font-size:12px;font-weight:700;color:#1d4ed8}
.status-pending{color:#b45309}
.status-active{color:#047857}
.status-passive,.status-cancelled{color:#991b1b}
.hero-logo{max-width:420px;width:100%;display:block;margin-left:auto}
.header-logo{width:52px;height:52px;object-fit:contain;border-radius:16px;background:#fff;border:1px solid var(--line);padding:6px}
.site-header .header-logo{width:72px;height:72px;border-radius:20px;padding:8px;box-shadow:0 10px 30px rgba(15,23,42,.06)}
.empty-state{padding:24px;border:1px dashed var(--line);border-radius:20px;color:var(--muted);background:#fbfdff}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:24px}
.subnav{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:16px}
.subnav a{padding:10px 14px;border-radius:999px;background:#fff;border:1px solid var(--line);font-size:13px;font-weight:600}
.subnav a.active{background:#0e1628;color:#fff;border-color:#0e1628}
.install-shell{min-height:100vh;background:linear-gradient(180deg,#f8fbff 0%,#eef4f9 100%);padding:36px 0}
.install-card{max-width:900px;margin:0 auto;background:#fff;border:1px solid var(--line);border-radius:28px;padding:30px;box-shadow:var(--shadow)}
.install-steps{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin:0 0 24px}
.install-step{padding:14px;border-radius:18px;background:#f8fbff;border:1px solid var(--line);font-size:13px;font-weight:700}
.badge-danger{background:rgba(239,68,68,.12);color:#b91c1c}
.code-inline{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;background:#f8fafc;border:1px solid var(--line);padding:2px 8px;border-radius:10px;font-size:13px}
@media (max-width: 820px){
  .kpi-row,.install-steps,.footer-grid,.form-row{grid-template-columns:1fr}
  .page-hero h1{font-size:34px}
}

.form-help{font-size:13px;color:#64748b;margin-top:10px}


.tab-links{display:flex;gap:10px;flex-wrap:wrap}
.tab-links a{padding:10px 14px;border:1px solid var(--line);border-radius:999px;background:#fff;color:var(--muted);font-weight:600}
.tab-links a.is-active{background:#eaf5ff;color:var(--primary);border-color:#b9dcfa}
summary.btn{cursor:pointer;list-style:none}
summary.btn::-webkit-details-marker{display:none}


.content-image{width:100%;max-height:220px;object-fit:cover;border-radius:18px;margin-bottom:14px;border:1px solid var(--line)}
.page-hero-image{max-width:220px;display:block;margin-bottom:18px}


/* Contact page pro patch */
.contact-hero {
  padding: 68px 0 54px;
  background:
    radial-gradient(circle at 10% 0%, rgba(11,106,168,.12), transparent 28%),
    radial-gradient(circle at 100% 0%, rgba(15,23,42,.07), transparent 26%),
    linear-gradient(180deg, #fbfdff 0%, #f3f8fd 100%);
}
.contact-hero-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(0, .95fr);
  gap: 26px;
  align-items: stretch;
}
.contact-hero-copy {
  padding: 18px 0;
}
.contact-hero-copy h1 {
  margin: 0 0 14px;
  font-size: 48px;
  line-height: 1.06;
  letter-spacing: -.03em;
}
.contact-hero-copy p {
  margin: 0;
  color: var(--muted);
  line-height: 1.8;
  font-size: 16px;
  max-width: 720px;
}
.contact-hero-actions {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  margin-top: 24px;
}
.contact-quick-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0,1fr));
  gap: 14px;
}
.contact-mini-card {
  position: relative;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  min-height: 150px;
  padding: 22px;
  border-radius: 24px;
  background: rgba(255,255,255,.9);
  border: 1px solid rgba(219,228,240,.96);
  box-shadow: 0 18px 36px rgba(15,23,42,.08);
  overflow: hidden;
}
.contact-mini-card::before {
  content: '';
  position: absolute;
  inset: 0 auto auto 0;
  width: 74px;
  height: 74px;
  border-radius: 0 0 24px 0;
  background: linear-gradient(135deg, rgba(11,106,168,.12), rgba(15,76,129,.02));
}
.contact-mini-card small {
  position: relative;
  display: inline-flex;
  align-self: flex-start;
  margin-bottom: 12px;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: var(--primary-2);
}
.contact-mini-card strong {
  position: relative;
  display: block;
  font-size: 22px;
  line-height: 1.2;
  margin-bottom: 10px;
}
.contact-mini-card span {
  position: relative;
  display: block;
  color: var(--muted);
  line-height: 1.65;
  font-size: 14px;
}
.contact-shell {
  display: grid;
  grid-template-columns: minmax(0, 1.15fr) minmax(0, .85fr);
  gap: 24px;
}
.contact-form-card,
.contact-info-card,
.contact-note-card,
.contact-map-card,
.contact-process-card {
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 28px;
  box-shadow: var(--shadow);
}
.contact-form-card { padding: 34px; }
.contact-form-head {
  display: flex;
  justify-content: space-between;
  gap: 18px;
  align-items: start;
  margin-bottom: 24px;
}
.contact-form-head h2,
.contact-info-card h3,
.contact-note-card h3,
.contact-map-card h3 { margin: 0 0 10px; }
.contact-form-head p,
.contact-info-card p,
.contact-note-card p,
.contact-map-card p { margin: 0; color: var(--muted); line-height: 1.75; }
.contact-pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 10px 14px;
  border-radius: 999px;
  background: #eaf5ff;
  border: 1px solid #b9dcfa;
  color: var(--primary);
  font-size: 12px;
  font-weight: 800;
  letter-spacing: .08em;
  text-transform: uppercase;
  white-space: nowrap;
}
.contact-form-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0,1fr));
  gap: 14px;
}
.contact-form-grid .full { grid-column: 1 / -1; }
.contact-form-grid textarea {
  min-height: 180px;
  resize: vertical;
}
.contact-side {
  display: grid;
  gap: 18px;
}
.contact-info-card,
.contact-note-card,
.contact-map-card { padding: 28px; }
.contact-info-grid {
  display: grid;
  gap: 14px;
  margin-top: 18px;
}
.contact-info-item {
  display: grid;
  grid-template-columns: 56px 1fr;
  gap: 14px;
  align-items: start;
  padding: 14px 0;
  border-bottom: 1px solid var(--line);
}
.contact-info-item:last-child { border-bottom: 0; padding-bottom: 0; }
.contact-icon {
  width: 56px;
  height: 56px;
  border-radius: 18px;
  display: grid;
  place-items: center;
  background: linear-gradient(135deg, #eff6ff, #e0f2fe);
  border: 1px solid #bfdbfe;
  color: var(--primary);
  font-size: 12px;
  font-weight: 800;
  letter-spacing: .08em;
  text-transform: uppercase;
}
.contact-info-item strong {
  display: block;
  margin-bottom: 6px;
  font-size: 17px;
}
.contact-info-item span,
.contact-info-item a {
  color: var(--muted);
  line-height: 1.7;
  word-break: break-word;
}
.contact-action-stack {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  margin-top: 18px;
}
.contact-note-list {
  display: grid;
  gap: 12px;
  margin-top: 18px;
}
.contact-note-list div {
  padding: 14px 16px;
  border-radius: 18px;
  background: #f8fbff;
  border: 1px solid var(--line);
}
.contact-note-list strong {
  display: block;
  margin-bottom: 6px;
  font-size: 15px;
}
.contact-map-card iframe {
  width: 100%;
  height: 280px;
  border: 0;
  border-radius: 20px;
  margin-top: 18px;
  background: #f1f5f9;
}
.contact-map-link {
  display: inline-flex;
  margin-top: 16px;
  color: var(--primary);
  font-weight: 700;
}
.contact-process-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap: 18px;
}
.contact-process-card {
  padding: 24px;
}
.contact-process-card strong {
  display: inline-flex;
  width: 44px;
  height: 44px;
  border-radius: 14px;
  align-items: center;
  justify-content: center;
  margin-bottom: 18px;
  background: linear-gradient(135deg, var(--primary), var(--primary-2));
  color: #fff;
  font-size: 16px;
}
.contact-process-card h3 {
  margin: 0 0 10px;
  font-size: 22px;
}
.contact-process-card p {
  margin: 0;
  color: var(--muted);
  line-height: 1.75;
}
@media (max-width: 1180px) {
  .contact-hero-copy h1 { font-size: 42px; }
}
@media (max-width: 1100px) {
  .contact-hero-grid,
  .contact-shell,
  .contact-process-grid { grid-template-columns: 1fr; }
}
@media (max-width: 820px) {
  .contact-hero { padding: 54px 0 42px; }
  .contact-hero-copy h1 { font-size: 36px; }
  .contact-form-card,
  .contact-info-card,
  .contact-note-card,
  .contact-map-card,
  .contact-process-card { padding: 22px; }
  .contact-form-head { flex-direction: column; }
  .contact-form-grid,
  .contact-quick-grid { grid-template-columns: 1fr; }
}
