:root {
  --rz-bg: #040f1a;
  --rz-surface: #071b2a;
  --rz-surface-2: #0b2436;
  --rz-text: #f4fbff;
  --rz-text-soft: #c8d8e5;
  --rz-text-dark: #0d1a28;
  --rz-muted-dark: #365066;
  --rz-light: #eaf2f6;
  --rz-card: #f7fbff;
  --rz-accent: #74d64b;
  --rz-cyan: #68f1ff;
  --rz-glow: rgba(104, 241, 255, 0.26);
  --rz-glow-green: rgba(116, 214, 75, 0.3);
  --rz-shadow-lg: 0 30px 90px rgba(2, 12, 20, 0.4);
  --rz-shadow-md: 0 14px 44px rgba(4, 16, 26, 0.24);
  --rz-radius: 18px;
  --rz-radius-sm: 12px;
  --rz-max: 1220px;
  --rz-hero-image: url("../img/rz-hero-premium-property-fast.jpg");
  --rz-motion-image: url("../img/rz-installed-exterior-fast.jpg");
  --rz-trust-image: url("../img/rz-night-security-trust-fast.jpg");
  --rz-final-image: url("../img/rz-night-security-trust-fast.jpg");
}

html {
  scroll-behavior: smooth;
}

body.ringzone-final-live-wow {
  background: #e9eff2;
  color: var(--rz-text-dark);
  font-family: "Inter", "Segoe UI", Arial, sans-serif;
  text-rendering: optimizeLegibility;
  -webkit-font-smoothing: antialiased;
}

body.ringzone-final-live-wow .container,
body.ringzone-final-live-wow .container-width,
body.ringzone-final-live-wow .row {
  max-width: none;
}

.rz-page,
.rz-builder-page {
  overflow-x: clip;
}

.rz-page a {
  text-decoration: none;
}

.rz-kicker,
.rz-eyebrow {
  margin: 0 0 10px;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 1.7px;
  text-transform: uppercase;
  color: #2fd07d;
}

.rz-section-title,
.rz-page h2 {
  margin: 0;
  font-size: clamp(32px, 4.3vw, 52px);
  line-height: 1.03;
  letter-spacing: 0;
  color: var(--rz-text-dark);
}

.rz-dark .rz-section-title,
.rz-dark h2,
.rz-final-cta h2,
.rz-trust-scene h2,
.rz-ux-final-native h2,
.rz-ux-trust-scene-native h2,
.rz-ux-services-native h2,
.rz-ux-reviews-native h2,
.rz-ux-audience-native h2 {
  color: var(--rz-text);
}

.rz-copy,
.rz-dark-copy,
.rz-page p,
.rz-page li {
  font-size: 15px;
  line-height: 1.63;
  letter-spacing: 0;
}

.rz-dark-copy,
.rz-dark p {
  color: #cdd7e1;
}

.rz-wrap {
  width: min(var(--rz-max), calc(100% - 56px));
  margin: 0 auto;
}

.rz-section {
  padding: clamp(64px, 8vw, 96px) 0;
}

.rz-btn,
.button.rz-btn,
.rz-page .button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 44px;
  border: 1px solid transparent;
  border-radius: 999px;
  padding: 0 20px;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.5px;
  text-transform: uppercase;
  transition: transform 0.25s ease, box-shadow 0.25s ease, background-color 0.25s ease, border-color 0.25s ease, color 0.25s ease;
}

.rz-btn:hover,
.button.rz-btn:hover,
.rz-page .button:hover {
  transform: translateY(-1px);
  box-shadow: 0 10px 20px rgba(9, 27, 40, 0.24);
}

.rz-btn-primary,
.button.rz-btn-primary,
.rz-page .button.rz-btn-primary {
  color: #031014 !important;
  background: linear-gradient(135deg, #d6fcff 0%, #7aff9b 100%) !important;
  border-color: rgba(126, 255, 189, 0.75) !important;
}

.rz-btn-ghost,
.button.rz-btn-ghost {
  color: #e9f6ff !important;
  background: rgba(8, 28, 42, 0.76) !important;
  border-color: rgba(158, 198, 224, 0.44) !important;
}

.rz-btn-hot,
.button.rz-btn-hot {
  color: #e9fbff !important;
  background: rgba(15, 38, 56, 0.9) !important;
  border-color: rgba(89, 242, 255, 0.5) !important;
}

.rz-reveal {
  opacity: 0.001;
  transform: translateY(24px);
  transition: opacity 0.65s ease, transform 0.65s ease;
}

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

/* Header */
.rz-site-header {
  position: fixed;
  top: calc(12px + var(--wp-admin--admin-bar--height, 0px));
  left: 50%;
  z-index: 999;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  width: min(calc(100% - 36px), 1220px);
  padding: 10px 16px;
  border-radius: 999px;
  transform: translateX(-50%);
  background: rgba(8, 21, 34, 0.72);
  border: 1px solid rgba(132, 201, 238, 0.2);
  box-shadow: 0 18px 40px rgba(3, 12, 21, 0.34);
  backdrop-filter: blur(14px);
}

.rz-logo img {
  width: clamp(190px, 16vw, 220px);
  max-height: 50px;
  object-fit: contain;
  object-position: left center;
}

.rz-menu {
  display: flex;
  align-items: center;
  gap: 18px;
}

.rz-nav {
  display: flex;
  align-items: center;
  gap: 16px;
}

.rz-nav a {
  color: #d9ebf7;
  font-size: 12px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.4px;
}

.rz-header-cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 38px;
  padding: 0 16px;
  border-radius: 999px;
  background: linear-gradient(120deg, #d8fbff 0%, #73f289 100%);
  color: #05212f;
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.rz-menu-toggle {
  display: none;
  width: 40px;
  height: 40px;
  border: 1px solid rgba(161, 209, 236, 0.45);
  border-radius: 12px;
  background: rgba(7, 27, 42, 0.72);
  padding: 9px;
}

.rz-menu-toggle span {
  display: block;
  width: 100%;
  height: 2px;
  border-radius: 2px;
  margin: 0 0 5px;
  background: #d9ebf7;
}

.rz-menu-toggle span:last-child {
  margin-bottom: 0;
}

/* Hero (UX Builder + fallback) */
body .section.rz-native-ux-homepage,
body .section.rz-ux-hero-shell,
.rz-hero {
  position: relative;
  overflow: hidden;
  background:
    radial-gradient(60% 68% at 18% 42%, rgba(91, 235, 255, 0.28) 0%, rgba(6, 17, 29, 0) 63%),
    radial-gradient(52% 58% at 88% 12%, rgba(117, 226, 90, 0.26) 0%, rgba(2, 10, 18, 0) 62%),
    linear-gradient(90deg, rgba(3, 13, 23, 0.9) 0%, rgba(3, 15, 25, 0.56) 48%, rgba(4, 17, 24, 0.78) 100%),
    var(--rz-hero-image) center right/cover no-repeat;
}

body .section.rz-native-ux-homepage::after,
body .section.rz-ux-hero-shell::after,
.rz-hero::after {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(180deg, rgba(3, 11, 19, 0.12) 0%, rgba(2, 11, 20, 0.5) 100%),
    linear-gradient(120deg, rgba(3, 15, 27, 0.72) 0%, rgba(3, 15, 27, 0.16) 44%, rgba(1, 9, 15, 0.34) 100%);
  pointer-events: none;
}

body .section.rz-native-ux-homepage > .section-content,
body .section.rz-ux-hero-shell > .section-content,
.rz-hero > * {
  position: relative;
  z-index: 1;
}

body .section.rz-native-ux-homepage .row,
body .section.rz-ux-hero-shell .row {
  max-width: min(var(--rz-max), calc(100% - 56px)) !important;
  margin-inline: auto !important;
  padding: clamp(128px, 12vw, 176px) 0 clamp(72px, 9vw, 116px);
}

.rz-hero {
  padding: clamp(122px, 11vw, 164px) 0 clamp(70px, 8vw, 108px);
}

.rz-hero-content {
  width: min(var(--rz-max), calc(100% - 56px));
  margin: 0 auto;
  display: grid;
  align-items: start;
  gap: 24px;
  grid-template-columns: 1.1fr 0.9fr;
}

body .rz-native-ux-homepage h1,
body .rz-ux-hero-shell h1,
.rz-hero h1 {
  margin: 8px 0 16px;
  color: #f5fcff;
  font-size: clamp(42px, 6.2vw, 72px);
  line-height: 0.96;
  letter-spacing: 0;
  max-width: 12ch;
  text-wrap: balance;
  text-shadow: 0 20px 60px rgba(0, 0, 0, 0.48), 0 0 22px rgba(107, 238, 255, 0.1);
}

.rz-hero-copy,
body .rz-native-ux-homepage .rz-hero-copy {
  color: #d9e8f4;
  max-width: 64ch;
  margin: 0 0 18px;
}

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

.rz-hero-proof {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 14px;
}

.rz-hero-proof span {
  display: inline-flex;
  align-items: center;
  min-height: 33px;
  border-radius: 999px;
  border: 1px solid rgba(153, 201, 226, 0.36);
  background: rgba(7, 27, 42, 0.6);
  color: #e2f0f8;
  font-size: 11px;
  font-weight: 650;
  padding: 0 12px;
}

body .rz-native-ux-homepage .row-inner {
  margin-top: 20px;
}

.rz-proof-pill {
  display: inline-flex;
  align-items: center;
  min-height: 34px;
  padding: 0 12px;
  border-radius: 999px;
  border: 1px solid rgba(153, 201, 226, 0.36);
  background: rgba(7, 27, 42, 0.6);
  color: #e2f0f8;
  font-size: 11px;
  font-weight: 650;
  margin: 0;
}

.rz-ux-glass-col > .col-inner,
.rz-hero-card {
  border-radius: 18px;
  border: 1px solid rgba(176, 224, 246, 0.42);
  background:
    radial-gradient(120% 100% at 16% 4%, rgba(134, 244, 255, 0.15) 0%, rgba(134, 244, 255, 0) 48%),
    linear-gradient(175deg, rgba(255, 255, 255, 0.2) 0%, rgba(34, 65, 78, 0.32) 42%, rgba(5, 18, 29, 0.82) 100%);
  box-shadow: 0 34px 95px rgba(0, 0, 0, 0.46), inset 0 1px 0 rgba(255, 255, 255, 0.16);
  backdrop-filter: blur(18px);
  padding: clamp(20px, 2vw, 26px);
}

.rz-card-topline {
  margin: 0 0 6px;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  color: #75f08d;
}

body .rz-ux-glass-col h2,
.rz-hero-card h2 {
  margin: 0 0 14px;
  color: #f5fcff;
  font-size: clamp(24px, 2.3vw, 34px);
  line-height: 1.1;
}

/* Postcode checker */
.rz-checker {
  display: grid;
  gap: 12px;
}

.rz-checker-steps {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.rz-checker-steps span {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  min-height: 28px;
  padding: 0 10px;
  border-radius: 999px;
  background: rgba(8, 29, 44, 0.58);
  border: 1px solid rgba(155, 196, 219, 0.3);
  font-size: 11px;
  color: #d7e8f4;
}

.rz-checker-steps b {
  color: #78f193;
}

.rz-field {
  display: grid;
  gap: 6px;
}

.rz-field > span {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 1.2px;
  text-transform: uppercase;
  color: #cff0ff;
}

.rz-checker input,
.rz-checker textarea {
  width: 100%;
  min-height: 42px;
  border-radius: 10px;
  border: 1px solid rgba(151, 196, 220, 0.4);
  background: rgba(4, 16, 27, 0.78);
  color: #f5fbff;
  padding: 10px 12px;
  font-size: 14px;
}

.rz-checker textarea {
  min-height: 86px;
  resize: vertical;
}

.rz-checker input::placeholder,
.rz-checker textarea::placeholder {
  color: #9eb6c9;
}

.rz-checker-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.rz-btn-quote {
  color: #e7f4ff !important;
  background: rgba(16, 42, 63, 0.9);
  border-color: rgba(119, 249, 160, 0.52);
}

.rz-flow-message {
  min-height: 21px;
  margin: 0;
  font-size: 13px;
  color: #c9dae7;
}

.rz-flow-message.is-good {
  color: #90ffbf;
}

.rz-flow-message.is-bad {
  color: #ffc3cd;
}

.rz-service-picker {
  display: grid;
  gap: 10px;
}

.rz-service-picker[hidden],
.rz-booking-fields[hidden],
.rz-btn-quote[hidden] {
  display: none !important;
}

.rz-picker-title {
  color: #ddf2ff;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 1.2px;
  font-weight: 700;
}

.rz-service-options {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
}

.rz-service-option {
  text-align: left;
  border-radius: 10px;
  border: 1px solid rgba(148, 195, 221, 0.38);
  background: rgba(7, 28, 42, 0.72);
  color: #edf7ff;
  padding: 10px;
}

.rz-service-option strong {
  display: block;
  margin-bottom: 2px;
  font-size: 13px;
}

.rz-service-option span {
  font-size: 11px;
  color: #9cecb8;
}

.rz-service-option.is-selected {
  border-color: rgba(117, 234, 143, 0.75);
  box-shadow: 0 0 0 1px rgba(117, 234, 143, 0.3) inset;
}

.rz-booking-fields {
  display: grid;
  gap: 11px;
}

.rz-booking-summary,
.rz-checker-note {
  margin: 0;
  font-size: 12px;
  color: #d3e4f0;
}

.rz-form-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.rz-submit {
  justify-self: start;
}

/* Trust strip */
body .section.rz-ux-trust-native,
.rz-trust-strip {
  background:
    linear-gradient(140deg, rgba(4, 14, 23, 0.98) 0%, rgba(7, 28, 44, 0.96) 48%, rgba(4, 14, 25, 0.96) 100%);
  border-top: 1px solid rgba(125, 199, 231, 0.18);
  border-bottom: 1px solid rgba(125, 199, 231, 0.18);
}

body .section.rz-ux-trust-native .row,
.rz-trust-strip {
  max-width: min(var(--rz-max), calc(100% - 56px)) !important;
  margin: 0 auto !important;
  padding: 14px 0;
}

body .section.rz-ux-trust-native .col-inner,
.rz-trust-strip > div {
  border-radius: 12px;
  border: 1px solid rgba(121, 187, 217, 0.18);
  background: rgba(5, 21, 35, 0.5);
  padding: 14px 14px 12px;
}

.rz-trust-dot {
  width: 8px;
  height: 8px;
  margin: 0 0 8px;
  border-radius: 50%;
  background: linear-gradient(120deg, #63efff, #73d64b);
  box-shadow: 0 0 16px rgba(100, 239, 255, 0.45);
}

body .section.rz-ux-trust-native h3 {
  margin: 0 0 4px;
  color: #f0f9ff;
  font-size: 15px;
  line-height: 1.2;
}

body .section.rz-ux-trust-native p:not(.rz-trust-dot) {
  margin: 0;
  color: #bdd2e3;
  font-size: 12px;
  line-height: 1.45;
}

.rz-trust-strip > div > span {
  display: block;
  width: 8px;
  height: 8px;
  margin: 0 0 8px;
  border-radius: 999px;
  background: linear-gradient(120deg, #63efff, #73d64b);
  box-shadow: 0 0 16px rgba(100, 239, 255, 0.45);
}

.rz-trust-strip strong,
.rz-trust-strip small {
  display: block;
}

.rz-trust-strip strong {
  color: #f0f9ff;
  font-size: 15px;
  line-height: 1.2;
}

.rz-trust-strip small {
  margin-top: 4px;
  color: #bdd2e3;
  font-size: 12px;
  line-height: 1.45;
}

/* Light sections */
body .section.rz-ux-authority-native,
body .section.rz-ux-story-native,
body .section.rz-ux-included-native,
body .section.rz-ux-pricing-native,
body .section.rz-ux-coverage-native,
body .section.rz-ux-faq-native,
body .section.rz-ux-booking-native,
.rz-section.rz-authority,
.rz-section.rz-story,
.rz-section.rz-included,
.rz-section.rz-pricing,
.rz-section.rz-coverage,
.rz-section.rz-faq,
.rz-section.rz-booking-band {
  background:
    radial-gradient(62% 62% at 92% 8%, rgba(123, 226, 190, 0.18) 0%, rgba(233, 239, 242, 0) 56%),
    linear-gradient(180deg, #edf4f6 0%, #e7eef2 100%);
}

body .section.rz-ux-authority-native,
body .section.rz-ux-story-native,
body .section.rz-ux-included-native,
body .section.rz-ux-pricing-native,
body .section.rz-ux-coverage-native,
body .section.rz-ux-faq-native,
body .section.rz-ux-booking-native {
  border-top: 1px solid #d8e4ec;
}

.rz-ux-card-col > .col-inner,
.rz-authority-card {
  height: 100%;
  border-radius: 16px;
  border: 1px solid rgba(202, 220, 231, 0.92);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.98) 0%, rgba(241, 248, 251, 0.96) 100%);
  box-shadow: 0 18px 48px rgba(6, 23, 35, 0.14), inset 0 1px 0 rgba(255, 255, 255, 0.9);
  padding: 20px 18px;
}

.rz-ux-card-col h3,
.rz-authority-card b {
  display: block;
  margin: 0 0 8px;
  color: #0f2232;
  font-size: 19px;
  line-height: 1.16;
}

.rz-ux-card-col p,
.rz-authority-card span {
  display: block;
  margin: 0;
  color: #3f5568;
  font-size: 14px;
}

/* Audience dark section */
body .section.rz-ux-audience-native,
.rz-positioning {
  background:
    radial-gradient(84% 70% at 18% 28%, rgba(84, 230, 255, 0.2) 0%, rgba(3, 13, 22, 0) 58%),
    linear-gradient(160deg, #02101b 0%, #08243a 56%, #041421 100%);
}

.rz-ux-audience-card > .col-inner,
.rz-audience-card {
  border-radius: 14px;
  border: 1px solid rgba(163, 198, 218, 0.32);
  background: rgba(10, 31, 46, 0.82);
  min-height: 100%;
  padding: 18px 16px;
}

.rz-ux-audience-card p:first-child,
.rz-audience-card > span {
  margin: 0 0 8px;
  display: inline-block;
  color: #73ef9d;
  font-size: 12px;
  font-weight: 700;
}

.rz-ux-audience-card h3,
.rz-audience-card h3 {
  margin: 0 0 8px;
  color: #f4fbff;
  font-size: 20px;
}

.rz-ux-audience-card p,
.rz-audience-card p {
  margin: 0;
  color: #ccdde9;
}

/* Story section */
body .section.rz-ux-story-native {
  background:
    radial-gradient(52% 40% at 90% 16%, rgba(102, 236, 255, 0.22) 0%, rgba(233, 239, 242, 0) 100%),
    #e9eff2;
}

.rz-ux-install-image-col > .col-inner,
.rz-device-scene {
  border-radius: 18px;
  min-height: 430px;
  background:
    linear-gradient(180deg, rgba(6, 20, 35, 0.14) 0%, rgba(4, 17, 31, 0.58) 100%),
    var(--rz-motion-image) center/cover no-repeat;
  box-shadow: var(--rz-shadow-lg);
  padding: 20px;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
}

.rz-ux-install-image-col h3,
.rz-device-caption strong {
  margin: 0;
  color: #f5fbff;
  font-size: 20px;
  line-height: 1.25;
}

.rz-step-list,
body .rz-ux-story-native .row-inner {
  display: grid;
  gap: 10px;
  margin-top: 16px;
}

.rz-step-list article,
body .rz-ux-story-native .row-inner .col-inner {
  border-left: 3px solid #6ee38f;
  padding: 4px 0 4px 12px;
}

.rz-step-list b,
body .rz-ux-story-native .row-inner h3 {
  margin: 0 0 3px;
  color: #0f2232;
  font-size: 16px;
}

.rz-step-list span,
body .rz-ux-story-native .row-inner p {
  color: #42586b;
  font-size: 13px;
}

/* Dark trust scene */
body .section.rz-ux-trust-scene-native,
.rz-trust-scene {
  position: relative;
  overflow: hidden;
  background:
    linear-gradient(160deg, rgba(3, 11, 20, 0.82) 0%, rgba(4, 14, 24, 0.82) 100%),
    var(--rz-trust-image) center/cover no-repeat;
}

body .section.rz-ux-trust-scene-native::before,
.rz-trust-scene::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(1, 8, 14, 0.42), rgba(1, 8, 14, 0.78));
}

body .section.rz-ux-trust-scene-native > .section-content,
.rz-trust-scene > * {
  position: relative;
  z-index: 1;
}

.rz-ux-dark-card > .col-inner,
.rz-image-led-card {
  border-radius: 14px;
  border: 1px solid rgba(150, 191, 214, 0.35);
  background: rgba(5, 21, 34, 0.68);
  backdrop-filter: blur(8px);
  padding: 16px 14px;
}

.rz-ux-dark-card p,
.rz-image-led-card span {
  margin: 0 0 7px;
  color: #78f09a;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 1.1px;
  text-transform: uppercase;
}

.rz-ux-dark-card h3,
.rz-image-led-card h3 {
  margin: 0;
  color: #f3fbff;
  font-size: 18px;
  line-height: 1.25;
}

/* Services */
body .section.rz-ux-services-native,
.rz-services-section {
  background:
    radial-gradient(66% 72% at 8% 26%, rgba(85, 230, 255, 0.24) 0%, rgba(4, 15, 25, 0) 56%),
    radial-gradient(62% 58% at 94% 74%, rgba(64, 222, 135, 0.2) 0%, rgba(4, 15, 25, 0) 54%),
    linear-gradient(158deg, #041623 0%, #06233a 54%, #041521 100%);
}

.rz-ux-service-card > .col-inner,
.rz-service-card {
  --rz-ux-service-img: url("../img/rz-hero-premium-property-fast.jpg");
  position: relative;
  min-height: 286px;
  border-radius: 18px;
  overflow: hidden;
  border: 1px solid rgba(165, 211, 234, 0.34);
  background:
    radial-gradient(96% 70% at 18% 8%, rgba(91, 233, 255, 0.16) 0%, rgba(4, 15, 24, 0) 52%),
    linear-gradient(180deg, rgba(2, 9, 15, 0.2) 0%, rgba(2, 10, 18, 0.62) 45%, rgba(2, 10, 18, 0.94) 100%),
    var(--rz-card-img, var(--rz-ux-service-img)) center/cover no-repeat;
  box-shadow: 0 18px 46px rgba(0, 0, 0, 0.26);
  padding: 18px 17px 16px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  gap: 10px;
}

.rz-ux-service-doorbell > .col-inner,
.rz-service-card.rz-service-doorbell {
  --rz-ux-service-img: url("../img/rz-doorbell-close-fast.jpg");
  background-position: center center;
}

.rz-ux-service-cctv > .col-inner,
.rz-service-card.rz-service-cctv {
  --rz-ux-service-img: url("../img/rz-stock-cctv-urban-fast.jpg");
  background-position: center center;
}

.rz-ux-service-alarm > .col-inner,
.rz-service-card.rz-service-alarm {
  --rz-ux-service-img: url("../img/rz-stock-keypad-access-fast.jpg");
  background-position: center center;
}

.rz-ux-service-wifi > .col-inner,
.rz-service-card.rz-service-wifi {
  --rz-ux-service-img: url("../img/rz-stock-wifi-router-fast.jpg");
  background-position: center 60%;
}

.rz-ux-service-tv > .col-inner,
.rz-service-card.rz-service-tv {
  --rz-ux-service-img: url("../img/rz-stock-tv-wall-mounted-fast.jpg");
  background-position: center center;
}

.rz-ux-service-airbnb > .col-inner,
.rz-service-card.rz-service-airbnb {
  --rz-ux-service-img: url("../img/rz-stock-airbnb-entry-fast.jpg");
  background-position: center 45%;
}

.rz-ux-service-card p:first-child,
.rz-service-card .rz-service-code {
  margin: 0;
  color: #9effbf;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 1.1px;
}

.rz-service-card span {
  display: block;
  margin: 0 0 4px;
  color: #a6f8bd;
  font-size: 12px;
  font-weight: 700;
}

.rz-ux-service-card h3,
.rz-service-card h3 {
  margin: 0 0 5px;
  color: #f7fdff;
  font-size: 27px;
  line-height: 1.03;
  text-shadow: 0 10px 28px rgba(0, 0, 0, 0.55);
}

.rz-ux-service-card .ux-text p:last-child,
.rz-service-card p {
  margin: 0;
  color: #edf6fb;
  font-size: 13px;
  line-height: 1.45;
}

.rz-ux-services-native .button,
.rz-service-card a {
  min-height: 40px;
  width: fit-content;
  border-radius: 999px;
  padding: 0 15px;
  border: 1px solid rgba(126, 255, 183, 0.44);
  background: rgba(5, 23, 35, 0.82);
  color: #f3fbff !important;
  font-size: 11px;
  letter-spacing: 0.4px;
  text-transform: uppercase;
}

/* Included section */
body .section.rz-ux-included-native {
  background:
    radial-gradient(48% 60% at 90% 18%, rgba(110, 237, 255, 0.16), rgba(233, 239, 242, 0) 62%),
    linear-gradient(165deg, #edf4f6 0%, #e7eef2 74%, rgba(162, 224, 185, 0.16) 100%);
}

.rz-ux-include-card > .col-inner,
.rz-include-card {
  min-height: 132px;
  border-radius: 14px;
  border: 1px solid rgba(203, 221, 232, 0.95);
  background: linear-gradient(180deg, #ffffff 0%, #f2f8fb 100%);
  box-shadow: 0 14px 38px rgba(12, 29, 42, 0.14);
  padding: 17px 16px;
  position: relative;
}

.rz-ux-include-card > .col-inner::before,
.rz-include-card::before {
  content: "";
  display: block;
  width: 9px;
  height: 9px;
  border-radius: 50%;
  background: linear-gradient(130deg, #5feaff, #74d64b);
  box-shadow: 0 0 14px rgba(92, 235, 255, 0.45);
  margin-bottom: 9px;
}

.rz-ux-include-card h3,
.rz-include-card strong {
  display: block;
  margin: 0 0 6px;
  color: #102334;
  font-size: 18px;
  line-height: 1.2;
}

.rz-ux-include-card p,
.rz-include-card small {
  display: block;
  margin: 0;
  color: #445c70;
  font-size: 13px;
}

/* Booking band */
body .section.rz-ux-booking-native,
.rz-booking-band {
  background: linear-gradient(120deg, #03243a 0%, #0a6f8d 56%, #61d946 100%);
}

body .section.rz-ux-booking-native h2,
body .section.rz-ux-booking-native p,
.rz-booking-band h2,
.rz-booking-band p {
  color: #f4fbff;
}

/* Pricing and coverage */
.rz-ux-price-card > .col-inner,
.rz-price-card {
  height: 100%;
  border-radius: 14px;
  border: 1px solid rgba(203, 221, 232, 0.95);
  background: linear-gradient(180deg, #ffffff 0%, #f2f8fb 100%);
  box-shadow: 0 14px 36px rgba(8, 26, 38, 0.13);
  padding: 18px 16px;
}

.rz-ux-price-featured > .col-inner,
.rz-price-featured {
  background: linear-gradient(160deg, #07344f 0%, #0a4e69 60%, #06273f 100%);
  border-color: rgba(117, 233, 141, 0.44);
}

.rz-ux-price-card p:first-child,
.rz-price-card span {
  margin: 0 0 7px;
  color: #0c3a52;
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 1.1px;
}

.rz-ux-price-featured p:first-child,
.rz-price-featured span {
  color: #91f2b3;
}

.rz-ux-price-card h3,
.rz-price-card strong {
  margin: 0 0 6px;
  color: #102334;
  font-size: 40px;
  line-height: 1;
}

.rz-ux-price-featured h3,
.rz-price-featured strong {
  color: #f4fbff;
}

.rz-ux-price-card p:last-child,
.rz-price-card p {
  margin: 0;
  color: #445b6e;
  font-size: 13px;
}

.rz-ux-price-featured p:last-child,
.rz-price-featured p {
  color: #cfdeea;
}

.rz-ux-coverage-native .button,
.rz-area-pills a {
  min-height: 34px;
  border-radius: 999px;
  border: 1px solid #9cb6c8;
  background: rgba(255, 255, 255, 0.5);
  color: #0f2739 !important;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.4px;
  text-transform: uppercase;
}

/* Reviews */
body .section.rz-ux-reviews-native,
.rz-reviews {
  background:
    radial-gradient(72% 68% at 14% 24%, rgba(80, 235, 255, 0.18) 0%, rgba(4, 16, 28, 0) 56%),
    radial-gradient(60% 70% at 94% 58%, rgba(113, 216, 91, 0.12) 0%, rgba(4, 16, 28, 0) 58%),
    linear-gradient(160deg, #05192a 0%, #06243a 54%, #061527 100%);
}

.rz-positioning .rz-section-title,
.rz-trust-scene h2,
.rz-services-section .rz-section-title,
.rz-reviews .rz-section-title {
  color: #f4fbff;
}

.rz-ux-review-card > .col-inner,
.rz-review-card {
  border-radius: 16px;
  border: 1px solid rgba(145, 201, 226, 0.24);
  background:
    linear-gradient(180deg, rgba(10, 35, 53, 0.82) 0%, rgba(7, 24, 39, 0.88) 100%);
  box-shadow: 0 20px 46px rgba(0, 0, 0, 0.2);
  padding: 20px 18px;
  min-height: 100%;
}

.rz-ux-review-card h3,
.rz-review-card h3 {
  margin: 0 0 10px;
  color: #f4fbff;
  font-size: 20px;
  line-height: 1.18;
}

.rz-ux-review-card h3::before,
.rz-review-card h3::before {
  content: "";
  display: block;
  width: 24px;
  height: 3px;
  border-radius: 999px;
  margin-bottom: 12px;
  background: linear-gradient(90deg, #68f1ff, #74d64b);
}

.rz-ux-review-card p:first-child,
.rz-review-card .rz-stars {
  margin: 0 0 10px;
  color: #9effbf;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 1px;
  text-transform: uppercase;
}

.rz-ux-review-card blockquote,
.rz-review-card blockquote {
  margin: 0;
  padding: 0;
  border: 0;
  color: #d6e8f2;
  font-size: 15px;
  line-height: 1.58;
}

.rz-ux-review-card h3 + p {
  margin: 0;
  color: #d6e8f2;
  font-size: 15px;
  line-height: 1.58;
}

.rz-ux-review-card p:last-child,
.rz-review-card figcaption {
  margin: 10px 0 0;
  color: #9cc0d8;
  font-size: 12px;
  font-weight: 650;
}

/* FAQ */
body .section.rz-ux-faq-native .accordion-item,
.rz-faq-list details {
  border-top: 1px solid #c8d8e4;
}

body .section.rz-ux-faq-native .accordion-item:last-child,
.rz-faq-list details:last-child {
  border-bottom: 1px solid #c8d8e4;
}

body .section.rz-ux-faq-native .accordion-title,
.rz-faq-list summary {
  padding: 16px 4px;
  color: #0e2233;
  font-size: 16px;
  font-weight: 650;
}

body .section.rz-ux-faq-native .accordion-inner,
.rz-faq-list p {
  margin: 0 0 14px;
  color: #43586a;
  font-size: 14px;
  line-height: 1.6;
}

/* Final CTA and footer */
body .section.rz-ux-final-native,
.rz-final-cta {
  position: relative;
  overflow: hidden;
  background:
    linear-gradient(180deg, rgba(3, 11, 19, 0.5), rgba(3, 11, 19, 0.82)),
    var(--rz-final-image) center/cover no-repeat;
}

body .section.rz-ux-final-native h2,
.rz-final-cta h2 {
  font-size: clamp(40px, 7vw, 72px);
  line-height: 0.95;
}

body .section.rz-ux-final-native .button {
  margin: 4px 6px;
}

body .section.rz-ux-footer-native,
.rz-footer {
  background: linear-gradient(160deg, #031222 0%, #061a2c 60%, #04101f 100%);
  color: #d4e6f2;
  border-top: 1px solid rgba(139, 188, 215, 0.2);
}

body .section.rz-ux-footer-native h3,
.rz-footer strong {
  margin: 0 0 8px;
  color: #f3fbff;
  font-size: 14px;
  text-transform: uppercase;
  letter-spacing: 0.7px;
}

body .section.rz-ux-footer-native p,
body .section.rz-ux-footer-native a,
.rz-footer a,
.rz-footer p {
  color: #c2d7e6;
  font-size: 13px;
  line-height: 1.6;
}

body .section.rz-ux-footer-native img {
  width: clamp(170px, 14vw, 190px);
  max-height: 50px;
  object-fit: contain;
  margin-bottom: 8px;
}

/* Sticky CTA */
.rz-sticky-cta {
  position: fixed;
  left: 10px;
  right: 10px;
  bottom: 10px;
  z-index: 999;
  display: none;
  align-items: center;
  justify-content: center;
  gap: 8px;
  background: rgba(4, 16, 26, 0.92);
  border: 1px solid rgba(148, 196, 223, 0.4);
  border-radius: 999px;
  padding: 7px;
  box-shadow: var(--rz-shadow-lg);
  backdrop-filter: blur(10px);
}

.rz-sticky-cta a {
  flex: 1;
  min-height: 34px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: rgba(8, 33, 50, 0.9);
  color: #e9f7ff;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.45px;
  text-transform: uppercase;
}

.rz-sticky-cta a:first-child {
  background: linear-gradient(140deg, #d9fcff 0%, #7cf89b 100%);
  color: #032131;
}

/* Fallback footer structure */
.rz-footer {
  width: min(var(--rz-max), calc(100% - 56px));
  margin: 0 auto;
  padding: 30px 0 56px;
  display: grid;
  gap: 24px;
}

.rz-footer-brand img {
  width: clamp(170px, 14vw, 190px);
  max-height: 50px;
  object-fit: contain;
}

.rz-footer-cols {
  display: grid;
  gap: 16px;
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.rz-footer-cols div {
  display: grid;
  gap: 6px;
}

/* Fallback layout helpers */
.rz-services-grid,
.rz-review-grid,
.rz-image-led-grid,
.rz-pricing-grid,
.rz-audience-grid,
.rz-include-row {
  display: grid;
  gap: 16px;
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.rz-authority-grid {
  display: grid;
  gap: 16px;
  grid-template-columns: 1.2fr 1fr 1fr 1fr;
}

.rz-story-grid {
  display: grid;
  gap: 28px;
  align-items: center;
  grid-template-columns: 1.1fr 1fr;
}

.rz-trust-strip {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
}

/* Responsive */
@media (max-width: 1120px) {
  .rz-site-header {
    width: calc(100% - 22px);
    top: calc(8px + var(--wp-admin--admin-bar--height, 0px));
    padding: 8px 10px;
  }

  .rz-logo img {
    width: clamp(140px, 30vw, 155px);
    max-height: 40px;
  }

  .rz-menu-toggle {
    display: block;
  }

  .rz-menu {
    position: absolute;
    top: calc(100% + 10px);
    left: 0;
    right: 0;
    display: grid;
    gap: 10px;
    padding: 12px;
    border-radius: 16px;
    border: 1px solid rgba(150, 198, 223, 0.28);
    background: rgba(6, 20, 33, 0.96);
    box-shadow: 0 22px 38px rgba(3, 10, 18, 0.4);
    opacity: 0;
    pointer-events: none;
    transform: translateY(-8px);
    transition: opacity 0.2s ease, transform 0.2s ease;
  }

  .rz-site-header.is-open .rz-menu {
    opacity: 1;
    pointer-events: auto;
    transform: none;
  }

  .rz-nav {
    flex-direction: column;
    align-items: stretch;
    gap: 6px;
  }

  .rz-nav a,
  .rz-header-cta {
    min-height: 38px;
    border-radius: 10px;
    display: flex;
    align-items: center;
    padding: 0 12px;
    background: rgba(9, 31, 46, 0.86);
    border: 1px solid rgba(142, 193, 221, 0.24);
    color: #e4f2fc;
  }

  .rz-header-cta {
    justify-content: center;
    background: linear-gradient(120deg, #d8fcff, #73f292);
    color: #042130;
    border: 0;
  }

  body .section.rz-native-ux-homepage .row,
  body .section.rz-ux-hero-shell .row {
    padding-top: clamp(90px, 26vw, 130px);
    padding-bottom: 52px;
  }

  .rz-hero-content {
    width: calc(100% - 26px);
    max-width: none;
    grid-template-columns: 1fr;
  }

  body .rz-native-ux-homepage h1,
  body .rz-ux-hero-shell h1 {
    max-width: none;
  }

  .rz-service-options {
    grid-template-columns: 1fr;
  }

  .rz-form-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 820px) {
  .rz-wrap,
  body .section.rz-native-ux-homepage .row,
  body .section.rz-ux-hero-shell .row,
  body .section.rz-ux-trust-native .row {
    width: calc(100% - 26px);
    max-width: none !important;
  }

  .rz-services-grid,
  .rz-review-grid,
  .rz-image-led-grid,
  .rz-pricing-grid,
  .rz-audience-grid,
  .rz-include-row,
  .rz-authority-grid,
  .rz-story-grid,
  .rz-trust-strip {
    grid-template-columns: 1fr;
  }

  .rz-ux-service-card > .col-inner,
  .rz-service-card {
    min-height: 244px;
  }

  .rz-ux-install-image-col > .col-inner,
  .rz-device-scene {
    min-height: 320px;
  }

  body .section.rz-ux-final-native h2 {
    font-size: clamp(34px, 11vw, 54px);
  }

  .rz-footer-cols {
    grid-template-columns: 1fr 1fr;
  }
}

@media (max-width: 430px) {
  body .section.rz-native-ux-homepage,
  body .section.rz-ux-hero-shell {
    min-height: auto !important;
  }

  body .rz-native-ux-homepage h1,
  body .rz-ux-hero-shell h1 {
    font-size: clamp(36px, 11.6vw, 46px);
    line-height: 0.98;
  }

  body .rz-native-ux-homepage .rz-hero-copy {
    font-size: 14px;
    line-height: 1.5;
  }

  body .rz-native-ux-homepage .row-inner .col-inner:nth-child(n+3) {
    display: none;
  }

  .rz-hero-proof span:nth-child(n+3) {
    display: none;
  }

  .rz-ux-glass-col > .col-inner {
    padding: 15px;
  }

  .rz-checker input,
  .rz-checker textarea {
    font-size: 16px;
  }

  .rz-ux-service-card h3 {
    font-size: 25px;
  }

  .rz-ux-include-card > .col-inner {
    min-height: 0;
  }

  .rz-sticky-cta {
    display: flex;
  }

  .rz-footer-cols {
    grid-template-columns: 1fr;
  }
}

/* Black-label visual system: less template, more premium installation brand */
:root {
  --rz-black: #02080f;
  --rz-ink: #061726;
  --rz-panel: rgba(3, 18, 29, 0.82);
  --rz-mint: #94ffb5;
  --rz-cyan: #4fe7ff;
  --rz-cream: #efffff;
}

body.ringzone-final-live-wow {
  background:
    radial-gradient(70% 80% at 50% -10%, rgba(58, 231, 255, 0.12), transparent 60%),
    var(--rz-black);
}

.rz-site-header {
  width: min(1160px, calc(100% - 48px));
  border-radius: 18px;
  background:
    linear-gradient(180deg, rgba(7, 25, 38, 0.88), rgba(2, 12, 21, 0.74));
  border-color: rgba(118, 232, 255, 0.28);
}

.rz-nav a {
  text-decoration: none;
}

.rz-nav a:hover {
  color: var(--rz-mint);
}

body .section.rz-native-ux-homepage,
body .section.rz-ux-hero-shell,
.rz-hero {
  background:
    radial-gradient(44% 72% at 18% 72%, rgba(54, 226, 255, 0.28), transparent 68%),
    radial-gradient(34% 54% at 82% 24%, rgba(148, 255, 181, 0.24), transparent 70%),
    linear-gradient(90deg, rgba(1, 7, 13, 0.98), rgba(3, 18, 30, 0.72) 44%, rgba(3, 18, 30, 0.28) 72%, rgba(1, 7, 13, 0.88)),
    var(--rz-hero-image) center right/cover no-repeat !important;
}

body .rz-native-ux-homepage h1,
body .rz-ux-hero-shell h1,
.rz-hero h1 {
  font-weight: 760;
  text-wrap: balance;
}

.rz-eyebrow,
.rz-kicker,
.rz-card-topline,
.rz-service-code {
  color: var(--rz-mint) !important;
}

.rz-hero-card,
.rz-ux-glass-col > .col-inner {
  background:
    linear-gradient(180deg, rgba(255,255,255,0.12), rgba(255,255,255,0.04)),
    linear-gradient(145deg, rgba(7, 37, 51, 0.8), rgba(1, 10, 18, 0.94));
  border-color: rgba(179, 249, 255, 0.38);
}

.rz-header-cta,
.rz-btn-primary,
.button.rz-btn-primary,
.rz-page .button.rz-btn-primary,
.rz-checker [data-rz-check],
.rz-ux-services-native .button,
.rz-ux-services-native .button.white,
.rz-ux-services-native .button.is-outline,
.rz-service-card a {
  background: linear-gradient(135deg, #e7fff3 0%, #94ffb5 100%) !important;
  color: #03131a !important;
  border: 0 !important;
  font-weight: 850 !important;
  letter-spacing: 0.04em;
}

body .section.rz-ux-authority-native,
body .section.rz-ux-story-native,
body .section.rz-ux-included-native,
body .section.rz-ux-pricing-native,
body .section.rz-ux-coverage-native,
body .section.rz-ux-faq-native,
.rz-section.rz-authority,
.rz-section.rz-story,
.rz-section.rz-included,
.rz-section.rz-pricing,
.rz-section.rz-coverage,
.rz-section.rz-faq {
  background:
    radial-gradient(42% 52% at 10% 0%, rgba(61, 230, 255, 0.16), transparent 70%),
    radial-gradient(40% 58% at 90% 90%, rgba(148, 255, 181, 0.18), transparent 72%),
    linear-gradient(180deg, #edf7f7, #e4eff1) !important;
}

.rz-ux-card-col > .col-inner,
.rz-authority-card,
.rz-ux-include-card > .col-inner,
.rz-include-card,
.rz-ux-price-card > .col-inner,
.rz-price-card {
  border-radius: 16px;
  border: 1px solid rgba(156, 190, 204, 0.54);
  background:
    linear-gradient(180deg, rgba(255,255,255,0.98), rgba(245,251,251,0.9));
  box-shadow: 0 24px 64px rgba(3, 20, 32, 0.12), inset 0 1px 0 rgba(255,255,255,0.98);
}

body .section.rz-ux-audience-native,
.rz-positioning,
body .section.rz-ux-reviews-native,
.rz-reviews {
  background:
    radial-gradient(60% 80% at 16% 18%, rgba(63, 226, 255, 0.16), transparent 68%),
    linear-gradient(135deg, #020b13 0%, #07243a 48%, #03111d 100%) !important;
}

body .section.rz-ux-services-native,
.rz-services-section {
  background:
    radial-gradient(42% 68% at 16% 14%, rgba(57, 221, 255, 0.24), transparent 68%),
    radial-gradient(44% 62% at 82% 78%, rgba(148, 255, 181, 0.22), transparent 70%),
    linear-gradient(145deg, #020b13 0%, #05263e 48%, #041d18 100%) !important;
}

.rz-services-section .rz-section-title,
body .section.rz-ux-services-native h2 {
  max-width: 860px;
  text-wrap: balance;
}

.rz-ux-service-card > .col-inner,
.rz-service-card {
  background:
    linear-gradient(180deg, rgba(0,0,0,0.02), rgba(1, 9, 16, 0.2) 28%, rgba(1, 9, 16, 0.96) 100%),
    radial-gradient(74% 46% at 18% 0%, rgba(79, 231, 255, 0.18), transparent 62%),
    var(--rz-card-img, var(--rz-ux-service-img)) center/cover no-repeat !important;
  border-color: rgba(172, 241, 255, 0.34);
}

.rz-service-card::after,
.rz-ux-service-card > .col-inner::after {
  content: "";
  position: absolute;
  inset: 1px;
  pointer-events: none;
  border-radius: inherit;
  background:
    linear-gradient(135deg, rgba(255,255,255,0.18), transparent 28%),
    linear-gradient(0deg, rgba(148,255,181,0.08), transparent 40%);
  opacity: 0.75;
}

.rz-service-card > *,
.rz-ux-service-card > .col-inner > * {
  position: relative;
  z-index: 1;
}

.rz-service-card span,
.rz-ux-service-card p:first-child {
  color: var(--rz-mint) !important;
  font-weight: 850;
}

body .section.rz-ux-booking-native,
.rz-booking-band {
  background:
    radial-gradient(44% 100% at 83% 50%, rgba(148, 255, 181, 0.62), transparent 66%),
    radial-gradient(40% 90% at 16% 48%, rgba(79, 231, 255, 0.26), transparent 70%),
    linear-gradient(120deg, #020b13 0%, #07334b 58%, #148a5c 100%) !important;
}

body .section.rz-ux-final-native,
.rz-final-cta {
  min-height: 470px;
  background:
    radial-gradient(36% 72% at 50% 48%, rgba(79, 231, 255, 0.24), transparent 70%),
    linear-gradient(90deg, rgba(1, 7, 13, 0.94), rgba(1, 7, 13, 0.34) 50%, rgba(1, 7, 13, 0.94)),
    var(--rz-final-image) center/cover no-repeat !important;
}

@media (min-width: 1180px) {
  .rz-services-grid {
    grid-template-columns: 1.08fr 1fr 1fr;
    align-items: stretch;
  }

  .rz-services-grid .rz-service-card:nth-child(6) {
    grid-column: span 2;
  }
}

@media (max-width: 430px) {
  .rz-site-header {
    border-radius: 18px;
    background: rgba(2, 13, 23, 0.92);
  }

  body .rz-native-ux-homepage h1,
  body .rz-ux-hero-shell h1,
  .rz-hero h1 {
    font-size: clamp(36px, 10.7vw, 44px);
  }

  .rz-ux-service-card > .col-inner,
  .rz-service-card,
  .rz-services-grid .rz-service-card:nth-child(1) {
    min-height: 286px;
  }

  .rz-ux-service-card h3,
  .rz-service-card h3 {
    font-size: 25px;
  }
}

@media (max-width: 390px) {
  .rz-btn,
  .button.rz-btn,
  .rz-page .button {
    min-height: 41px;
    padding: 0 14px;
    font-size: 10px;
  }

  .rz-ux-price-card h3 {
    font-size: 34px;
  }
}

@media (max-width: 360px) {
  body .rz-native-ux-homepage h1,
  body .rz-ux-hero-shell h1 {
    font-size: 33px;
  }

  .rz-proof-pill {
    font-size: 10px;
  }

  .rz-ux-service-card > .col-inner {
    min-height: 228px;
    padding: 12px;
  }
}

@media (prefers-reduced-motion: reduce) {
  html {
    scroll-behavior: auto;
  }

  .rz-reveal {
    opacity: 1;
    transform: none;
    transition: none;
  }

  .rz-btn,
  .button.rz-btn,
  .rz-page .button {
    transition: none;
  }
}

/* Final production design pass: UX-native RingZone polish */
body.ringzone-final-live-wow {
  margin: 0;
  background:
    radial-gradient(70% 35% at 80% 0%, rgba(93, 226, 255, 0.08), transparent 62%),
    #e8f0f3;
}

body.ringzone-final-live-wow *,
body.ringzone-final-live-wow *::before,
body.ringzone-final-live-wow *::after {
  box-sizing: border-box;
}

body.ringzone-final-live-wow .section {
  overflow: hidden;
}

body.ringzone-final-live-wow .section .row {
  width: min(var(--rz-max), calc(100% - 56px)) !important;
  max-width: min(var(--rz-max), calc(100% - 56px)) !important;
  margin-inline: auto !important;
}

body.ringzone-final-live-wow .rz-reveal {
  opacity: 1;
  transform: none;
}

.rz-site-header {
  background:
    linear-gradient(135deg, rgba(4, 20, 34, 0.86), rgba(7, 29, 45, 0.68));
  border-color: rgba(139, 225, 255, 0.26);
  box-shadow: 0 18px 54px rgba(0, 0, 0, 0.38), inset 0 1px 0 rgba(255, 255, 255, 0.08);
}

.rz-logo {
  display: inline-flex;
  align-items: center;
  min-height: 42px;
}

.rz-logo img {
  display: block;
  width: clamp(188px, 15vw, 216px);
  max-height: 50px;
  object-fit: contain;
}

body .section.rz-native-ux-homepage,
body .section.rz-ux-hero-shell,
.rz-hero {
  min-height: 760px;
  background:
    radial-gradient(42% 50% at 24% 50%, rgba(87, 230, 255, 0.24) 0%, rgba(87, 230, 255, 0) 65%),
    radial-gradient(38% 42% at 83% 22%, rgba(113, 238, 117, 0.22) 0%, rgba(113, 238, 117, 0) 68%),
    linear-gradient(90deg, rgba(2, 11, 20, 0.96) 0%, rgba(2, 12, 21, var(--rz-hero-overlay, 0.72)) 45%, rgba(2, 12, 21, 0.48) 72%, rgba(2, 12, 21, 0.72) 100%),
    var(--rz-hero-image) center right/cover no-repeat;
}

body .section.rz-native-ux-homepage::after,
body .section.rz-ux-hero-shell::after,
.rz-hero::after {
  background:
    linear-gradient(180deg, rgba(3, 11, 19, 0.04) 0%, rgba(3, 11, 19, 0.76) 100%),
    linear-gradient(115deg, rgba(2, 10, 18, 0.18) 0%, rgba(2, 10, 18, 0) 48%, rgba(2, 10, 18, 0.36) 100%);
}

body .section.rz-native-ux-homepage .row,
body .section.rz-ux-hero-shell .row {
  min-height: 760px;
  padding: clamp(112px, 9vw, 150px) 0 clamp(76px, 7vw, 104px) !important;
}

body .rz-native-ux-homepage h1,
body .rz-ux-hero-shell h1,
.rz-hero h1 {
  max-width: 12ch;
  font-size: clamp(54px, 6.1vw, 82px);
  line-height: 0.94;
  text-shadow: 0 18px 70px rgba(0, 0, 0, 0.62);
}

.rz-hero {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(340px, 440px);
  gap: clamp(26px, 5vw, 64px);
  align-items: center;
  padding-inline: max(28px, calc((100vw - var(--rz-max)) / 2));
}

.rz-hero-light {
  position: absolute;
  inset: 0;
  pointer-events: none;
}

.rz-hero-content {
  width: auto;
  max-width: 760px;
  margin: 0;
  display: block;
}

.rz-hero-card,
.rz-ux-glass-col > .col-inner {
  max-width: 430px;
  margin-left: auto;
  border-radius: 22px;
  border-color: rgba(191, 235, 255, 0.45);
  background:
    radial-gradient(120% 110% at 10% 0%, rgba(116, 246, 255, 0.18), transparent 45%),
    linear-gradient(155deg, rgba(255, 255, 255, 0.2), rgba(19, 49, 65, 0.44) 44%, rgba(4, 17, 28, 0.9));
  box-shadow: 0 36px 110px rgba(0, 0, 0, 0.58), inset 0 1px 0 rgba(255, 255, 255, 0.18);
}

.rz-checker input,
.rz-checker textarea {
  background: rgba(241, 250, 255, 0.96);
  border-color: rgba(255, 255, 255, 0.8);
  color: #061724;
}

.rz-checker input::placeholder,
.rz-checker textarea::placeholder {
  color: #607383;
}

.rz-checker-steps span,
.rz-service-option {
  background: rgba(7, 30, 45, 0.76);
}

body .section.rz-ux-trust-native .row,
.rz-trust-strip {
  padding: 10px 0 !important;
}

body .section.rz-ux-trust-native .col-inner,
.rz-trust-strip > div {
  min-height: 86px;
  background:
    linear-gradient(180deg, rgba(13, 44, 64, 0.68), rgba(4, 20, 34, 0.72));
}

body .section.rz-ux-authority-native,
body .section.rz-ux-story-native,
body .section.rz-ux-included-native,
body .section.rz-ux-pricing-native,
body .section.rz-ux-coverage-native,
body .section.rz-ux-faq-native,
.rz-section.rz-authority,
.rz-section.rz-story,
.rz-section.rz-included,
.rz-section.rz-pricing,
.rz-section.rz-coverage,
.rz-section.rz-faq {
  background:
    radial-gradient(44% 52% at 88% 8%, rgba(103, 239, 255, 0.16), transparent 62%),
    radial-gradient(46% 40% at 12% 88%, rgba(117, 218, 85, 0.12), transparent 62%),
    linear-gradient(180deg, #edf5f7 0%, #e7eef2 100%);
}

body .section.rz-ux-authority-native,
body .section.rz-ux-story-native,
body .section.rz-ux-included-native,
body .section.rz-ux-pricing-native,
body .section.rz-ux-coverage-native,
body .section.rz-ux-faq-native {
  padding-top: clamp(70px, 8vw, 108px) !important;
  padding-bottom: clamp(70px, 8vw, 108px) !important;
}

.rz-ux-card-col > .col-inner,
.rz-authority-card,
.rz-ux-include-card > .col-inner,
.rz-include-card,
.rz-ux-price-card > .col-inner,
.rz-price-card {
  border-radius: 18px;
  border-color: rgba(188, 211, 224, 0.92);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(244, 250, 252, 0.94));
  box-shadow: 0 20px 52px rgba(5, 22, 35, 0.14), inset 0 1px 0 rgba(255, 255, 255, 0.94);
}

.rz-ux-card-col > .col-inner::before,
.rz-authority-card::before {
  content: "";
  display: block;
  width: 32px;
  height: 3px;
  border-radius: 999px;
  margin-bottom: 14px;
  background: linear-gradient(90deg, #58e9ff, #76df55);
}

body .section.rz-ux-audience-native,
.rz-positioning {
  background:
    radial-gradient(54% 68% at 14% 24%, rgba(75, 224, 255, 0.2), transparent 64%),
    linear-gradient(150deg, #02101b 0%, #062238 52%, #031322 100%);
}

.rz-ux-audience-card > .col-inner,
.rz-audience-card,
.rz-ux-dark-card > .col-inner,
.rz-image-led-card {
  background:
    linear-gradient(180deg, rgba(13, 43, 61, 0.86), rgba(6, 25, 39, 0.9));
  border-color: rgba(126, 199, 230, 0.28);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.06), 0 18px 46px rgba(0,0,0,0.18);
}

.rz-ux-install-image-col > .col-inner,
.rz-device-scene {
  min-height: 470px;
  background:
    linear-gradient(180deg, rgba(4, 16, 28, 0.05), rgba(4, 16, 28, 0.52)),
    var(--rz-motion-image) center/cover no-repeat;
}

body .section.rz-ux-trust-scene-native,
.rz-trust-scene {
  background:
    linear-gradient(90deg, rgba(2, 11, 20, 0.84), rgba(2, 11, 20, 0.52) 50%, rgba(2, 11, 20, 0.82)),
    var(--rz-trust-image) center/cover no-repeat;
}

body .section.rz-ux-services-native,
.rz-services-section {
  background:
    radial-gradient(48% 60% at 10% 12%, rgba(78, 229, 255, 0.22), transparent 65%),
    radial-gradient(46% 56% at 86% 88%, rgba(104, 227, 89, 0.16), transparent 66%),
    linear-gradient(160deg, #031321 0%, #06243a 54%, #031321 100%);
}

body .section.rz-ux-services-native {
  padding-top: clamp(78px, 8vw, 116px) !important;
  padding-bottom: clamp(80px, 8vw, 120px) !important;
}

.rz-ux-service-card > .col-inner,
.rz-service-card {
  min-height: 318px;
  border-radius: 20px;
  border-color: rgba(178, 224, 242, 0.28);
  background:
    linear-gradient(180deg, rgba(0, 0, 0, 0.08), rgba(2, 8, 14, 0.64) 48%, rgba(2, 8, 14, 0.96)),
    radial-gradient(80% 54% at 18% 6%, rgba(76, 227, 255, 0.18), transparent 58%),
    var(--rz-card-img, var(--rz-ux-service-img)) center/cover no-repeat;
  box-shadow: 0 24px 60px rgba(0,0,0,0.28), inset 0 1px 0 rgba(255,255,255,0.08);
}

.rz-ux-service-card:nth-of-type(3n+2) > .col-inner,
.rz-services-grid .rz-service-card:nth-child(3n+2) {
  transform: translateY(14px);
}

.rz-ux-service-card:nth-of-type(3n+3) > .col-inner,
.rz-services-grid .rz-service-card:nth-child(3n+3) {
  min-height: 292px;
}

.rz-ux-service-card h3,
.rz-service-card h3 {
  font-size: clamp(24px, 2.1vw, 32px);
}

.rz-ux-services-native .button,
.rz-ux-services-native .button.white,
.rz-ux-services-native .button.is-outline,
.rz-service-card a {
  background: linear-gradient(135deg, rgba(8, 31, 45, 0.94), rgba(12, 54, 65, 0.92)) !important;
  border: 1px solid rgba(111, 244, 155, 0.62) !important;
  color: #f4fbff !important;
  box-shadow: 0 10px 24px rgba(0, 0, 0, 0.24);
}

.rz-ux-services-native .button span,
.rz-ux-services-native .button {
  color: #f4fbff !important;
}

body .section.rz-ux-booking-native,
.rz-booking-band {
  background:
    radial-gradient(52% 84% at 88% 44%, rgba(117, 222, 76, 0.62), transparent 64%),
    linear-gradient(125deg, #021827 0%, #04526a 54%, #178d64 100%);
}

body .section.rz-ux-booking-native {
  padding-top: clamp(56px, 6vw, 82px) !important;
  padding-bottom: clamp(56px, 6vw, 82px) !important;
}

body .section.rz-ux-booking-native h2,
body .section.rz-ux-booking-native p,
.rz-booking-band h2,
.rz-booking-band p {
  color: #f4fbff;
  text-shadow: 0 8px 26px rgba(0, 0, 0, 0.28);
}

.rz-ux-coverage-native .button,
.rz-area-pills a {
  background: rgba(255, 255, 255, 0.72) !important;
  border-color: rgba(10, 52, 72, 0.32) !important;
  box-shadow: 0 8px 20px rgba(6, 20, 32, 0.08);
}

body .section.rz-ux-reviews-native,
.rz-reviews {
  background:
    radial-gradient(54% 80% at 16% 28%, rgba(82, 231, 255, 0.18), transparent 64%),
    linear-gradient(150deg, #031321 0%, #06233a 56%, #031321 100%);
}

.rz-ux-review-card > .col-inner,
.rz-review-card {
  background:
    linear-gradient(180deg, rgba(12, 42, 61, 0.86), rgba(5, 23, 37, 0.9));
  border-color: rgba(130, 205, 232, 0.28);
}

body .section.rz-ux-faq-native .accordion-title,
.rz-faq-list summary {
  font-size: 17px;
}

body .section.rz-ux-final-native,
.rz-final-cta {
  min-height: 360px;
  display: flex;
  align-items: center;
  background:
    linear-gradient(90deg, rgba(2, 11, 20, 0.86), rgba(2, 11, 20, 0.34) 52%, rgba(2, 11, 20, 0.86)),
    var(--rz-final-image) center/cover no-repeat;
}

body .section.rz-ux-footer-native,
.rz-footer {
  background:
    radial-gradient(40% 120% at 12% 0%, rgba(74, 224, 255, 0.12), transparent 60%),
    linear-gradient(160deg, #031222 0%, #061c2f 58%, #03101d 100%);
}

body .section.rz-ux-footer-native {
  padding-top: 42px !important;
  padding-bottom: 44px !important;
}

.rz-booking-band-inner,
.rz-coverage-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.25fr) minmax(280px, 0.75fr);
  gap: clamp(22px, 4vw, 54px);
  align-items: center;
}

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

.rz-booking-cta {
  border-radius: 18px;
  border: 1px solid rgba(220, 255, 235, 0.42);
  background: rgba(2, 17, 28, 0.56);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.12);
  padding: 18px;
}

.rz-booking-cta p {
  margin: 0 0 12px;
  color: #f4fbff;
}

.rz-booking-points,
.rz-area-pills {
  display: flex;
  flex-wrap: wrap;
  gap: 9px;
}

.rz-booking-points span {
  display: inline-flex;
  align-items: center;
  min-height: 34px;
  border-radius: 999px;
  padding: 0 12px;
  background: rgba(255,255,255,0.14);
  border: 1px solid rgba(255,255,255,0.22);
  color: #f3fbff;
  font-size: 12px;
  font-weight: 700;
}

.rz-final-inner {
  width: min(1080px, calc(100% - 56px));
  margin: 0 auto;
  text-align: center;
}

.rz-center-actions {
  justify-content: center;
}

.rz-footer {
  width: 100%;
  max-width: none;
  margin: 0;
  padding-inline: max(28px, calc((100vw - var(--rz-max)) / 2));
}

@media (max-width: 1120px) {
  .rz-hero {
    grid-template-columns: 1fr;
    min-height: auto;
    padding-top: 118px;
    padding-bottom: 54px;
  }

  .rz-hero-card,
  .rz-ux-glass-col > .col-inner {
    margin-left: 0;
  }
}

@media (max-width: 820px) {
  body.ringzone-final-live-wow .section .row,
  body .section.rz-native-ux-homepage .row,
  body .section.rz-ux-hero-shell .row,
  body .section.rz-ux-trust-native .row {
    width: calc(100% - 28px) !important;
    max-width: calc(100% - 28px) !important;
  }

  body .section.rz-ux-authority-native,
  body .section.rz-ux-story-native,
  body .section.rz-ux-included-native,
  body .section.rz-ux-pricing-native,
  body .section.rz-ux-coverage-native,
  body .section.rz-ux-faq-native,
  body .section.rz-ux-audience-native,
  body .section.rz-ux-trust-scene-native,
  body .section.rz-ux-services-native,
  body .section.rz-ux-reviews-native,
  .rz-section {
    padding-top: 56px !important;
    padding-bottom: 56px !important;
  }

  .rz-ux-service-card:nth-of-type(n) > .col-inner,
  .rz-services-grid .rz-service-card:nth-child(n) {
    transform: none;
  }

  .rz-booking-band-inner,
  .rz-coverage-grid {
    grid-template-columns: 1fr;
  }

  .rz-include-row {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 430px) {
  .rz-site-header {
    width: calc(100% - 18px);
    padding: 7px 8px;
  }

  .rz-logo {
    min-height: 36px;
  }

  .rz-logo img {
    width: clamp(136px, 40vw, 152px);
    max-height: 38px;
  }

  body .section.rz-native-ux-homepage,
  body .section.rz-ux-hero-shell {
    min-height: 0 !important;
    background-position: 62% center;
  }

  body .section.rz-native-ux-homepage .row,
  body .section.rz-ux-hero-shell .row {
    min-height: 0;
    padding-top: 78px !important;
    padding-bottom: 30px !important;
  }

  .rz-hero {
    padding: 78px 14px 34px;
  }

  body .rz-native-ux-homepage h1,
  body .rz-ux-hero-shell h1,
  .rz-hero h1 {
    font-size: clamp(34px, 10.4vw, 42px);
    max-width: 12ch;
  }

  body .rz-native-ux-homepage .rz-hero-copy,
  .rz-hero-copy {
    font-size: 13px;
    line-height: 1.45;
    margin-bottom: 12px;
  }

  .rz-ux-glass-col > .col-inner,
  .rz-hero-card {
    max-width: none;
    padding: 16px;
    border-radius: 18px;
  }

  body .rz-ux-glass-col h2,
  .rz-hero-card h2 {
    font-size: 20px;
  }

  .rz-checker {
    gap: 9px;
  }

  .rz-checker-steps span {
    min-height: 26px;
    font-size: 10px;
    padding: 0 8px;
  }

  .rz-checker input,
  .rz-checker textarea {
    min-height: 40px;
    padding: 9px 11px;
  }

  body .section.rz-ux-trust-native .row {
    padding: 8px 0 !important;
  }

  body .section.rz-ux-trust-native .col-inner {
    min-height: 0;
    padding: 11px 12px;
  }

  body .section.rz-ux-authority-native,
  body .section.rz-ux-story-native,
  body .section.rz-ux-included-native,
  body .section.rz-ux-pricing-native,
  body .section.rz-ux-coverage-native,
  body .section.rz-ux-faq-native,
  body .section.rz-ux-audience-native,
  body .section.rz-ux-trust-scene-native,
  body .section.rz-ux-services-native,
  body .section.rz-ux-reviews-native,
  body .section.rz-ux-booking-native,
  body .section.rz-ux-final-native,
  body .section.rz-ux-footer-native,
  .rz-section,
  .rz-final-cta,
  .rz-footer {
    padding-top: 44px !important;
    padding-bottom: 44px !important;
  }

  .rz-section-title,
  .rz-page h2,
  body .section.rz-ux-audience-native h2,
  body .section.rz-ux-services-native h2,
  body .section.rz-ux-reviews-native h2 {
    font-size: clamp(29px, 8.7vw, 37px);
    line-height: 1.03;
  }

  .rz-ux-card-col > .col-inner,
  .rz-ux-audience-card > .col-inner,
  .rz-ux-include-card > .col-inner,
  .rz-ux-price-card > .col-inner,
  .rz-ux-review-card > .col-inner {
    padding: 15px;
    min-height: 0;
  }

  .rz-ux-install-image-col > .col-inner,
  .rz-device-scene {
    min-height: 250px;
    border-radius: 16px;
  }

  .rz-ux-service-card > .col-inner,
  .rz-service-card {
    min-height: 230px;
    padding: 15px;
    border-radius: 16px;
  }

  .rz-ux-service-card h3,
  .rz-service-card h3 {
    font-size: 24px;
  }

  .rz-ux-services-native .button,
  .rz-service-card a {
    min-height: 38px;
    width: 100%;
    justify-content: center;
    font-size: 10px;
  }

  .rz-ux-price-card h3,
  .rz-price-card strong {
    font-size: 34px;
  }

  body .section.rz-ux-booking-native {
    min-height: 0 !important;
  }

  body .section.rz-ux-final-native,
  .rz-final-cta {
    min-height: 260px;
  }

  body .section.rz-ux-final-native h2,
  .rz-final-cta h2 {
    font-size: clamp(34px, 10.2vw, 44px);
  }

  .rz-booking-cta {
    padding: 14px;
  }

  .rz-booking-points span,
  .rz-area-pills a {
    min-height: 32px;
    font-size: 10px;
  }

  .rz-final-inner {
    width: calc(100% - 28px);
  }

  .rz-footer {
    padding-inline: 14px;
  }

  body .section.rz-ux-footer-native p,
  body .section.rz-ux-footer-native a,
  .rz-footer a,
  .rz-footer p {
    font-size: 12px;
    line-height: 1.48;
  }

  .rz-sticky-cta {
    left: 12px;
    right: 12px;
    bottom: 8px;
  }
}

@media (max-width: 360px) {
  body .rz-native-ux-homepage h1,
  body .rz-ux-hero-shell h1,
  .rz-hero h1 {
    font-size: 35px;
  }

  .rz-ux-service-card > .col-inner,
  .rz-service-card {
    min-height: 218px;
  }
}

/* Cinematic WOW direction: premium studio layer */
:root {
  --rz-hero-image: url("../img/rz-wow-hero-cinematic.jpg");
  --rz-motion-image: url("../img/rz-installed-exterior-fast.jpg");
  --rz-trust-image: url("../img/rz-wow-night-trust.jpg");
  --rz-final-image: url("../img/rz-wow-night-trust.jpg");
  --rz-light-wash: url("../img/rz-wow-light-wash.jpg");
}

body.ringzone-final-live-wow {
  background: #06131f;
}

.rz-page {
  background: #eaf2f5;
}

.rz-site-header {
  width: min(calc(100% - 48px), 1240px);
  min-height: 66px;
  padding: 10px 20px;
  background:
    linear-gradient(90deg, rgba(2, 14, 25, 0.86), rgba(6, 24, 38, 0.72) 55%, rgba(2, 14, 25, 0.86));
  border-color: rgba(128, 230, 255, 0.32);
  box-shadow: 0 24px 80px rgba(0, 0, 0, 0.44), inset 0 1px 0 rgba(255, 255, 255, 0.11);
}

.rz-logo img {
  filter: drop-shadow(0 10px 22px rgba(0, 0, 0, 0.36));
}

.rz-header-cta,
.rz-btn-primary,
.button.rz-btn-primary,
.rz-page .button.rz-btn-primary,
.rz-checker [data-rz-check] {
  background: linear-gradient(135deg, #dffff3 0%, #7aff98 100%) !important;
  color: #03141c !important;
  box-shadow: 0 14px 34px rgba(96, 255, 160, 0.22), inset 0 1px 0 rgba(255, 255, 255, 0.58);
}

body .section.rz-native-ux-homepage,
body .section.rz-ux-hero-shell,
.rz-hero {
  min-height: min(920px, 100svh);
  isolation: isolate;
  background:
    linear-gradient(90deg, rgba(2, 10, 18, 0.84) 0%, rgba(2, 10, 18, 0.58) 42%, rgba(2, 10, 18, 0.28) 70%, rgba(2, 10, 18, 0.76) 100%),
    var(--rz-hero-image) center/cover no-repeat;
}

body .section.rz-native-ux-homepage::before,
body .section.rz-ux-hero-shell::before,
.rz-hero::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  background:
    radial-gradient(42% 58% at 18% 64%, rgba(85, 232, 255, 0.34), transparent 68%),
    radial-gradient(38% 44% at 82% 18%, rgba(111, 239, 88, 0.28), transparent 70%),
    linear-gradient(180deg, transparent 0%, rgba(0, 7, 13, 0.36) 72%, rgba(0, 7, 13, 0.9) 100%);
  pointer-events: none;
}

body .section.rz-native-ux-homepage::after,
body .section.rz-ux-hero-shell::after,
.rz-hero::after {
  background:
    linear-gradient(90deg, rgba(0, 10, 18, 0.68), transparent 45%, rgba(0, 10, 18, 0.25)),
    linear-gradient(180deg, rgba(0,0,0,0.08), rgba(0, 8, 15, 0.88));
}

body .section.rz-native-ux-homepage .row,
body .section.rz-ux-hero-shell .row {
  min-height: min(920px, 100svh);
  align-items: center !important;
  padding-top: clamp(116px, 8vw, 156px) !important;
  padding-bottom: clamp(86px, 7vw, 128px) !important;
}

body .rz-native-ux-homepage h1,
body .rz-ux-hero-shell h1,
.rz-hero h1 {
  max-width: 11.5ch;
  margin-top: 12px;
  font-size: clamp(68px, 7vw, 112px);
  line-height: 0.88;
  letter-spacing: -0.02em;
  text-shadow: 0 30px 90px rgba(0, 0, 0, 0.72), 0 0 40px rgba(100, 239, 255, 0.11);
}

.rz-hero-copy,
body .rz-native-ux-homepage .rz-hero-copy {
  max-width: 58ch;
  font-size: clamp(16px, 1.1vw, 19px);
  line-height: 1.66;
  color: #e8f4fb;
}

.rz-hero-actions,
body .rz-native-ux-homepage .button,
body .rz-ux-hero-shell .button {
  margin-top: 6px;
}

.rz-proof-pill,
.rz-hero-proof span {
  min-height: 38px;
  padding-inline: 16px;
  background: rgba(3, 19, 32, 0.62);
  border-color: rgba(128, 214, 245, 0.44);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.08);
}

.rz-hero-card,
.rz-ux-glass-col > .col-inner {
  max-width: 470px;
  border-radius: 28px;
  padding: clamp(26px, 2.4vw, 36px);
  background:
    radial-gradient(110% 92% at 0% 0%, rgba(173, 255, 250, 0.24), transparent 42%),
    linear-gradient(155deg, rgba(255,255,255,0.24), rgba(18, 54, 65, 0.44) 38%, rgba(1, 13, 24, 0.92) 100%);
  border-color: rgba(203, 248, 255, 0.52);
  box-shadow: 0 44px 140px rgba(0, 0, 0, 0.62), 0 0 60px rgba(73, 229, 255, 0.12), inset 0 1px 0 rgba(255,255,255,0.2);
}

body .rz-ux-glass-col h2,
.rz-hero-card h2 {
  font-size: clamp(30px, 2.7vw, 42px);
  line-height: 1.02;
}

.rz-checker-steps span,
.rz-service-option {
  background: rgba(1, 18, 31, 0.78);
  border-color: rgba(139, 221, 255, 0.36);
}

.rz-checker input,
.rz-checker textarea {
  min-height: 50px;
  border-radius: 14px;
}

body .section.rz-ux-trust-native,
.rz-trust-strip {
  position: relative;
  z-index: 5;
  margin-top: -1px;
  background:
    linear-gradient(90deg, #041521, #08283d 52%, #041521);
}

body .section.rz-ux-trust-native .row,
.rz-trust-strip {
  padding: 16px 0 !important;
}

body .section.rz-ux-trust-native .col-inner,
.rz-trust-strip > div {
  min-height: 102px;
  padding: 18px 20px;
  background:
    linear-gradient(180deg, rgba(12, 46, 67, 0.88), rgba(4, 22, 36, 0.9));
  border-color: rgba(111, 218, 255, 0.25);
}

body .section.rz-ux-authority-native,
body .section.rz-ux-story-native,
body .section.rz-ux-included-native,
body .section.rz-ux-pricing-native,
body .section.rz-ux-coverage-native,
body .section.rz-ux-faq-native,
.rz-section.rz-authority,
.rz-section.rz-story,
.rz-section.rz-included,
.rz-section.rz-pricing,
.rz-section.rz-coverage,
.rz-section.rz-faq {
  background:
    linear-gradient(180deg, rgba(235, 244, 247, 0.92), rgba(232, 241, 244, 0.96)),
    var(--rz-light-wash) center/cover no-repeat;
}

body .section.rz-ux-authority-native,
body .section.rz-ux-story-native,
body .section.rz-ux-included-native,
body .section.rz-ux-pricing-native,
body .section.rz-ux-coverage-native,
body .section.rz-ux-faq-native,
.rz-section {
  padding-top: clamp(96px, 9vw, 150px) !important;
  padding-bottom: clamp(96px, 9vw, 150px) !important;
}

.rz-ux-card-col > .col-inner,
.rz-authority-card,
.rz-ux-include-card > .col-inner,
.rz-include-card,
.rz-ux-price-card > .col-inner,
.rz-price-card {
  border-radius: 24px;
  background:
    linear-gradient(180deg, rgba(255,255,255,0.96), rgba(242,249,251,0.88));
  border: 1px solid rgba(169, 204, 222, 0.76);
  box-shadow: 0 34px 90px rgba(7, 27, 41, 0.16), inset 0 1px 0 rgba(255,255,255,0.96);
}

.rz-ux-card-col > .col-inner,
.rz-authority-card {
  min-height: 250px;
  padding: 30px 26px;
}

.rz-ux-card-col h3,
.rz-authority-card b {
  font-size: clamp(22px, 1.7vw, 28px);
}

body .section.rz-ux-audience-native,
.rz-positioning {
  position: relative;
  background:
    linear-gradient(90deg, rgba(2, 12, 22, 0.94), rgba(4, 28, 44, 0.84) 50%, rgba(2, 12, 22, 0.96)),
    var(--rz-trust-image) center/cover no-repeat;
}

body .section.rz-ux-audience-native .rz-section-title,
.rz-positioning .rz-section-title {
  max-width: 980px;
  font-size: clamp(44px, 4.5vw, 70px);
}

.rz-ux-audience-card > .col-inner,
.rz-audience-card {
  min-height: 210px;
  padding: 26px;
  border-radius: 22px;
  background:
    linear-gradient(180deg, rgba(12, 50, 70, 0.78), rgba(4, 24, 38, 0.9));
  backdrop-filter: blur(14px);
}

.rz-ux-install-image-col > .col-inner,
.rz-device-scene {
  min-height: 520px;
  border-radius: 30px;
  box-shadow: 0 42px 110px rgba(5, 22, 35, 0.36);
}

body .section.rz-ux-trust-scene-native,
.rz-trust-scene {
  min-height: 520px;
  background:
    linear-gradient(90deg, rgba(2, 10, 18, 0.92), rgba(2, 10, 18, 0.42) 48%, rgba(2, 10, 18, 0.86)),
    var(--rz-trust-image) center/cover no-repeat;
}

body .section.rz-ux-trust-scene-native h2,
.rz-trust-scene h2 {
  max-width: 880px;
  font-size: clamp(42px, 4.8vw, 78px);
}

.rz-ux-dark-card > .col-inner,
.rz-image-led-card {
  min-height: 138px;
  border-radius: 20px;
  background: rgba(5, 25, 39, 0.72);
  backdrop-filter: blur(16px);
}

body .section.rz-ux-services-native,
.rz-services-section {
  background:
    radial-gradient(50% 80% at 18% 10%, rgba(80, 231, 255, 0.26), transparent 68%),
    radial-gradient(42% 52% at 88% 86%, rgba(105, 228, 82, 0.24), transparent 68%),
    linear-gradient(160deg, #020f19 0%, #06283f 50%, #02101b 100%);
}

.rz-services-grid {
  gap: 22px;
}

.rz-ux-service-card > .col-inner,
.rz-service-card {
  min-height: 372px;
  border-radius: 26px;
  border-color: rgba(169, 229, 249, 0.34);
  padding: 26px;
  background:
    linear-gradient(180deg, rgba(0, 0, 0, 0.04), rgba(2, 8, 14, 0.42) 38%, rgba(2, 8, 14, 0.96)),
    radial-gradient(80% 60% at 15% 0%, rgba(87, 235, 255, 0.28), transparent 58%),
    var(--rz-card-img, var(--rz-ux-service-img)) center/cover no-repeat;
  box-shadow: 0 38px 100px rgba(0, 0, 0, 0.34), inset 0 1px 0 rgba(255,255,255,0.12);
}

.rz-services-grid .rz-service-card:nth-child(1),
.rz-ux-services-native .rz-ux-service-card:nth-child(2) > .col-inner {
  min-height: 430px;
}

.rz-ux-service-card h3,
.rz-service-card h3 {
  max-width: 10ch;
  font-size: clamp(34px, 3vw, 48px);
  letter-spacing: -0.01em;
}

.rz-service-card p,
.rz-ux-service-card .ux-text p:last-child {
  max-width: 48ch;
  font-size: 15px;
}

.rz-ux-services-native .button,
.rz-service-card a {
  min-height: 46px;
  padding: 0 20px;
  background: linear-gradient(135deg, rgba(207,255,244,0.95), rgba(118,255,152,0.95)) !important;
  color: #041722 !important;
  border: 0 !important;
}

.rz-ux-services-native .button span {
  color: #041722 !important;
}

.rz-ux-include-card > .col-inner,
.rz-include-card {
  min-height: 170px;
  padding: 24px 22px;
}

body .section.rz-ux-booking-native,
.rz-booking-band {
  background:
    radial-gradient(52% 120% at 86% 46%, rgba(123, 255, 91, 0.92), transparent 62%),
    radial-gradient(40% 90% at 18% 50%, rgba(75, 231, 255, 0.32), transparent 66%),
    linear-gradient(125deg, #020f19 0%, #06546c 55%, #42d24f 100%);
}

.rz-booking-cta {
  background: rgba(1, 13, 22, 0.72);
  box-shadow: 0 28px 70px rgba(0,0,0,0.22), inset 0 1px 0 rgba(255,255,255,0.14);
}

.rz-ux-price-featured > .col-inner,
.rz-price-featured {
  background:
    radial-gradient(90% 110% at 20% 0%, rgba(84, 239, 255, 0.28), transparent 50%),
    linear-gradient(160deg, #041927 0%, #0a4a63 60%, #041927 100%);
}

body .section.rz-ux-reviews-native,
.rz-reviews {
  background:
    radial-gradient(52% 80% at 8% 18%, rgba(75, 232, 255, 0.22), transparent 64%),
    linear-gradient(150deg, #020f19 0%, #06263d 58%, #020f19 100%);
}

.rz-ux-review-card > .col-inner,
.rz-review-card {
  min-height: 180px;
  border-radius: 22px;
}

body .section.rz-ux-final-native,
.rz-final-cta {
  min-height: 500px;
  background:
    radial-gradient(42% 74% at 50% 40%, rgba(82, 232, 255, 0.26), transparent 70%),
    linear-gradient(90deg, rgba(2, 10, 18, 0.88), rgba(2, 10, 18, 0.26) 50%, rgba(2, 10, 18, 0.88)),
    var(--rz-final-image) center/cover no-repeat;
}

body .section.rz-ux-final-native h2,
.rz-final-cta h2 {
  font-size: clamp(58px, 7.5vw, 112px);
  line-height: 0.9;
  text-shadow: 0 28px 90px rgba(0,0,0,0.78);
}

@media (min-width: 1180px) {
  .rz-services-grid {
    grid-template-columns: 1.15fr 1fr 1fr;
  }

  .rz-services-grid .rz-service-card:nth-child(1) {
    grid-row: span 2;
  }

  .rz-services-grid .rz-service-card:nth-child(6) {
    grid-column: span 2;
    min-height: 360px;
  }
}

@media (max-width: 820px) {
  body .section.rz-native-ux-homepage,
  body .section.rz-ux-hero-shell,
  .rz-hero {
    min-height: auto;
  }

  body .section.rz-native-ux-homepage .row,
  body .section.rz-ux-hero-shell .row {
    min-height: 0;
    padding-top: 100px !important;
  }

  body .section.rz-ux-authority-native,
  body .section.rz-ux-story-native,
  body .section.rz-ux-included-native,
  body .section.rz-ux-pricing-native,
  body .section.rz-ux-coverage-native,
  body .section.rz-ux-faq-native,
  body .section.rz-ux-audience-native,
  body .section.rz-ux-trust-scene-native,
  body .section.rz-ux-services-native,
  body .section.rz-ux-reviews-native,
  .rz-section {
    padding-top: 70px !important;
    padding-bottom: 70px !important;
  }
}

@media (max-width: 430px) {
  .rz-site-header {
    min-height: 56px;
    border-radius: 22px;
  }

  .rz-menu-toggle {
    width: 42px;
    height: 42px;
  }

  body .section.rz-native-ux-homepage .row,
  body .section.rz-ux-hero-shell .row {
    padding-top: 84px !important;
    padding-bottom: 42px !important;
  }

  body .rz-native-ux-homepage h1,
  body .rz-ux-hero-shell h1,
  .rz-hero h1 {
    font-size: clamp(42px, 12.4vw, 54px);
    line-height: 0.92;
  }

  body .rz-ux-glass-col h2,
  .rz-hero-card h2 {
    font-size: 31px;
  }

  .rz-hero-card,
  .rz-ux-glass-col > .col-inner {
    padding: 22px;
    border-radius: 24px;
  }

  body .section.rz-ux-authority-native,
  body .section.rz-ux-story-native,
  body .section.rz-ux-included-native,
  body .section.rz-ux-pricing-native,
  body .section.rz-ux-coverage-native,
  body .section.rz-ux-faq-native,
  body .section.rz-ux-audience-native,
  body .section.rz-ux-trust-scene-native,
  body .section.rz-ux-services-native,
  body .section.rz-ux-reviews-native,
  body .section.rz-ux-booking-native,
  body .section.rz-ux-final-native,
  .rz-section,
  .rz-final-cta {
    padding-top: 58px !important;
    padding-bottom: 58px !important;
  }

  .rz-section-title,
  .rz-page h2,
  body .section.rz-ux-audience-native h2,
  body .section.rz-ux-services-native h2,
  body .section.rz-ux-reviews-native h2 {
    font-size: clamp(34px, 10.4vw, 46px);
  }

  .rz-ux-card-col > .col-inner,
  .rz-authority-card,
  .rz-ux-audience-card > .col-inner,
  .rz-audience-card,
  .rz-ux-include-card > .col-inner,
  .rz-include-card,
  .rz-ux-price-card > .col-inner,
  .rz-price-card,
  .rz-ux-review-card > .col-inner,
  .rz-review-card {
    border-radius: 20px;
    padding: 20px;
  }

  .rz-ux-install-image-col > .col-inner,
  .rz-device-scene {
    min-height: 340px;
  }

  .rz-ux-service-card > .col-inner,
  .rz-service-card,
  .rz-services-grid .rz-service-card:nth-child(1) {
    min-height: 320px;
  }

  .rz-ux-service-card h3,
  .rz-service-card h3 {
    font-size: 31px;
  }

  body .section.rz-ux-final-native h2,
  .rz-final-cta h2 {
    font-size: clamp(40px, 12vw, 54px);
  }
}

/* Final production polish: cinematic density, no hidden content, no mobile overlap */
:root {
  --rz-wrap-final: min(1180px, calc(100% - 44px));
}

body.ringzone-final-live-wow {
  overflow-x: hidden;
  background: #06131f;
  text-rendering: geometricPrecision;
}

body.ringzone-final-live-wow .section .row,
.rz-wrap {
  width: var(--rz-wrap-final) !important;
  max-width: var(--rz-wrap-final) !important;
}

.rz-site-header {
  width: min(1180px, calc(100% - 40px));
  min-height: 62px;
  top: calc(18px + var(--wp-admin--admin-bar--height, 0px));
  padding: 9px 16px;
  border-radius: 999px;
  background:
    linear-gradient(90deg, rgba(2, 15, 26, 0.92), rgba(9, 31, 47, 0.76) 54%, rgba(2, 15, 26, 0.94));
  border: 1px solid rgba(143, 234, 255, 0.34);
  box-shadow: 0 22px 68px rgba(0, 0, 0, 0.42), inset 0 1px 0 rgba(255,255,255,0.16);
}

.rz-logo {
  min-width: 0;
}

.rz-logo img,
body .section.rz-ux-footer-native img,
.rz-footer-brand img {
  object-fit: contain;
  object-position: left center;
}

.rz-logo img {
  width: clamp(178px, 14vw, 212px);
  max-width: 212px;
  max-height: 48px;
}

.rz-nav a {
  color: rgba(237, 252, 255, 0.92);
  font-size: 12px;
  letter-spacing: 0.08em;
}

.rz-header-cta {
  min-height: 40px;
  padding-inline: 18px;
}

body .section.rz-native-ux-homepage,
body .section.rz-ux-hero-shell,
.rz-hero {
  min-height: clamp(720px, 88svh, 850px) !important;
  background:
    radial-gradient(48% 68% at 22% 58%, rgba(43, 220, 255, 0.34), transparent 68%),
    radial-gradient(36% 52% at 86% 20%, rgba(110, 255, 91, 0.26), transparent 68%),
    linear-gradient(90deg, rgba(1, 8, 15, 0.94) 0%, rgba(2, 12, 22, 0.74) 42%, rgba(2, 12, 22, 0.34) 72%, rgba(1, 8, 15, 0.78) 100%),
    var(--rz-hero-image) center right/cover no-repeat !important;
}

body .section.rz-native-ux-homepage::before,
body .section.rz-ux-hero-shell::before,
.rz-hero::before {
  background:
    linear-gradient(180deg, rgba(0,0,0,0.42), transparent 34%, rgba(0,0,0,0.46)),
    repeating-linear-gradient(90deg, rgba(255,255,255,0.045) 0 1px, transparent 1px 80px) !important;
  opacity: 0.5;
}

body .section.rz-native-ux-homepage::after,
body .section.rz-ux-hero-shell::after,
.rz-hero::after {
  background:
    radial-gradient(42% 28% at 34% 100%, rgba(75, 242, 255, 0.28), transparent 72%),
    linear-gradient(180deg, transparent 0%, rgba(2, 11, 19, 0.28) 72%, rgba(2, 11, 19, 0.98) 100%) !important;
}

body .section.rz-native-ux-homepage .row,
body .section.rz-ux-hero-shell .row,
.rz-hero {
  align-items: center !important;
}

body .section.rz-native-ux-homepage .row,
body .section.rz-ux-hero-shell .row {
  min-height: clamp(720px, 88svh, 850px) !important;
  padding-top: 92px !important;
  padding-bottom: 76px !important;
}

.rz-hero {
  display: grid;
  grid-template-columns: minmax(0, 1.08fr) minmax(340px, 0.72fr);
  gap: clamp(34px, 6vw, 90px);
  padding: 120px max(32px, calc((100vw - 1180px) / 2)) 82px;
}

body .rz-native-ux-homepage h1,
body .rz-ux-hero-shell h1,
.rz-hero h1 {
  max-width: 680px;
  font-size: clamp(72px, 7.4vw, 124px);
  line-height: 0.82;
  letter-spacing: -0.045em;
  color: #f4feff;
  text-shadow: 0 28px 96px rgba(0, 0, 0, 0.84);
}

.rz-hero-copy,
body .rz-native-ux-homepage .rz-hero-copy {
  max-width: 610px;
  color: rgba(239, 253, 255, 0.9);
  font-size: clamp(16px, 1.1vw, 19px);
  line-height: 1.5;
}

.rz-hero-actions,
body .rz-ux-hero-shell .button {
  margin-top: 18px;
}

.rz-proof-pill,
.rz-hero-proof span {
  min-height: 34px;
  padding: 9px 14px;
  font-size: 11px;
  background: rgba(3, 22, 36, 0.74);
}

.rz-hero-card,
.rz-ux-glass-col > .col-inner {
  max-width: 440px;
  padding: clamp(24px, 2.2vw, 34px);
  background:
    radial-gradient(100% 88% at 0% 0%, rgba(187,255,248,0.2), transparent 44%),
    linear-gradient(150deg, rgba(255,255,255,0.2), rgba(11, 42, 57, 0.62) 38%, rgba(1, 12, 22, 0.94) 100%);
  border: 1px solid rgba(198, 249, 255, 0.5);
  box-shadow: 0 42px 130px rgba(0,0,0,0.56), 0 0 0 1px rgba(255,255,255,0.06) inset;
}

body .rz-ux-glass-col h2,
.rz-hero-card h2 {
  font-size: clamp(26px, 2.35vw, 38px);
}

.rz-checker-steps {
  gap: 8px;
}

.rz-checker-steps span,
.rz-service-option {
  min-height: 38px;
  padding: 9px 10px;
}

.rz-checker input,
.rz-checker textarea {
  min-height: 46px;
}

body .section.rz-ux-trust-native .row,
.rz-trust-strip {
  padding: 12px 0 !important;
}

body .section.rz-ux-trust-native .col-inner,
.rz-trust-strip > div {
  min-height: 88px;
  padding: 16px 18px;
}

body .section.rz-ux-authority-native,
body .section.rz-ux-story-native,
body .section.rz-ux-included-native,
body .section.rz-ux-pricing-native,
body .section.rz-ux-coverage-native,
body .section.rz-ux-faq-native,
.rz-section.rz-authority,
.rz-section.rz-story,
.rz-section.rz-included,
.rz-section.rz-pricing,
.rz-section.rz-coverage,
.rz-section.rz-faq {
  background:
    radial-gradient(48% 52% at 8% 8%, rgba(86, 226, 255, 0.18), transparent 68%),
    radial-gradient(42% 56% at 92% 78%, rgba(124, 255, 143, 0.16), transparent 72%),
    linear-gradient(180deg, #eef7f8 0%, #e6f0f3 100%) !important;
}

body .section.rz-ux-authority-native,
body .section.rz-ux-story-native,
body .section.rz-ux-included-native,
body .section.rz-ux-pricing-native,
body .section.rz-ux-coverage-native,
body .section.rz-ux-faq-native,
.rz-section.rz-authority,
.rz-section.rz-story,
.rz-section.rz-included,
.rz-section.rz-pricing,
.rz-section.rz-coverage,
.rz-section.rz-faq {
  padding-top: clamp(74px, 6.8vw, 110px) !important;
  padding-bottom: clamp(74px, 6.8vw, 110px) !important;
}

.rz-ux-card-col > .col-inner,
.rz-authority-card {
  min-height: 210px;
  padding: 24px;
}

.rz-ux-card-col h3,
.rz-authority-card b {
  font-size: clamp(20px, 1.45vw, 25px);
}

body .section.rz-ux-audience-native,
.rz-positioning {
  padding-top: clamp(82px, 7vw, 118px) !important;
  padding-bottom: clamp(82px, 7vw, 118px) !important;
  background:
    radial-gradient(52% 70% at 22% 20%, rgba(72, 229, 255, 0.18), transparent 66%),
    linear-gradient(90deg, rgba(1, 10, 18, 0.96), rgba(5, 30, 47, 0.88), rgba(1, 10, 18, 0.96)),
    var(--rz-trust-image) center/cover no-repeat !important;
}

body .section.rz-ux-audience-native .rz-section-title,
.rz-positioning .rz-section-title {
  max-width: 1040px;
  font-size: clamp(42px, 4.2vw, 62px);
}

.rz-ux-audience-card > .col-inner,
.rz-audience-card,
.rz-ux-dark-card > .col-inner,
.rz-image-led-card,
.rz-ux-review-card > .col-inner,
.rz-review-card {
  border: 1px solid rgba(128, 223, 255, 0.28);
  background:
    linear-gradient(180deg, rgba(11, 47, 67, 0.78), rgba(3, 19, 32, 0.9));
  box-shadow: 0 24px 70px rgba(0,0,0,0.22), inset 0 1px 0 rgba(255,255,255,0.09);
}

.rz-ux-install-image-col > .col-inner,
.rz-device-scene {
  min-height: clamp(360px, 38vw, 480px);
  border-radius: 26px;
}

body .section.rz-ux-trust-scene-native,
.rz-trust-scene {
  min-height: 460px;
  padding-top: clamp(82px, 7vw, 120px) !important;
  padding-bottom: clamp(82px, 7vw, 120px) !important;
}

body .section.rz-ux-trust-scene-native h2,
.rz-trust-scene h2 {
  font-size: clamp(40px, 4.2vw, 64px);
}

body .section.rz-ux-services-native,
.rz-services-section {
  padding-top: clamp(86px, 7vw, 120px) !important;
  padding-bottom: clamp(92px, 7vw, 128px) !important;
  background:
    radial-gradient(44% 68% at 16% 12%, rgba(68, 231, 255, 0.28), transparent 68%),
    radial-gradient(38% 54% at 88% 72%, rgba(95, 241, 106, 0.24), transparent 72%),
    linear-gradient(155deg, #020d17 0%, #062a42 50%, #02101b 100%) !important;
}

.rz-services-grid {
  gap: 20px;
}

.rz-ux-service-card > .col-inner,
.rz-service-card {
  min-height: 340px;
  padding: 22px;
  border-radius: 22px;
  background:
    linear-gradient(180deg, rgba(0,0,0,0.08), rgba(2,8,14,0.28) 28%, rgba(2,8,14,0.94) 100%),
    radial-gradient(84% 58% at 10% 0%, rgba(99, 241, 255, 0.22), transparent 60%),
    var(--rz-card-img, var(--rz-ux-service-img)) center/cover no-repeat !important;
}

.rz-ux-service-doorbell > .col-inner,
.rz-service-doorbell {
  --rz-ux-service-img: url("../img/rz-service-doorbell-luxe.jpg");
  background-position: 55% center !important;
}

.rz-ux-service-cctv > .col-inner,
.rz-service-cctv-camera-installation {
  --rz-ux-service-img: url("../img/rz-service-cctv-luxe.jpg");
}

.rz-ux-service-alarm > .col-inner,
.rz-service-smart-alarm-installation {
  --rz-ux-service-img: url("../img/rz-service-alarm-luxe.jpg");
}

.rz-ux-service-wifi > .col-inner,
.rz-service-wifi-mesh-setup {
  --rz-ux-service-img: url("../img/rz-service-wifi-luxe.jpg");
}

.rz-ux-service-tv > .col-inner,
.rz-service-tv-wall-mounting {
  --rz-ux-service-img: url("../img/rz-service-tv-luxe.jpg");
}

.rz-ux-service-airbnb > .col-inner,
.rz-service-airbnb-security-package {
  --rz-ux-service-img: url("../img/rz-service-airbnb-luxe.jpg");
}

.rz-ux-service-card h3,
.rz-service-card h3 {
  max-width: 11ch;
  font-size: clamp(25px, 2.1vw, 36px);
  line-height: 0.95;
}

.rz-ux-service-card .ux-text p:last-child,
.rz-service-card p {
  font-size: 14px;
  line-height: 1.42;
}

.rz-ux-services-native .button,
.rz-service-card a {
  min-height: 40px;
  padding: 0 16px;
  border-radius: 999px;
  color: #04202d !important;
}

.rz-ux-include-card > .col-inner,
.rz-include-card {
  min-height: 148px;
  padding: 22px;
}

body .section.rz-ux-booking-native,
.rz-booking-band {
  padding-top: 68px !important;
  padding-bottom: 68px !important;
  position: relative;
  overflow: hidden;
  color: #f4feff;
  background:
    radial-gradient(48% 120% at 88% 42%, rgba(105, 255, 92, 0.82), transparent 64%),
    radial-gradient(40% 92% at 14% 50%, rgba(64, 229, 255, 0.28), transparent 68%),
    linear-gradient(125deg, #020d17 0%, #063247 52%, #119861 100%) !important;
}

body .section.rz-ux-booking-native::before,
.rz-booking-band::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    linear-gradient(90deg, rgba(2, 10, 18, 0.74), rgba(2, 10, 18, 0.24) 58%, rgba(2, 10, 18, 0.04)),
    repeating-linear-gradient(90deg, rgba(255,255,255,0.055) 0 1px, transparent 1px 86px);
}

body .section.rz-ux-booking-native > .section-content,
.rz-booking-band > * {
  position: relative;
  z-index: 1;
}

body .section.rz-ux-booking-native h2,
.rz-booking-band h2 {
  color: #f5feff !important;
  max-width: 620px;
  font-size: clamp(36px, 4.2vw, 62px);
  line-height: 0.95;
  text-shadow: 0 20px 70px rgba(0,0,0,0.55);
}

body .section.rz-ux-booking-native p,
.rz-booking-band p,
.rz-booking-points span {
  color: rgba(239, 253, 255, 0.88) !important;
}

.rz-booking-cta {
  border: 1px solid rgba(205, 255, 245, 0.34);
  background:
    radial-gradient(110% 110% at 0% 0%, rgba(216, 255, 245, 0.22), transparent 42%),
    linear-gradient(150deg, rgba(255,255,255,0.18), rgba(6, 32, 48, 0.78));
  backdrop-filter: blur(18px);
}

.rz-ux-price-card > .col-inner,
.rz-price-card {
  min-height: 160px;
}

.rz-ux-price-card h3,
.rz-price-card strong {
  font-size: clamp(34px, 3.2vw, 52px);
}

body .section.rz-ux-reviews-native,
.rz-reviews {
  padding-top: clamp(78px, 6.8vw, 108px) !important;
  padding-bottom: clamp(78px, 6.8vw, 108px) !important;
}

.rz-ux-review-card > .col-inner,
.rz-review-card {
  min-height: 150px;
}

body .section.rz-ux-final-native,
.rz-final-cta {
  min-height: 420px;
  padding-top: clamp(82px, 7vw, 120px) !important;
  padding-bottom: clamp(82px, 7vw, 120px) !important;
}

body .section.rz-ux-final-native h2,
.rz-final-cta h2 {
  font-size: clamp(54px, 6.4vw, 92px);
}

body .section.rz-ux-footer-native,
.rz-footer {
  background: linear-gradient(180deg, #041928, #03111d) !important;
}

@media (min-width: 1180px) {
  .rz-services-grid {
    grid-template-columns: 1.08fr 1fr 1fr;
  }

  .rz-services-grid .rz-service-card:nth-child(1) {
    min-height: 700px;
  }

  .rz-services-grid .rz-service-card:nth-child(6) {
    min-height: 340px;
  }
}

@media (max-width: 1120px) {
  .rz-site-header {
    width: min(calc(100% - 28px), 980px);
  }

  .rz-hero {
    grid-template-columns: 1fr;
    padding-left: 24px;
    padding-right: 24px;
  }
}

@media (max-width: 820px) {
  body.ringzone-final-live-wow .section .row,
  .rz-wrap {
    width: min(100% - 28px, 720px) !important;
    max-width: min(100% - 28px, 720px) !important;
  }

  body .section.rz-native-ux-homepage,
  body .section.rz-ux-hero-shell,
  .rz-hero {
    min-height: auto !important;
    background-position: 62% center !important;
  }

  body .section.rz-native-ux-homepage .row,
  body .section.rz-ux-hero-shell .row {
    min-height: 0 !important;
    padding-top: 94px !important;
    padding-bottom: 48px !important;
  }

  .rz-hero {
    display: block;
    padding: 96px 18px 42px;
  }

  .rz-logo img {
    max-width: 148px;
    max-height: 38px;
  }

  .rz-menu {
    top: calc(66px + var(--wp-admin--admin-bar--height, 0px));
  }

  body .section.rz-ux-authority-native,
  body .section.rz-ux-story-native,
  body .section.rz-ux-included-native,
  body .section.rz-ux-pricing-native,
  body .section.rz-ux-coverage-native,
  body .section.rz-ux-faq-native,
  body .section.rz-ux-audience-native,
  body .section.rz-ux-trust-scene-native,
  body .section.rz-ux-services-native,
  body .section.rz-ux-reviews-native,
  body .section.rz-ux-booking-native,
  body .section.rz-ux-final-native,
  .rz-section,
  .rz-final-cta {
    padding-top: 58px !important;
    padding-bottom: 58px !important;
  }

  body .section.rz-ux-trust-native .row {
    width: 100% !important;
    max-width: 100% !important;
  }

  body .section.rz-ux-trust-native .col-inner,
  .rz-trust-strip > div {
    min-height: 74px;
  }

  .rz-services-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 430px) {
  body.ringzone-final-live-wow {
    padding-bottom: 0;
  }

  .rz-site-header {
    left: 12px;
    right: 12px;
    width: auto;
    min-height: 54px;
    top: calc(10px + var(--wp-admin--admin-bar--height, 0px));
    padding: 7px 10px;
  }

  .rz-logo img {
    max-width: 142px;
    max-height: 36px;
  }

  .rz-menu-toggle {
    width: 38px;
    height: 38px;
  }

  body .section.rz-native-ux-homepage .row,
  body .section.rz-ux-hero-shell .row {
    padding-top: 78px !important;
    padding-bottom: 34px !important;
  }

  .rz-hero {
    padding: 78px 14px 34px;
  }

  body .rz-native-ux-homepage h1,
  body .rz-ux-hero-shell h1,
  .rz-hero h1 {
    font-size: clamp(39px, 12vw, 48px);
    line-height: 0.88;
    max-width: 9ch;
  }

  .rz-hero-copy,
  body .rz-native-ux-homepage .rz-hero-copy {
    font-size: 14px;
    line-height: 1.42;
  }

  .rz-hero-actions,
  body .rz-ux-hero-shell .button {
    gap: 8px;
  }

  .rz-btn,
  .button.rz-btn,
  .rz-page .button,
  .rz-header-cta {
    min-height: 38px;
    padding-inline: 13px;
    font-size: 10px;
  }

  .rz-proof-pill:nth-child(n+3),
  .rz-hero-proof span:nth-child(n+3) {
    display: none;
  }

  .rz-hero-card,
  .rz-ux-glass-col > .col-inner {
    max-width: none;
    margin-top: 20px;
    padding: 18px;
    border-radius: 20px;
  }

  body .rz-ux-glass-col h2,
  .rz-hero-card h2 {
    font-size: 24px;
  }

  .rz-checker-steps {
    grid-template-columns: 1fr;
  }

  .rz-service-picker {
    grid-template-columns: 1fr;
  }

  .rz-section-title,
  .rz-page h2,
  body .section.rz-ux-audience-native h2,
  body .section.rz-ux-services-native h2,
  body .section.rz-ux-reviews-native h2 {
    font-size: clamp(28px, 8.7vw, 38px);
    line-height: 0.98;
  }

  .rz-ux-card-col > .col-inner,
  .rz-authority-card,
  .rz-ux-audience-card > .col-inner,
  .rz-audience-card,
  .rz-ux-include-card > .col-inner,
  .rz-include-card,
  .rz-ux-price-card > .col-inner,
  .rz-price-card,
  .rz-ux-review-card > .col-inner,
  .rz-review-card {
    min-height: 0;
    padding: 18px;
    border-radius: 18px;
  }

  .rz-ux-install-image-col > .col-inner,
  .rz-device-scene {
    min-height: 290px;
  }

  .rz-ux-service-card > .col-inner,
  .rz-service-card,
  .rz-services-grid .rz-service-card:nth-child(1) {
    min-height: 292px;
    padding: 18px;
    border-radius: 20px;
  }

  .rz-ux-service-card h3,
  .rz-service-card h3 {
    font-size: 26px;
  }

  .rz-ux-service-card .ux-text p:last-child,
  .rz-service-card p {
    font-size: 13px;
  }

  .rz-ux-services-native .button,
  .rz-service-card a {
    min-height: 36px;
    font-size: 9px;
  }

  body .section.rz-ux-booking-native {
    background:
      radial-gradient(86% 90% at 84% 20%, rgba(112, 255, 91, 0.82), transparent 68%),
      linear-gradient(130deg, #03131f, #07566a 58%, #35ce55) !important;
  }

  body .section.rz-ux-final-native h2,
  .rz-final-cta h2 {
    font-size: clamp(36px, 11vw, 48px);
  }

  .rz-footer,
  body .section.rz-ux-footer-native {
    padding-bottom: 28px !important;
  }

  .rz-sticky-cta {
    position: relative;
    left: auto;
    right: auto;
    bottom: auto;
    z-index: 2;
    display: flex !important;
    width: min(100% - 24px, 360px);
    margin: 12px auto 16px;
    padding: 6px;
    border-radius: 999px;
    box-shadow: 0 16px 40px rgba(0,0,0,0.2);
  }

  .rz-sticky-cta a {
    min-height: 32px;
    font-size: 9px;
  }
}

@media (max-width: 360px) {
  body .rz-native-ux-homepage h1,
  body .rz-ux-hero-shell h1,
  .rz-hero h1 {
    font-size: 36px;
  }
}

/* Final art-direction correction: luxury scale, readable CTAs, calmer mobile */
.rz-site-header {
  top: calc(22px + var(--wp-admin--admin-bar--height, 0px));
  min-height: 58px;
  padding: 8px 18px;
  background:
    linear-gradient(90deg, rgba(2, 15, 26, 0.94), rgba(7, 29, 44, 0.82) 54%, rgba(2, 15, 26, 0.96));
}

.rz-logo img {
  width: clamp(168px, 12vw, 198px);
  max-width: 198px;
  max-height: 44px;
}

body .section.rz-native-ux-homepage,
body .section.rz-ux-hero-shell,
.rz-hero {
  min-height: clamp(690px, 82svh, 790px) !important;
  background:
    radial-gradient(42% 62% at 21% 62%, rgba(43, 220, 255, 0.28), transparent 68%),
    radial-gradient(34% 50% at 83% 18%, rgba(110, 255, 91, 0.22), transparent 68%),
    linear-gradient(90deg, rgba(1, 8, 15, 0.95) 0%, rgba(2, 12, 22, 0.78) 42%, rgba(2, 12, 22, 0.42) 72%, rgba(1, 8, 15, 0.82) 100%),
    var(--rz-hero-image) center right/cover no-repeat !important;
}

body .section.rz-native-ux-homepage .row,
body .section.rz-ux-hero-shell .row {
  min-height: clamp(690px, 82svh, 790px) !important;
  padding-top: 104px !important;
  padding-bottom: 54px !important;
}

.rz-hero {
  grid-template-columns: minmax(0, 0.96fr) minmax(340px, 0.72fr);
  padding-top: 118px;
  padding-bottom: 54px;
}

body .rz-native-ux-homepage h1,
body .rz-ux-hero-shell h1,
.rz-hero h1 {
  max-width: 620px;
  font-size: clamp(58px, 5.7vw, 94px);
  line-height: 0.9;
  letter-spacing: -0.04em;
}

.rz-hero-copy,
body .rz-native-ux-homepage .rz-hero-copy {
  max-width: 560px;
  font-size: clamp(15px, 1vw, 17px);
}

.rz-hero-card,
.rz-ux-glass-col > .col-inner {
  max-width: 410px;
  border-radius: 24px;
}

body .rz-ux-glass-col h2,
.rz-hero-card h2 {
  font-size: clamp(24px, 2vw, 32px);
  line-height: 1.02;
}

.rz-header-cta,
.rz-btn-primary,
.button.rz-btn-primary,
.rz-page .button.rz-btn-primary,
.rz-checker [data-rz-check],
.rz-ux-services-native .button,
.rz-ux-services-native .button.white,
.rz-ux-services-native .button.is-outline,
.rz-service-card a {
  background: linear-gradient(135deg, #eafff8 0%, #8dffad 100%) !important;
  color: #03141c !important;
  border: 1px solid rgba(222, 255, 244, 0.9) !important;
  box-shadow: 0 16px 38px rgba(105, 255, 164, 0.28), inset 0 1px 0 rgba(255,255,255,0.75) !important;
  opacity: 1 !important;
}

.rz-ux-services-native .button span,
.rz-service-card a,
.rz-service-card a *,
.rz-btn-primary span,
.button.rz-btn-primary span {
  color: #03141c !important;
  opacity: 1 !important;
}

.rz-ux-service-card > .col-inner,
.rz-service-card {
  min-height: 318px;
  border-radius: 24px;
  border: 1px solid rgba(166, 230, 250, 0.42);
  box-shadow: 0 32px 82px rgba(0,0,0,0.34), inset 0 1px 0 rgba(255,255,255,0.14);
}

.rz-ux-service-card h3,
.rz-service-card h3 {
  font-size: clamp(24px, 1.9vw, 34px);
  text-shadow: 0 12px 40px rgba(0,0,0,0.7);
}

.rz-ux-service-card .ux-text p:last-child,
.rz-service-card p {
  color: rgba(250, 255, 255, 0.92);
  text-shadow: 0 8px 28px rgba(0,0,0,0.72);
}

@media (min-width: 1180px) {
  .rz-services-grid .rz-service-card:nth-child(1) {
    min-height: 660px;
  }
}

@media (max-width: 820px) {
  .rz-site-header {
    top: calc(12px + var(--wp-admin--admin-bar--height, 0px));
  }

  body .section.rz-native-ux-homepage,
  body .section.rz-ux-hero-shell,
  .rz-hero {
    background-position: 68% center !important;
  }
}

@media (max-width: 430px) {
  .rz-site-header {
    left: 12px;
    right: 12px;
    min-height: 52px;
    padding: 7px 10px;
    border-radius: 24px;
  }

  .rz-logo img {
    max-width: 132px;
    max-height: 34px;
  }

  body .section.rz-native-ux-homepage,
  body .section.rz-ux-hero-shell,
  .rz-hero {
    background:
      radial-gradient(90% 46% at 22% 48%, rgba(43, 220, 255, 0.22), transparent 70%),
      radial-gradient(62% 36% at 92% 18%, rgba(110, 255, 91, 0.2), transparent 72%),
      linear-gradient(90deg, rgba(1, 8, 15, 0.96), rgba(2, 12, 22, 0.68)),
      var(--rz-hero-image) 66% center/cover no-repeat !important;
  }

  body .section.rz-native-ux-homepage .row,
  body .section.rz-ux-hero-shell .row {
    padding-top: 82px !important;
    padding-bottom: 30px !important;
  }

  .rz-hero {
    padding-top: 82px;
    padding-bottom: 30px;
  }

  body .rz-native-ux-homepage h1,
  body .rz-ux-hero-shell h1,
  .rz-hero h1 {
    max-width: 10.5ch;
    font-size: clamp(34px, 10.2vw, 42px);
    line-height: 0.94;
    letter-spacing: -0.035em;
  }

  .rz-hero-copy,
  body .rz-native-ux-homepage .rz-hero-copy {
    font-size: 13px;
    line-height: 1.42;
    max-width: 31ch;
  }

  .rz-hero-card,
  .rz-ux-glass-col > .col-inner {
    margin-top: 16px;
    padding: 16px;
    border-radius: 18px;
  }

  body .rz-ux-glass-col h2,
  .rz-hero-card h2 {
    font-size: 21px;
  }

  .rz-checker input,
  .rz-checker textarea {
    min-height: 42px;
    font-size: 14px;
  }

  .rz-checker-steps span,
  .rz-service-option {
    min-height: 34px;
    font-size: 11px;
  }

  .rz-ux-service-card > .col-inner,
  .rz-service-card,
  .rz-services-grid .rz-service-card:nth-child(1) {
    min-height: 270px;
  }

  .rz-ux-service-card h3,
  .rz-service-card h3 {
    font-size: 23px;
  }
}
