/*
Theme Name: RenoFront Kompletny
Theme URI: https://renofront.pl
Author: RenoFront
Author URI: https://renofront.pl
Description: Kompletny motyw WordPress dla usługi renowacji frontów PCV/MDF: usuwanie starej odchodzącej okleiny, przygotowanie powierzchni i malowanie frontów zewnętrznie oraz wewnętrznie. Motyw zawiera gotową stronę główną, nagłówek, stopkę, podstrony, cennik, realizacje i formularz wyceny ze zdjęciami.
Version: 2.0.0
Requires at least: 6.0
Tested up to: 6.7
Requires PHP: 7.4
Text Domain: renofront
*/

:root {
  --rf-bg: #f6f0e8;
  --rf-soft: #fffaf2;
  --rf-card: #ffffff;
  --rf-dark: #101316;
  --rf-dark-2: #171b1f;
  --rf-text: #151719;
  --rf-muted: #687078;
  --rf-border: #e6d9c9;
  --rf-border-2: #d3b98e;
  --rf-gold: #d9a447;
  --rf-gold-2: #f0c773;
  --rf-green: #2f5143;
  --rf-radius: 22px;
  --rf-radius-lg: 30px;
  --rf-shadow: 0 26px 70px rgba(16, 19, 22, .16);
  --rf-shadow-soft: 0 14px 40px rgba(16, 19, 22, .10);
  --rf-container: 1420px;
  --rf-font: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Arial, sans-serif;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  background: var(--rf-bg);
  color: var(--rf-text);
  font-family: var(--rf-font);
  line-height: 1.55;
  overflow-x: hidden;
}
a { color: inherit; text-decoration: none; }
img { max-width: 100%; height: auto; display: block; }
button, input, textarea, select { font: inherit; }
::selection { background: rgba(217,164,71,.32); }
.screen-reader-text{position:absolute!important;clip:rect(1px,1px,1px,1px);clip-path:inset(50%);height:1px;width:1px;overflow:hidden;word-wrap:normal!important;}

.rf-container {
  width: min(var(--rf-container), calc(100% - 40px));
  margin-inline: auto;
}

.rf-topbar {
  background: #0b0e11;
  color: rgba(255,255,255,.84);
  font-size: 13px;
  border-bottom: 1px solid rgba(217,164,71,.35);
}
.rf-topbar__inner {
  width: min(var(--rf-container), calc(100% - 40px));
  margin-inline: auto;
  min-height: 38px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
}
.rf-topbar__left,
.rf-topbar__right { display: flex; align-items: center; gap: 24px; flex-wrap: wrap; }
.rf-topbar strong { color: #fff; }
.rf-topbar svg { width: 16px; height: 16px; color: var(--rf-gold); vertical-align: -3px; margin-right: 7px; }

.rf-header {
  position: sticky;
  top: 0;
  z-index: 1000;
  background: rgba(255, 249, 240, .94);
  backdrop-filter: blur(18px);
  border-bottom: 1px solid rgba(211, 185, 142, .62);
}
.admin-bar .rf-header { top: 32px; }
.rf-header__inner {
  width: min(var(--rf-container), calc(100% - 40px));
  margin-inline: auto;
  min-height: 76px;
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 34px;
}
.rf-logo { line-height: 1; display: inline-flex; flex-direction: column; min-width: max-content; }
.rf-logo__main { font-size: clamp(26px, 2.6vw, 38px); font-weight: 950; letter-spacing: .05em; color: #151719; }
.rf-logo__main span { color: var(--rf-gold); }
.rf-logo__tagline { margin-top: 7px; font-size: 10px; font-weight: 850; letter-spacing: .26em; color: #25292d; text-transform: uppercase; }
.rf-nav { justify-self: center; }
.rf-nav ul { list-style: none; padding: 0; margin: 0; display: flex; align-items: center; gap: 3px; }
.rf-nav a {
  display: inline-flex;
  align-items: center;
  min-height: 42px;
  padding: 10px 14px;
  border-radius: 999px;
  font-size: 13px;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .035em;
  color: #1d2023;
  transition: .2s ease;
}
.rf-nav a:hover,
.rf-nav .current-menu-item > a,
.rf-nav .current_page_item > a { background: #fff; box-shadow: 0 12px 28px rgba(16,19,22,.08); }
.rf-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  min-height: 48px;
  padding: 13px 22px;
  border-radius: 13px;
  border: 1px solid transparent;
  font-weight: 950;
  font-size: 14px;
  line-height: 1;
  cursor: pointer;
  transition: transform .18s ease, box-shadow .18s ease, background .18s ease, border-color .18s ease;
}
.rf-btn:hover { transform: translateY(-1px); }
.rf-btn--gold { background: linear-gradient(135deg, var(--rf-gold), var(--rf-gold-2)); color: #15110b; box-shadow: 0 14px 34px rgba(217,164,71,.34); }
.rf-btn--dark { background: #11161a; color: #fff; border-color: rgba(255,255,255,.12); }
.rf-btn--outline { border-color: rgba(255,255,255,.34); color: #fff; background: rgba(255,255,255,.05); }
.rf-btn--outline-dark { border-color: #1d2328; color: #13171b; background: transparent; }
.rf-mobile-toggle { display: none; border: 0; background: #11161a; color: #fff; width: 44px; height: 44px; border-radius: 13px; align-items: center; justify-content: center; }
.rf-mobile-toggle span,
.rf-mobile-toggle span::before,
.rf-mobile-toggle span::after { content: ""; display: block; width: 20px; height: 2px; background: currentColor; border-radius: 2px; position: relative; }
.rf-mobile-toggle span::before { position: absolute; top: -7px; }
.rf-mobile-toggle span::after { position: absolute; top: 7px; }

.rf-hero {
  background: #0e1216;
  color: #fff;
  border-bottom: 1px solid rgba(217,164,71,.35);
}
.rf-hero__shell {
  width: min(1680px, 100%);
  margin-inline: auto;
  min-height: 610px;
  display: grid;
  grid-template-columns: minmax(380px, 43%) minmax(0, 57%);
  align-items: stretch;
  overflow: hidden;
}
.rf-hero__content {
  position: relative;
  z-index: 2;
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: clamp(48px, 5vw, 86px) clamp(28px, 4vw, 76px);
  background:
    radial-gradient(circle at 20% 22%, rgba(217,164,71,.18), transparent 28%),
    linear-gradient(90deg, #101316 0%, #12171c 70%, rgba(18,23,28,.92) 100%);
}
.rf-hero__eyebrow {
  display: inline-flex;
  width: max-content;
  max-width: 100%;
  align-items: center;
  gap: 9px;
  padding: 9px 13px;
  border: 1px solid rgba(217,164,71,.58);
  color: #ffe0a0;
  border-radius: 999px;
  background: rgba(217,164,71,.08);
  font-size: 13px;
  font-weight: 900;
  margin-bottom: 22px;
}
.rf-hero h1 {
  margin: 0;
  max-width: 720px;
  font-size: clamp(46px, 5.2vw, 82px);
  line-height: .93;
  letter-spacing: -.055em;
  font-weight: 980;
}
.rf-hero h1 span { color: var(--rf-gold-2); }
.rf-hero__lead {
  max-width: 650px;
  margin: 24px 0 0;
  font-size: clamp(17px, 1.35vw, 21px);
  color: rgba(255,255,255,.82);
}
.rf-hero__chips {
  margin: 26px 0 0;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
  max-width: 720px;
}
.rf-chip {
  display: flex;
  align-items: center;
  gap: 12px;
  min-height: 62px;
  padding: 13px 15px;
  border: 1px solid rgba(255,255,255,.20);
  border-radius: 14px;
  background: rgba(255,255,255,.065);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.08);
  font-weight: 900;
  font-size: 14px;
  line-height: 1.25;
}
.rf-chip__icon,
.rf-feature__icon,
.rf-step__icon {
  flex: 0 0 auto;
  width: 36px;
  height: 36px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 12px;
  background: linear-gradient(135deg, var(--rf-gold), var(--rf-gold-2));
  color: #17110a;
  box-shadow: 0 10px 24px rgba(217,164,71,.26);
}
.rf-chip svg,
.rf-feature__icon svg,
.rf-step__icon svg { width: 20px; height: 20px; }
.rf-hero__actions { margin-top: 28px; display: flex; gap: 14px; flex-wrap: wrap; }
.rf-hero__visual {
  position: relative;
  min-height: 610px;
  background: #1a1e22 url('assets/img/hero-before-after.png') center / cover no-repeat;
  border-left: 1px solid rgba(217,164,71,.35);
}
.rf-hero__visual::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, rgba(14,18,22,.23) 0%, rgba(14,18,22,.02) 42%, transparent 100%);
  pointer-events: none;
}
.rf-hero__note {
  position: absolute;
  right: clamp(18px, 4vw, 56px);
  bottom: clamp(22px, 4vw, 54px);
  width: min(360px, calc(100% - 38px));
  padding: 18px;
  border-radius: 18px;
  background: rgba(13, 17, 21, .78);
  backdrop-filter: blur(12px);
  border: 1px solid rgba(255,255,255,.16);
  box-shadow: var(--rf-shadow);
}
.rf-hero__note b { display: block; color: #fff; font-size: 18px; margin-bottom: 10px; }
.rf-hero__note ul { margin: 0; padding: 0; list-style: none; display: grid; gap: 8px; }
.rf-hero__note li { display: flex; gap: 9px; color: rgba(255,255,255,.86); font-size: 14px; }
.rf-hero__note li::before { content: "✓"; color: var(--rf-gold-2); font-weight: 950; }

.rf-feature-strip { background: var(--rf-soft); border-bottom: 1px solid var(--rf-border); }
.rf-feature-strip__inner {
  width: min(1280px, calc(100% - 40px));
  margin-inline: auto;
  transform: translateY(-26px);
  margin-bottom: -26px;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0;
  border: 1px solid rgba(230,217,201,.95);
  border-radius: 24px;
  background: rgba(255,255,255,.95);
  box-shadow: var(--rf-shadow-soft);
  overflow: hidden;
}
.rf-feature {
  display: grid;
  grid-template-columns: 58px 1fr;
  gap: 18px;
  align-items: center;
  padding: 24px 28px;
  border-right: 1px solid var(--rf-border);
}
.rf-feature:last-child { border-right: 0; }
.rf-feature h3 { margin: 0 0 5px; font-size: 19px; line-height: 1.15; }
.rf-feature p { margin: 0; color: var(--rf-muted); font-size: 14px; }
.rf-feature__icon { width: 54px; height: 54px; border-radius: 14px; }
.rf-feature__icon svg { width: 28px; height: 28px; }

.rf-section { padding: clamp(56px, 6vw, 92px) 0; }
.rf-section--white { background: #fffaf3; border-block: 1px solid var(--rf-border); }
.rf-section--dark { background: #101316; color: #fff; }
.rf-section__head { max-width: 860px; margin: 0 auto 38px; text-align: center; }
.rf-kicker { margin: 0 0 10px; color: var(--rf-gold); font-weight: 950; letter-spacing: .11em; text-transform: uppercase; font-size: 13px; }
.rf-title { margin: 0; font-size: clamp(32px, 3.6vw, 52px); line-height: 1.02; letter-spacing: -.035em; font-weight: 950; }
.rf-lead { margin: 16px auto 0; max-width: 740px; color: var(--rf-muted); font-size: 18px; }
.rf-section--dark .rf-lead { color: rgba(255,255,255,.72); }

.rf-process-wide {
  display: grid;
  grid-template-columns: .86fr repeat(4, 1fr);
  gap: 0;
  border: 1px solid var(--rf-border);
  border-radius: 26px;
  background: rgba(255,255,255,.72);
  overflow: hidden;
  box-shadow: var(--rf-shadow-soft);
}
.rf-process-title { padding: 28px; background: #fff; border-right: 1px solid var(--rf-border); }
.rf-process-title h2 { margin: 0 0 10px; font-size: 28px; line-height: 1.05; }
.rf-process-title p { margin: 0; color: var(--rf-muted); }
.rf-step-mini { position: relative; min-height: 190px; padding: 28px 22px; background: #fffaf3; border-right: 1px solid var(--rf-border); text-align: center; }
.rf-step-mini:last-child { border-right: 0; }
.rf-step-mini__nr { position: absolute; top: 20px; left: 20px; width: 30px; height: 30px; border-radius: 999px; display: flex; align-items: center; justify-content: center; background: var(--rf-gold); color: #111; font-weight: 950; box-shadow: 0 8px 20px rgba(217,164,71,.24); }
.rf-step-mini svg { width: 46px; height: 46px; color: #151719; margin: 8px auto 14px; }
.rf-step-mini h3 { margin: 0 0 7px; font-size: 17px; line-height: 1.1; }
.rf-step-mini p { margin: 0; color: var(--rf-muted); font-size: 14px; }

.rf-grid-3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; }
.rf-card { background: #fff; border: 1px solid var(--rf-border); border-radius: 24px; overflow: hidden; box-shadow: var(--rf-shadow-soft); }
.rf-card__media { min-height: 210px; background: #ddd center / cover no-repeat; }
.rf-card__body { padding: 24px; }
.rf-card h3 { margin: 0 0 10px; font-size: 24px; line-height: 1.1; }
.rf-card p { margin: 0; color: var(--rf-muted); }
.rf-card ul { margin: 18px 0 0; padding: 0; list-style: none; display: grid; gap: 9px; color: var(--rf-muted); }
.rf-card li { display: flex; gap: 8px; }
.rf-card li::before { content: "✓"; color: var(--rf-gold); font-weight: 950; }
.rf-link { display: inline-flex; margin-top: 18px; color: #9a6a1d; font-weight: 950; }

.rf-results-grid {
  display: grid;
  grid-template-columns: 1.1fr 1fr 1fr;
  gap: 18px;
}
.rf-result-card {
  position: relative;
  min-height: 270px;
  overflow: hidden;
  border-radius: 22px;
  border: 1px solid var(--rf-border);
  background: #ddd center / cover no-repeat;
  box-shadow: var(--rf-shadow-soft);
}
.rf-result-card--big { min-height: 380px; grid-row: span 2; }
.rf-result-card::after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, transparent 40%, rgba(0,0,0,.70)); }
.rf-result-card__label { position: absolute; left: 16px; bottom: 16px; z-index: 2; display: flex; gap: 8px; flex-wrap: wrap; }
.rf-tag { display: inline-flex; padding: 7px 10px; border-radius: 999px; background: rgba(15,19,22,.9); color: #fff; font-size: 12px; font-weight: 950; }
.rf-tag--gold { background: linear-gradient(135deg, var(--rf-gold), var(--rf-gold-2)); color: #17110a; }

.rf-info-layout { display: grid; grid-template-columns: 1.05fr .95fr; gap: 26px; align-items: start; }
.rf-price-box,
.rf-faq-box,
.rf-contact-box,
.rf-include-box { background: #fff; border: 1px solid var(--rf-border); border-radius: 24px; box-shadow: var(--rf-shadow-soft); overflow: hidden; }
.rf-price-table { width: 100%; border-collapse: collapse; background: #fff; }
.rf-price-table th,
.rf-price-table td { padding: 16px 18px; border-bottom: 1px solid var(--rf-border); text-align: left; vertical-align: top; }
.rf-price-table th { background: #11161a; color: #fff; font-size: 13px; text-transform: uppercase; letter-spacing: .06em; }
.rf-price-table td { font-size: 15px; }
.rf-price-table td:last-child { font-weight: 950; color: #11161a; white-space: nowrap; }
.rf-price-note { padding: 18px; color: var(--rf-muted); font-size: 14px; }
.rf-include-box { padding: 24px; }
.rf-include-box h3 { margin: 0 0 14px; font-size: 24px; }
.rf-check-list { margin: 0; padding: 0; list-style: none; display: grid; gap: 10px; }
.rf-check-list li { display: flex; gap: 10px; color: #353b41; }
.rf-check-list li::before { content: "✓"; width: 22px; height: 22px; flex: 0 0 auto; border-radius: 999px; background: rgba(217,164,71,.18); color: #9a6a1d; display: inline-flex; align-items: center; justify-content: center; font-weight: 950; }
.rf-faq-item { border-bottom: 1px solid var(--rf-border); }
.rf-faq-item:last-child { border-bottom: 0; }
.rf-faq-question { width: 100%; border: 0; background: #fff; padding: 17px 20px; display: flex; align-items: center; justify-content: space-between; gap: 16px; text-align: left; font-weight: 950; cursor: pointer; }
.rf-faq-question span:last-child { color: var(--rf-gold); font-size: 22px; line-height: 1; }
.rf-faq-answer { display: none; padding: 0 20px 18px; color: var(--rf-muted); }
.rf-faq-item.is-open .rf-faq-answer { display: block; }

.rf-quote-band { background: #11161a; color: #fff; border-top: 1px solid rgba(217,164,71,.45); border-bottom: 1px solid rgba(217,164,71,.45); }
.rf-quote-band__inner {
  width: min(var(--rf-container), calc(100% - 40px));
  margin-inline: auto;
  display: grid;
  grid-template-columns: 360px 1fr;
  gap: 34px;
  align-items: center;
  padding: 42px 0;
}
.rf-quote-band__image { min-height: 250px; border-radius: 24px; background: #333 url('assets/img/contact-kitchen.png') center / cover no-repeat; box-shadow: var(--rf-shadow); }
.rf-quote-band h2 { margin: 0; font-size: clamp(30px, 3vw, 48px); line-height: 1.02; letter-spacing: -.035em; }
.rf-quote-band h2 span { color: var(--rf-gold-2); }
.rf-quote-steps { display: flex; gap: 22px; flex-wrap: wrap; margin: 20px 0 0; color: rgba(255,255,255,.8); }
.rf-quote-steps span { display: flex; align-items: center; gap: 9px; font-weight: 850; }
.rf-quote-steps svg { width: 22px; height: 22px; color: var(--rf-gold); }

.rf-form { display: grid; gap: 12px; }
.rf-form--dark { margin-top: 24px; }
.rf-form-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; }
.rf-form input,
.rf-form textarea,
.rf-form select {
  width: 100%;
  min-height: 48px;
  border: 1px solid var(--rf-border);
  border-radius: 12px;
  background: #fff;
  padding: 12px 14px;
  color: #14171a;
  outline: none;
  transition: border-color .18s ease, box-shadow .18s ease;
}
.rf-form textarea { min-height: 112px; resize: vertical; }
.rf-form input:focus,
.rf-form textarea:focus,
.rf-form select:focus { border-color: var(--rf-gold); box-shadow: 0 0 0 4px rgba(217,164,71,.13); }
.rf-form-note { font-size: 13px; color: rgba(255,255,255,.64); }
.rf-form input[type="file"] { background: rgba(255,255,255,.96); padding: 11px; }
.rf-form-message { padding: 14px 16px; border-radius: 14px; background: rgba(47,81,67,.12); color: #244638; font-weight: 800; margin-bottom: 16px; border: 1px solid rgba(47,81,67,.22); }
.rf-form-error { background: rgba(159,61,46,.12); color: #842a1d; border-color: rgba(159,61,46,.20); }

.rf-page-hero { padding: 72px 0; background: #11161a; color: #fff; border-bottom: 1px solid rgba(217,164,71,.4); }
.rf-page-hero__inner { width: min(var(--rf-container), calc(100% - 40px)); margin-inline: auto; display: grid; grid-template-columns: 1fr 480px; gap: 48px; align-items: center; }
.rf-page-hero h1 { margin: 0; font-size: clamp(40px, 5vw, 70px); line-height: .96; letter-spacing: -.05em; font-weight: 980; }
.rf-page-hero p { margin: 18px 0 0; color: rgba(255,255,255,.78); font-size: 19px; max-width: 760px; }
.rf-page-hero__image { min-height: 310px; border-radius: 28px; background: #333 url('assets/img/hero-before-after.png') center / cover no-repeat; border: 1px solid rgba(255,255,255,.14); box-shadow: var(--rf-shadow); }
.rf-content { padding: 64px 0; }
.rf-content .rf-container { max-width: 1100px; }
.rf-content h2 { font-size: clamp(30px, 3vw, 44px); line-height: 1.05; margin: 0 0 18px; }
.rf-content p { color: var(--rf-muted); font-size: 18px; }
.rf-two-col { display: grid; grid-template-columns: 1fr 1fr; gap: 26px; }
.rf-panel { background: #fff; border: 1px solid var(--rf-border); border-radius: 24px; padding: 28px; box-shadow: var(--rf-shadow-soft); }
.rf-panel h3 { margin: 0 0 12px; font-size: 24px; line-height: 1.12; }
.rf-panel p { margin: 0; }

.rf-footer { background: #11161a; color: #fff; }
.rf-footer__inner { width: min(var(--rf-container), calc(100% - 40px)); margin-inline: auto; padding: 54px 0 26px; }
.rf-footer__grid { display: grid; grid-template-columns: 1.3fr .8fr .8fr 1fr; gap: 40px; }
.rf-footer h3 { margin: 0 0 15px; color: #fff; }
.rf-footer p,
.rf-footer li,
.rf-footer a { color: rgba(255,255,255,.72); }
.rf-footer ul { list-style: none; padding: 0; margin: 0; display: grid; gap: 8px; }
.rf-footer a:hover { color: #fff; }
.rf-footer__bottom { margin-top: 38px; padding-top: 20px; border-top: 1px solid rgba(255,255,255,.12); display: flex; justify-content: space-between; gap: 20px; color: rgba(255,255,255,.58); font-size: 13px; }

@media (max-width: 1180px) {
  .rf-header__inner { grid-template-columns: auto auto; justify-content: space-between; }
  .rf-mobile-toggle { display: inline-flex; }
  .rf-header__cta { display: none; }
  .rf-nav { position: fixed; top: 115px; left: 20px; right: 20px; display: none; background: #fffaf3; border: 1px solid var(--rf-border); border-radius: 22px; box-shadow: var(--rf-shadow); padding: 10px; }
  .admin-bar .rf-nav { top: 147px; }
  body.rf-menu-open .rf-nav { display: block; }
  .rf-nav ul { display: grid; gap: 2px; }
  .rf-nav a { width: 100%; justify-content: center; }
  .rf-hero__shell { grid-template-columns: 1fr; }
  .rf-hero__content { padding-bottom: 42px; }
  .rf-hero__visual { min-height: 440px; border-left: 0; }
  .rf-feature-strip__inner { grid-template-columns: 1fr; }
  .rf-feature { border-right: 0; border-bottom: 1px solid var(--rf-border); }
  .rf-feature:last-child { border-bottom: 0; }
  .rf-process-wide { grid-template-columns: 1fr 1fr; }
  .rf-process-title { grid-column: 1 / -1; border-right: 0; border-bottom: 1px solid var(--rf-border); }
  .rf-results-grid, .rf-info-layout, .rf-quote-band__inner, .rf-page-hero__inner, .rf-footer__grid { grid-template-columns: 1fr; }
  .rf-result-card--big { grid-row: auto; }
}
@media (max-width: 780px) {
  .admin-bar .rf-header { top: 46px; }
  .rf-topbar__inner { justify-content: center; text-align: center; }
  .rf-topbar__left { display: none; }
  .rf-topbar__right { justify-content: center; gap: 12px; }
  .rf-header__inner { min-height: 68px; width: min(100% - 28px, var(--rf-container)); }
  .rf-logo__main { font-size: 25px; }
  .rf-logo__tagline { font-size: 8px; letter-spacing: .18em; }
  .rf-nav { top: 104px; left: 14px; right: 14px; }
  .admin-bar .rf-nav { top: 150px; }
  .rf-hero__shell { min-height: auto; }
  .rf-hero__content { padding: 38px 20px 32px; }
  .rf-hero h1 { font-size: clamp(42px, 13vw, 58px); }
  .rf-hero__lead { font-size: 16px; }
  .rf-hero__chips { grid-template-columns: 1fr; }
  .rf-hero__visual { min-height: 310px; }
  .rf-hero__note { display: none; }
  .rf-feature-strip__inner { transform: none; margin-top: 0; margin-bottom: 0; width: min(100% - 28px, 1280px); }
  .rf-feature { grid-template-columns: 48px 1fr; padding: 20px; }
  .rf-feature__icon { width: 46px; height: 46px; }
  .rf-section { padding: 48px 0; }
  .rf-container { width: min(100% - 28px, var(--rf-container)); }
  .rf-process-wide { grid-template-columns: 1fr; }
  .rf-step-mini { border-right: 0; border-bottom: 1px solid var(--rf-border); min-height: auto; }
  .rf-grid-3, .rf-two-col, .rf-form-grid { grid-template-columns: 1fr; }
  .rf-price-table th:nth-child(2), .rf-price-table td:nth-child(2) { display: none; }
  .rf-price-table th, .rf-price-table td { padding: 13px 12px; font-size: 14px; }
  .rf-quote-band__image { min-height: 180px; }
  .rf-footer__bottom { flex-direction: column; }
}
