/* =========================================
   RSE subpages
   Shared layout + page-specific polish
   Works with index.css tokens/components
   ========================================= */

.page{
  padding: 30px 0 44px;
}

.stack{
  display: grid;
  gap: 22px;
}

.two,
.three,
.row,
.grid2,
.pp-grid{
  display: grid;
  gap: 16px;
  align-items: start;
}

.two,
.row,
.grid2,
.pp-grid{
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.three{
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.card{
  position: relative;
  overflow: hidden;
  border-radius: 26px;
}

.card::before{
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(255,255,255,.2), rgba(255,255,255,0));
  pointer-events: none;
}

.card > *{
  position: relative;
  z-index: 1;
}

.card.soft,
.card.accent,
.soft-tone,
.note,
.toggle-block,
.form-status,
.choice,
.flyer,
.pp-card,
.pp-head,
.paxton-terms,
.sigpad,
.docs-cancel-card,
.updates-panel,
.updates-survey-card,
.updates-admin-note{
  box-shadow: var(--shadow-soft);
}

.card.soft{
  border: 1px solid rgba(31,39,34,.10);
  background: linear-gradient(180deg, rgba(255,255,255,.86) 0%, rgba(243,238,228,.92) 100%);
}

.card.accent{
  border: 1px solid rgba(79,107,87,.18);
  background:
    radial-gradient(circle at top right, rgba(200,122,44,.10), transparent 28%),
    radial-gradient(circle at top left, rgba(123,138,42,.10), transparent 34%),
    linear-gradient(180deg, rgba(255,255,255,.92) 0%, rgba(236,243,233,.94) 100%);
}

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

.badge{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 30px;
  padding: 6px 12px;
  border-radius: 999px;
  border: 1px solid rgba(31,39,34,.10);
  background: rgba(255,255,255,.7);
  font-size: 11px;
  font-weight: 900;
  letter-spacing: .06em;
  text-transform: uppercase;
  color: var(--deep-green);
  white-space: nowrap;
}

.note,
.smallprint,
.hint,
.page-intro,
.linklist,
.list,
.flow,
.security-checklist,
.contacts-checklist,
.docs-checklist,
.community-helper-list{
  max-width: none;
}

.note{
  margin-top: 14px;
  padding: 14px 16px;
  border-radius: 18px;
  border: 1px solid rgba(31,39,34,.08);
  background: rgba(255,255,255,.64);
  font-size: 13.5px;
  line-height: 1.58;
  color: rgba(31,39,34,.72);
}

.note strong{ color: var(--ink); }

.smallprint{
  font-size: 12px;
  line-height: 1.6;
  color: rgba(31,39,34,.60);
}

.page-intro{
  margin: 0;
  font-size: 15px;
  line-height: 1.64;
  color: rgba(31,39,34,.74);
}

.backlink{
  display: inline-block;
  margin-top: 8px;
  font-weight: 900;
  color: var(--deep-green);
}

.backlink:hover{
  text-decoration: underline;
  text-underline-offset: 4px;
}

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

.field label{
  display: block;
  margin-bottom: 7px;
  font-size: 12px;
  font-weight: 900;
  letter-spacing: .03em;
  color: rgba(31,39,34,.78);
}

.input,
.select,
.textarea,
.join-page select.input,
.docs-page select.input{
  width: 100%;
  border: 1px solid rgba(31,39,34,.12);
  border-radius: 16px;
  background: rgba(255,255,255,.82);
  padding: 13px 14px;
  font-size: 14px;
  line-height: 1.45;
  color: var(--ink);
  outline: none;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.35);
  transition: border-color .15s ease, box-shadow .15s ease, background .15s ease, transform .15s ease;
}

.input:hover,
.select:hover,
.textarea:hover,
.join-page select.input:hover,
.docs-page select.input:hover{
  border-color: rgba(111,168,165,.24);
}

.input:focus,
.select:focus,
.textarea:focus,
.join-page select.input:focus,
.docs-page select.input:focus{
  border-color: rgba(111,168,165,.44);
  box-shadow: 0 0 0 4px rgba(111,168,165,.10);
  background: rgba(255,255,255,.94);
}

.textarea{ min-height: 110px; resize: vertical; }

.hint{
  margin-top: 7px;
  font-size: 12px;
  line-height: 1.45;
  color: rgba(31,39,34,.60);
}

.btnrow{
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
  margin-top: 6px;
}

.form-status{
  padding: 13px 14px;
  border-radius: 16px;
  border: 1px solid rgba(31,39,34,.08);
  background: rgba(255,255,255,.78);
  font-weight: 800;
}

.form-status.success{
  background: rgba(235,247,236,.94);
  border-color: rgba(62,135,74,.20);
}

.form-status.error{
  background: rgba(252,241,239,.94);
  border-color: rgba(183,28,28,.18);
}

.hp{
  position: absolute;
  left: -9999px;
  top: auto;
  width: 1px;
  height: 1px;
  overflow: hidden;
}

.form-section-title{
  margin: 22px 0 8px;
  padding: 10px 14px;
  border-radius: 14px;
  border: 1px solid rgba(31,39,34,.08);
  background: rgba(255,255,255,.72);
  font-size: 14px;
  font-weight: 950;
  letter-spacing: .04em;
  text-transform: uppercase;
  color: var(--ink);
}

.form-section-title:first-of-type{ margin-top: 10px; }

.choice{
  position: relative;
  display: flex;
  gap: 10px;
  align-items: flex-start;
  padding: 13px 14px;
  border-radius: 18px;
  border: 1px solid rgba(31,39,34,.08);
  background: linear-gradient(180deg, rgba(255,255,255,.84) 0%, rgba(244,239,230,.90) 100%);
  line-height: 1.5;
  transition: transform .14s ease, box-shadow .14s ease, border-color .14s ease;
}

.choice:hover{
  transform: translateY(-1px);
  border-color: rgba(123,138,42,.18);
}

.choice input{
  margin-top: 4px;
  accent-color: var(--olive);
}

.toggle-block{
  margin-top: 12px;
  padding: 14px;
  border-radius: 20px;
  border: 1px solid rgba(31,39,34,.08);
  background: linear-gradient(180deg, rgba(255,255,255,.76) 0%, rgba(244,239,230,.78) 100%);
}

.linklist,
.list,
.flow{
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  gap: 10px;
}

.linklist li,
.list li,
.flow li{
  padding: 13px 14px;
  border-radius: 16px;
  border: 1px solid rgba(31,39,34,.08);
  background: rgba(255,255,255,.64);
}

.linklist li,
.list li{
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  align-items: baseline;
}

.flow{
  counter-reset: step;
}

.flow li{
  counter-increment: step;
  display: grid;
  grid-template-columns: 30px 1fr;
  gap: 12px;
}

.flow li::before{
  content: counter(step) ".";
  color: rgba(31,39,34,.56);
  font-weight: 950;
  text-align: right;
}

.linklist a,
.list a{
  color: var(--deep-green);
  font-weight: 900;
}

.sep{
  margin: 0 6px;
  opacity: .34;
  font-weight: 900;
}

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

.flyer{
  margin: 0;
  padding: 10px;
  border-radius: 20px;
  border: 1px solid rgba(31,39,34,.08);
  background: rgba(255,255,255,.70);
}

.flyer img{
  width: 100%;
  height: 240px;
  object-fit: cover;
  border-radius: 14px;
}

.flyer figcaption{
  margin-top: 10px;
  font-size: 12px;
  color: rgba(31,39,34,.62);
}

.print-pack{
  margin-top: 16px;
  padding: 14px;
  border-radius: 22px;
  border: 1px solid rgba(31,39,34,.10);
  background: rgba(255,255,255,.68);
}

.pp-head,
.pp-card{
  border: 1px solid rgba(31,39,34,.10);
  background: rgba(255,255,255,.9);
}

.pp-head{
  display: flex;
  justify-content: space-between;
  gap: 18px;
  align-items: flex-start;
  padding: 14px;
  border-radius: 18px;
}

.pp-head h3{ margin: 0; font-size: 18px; }
.pp-muted{ opacity: .72; font-weight: 700; }
.pp-meta{ font-size: 14px; line-height: 1.55; }

.pp-card{
  margin-top: 12px;
  padding: 14px;
  border-radius: 18px;
}

.pp-card h4{
  margin: 0 0 10px;
  font-size: 13px;
  text-transform: uppercase;
  letter-spacing: .06em;
  color: rgba(31,39,34,.62);
}

.pp-box,
.pp-note{
  margin-top: 8px;
  padding: 10px 12px;
  border-radius: 12px;
  background: rgba(255,255,255,.88);
  border: 1px solid rgba(31,39,34,.10);
}

.pp-box{ white-space: pre-wrap; }
.pp-note{ border-left: 4px solid rgba(31,39,34,.18); }
.pp-sign{ margin-top: 16px; }
.pp-sign .line{
  height: 1px;
  width: 320px;
  max-width: 100%;
  background: rgba(31,39,34,.40);
  margin-bottom: 6px;
}

.pp-sigimg{
  width: 320px;
  max-width: 100%;
  padding: 8px;
  border-radius: 12px;
  border: 1px solid rgba(31,39,34,.16);
  background: rgba(255,255,255,.94);
  margin-top: 8px;
}

.pp-sigimg img{
  display: block;
  max-width: 100%;
  max-height: 70px;
}

.paxton-terms{
  margin-top: 12px;
  padding: 12px 14px;
  border-radius: 18px;
  border: 1px solid rgba(31,39,34,.10);
  background: linear-gradient(180deg, rgba(255,255,255,.76) 0%, rgba(245,239,234,.78) 100%);
}

.paxton-terms summary{ cursor: pointer; font-weight: 900; }
.paxton-terms-body{ margin-top: 10px; line-height: 1.6; }
.paxton-terms-body hr{ border: 0; border-top: 1px solid rgba(31,39,34,.14); margin: 14px 0; }

.sigpad{
  border-radius: 20px;
  border: 1px solid rgba(31,39,34,.14);
  background: linear-gradient(180deg, rgba(255,255,255,.92) 0%, rgba(247,243,236,.92) 100%);
  padding: 8px;
}

.sigpad canvas{
  width: 100%;
  height: 150px;
  display: block;
  border-radius: 12px;
  background: rgba(255,255,255,.78);
}

.micro-links a.active{
  opacity: 1;
  text-decoration: underline;
  text-underline-offset: 4px;
  text-decoration-thickness: 2px;
}

.topbar .micro-links a[aria-current="page"]{
  opacity: 1;
  text-decoration: underline;
  text-underline-offset: 4px;
  text-decoration-thickness: 2px;
}

/* ---------- Shared intro and section patterns ---------- */
.contacts-intro-card,
.community-intro-card,
.docs-intro-card,
.join-intro-card,
.security-intro-card,
.updates-intro-card,
.contacts-band,
.community-band,
.docs-band,
.join-guidance-card,
.security-info-band,
.security-final-card,
.community-info-band,
.updates-band,
.updates-admin-note,
.docs-cancel-card{
  border-radius: 28px;
  border: 1px solid rgba(31,39,34,.10);
  box-shadow: var(--shadow-main);
}

.contacts-intro-card,
.community-intro-card,
.docs-intro-card,
.join-intro-card,
.security-intro-card,
.updates-intro-card{
  padding: 26px;
}

.contacts-title,
.community-title,
.docs-title,
.join-title,
.security-title,
.updates-title{
  margin: 0 0 10px;
  font-size: clamp(2.1rem, 4vw, 3.3rem);
  line-height: 1.02;
  letter-spacing: -.04em;
  color: var(--ink);
}

.contacts-lead,
.community-lead,
.docs-lead,
.join-lead,
.security-lead,
.updates-lead{
  margin: 0;
  font-size: 15.5px;
  line-height: 1.65;
  color: rgba(31,39,34,.76);
}

.contacts-keyfacts,
.community-keyfacts,
.docs-keyfacts,
.join-keyfacts,
.security-keyfacts,
.updates-keyfacts{
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
  margin-top: 20px;
}

.contacts-fact,
.community-fact,
.docs-fact,
.join-fact,
.security-fact,
.updates-fact{
  padding: 14px 16px;
  border-radius: 18px;
  border: 1px solid rgba(31,39,34,.08);
  background: rgba(255,255,255,.66);
}

.contacts-fact .k,
.community-fact .k,
.docs-fact .k,
.join-fact .k,
.security-fact .k,
.updates-fact .k{
  display: block;
  margin-bottom: 4px;
  font-size: 11px;
  font-weight: 900;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: rgba(31,39,34,.58);
}

.contacts-fact .v,
.community-fact .v,
.docs-fact .v,
.join-fact .v,
.security-fact .v,
.updates-fact .v{
  font-size: 15px;
  line-height: 1.35;
  color: var(--ink);
}

.contacts-section,
.community-section,
.docs-section,
.security-section,
.updates-section{
  margin-bottom: 22px;
}

.contacts-section-head,
.community-section-head,
.updates-section-head,
.security-section-head{
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 14px;
}

.contacts-band,
.community-band,
.docs-band,
.updates-band,
.community-info-band,
.security-info-band,
.security-final-card{
  display: grid;
  gap: 18px;
  align-items: center;
  padding: 22px;
}

.contacts-band,
.community-band,
.updates-band{
  grid-template-columns: 1.1fr .9fr;
}

.community-info-band,
.security-info-band{
  grid-template-columns: 1.15fr .85fr;
}

.contacts-band h2,
.community-band h2,
.docs-band h2,
.join-guidance-card h2,
.community-info-band h2,
.security-section-head h2,
.security-info-band h2,
.security-final-card h2,
.updates-band h2,
.updates-section-head h2,
.contacts-section-head h2,
.community-section-head h2{
  margin: 0;
  font-size: clamp(1.75rem, 3vw, 2.35rem);
  line-height: 1.08;
  letter-spacing: -.03em;
}

.contacts-flow,
.community-flow,
.docs-flow,
.updates-flow,
.security-process{
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
}

.contacts-flow,
.community-flow,
.updates-flow{ justify-content: flex-end; }

.contacts-flow-step,
.community-flow-step,
.docs-flow-step,
.updates-flow-step,
.process-step{
  min-height: 46px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0 14px;
  border-radius: 14px;
  border: 1px solid rgba(31,39,34,.10);
  background: rgba(255,255,255,.74);
  font-weight: 900;
  color: var(--ink);
}

.contacts-flow-arrow,
.community-flow-arrow,
.docs-flow-arrow,
.updates-flow-arrow,
.process-arrow{
  font-weight: 900;
  color: rgba(31,39,34,.44);
}

/* ---------- Security ---------- */
.security-intro-card{
  background:
    radial-gradient(circle at top right, rgba(200,122,44,.12), transparent 30%),
    radial-gradient(circle at top left, rgba(123,138,42,.10), transparent 35%),
    linear-gradient(180deg, rgba(255,255,255,.92) 0%, rgba(244,239,230,.95) 100%);
}

.security-panel,
.security-role-card{
  padding: 22px;
  border-radius: 24px;
  border: 1px solid rgba(31,39,34,.10);
  background: linear-gradient(180deg, rgba(255,255,255,.84) 0%, rgba(243,238,228,.90) 100%);
}

.security-panel.soft-tone{
  background:
    radial-gradient(circle at top right, rgba(111,168,165,.08), transparent 30%),
    linear-gradient(180deg, rgba(255,255,255,.86) 0%, rgba(238,243,237,.92) 100%);
}

.security-panel h3,
.security-role-card h3{
  margin: 0 0 8px;
  font-size: 24px;
  line-height: 1.12;
}

.security-panel p,
.security-role-card p,
.security-info-band p,
.security-final-card p{
  margin: 0;
  color: rgba(31,39,34,.76);
  line-height: 1.6;
}

.security-statement{
  margin-top: 14px;
  padding: 16px 18px;
  border-radius: 18px;
  background: linear-gradient(135deg, rgba(200,122,44,.96) 0%, rgba(123,138,42,.92) 100%);
  color: #fff;
  font-weight: 900;
  font-size: 18px;
  line-height: 1.35;
}

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

.security-chip,
.mini-point{
  display: flex;
  align-items: center;
  min-height: 46px;
  padding: 10px 12px;
  border-radius: 14px;
  border: 1px solid rgba(31,39,34,.08);
  background: rgba(255,255,255,.72);
  color: rgba(31,39,34,.82);
  font-weight: 800;
  line-height: 1.4;
}

.security-info-band{
  background:
    radial-gradient(circle at top right, rgba(200,122,44,.10), transparent 30%),
    radial-gradient(circle at top left, rgba(111,168,165,.08), transparent 35%),
    linear-gradient(180deg, rgba(255,255,255,.90) 0%, rgba(244,239,230,.94) 100%);
}

.security-final-card{
  display: flex;
  justify-content: space-between;
  background:
    radial-gradient(circle at top right, rgba(111,168,165,.10), transparent 32%),
    linear-gradient(180deg, rgba(255,255,255,.90) 0%, rgba(244,239,230,.94) 100%);
}

.security-checklist,
.contacts-checklist,
.docs-checklist{
  list-style: none;
  padding: 0;
  margin: 16px 0 0;
  display: grid;
  gap: 10px;
}

.security-checklist li,
.contacts-checklist li,
.docs-checklist li{
  position: relative;
  padding: 12px 14px 12px 42px;
  border-radius: 16px;
  border: 1px solid rgba(31,39,34,.08);
  background: rgba(255,255,255,.64);
  color: rgba(31,39,34,.80);
  line-height: 1.5;
}

.security-checklist li::before,
.contacts-checklist li::before,
.docs-checklist li::before{
  content: "•";
  position: absolute;
  left: 16px;
  top: 9px;
  font-size: 22px;
  line-height: 1;
  color: var(--olive);
  font-weight: 900;
}

/* ---------- Contacts ---------- */
.contacts-intro-card{
  background:
    radial-gradient(circle at top right, rgba(157,77,63,.12), transparent 30%),
    radial-gradient(circle at top left, rgba(200,122,44,.10), transparent 34%),
    linear-gradient(180deg, rgba(255,255,255,.92) 0%, rgba(244,239,230,.95) 100%);
}

.contacts-band{
  background:
    radial-gradient(circle at top right, rgba(200,122,44,.12), transparent 30%),
    radial-gradient(circle at top left, rgba(111,168,165,.10), transparent 34%),
    linear-gradient(180deg, rgba(255,255,255,.90) 0%, rgba(244,239,230,.94) 100%);
}

.contacts-grid{ align-items: stretch; }

.contacts-panel{
  padding: 22px;
  border-radius: 24px;
  border: 1px solid rgba(31,39,34,.10);
  background: linear-gradient(180deg, rgba(255,255,255,.84) 0%, rgba(243,238,228,.90) 100%);
}

.contacts-panel-primary{
  background:
    radial-gradient(circle at top right, rgba(111,168,165,.18), transparent 34%),
    linear-gradient(180deg, rgba(237,248,246,.96) 0%, rgba(223,241,236,.96) 100%);
  border-color: rgba(63,95,69,.18);
}

.contacts-panel-alert{
  background:
    radial-gradient(circle at top right, rgba(157,77,63,.18), transparent 34%),
    linear-gradient(180deg, rgba(252,241,239,.96) 0%, rgba(247,228,224,.96) 100%);
  border-color: rgba(157,77,63,.18);
}

.contacts-panel.soft-tone{ background: linear-gradient(180deg, rgba(255,255,255,.90) 0%, rgba(245,240,230,.96) 100%); }

.contacts-panel-head,
.community-platform-head,
.join-downloads-head,
.docs-cancel-head{
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 10px;
}

.contacts-actions,
.directory-links{
  display: grid;
  gap: 12px;
}

.contact-action{
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  padding: 14px 16px;
  border-radius: 16px;
  border: 1px solid rgba(31,39,34,.10);
  background: linear-gradient(180deg, rgba(255,255,255,.94) 0%, rgba(244,239,230,.94) 100%);
}

.contact-action.strong{ color: #fff; }
.contacts-page a[href="tel:+27123489187"].contact-action.strong{ background: linear-gradient(135deg, #487a67 0%, #6fa8a5 100%); }
.contacts-page a[href="tel:112"].contact-action.strong{ background: linear-gradient(135deg, #b84f43 0%, #d06757 100%); }
.contacts-page a[href*="wa.me"].contact-action{ background: linear-gradient(135deg, rgba(37,211,102,.16) 0%, rgba(255,255,255,.94) 100%); border-color: rgba(37,211,102,.22); }
.contacts-page a[href="tel:10111"].contact-action{ background: linear-gradient(135deg, rgba(32,86,159,.16) 0%, rgba(255,255,255,.94) 100%); border-color: rgba(32,86,159,.22); }
.contacts-page a[href="tel:10111"].contact-action strong{ color: #20569f; }

.contact-action .label{
  font-size: 12px;
  font-weight: 900;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: rgba(31,39,34,.58);
}

.contact-action strong{ font-size: 18px; color: var(--ink); }
.contact-action.strong .label,
.contact-action.strong strong{ color: #fff; }

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

.directory-card{
  padding: 18px;
  border-radius: 20px;
  border: 1px solid rgba(31,39,34,.08);
  background: rgba(255,255,255,.72);
}

.directory-card:nth-child(1){ background: linear-gradient(180deg, rgba(236,245,240,.96) 0%, rgba(226,238,231,.96) 100%); }
.directory-card:nth-child(2){ background: linear-gradient(180deg, rgba(246,239,230,.96) 0%, rgba(239,230,219,.96) 100%); }
.directory-card:nth-child(3){ background: linear-gradient(180deg, rgba(244,236,228,.96) 0%, rgba(238,226,215,.96) 100%); }
.directory-card:nth-child(4){ background: linear-gradient(180deg, rgba(236,241,247,.96) 0%, rgba(226,233,241,.96) 100%); }

.directory-card h3{ margin: 0 0 4px; font-size: 21px; }
.directory-card p{ margin: 0 0 12px; color: rgba(31,39,34,.62); }
.directory-links a{ font-weight: 800; color: var(--deep-green); }

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

.contacts-chip{
  display: grid;
  gap: 4px;
  padding: 14px 16px;
  border-radius: 18px;
  border: 1px solid rgba(31,39,34,.08);
  background: rgba(255,255,255,.72);
  transition: transform .14s ease, box-shadow .14s ease;
}

.contacts-chip:hover{ transform: translateY(-2px); box-shadow: var(--shadow-soft); }
.contacts-chip span{ font-size: 12px; font-weight: 900; letter-spacing: .06em; text-transform: uppercase; color: rgba(31,39,34,.58); }
.contacts-chip strong{ font-size: 18px; color: var(--ink); }
.contacts-chip:nth-child(1){ background: linear-gradient(135deg, rgba(224,244,228,.96) 0%, rgba(240,249,242,.96) 100%); border-color: rgba(62,135,74,.18); }
.contacts-chip:nth-child(1) strong{ color: #2e7d32; }
.contacts-chip:nth-child(2){ background: linear-gradient(135deg, rgba(230,246,236,.96) 0%, rgba(242,250,245,.96) 100%); border-color: rgba(46,125,50,.16); }
.contacts-chip:nth-child(2) strong{ color: #2f7a52; }
.contacts-chip:nth-child(3){ background: linear-gradient(135deg, rgba(252,236,228,.96) 0%, rgba(250,245,240,.96) 100%); border-color: rgba(200,122,44,.22); }
.contacts-chip:nth-child(3) strong{ color: #c87a2c; }
.contacts-chip:nth-child(4){ background: linear-gradient(135deg, rgba(250,231,227,.96) 0%, rgba(252,242,240,.96) 100%); border-color: rgba(157,77,63,.22); }
.contacts-chip:nth-child(4) strong{ color: #9d4d3f; }
.contacts-chip:nth-child(5){ background: linear-gradient(135deg, rgba(232,238,248,.96) 0%, rgba(242,246,252,.96) 100%); border-color: rgba(58,91,138,.20); }
.contacts-chip:nth-child(5) strong{ color: #3f5f8d; }
.contacts-chip:nth-child(6){ background: linear-gradient(135deg, rgba(248,240,226,.96) 0%, rgba(251,246,239,.96) 100%); border-color: rgba(166,118,55,.18); }
.contacts-chip:nth-child(6) strong{ color: #9a6a2a; }

/* ---------- Join ---------- */
.join-intro-card{
  background:
    radial-gradient(circle at top right, rgba(200,122,44,.10), transparent 30%),
    radial-gradient(circle at top left, rgba(123,138,42,.10), transparent 35%),
    linear-gradient(180deg, rgba(255,255,255,.92) 0%, rgba(244,239,230,.95) 100%);
}

.join-guidance-card{
  padding: 22px;
  background:
    radial-gradient(circle at top right, rgba(111,168,165,.08), transparent 30%),
    linear-gradient(180deg, rgba(255,255,255,.90) 0%, rgba(244,239,230,.94) 100%);
}

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

.join-step{
  min-height: 58px;
  display: flex;
  align-items: center;
  padding: 12px 14px;
  border-radius: 16px;
  border: 1px solid rgba(31,39,34,.08);
  background: rgba(255,255,255,.72);
  font-weight: 800;
  color: rgba(31,39,34,.82);
}

.join-form-shell{
  padding: 24px;
  border: 1px solid rgba(79,107,87,.18);
  box-shadow: 0 18px 36px rgba(40,55,45,.10);
}

.join-page .form-section-title:nth-of-type(1){ background: linear-gradient(135deg, rgba(111,168,165,.16) 0%, rgba(255,255,255,.82) 100%); border-color: rgba(111,168,165,.20); }
.join-page .form-section-title:nth-of-type(2){ background: linear-gradient(135deg, rgba(200,122,44,.14) 0%, rgba(255,255,255,.82) 100%); border-color: rgba(200,122,44,.18); }
.join-page .form-section-title:nth-of-type(3){ background: linear-gradient(135deg, rgba(123,138,42,.16) 0%, rgba(255,255,255,.82) 100%); border-color: rgba(123,138,42,.18); }
.join-page .form-section-title:nth-of-type(4){ background: linear-gradient(135deg, rgba(63,95,69,.14) 0%, rgba(255,255,255,.82) 100%); border-color: rgba(63,95,69,.18); }
.join-page .form-section-title:nth-of-type(5){ background: linear-gradient(135deg, rgba(157,77,63,.12) 0%, rgba(255,255,255,.82) 100%); border-color: rgba(157,77,63,.16); }
.join-page .form-section-title:nth-of-type(6),
.join-page .form-section-title:nth-of-type(7){ background: linear-gradient(135deg, rgba(111,168,165,.10) 0%, rgba(200,122,44,.10) 100%); }

.join-page label.choice:has(input[name="levy"]){ background: linear-gradient(180deg, rgba(239,246,233,.94) 0%, rgba(247,242,232,.92) 100%); }
.join-page label.choice:has(input[name="monitoring"]){ background: linear-gradient(180deg, rgba(248,241,230,.96) 0%, rgba(255,255,255,.90) 100%); }
.join-page label.choice:has(input[name="payment_method"]){ background: linear-gradient(180deg, rgba(236,244,247,.96) 0%, rgba(255,255,255,.90) 100%); border-color: rgba(111,168,165,.18); }
.join-page label.choice:has(#want_alarm_link),
.join-page label.choice:has(#want_concession){ background: linear-gradient(180deg, rgba(243,237,247,.94) 0%, rgba(255,255,255,.90) 100%); border-color: rgba(137,109,170,.16); }
.join-page label.choice:has(#agree_terms){ background: linear-gradient(180deg, rgba(235,244,237,.96) 0%, rgba(255,255,255,.90) 100%); border-color: rgba(63,95,69,.18); }
.join-page .toggle-block .toggle-block{ background: linear-gradient(180deg, rgba(255,255,255,.74) 0%, rgba(247,242,234,.74) 100%); }
.join-page #printPackCard,
.join-downloads-card{
  padding: 22px;
  border-radius: 24px;
  border: 1px solid rgba(31,39,34,.10);
  background:
    radial-gradient(circle at top right, rgba(200,122,44,.10), transparent 30%),
    radial-gradient(circle at top left, rgba(123,138,42,.08), transparent 34%),
    linear-gradient(180deg, rgba(255,255,255,.90) 0%, rgba(244,239,230,.94) 100%);
}

/* ---------- Community ---------- */
.community-intro-card{
  background:
    radial-gradient(circle at top right, rgba(123,138,42,.12), transparent 30%),
    radial-gradient(circle at top left, rgba(111,168,165,.10), transparent 35%),
    linear-gradient(180deg, rgba(255,255,255,.92) 0%, rgba(244,239,230,.95) 100%);
}

.community-band,
.community-info-band{
  background:
    radial-gradient(circle at top right, rgba(200,122,44,.10), transparent 30%),
    radial-gradient(circle at top left, rgba(111,168,165,.08), transparent 35%),
    linear-gradient(180deg, rgba(255,255,255,.90) 0%, rgba(244,239,230,.94) 100%);
}

.community-flow{ 
  display: grid;
  grid-template-columns: 1fr auto 1fr auto 1fr;
  justify-content: stretch;
}
.community-flow-step{ width: 100%; text-align: center; white-space: nowrap; }
.community-platform{
  padding: 22px;
  border-radius: 24px;
  border: 1px solid rgba(31,39,34,.10);
}
.community-platform.whatsapp{
  background:
    radial-gradient(circle at top right, rgba(37,211,102,.12), transparent 30%),
    linear-gradient(180deg, rgba(236,248,240,.96) 0%, rgba(244,239,230,.92) 100%);
}
.community-platform.telegram{
  background:
    radial-gradient(circle at top right, rgba(32,86,159,.12), transparent 30%),
    linear-gradient(180deg, rgba(236,242,250,.96) 0%, rgba(244,239,230,.92) 100%);
}
.community-platform-kicker{
  font-size: 12px;
  font-weight: 900;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: rgba(31,39,34,.58);
  margin-bottom: 4px;
}
.community-platform h3{ margin: 0; font-size: clamp(24px, 2.4vw, 32px); line-height: 1.08; }
.community-group-grid{
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}
.community-group-grid.smaller{ grid-template-columns: 1fr; }
.community-group-card{
  padding: 16px;
  border-radius: 18px;
  border: 1px solid rgba(31,39,34,.08);
  background: rgba(255,255,255,.76);
}
.community-group-card h4{ margin: 0 0 6px; font-size: 18px; letter-spacing: 0; text-transform: none; color: var(--ink); }
.community-group-card p{ margin: 0; color: rgba(31,39,34,.72); line-height: 1.52; }
.community-group-card.featured{ background: linear-gradient(135deg, rgba(200,122,44,.12) 0%, rgba(123,138,42,.12) 100%); border-color: rgba(123,138,42,.18); }
.community-form-shell{ padding: 24px; border: 1px solid rgba(79,107,87,.18); box-shadow: 0 18px 36px rgba(40,55,45,.10); }
.community-page .community-form-shell .form-section-title:nth-of-type(1){ background: linear-gradient(135deg, rgba(111,168,165,.16) 0%, rgba(255,255,255,.82) 100%); border-color: rgba(111,168,165,.20); }
.community-page .community-form-shell .form-section-title:nth-of-type(2){ background: linear-gradient(135deg, rgba(123,138,42,.16) 0%, rgba(255,255,255,.82) 100%); border-color: rgba(123,138,42,.18); }
.community-page .community-form-shell .form-section-title:nth-of-type(3){ background: linear-gradient(135deg, rgba(200,122,44,.14) 0%, rgba(255,255,255,.82) 100%); border-color: rgba(200,122,44,.18); }
.community-helper-head h3{ margin: 0; font-size: 22px; line-height: 1.12; }
.community-helper-list{ margin: 12px 0 0 18px; color: rgba(31,39,34,.72); line-height: 1.6; }
.community-helper-list li{ margin: 8px 0; }

/* ---------- Docs ---------- */
.docs-intro-card{
  background:
    radial-gradient(circle at top right, rgba(111,168,165,.10), transparent 30%),
    radial-gradient(circle at top left, rgba(200,122,44,.10), transparent 34%),
    linear-gradient(180deg, rgba(255,255,255,.92) 0%, rgba(244,239,230,.95) 100%);
}
.docs-band{
  grid-template-columns: 1.1fr .9fr;
  background:
    radial-gradient(circle at top right, rgba(111,168,165,.08), transparent 30%),
    linear-gradient(180deg, rgba(255,255,255,.90) 0%, rgba(244,239,230,.94) 100%);
}
.docs-form-shell,
.docs-form-shell-alt{
  padding: 24px;
}
.docs-page .form-section-title:nth-of-type(1){ background: linear-gradient(135deg, rgba(111,168,165,.14) 0%, rgba(255,255,255,.82) 100%); border-color: rgba(111,168,165,.18); }
.docs-page .form-section-title:nth-of-type(2){ background: linear-gradient(135deg, rgba(200,122,44,.14) 0%, rgba(255,255,255,.82) 100%); border-color: rgba(200,122,44,.18); }
.docs-page .form-section-title:nth-of-type(3){ background: linear-gradient(135deg, rgba(123,138,42,.12) 0%, rgba(255,255,255,.82) 100%); border-color: rgba(123,138,42,.16); }
.docs-cancel-card{
  padding: 22px;
  background:
    radial-gradient(circle at top right, rgba(200,122,44,.10), transparent 30%),
    linear-gradient(180deg, rgba(255,255,255,.90) 0%, rgba(244,239,230,.94) 100%);
}
.docs-cancel-grid{
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
  margin-top: 14px;
}
.docs-cancel-box{
  padding: 18px;
  border-radius: 20px;
  border: 1px solid rgba(31,39,34,.08);
  background: rgba(255,255,255,.72);
}
.docs-cancel-box h3{ margin: 0 0 10px; }
.docs-cancel-mail{ font-weight: 900; color: var(--deep-green); }

/* ---------- Updates ---------- */
.updates-intro-card{
  background:
    radial-gradient(circle at top right, rgba(200,122,44,.12), transparent 30%),
    radial-gradient(circle at top left, rgba(111,168,165,.10), transparent 34%),
    linear-gradient(180deg, rgba(255,255,255,.92) 0%, rgba(244,239,230,.95) 100%);
}
.updates-band,
.updates-admin-note{
  background:
    radial-gradient(circle at top right, rgba(200,122,44,.10), transparent 30%),
    radial-gradient(circle at top left, rgba(111,168,165,.08), transparent 34%),
    linear-gradient(180deg, rgba(255,255,255,.90) 0%, rgba(244,239,230,.94) 100%);
}
.updates-grid,
.updates-survey-grid{ align-items: stretch; }
.updates-panel,
.updates-survey-card{
  padding: 22px;
  border-radius: 24px;
  border: 1px solid rgba(31,39,34,.10);
  background: linear-gradient(180deg, rgba(255,255,255,.86) 0%, rgba(243,238,228,.92) 100%);
}
.updates-panel-news{ background: linear-gradient(180deg, rgba(236,245,240,.96) 0%, rgba(244,239,230,.92) 100%); }
.updates-panel-archive{ background: linear-gradient(180deg, rgba(246,239,230,.96) 0%, rgba(244,239,230,.92) 100%); }
.updates-panel-events{ background: linear-gradient(180deg, rgba(255,255,255,.88) 0%, rgba(244,239,230,.94) 100%); }
.updates-download-card{
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  margin-top: 16px;
  padding: 14px 16px;
  border-radius: 18px;
  border: 1px solid rgba(31,39,34,.08);
  background: rgba(255,255,255,.78);
}
.updates-download-card .label{
  display: block;
  margin-bottom: 3px;
  font-size: 12px;
  font-weight: 900;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: rgba(31,39,34,.58);
}
.updates-mini-points,
.community-mini-points,
.security-mini-points{
  display: grid;
  gap: 10px;
}

/* ---------- Responsive ---------- */
@media (max-width: 980px){
  .two,
  .three,
  .row,
  .grid2,
  .pp-grid,
  .contacts-keyfacts,
  .community-keyfacts,
  .docs-keyfacts,
  .join-keyfacts,
  .security-keyfacts,
  .updates-keyfacts,
  .security-chip-grid,
  .contacts-directory,
  .contacts-chip-grid,
  .community-group-grid,
  .join-steps,
  .docs-cancel-grid,
  .community-info-band,
  .security-info-band{
    grid-template-columns: 1fr;
  }

  .contacts-band,
  .community-band,
  .docs-band,
  .updates-band,
  .security-final-card{
    grid-template-columns: 1fr;
  }

  .contacts-flow,
  .community-flow,
  .updates-flow{
    justify-content: flex-start;
  }

  .community-flow{
    display: flex;
  }

  .community-flow-step{
    width: auto;
    white-space: normal;
    text-align: left;
  }

  .security-final-card{
    flex-direction: column;
    align-items: flex-start;
  }
}

@media (max-width: 720px){
  .page{ padding: 22px 0 34px; }

  .contacts-intro-card,
  .community-intro-card,
  .docs-intro-card,
  .join-intro-card,
  .security-intro-card,
  .updates-intro-card,
  .contacts-band,
  .community-band,
  .docs-band,
  .join-guidance-card,
  .join-form-shell,
  .join-downloads-card,
  .community-info-band,
  .community-platform,
  .community-form-shell,
  .docs-form-shell,
  .docs-form-shell-alt,
  .docs-cancel-card,
  .security-panel,
  .security-info-band,
  .security-final-card,
  .updates-band,
  .updates-panel,
  .updates-survey-card,
  .updates-admin-note{
    padding: 20px;
  }

  .contacts-title,
  .community-title,
  .docs-title,
  .join-title,
  .security-title,
  .updates-title{
    font-size: clamp(1.95rem, 8vw, 2.7rem);
  }

  .micro-links{
    flex-wrap: nowrap;
    overflow-x: auto;
    white-space: nowrap;
    -webkit-overflow-scrolling: touch;
    padding-bottom: 4px;
    gap: 12px;
  }
  .micro-links::-webkit-scrollbar{ height: 0; }

  .contacts-flow-arrow,
  .community-flow-arrow,
  .docs-flow-arrow,
  .updates-flow-arrow,
  .process-arrow{ display: none; }

  .flyers{ grid-template-columns: 1fr; }
  .flyer img{ height: 220px; }
  .pp-head,
  .updates-download-card{ flex-direction: column; align-items: flex-start; }
}

@media print {
  body *{ visibility: hidden !important; }
  #printPackCard,
  #printPackCard *{ visibility: visible !important; }
  #printPackCard{
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
  }
  .topbar,
  .footer,
  .btnrow,
  .backlink{ display: none !important; }
  .pp-card,
  .pp-head{ break-inside: avoid; }
}

/* Default (desktop) */
.nav-how .short{
  display: none !important;
}

.nav-how .full{
  display: inline;
}

/* Mobile */
@media (max-width: 720px){
  .nav-how .full{
    display: none !important;
  }

  .nav-how .short{
    display: inline !important;
  }
}

#sigCanvas{
  touch-action: none;
}

.updates-stats-row{
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
  margin-bottom: 16px;
}

.updates-stat-card{
  padding: 18px;
  border-radius: 20px;
  border: 1px solid rgba(31,39,34,.08);
  background: rgba(255,255,255,.74);
  box-shadow: var(--shadow-soft);
}

.updates-stat-card span{
  display: block;
  margin-bottom: 6px;
  font-size: 11px;
  font-weight: 900;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: rgba(31,39,34,.58);
}

.updates-stat-card strong{
  display: block;
  font-size: clamp(2rem, 4vw, 3rem);
  line-height: 1;
  color: var(--deep-green);
}

.updates-stat-card small{
  display: block;
  margin-top: 8px;
  color: rgba(31,39,34,.62);
}

@media (max-width: 720px){
  .updates-stats-row{
    grid-template-columns: 1fr;
  }
}

.updates-stats-row-4{
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

@media (max-width: 980px){
  .updates-stats-row-4{
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 720px){
  .updates-stats-row-4{
    grid-template-columns: 1fr;
  }
}

.crime-chart-wrap{
  position: relative;
  width: 100%;
  height: 400px;
}

@media (max-width: 720px){
  .updates-section .updates-panel{
    padding: 14px;
  }

  .crime-chart-wrap{
    height: 320px;
  }
}

@media (max-width: 420px){
  .crime-chart-wrap{
    height: 300px;
  }
}