/* @font-face rules are inlined in index.php <head> for faster LCP */

:root {
  --rf-black: #080808;
  --rf-white: #ffffff;
  --rf-blue: #1a7efb;
  --rf-btn: #1262d3; /* WCAG AA: ~5.5:1 contrast with white */
  --rf-muted: rgba(255, 255, 255, 0.68);
  --rf-soft: rgba(255, 255, 255, 0.1);
  --rf-line: rgba(255, 255, 255, 0.16);
  --rf-card: #101010;
  --rf-card-2: #151515;
  --rf-shadow: 0 24px 80px rgba(0, 0, 0, 0.35);
  --rf-headline: 'Shantell Sans', ui-rounded, cursive;
  --rf-nav: 'Lato', Arial, sans-serif;
  --rf-base: 'Sohne', 'Inter', 'Segoe UI', Arial, sans-serif;
}

html {
  scroll-behavior: smooth;
  background: var(--rf-black);
}

body {
  margin: 0;
  min-height: 100%;
  background: var(--rf-black);
  overflow-x: hidden;
}

body.rf-menu-open { overflow: auto; }

.rf-page, .rf-page * { box-sizing: border-box; }
.rf-page {
  position: relative;
  min-height: 100vh;
  margin: 0;
  padding-top: 100px;
  background: radial-gradient(circle at 12% 4%, rgba(26, 126, 251, 0.2), transparent 24rem), radial-gradient(circle at 90% 10%, rgba(255, 255, 255, 0.12), transparent 28rem), linear-gradient(180deg, #080808 0%, #0d0d0d 52%, #080808 100%);
  color: var(--rf-white);
  font-family: var(--rf-base);
  overflow-x: hidden;
  overflow-y: visible;
  isolation: isolate;
}
.rf-page::before {
  content: '';
  position: fixed;
  inset: 0;
  pointer-events: none;
  background-image: linear-gradient(rgba(255, 255, 255, 0.04) 1px, transparent 1px), linear-gradient(90deg, rgba(255, 255, 255, 0.04) 1px, transparent 1px);
  background-size: 54px 54px;
  mask-image: linear-gradient(to bottom, black, transparent 82%);
  z-index: -2;
}
.rf-noise {
  position: fixed;
  inset: 0;
  pointer-events: none;
  opacity: 0.08;
  z-index: -1;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 220 220' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.75' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.7'/%3E%3C/svg%3E");
}
.rf-container { width: min(1180px, calc(100% - 40px)); margin: 0 auto; }
.rf-nav {
  position: fixed;
  top: 14px;
  left: 50%;
  z-index: 1000;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
  width: min(1180px, calc(100% - 28px));
  margin: 0;
  padding: 14px 14px 14px 20px;
  transform: translateX(-50%);
  border: 1px solid var(--rf-line);
  border-radius: 999px;
  background: rgba(8, 8, 8, 0.78);
  backdrop-filter: blur(18px);
  box-shadow: 0 18px 60px rgba(0, 0, 0, 0.24);
}
.rf-brand { display: inline-flex; align-items: center; gap: 12px; color: var(--rf-white); text-decoration: none; font-family: var(--rf-nav); font-size: 18px; font-weight: 700; letter-spacing: -0.03em; }
.rf-logo-img { display: block; width: 36px; height: 36px; object-fit: cover; flex: 0 0 auto; }
.rf-nav-links { display: flex; align-items: center; gap: 6px; }
.rf-nav-links a { padding: 12px 17px; border-radius: 999px; color: rgba(255, 255, 255, 0.78); text-decoration: none; font-family: var(--rf-nav); font-size: 16px; font-weight: 700; transition: color 0.2s ease, background 0.2s ease; }
.rf-nav-links a:hover { color: var(--rf-white); background: rgba(255, 255, 255, 0.1); }
.rf-nav-cta { display: inline-flex; align-items: center; justify-content: center; gap: 8px; min-height: 48px; padding: 0 22px; border: 0; border-radius: 999px; background: var(--rf-btn); color: var(--rf-white); text-decoration: none; font-family: var(--rf-nav); font-size: 15px; font-weight: 700; cursor: pointer; box-shadow: 0 18px 46px rgba(18, 98, 211, 0.34); transition: transform 0.2s ease, box-shadow 0.2s ease; }
.rf-nav-cta:hover { transform: translateY(-2px); box-shadow: 0 20px 48px rgba(18, 98, 211, 0.42); }
.rf-download-icon { display: inline-flex; align-items: center; justify-content: center; width: 17px; height: 17px; transition: transform 0.2s ease; }
.rf-download-icon svg { display: block; width: 100%; height: 100%; fill: none; stroke: currentColor; stroke-width: 2.2; stroke-linecap: round; stroke-linejoin: round; }
.rf-nav-cta:hover .rf-download-icon { transform: translateY(2px); }
.rf-menu-btn { display: none; align-items: center; justify-content: center; width: 42px; height: 42px; padding: 0; border: 1px solid var(--rf-line); border-radius: 999px; background: transparent; color: var(--rf-white); font-size: 20px; line-height: 1; cursor: pointer; }
.rf-menu-btn span { display: flex; align-items: center; justify-content: center; width: 1em; height: 1em; line-height: 1; transform: translateY(-1px); }
.rf-hero { position: relative; padding: 88px 0 74px; }
.rf-hero-grid { display: grid; grid-template-columns: minmax(0, 1.02fr) minmax(340px, 0.78fr); align-items: center; gap: 54px; }
.rf-kicker { display: inline-flex; align-items: center; gap: 10px; padding: 7px 11px; border: 1px solid var(--rf-line); border-radius: 999px; background: rgba(255, 255, 255, 0.06); color: var(--rf-muted); font-family: var(--rf-nav); font-size: 12px; font-weight: 700; }
.rf-dot { width: 8px; height: 8px; border-radius: 99px; background: var(--rf-blue); box-shadow: 0 0 24px var(--rf-blue); }
.rf-page h1, .rf-page h2, .rf-page h3 { font-family: var(--rf-headline); font-weight: 700; letter-spacing: -0.055em; line-height: 0.95; margin: 0; color: var(--rf-white); }
.rf-hero h1 { margin-top: 22px; font-size: clamp(23px, 4.8vw, 40px); max-width: 820px; }
.rf-blue { color: var(--rf-blue); }
.rf-free-word { position: relative; display: inline-block; color: var(--rf-white); }
.rf-free-word::after { content: ''; position: absolute; left: 0.02em; right: 0.03em; bottom: 0.03em; height: 0.13em; background: var(--rf-blue); border-radius: 99px; z-index: -1; }
.rf-hero-copy { margin: 22px 0 0; max-width: 660px; color: var(--rf-muted); font-size: clamp(16px, 1.8vw, 21px); line-height: 1.48; }
.rf-actions { display: flex; flex-wrap: wrap; gap: 14px; margin-top: 34px; }
.rf-btn { position: relative; display: inline-flex; align-items: center; justify-content: center; gap: 10px; min-height: 52px; padding: 0 22px; border: 1px solid transparent; border-radius: 999px; font-family: var(--rf-nav); font-size: 14px; font-weight: 700; text-decoration: none; cursor: pointer; overflow: hidden; transition: transform 0.2s ease, border-color 0.2s ease, background 0.2s ease, color 0.2s ease; }
.rf-btn-primary { background: var(--rf-btn); color: var(--rf-white); box-shadow: 0 18px 46px rgba(18, 98, 211, 0.34); }
.rf-btn-primary:hover, .rf-btn-secondary:hover { transform: translateY(-3px); }
.rf-btn-secondary { border-color: var(--rf-line); background: rgba(255, 255, 255, 0.04); color: var(--rf-white); }
.rf-btn:hover .rf-download-icon { transform: translateY(2px); }
.rf-trust { display: flex; flex-wrap: wrap; gap: 16px; margin-top: 26px; color: rgba(255, 255, 255, 0.56); font-size: 13px; }
.rf-trust span { display: inline-flex; align-items: center; gap: 8px; }
.rf-check { color: var(--rf-blue); font-weight: 800; }
.rf-demo-card { position: relative; padding: 18px; border: 1px solid var(--rf-line); border-radius: 32px; background: linear-gradient(180deg, rgba(255, 255, 255, 0.11), rgba(255, 255, 255, 0.04)); box-shadow: var(--rf-shadow); }
.rf-window { overflow: hidden; border: 1px solid var(--rf-line); border-radius: 24px; background: #0c0c0c; }
.rf-window-top { display: flex; align-items: center; justify-content: space-between; gap: 16px; padding: 14px 16px; border-bottom: 1px solid var(--rf-line); background: rgba(255, 255, 255, 0.04); }
.rf-lights { display: flex; gap: 7px; }
.rf-lights i { width: 10px; height: 10px; border-radius: 50%; background: rgba(255, 255, 255, 0.24); }
.rf-window-title { color: rgba(255, 255, 255, 0.7); font-family: var(--rf-nav); font-size: 12px; font-weight: 700; }
.rf-demo-body { display: grid; grid-template-rows: auto auto auto; padding: 22px; }
.rf-before, .rf-after { min-height: 146px; padding: 18px; border: 1px solid var(--rf-line); border-radius: 18px; background: rgba(255, 255, 255, 0.045); }
.rf-label { display: flex; justify-content: space-between; margin-bottom: 12px; color: rgba(255, 255, 255, 0.56); font-family: var(--rf-nav); font-size: 12px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.08em; }
.rf-text { height: 78px; overflow: hidden; color: rgba(255, 255, 255, 0.86); font-size: 16px; line-height: 1.5; }
.rf-after { margin-top: 14px; border-color: rgba(26, 126, 251, 0.42); background: rgba(26, 126, 251, 0.1); }
.rf-demo-controls { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 10px; margin-top: 14px; }
.rf-mode-btn { min-height: 42px; border: 1px solid var(--rf-line); border-radius: 14px; background: rgba(255, 255, 255, 0.05); color: var(--rf-white); font-family: var(--rf-nav); font-weight: 700; cursor: pointer; transition: background 0.2s ease, border-color 0.2s ease; }
.rf-mode-btn.is-active, .rf-mode-btn:hover { border-color: var(--rf-blue); background: rgba(26, 126, 251, 0.18); }
.rf-floating-badge { position: absolute; right: -18px; top: -20px; z-index: 3; max-width: 190px; padding: 14px 16px; border: 1px solid rgba(26, 126, 251, 0.46); border-radius: 18px; background: rgba(8, 8, 8, 0.86); backdrop-filter: blur(18px); box-shadow: 0 18px 48px rgba(0, 0, 0, 0.32); transform: rotate(-2deg); pointer-events: none; }
.rf-floating-badge strong { display: block; color: var(--rf-blue); font-family: var(--rf-headline); font-size: 22px; letter-spacing: -0.05em; }
.rf-floating-badge span { color: var(--rf-muted); font-size: 12px; line-height: 1.35; }
.rf-section { padding: 84px 0; }
.rf-section-head { display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 16px; margin-bottom: 34px; text-align: center; }
.rf-section h2 { max-width: 1100px; font-size: clamp(30px, 4.8vw, 50px); }
.rf-section-lead { max-width: 650px; margin: 0 auto; color: var(--rf-muted); font-size: 16px; line-height: 1.55; }
.rf-marquee { overflow: hidden; border-block: 1px solid var(--rf-line); background: rgba(255, 255, 255, 0.035); }
.rf-marquee-track { display: flex; width: max-content; animation: rf-marquee 24s linear infinite; }
.rf-marquee span { padding: 18px 22px; color: rgba(255, 255, 255, 0.76); font-family: var(--rf-nav); font-size: 12px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.08em; white-space: nowrap; }
@keyframes rf-marquee { to { transform: translateX(-50%); } }
.rf-feature-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 16px; }
.rf-feature { min-height: 240px; padding: 24px; border: 1px solid var(--rf-line); border-radius: 28px; background: linear-gradient(180deg, rgba(255, 255, 255, 0.07), rgba(255, 255, 255, 0.035)); transition: transform 0.25s ease, border-color 0.25s ease, background 0.25s ease; }
.rf-feature:hover { transform: translateY(-6px); border-color: rgba(26, 126, 251, 0.5); background: linear-gradient(180deg, rgba(26, 126, 251, 0.16), rgba(255, 255, 255, 0.035)); }
.rf-icon { display: grid; place-items: center; width: 48px; height: 48px; margin-bottom: 28px; border: 1px solid var(--rf-line); border-radius: 16px; background: var(--rf-white); color: var(--rf-black); font-size: 22px; }
.rf-feature h3 { margin-bottom: 12px; font-size: 20px; letter-spacing: -0.04em; }
.rf-feature p { margin: 0; color: var(--rf-muted); line-height: 1.55; }
.rf-steps { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 14px; counter-reset: steps; }
.rf-step { position: relative; min-height: 210px; padding: 22px; border: 1px solid var(--rf-line); border-radius: 24px; background: var(--rf-card); counter-increment: steps; }
.rf-step::before { content: '0' counter(steps); display: inline-flex; align-items: center; justify-content: center; width: 44px; height: 44px; margin-bottom: 40px; border-radius: 50%; background: var(--rf-white); color: var(--rf-black); font-family: var(--rf-nav); font-weight: 700; }
.rf-step h3 { margin-bottom: 10px; font-size: 21px; }
.rf-step p { margin: 0; color: var(--rf-muted); line-height: 1.5; }
.rf-video-card { position: relative; overflow: hidden; display: flex; align-items: center; justify-content: center; padding: 12px; border: 1px solid var(--rf-line); border-radius: 34px; background: linear-gradient(135deg, rgba(255, 255, 255, 0.08), rgba(255, 255, 255, 0.02)), radial-gradient(circle at 50% 30%, rgba(26, 126, 251, 0.22), transparent 22rem), #0c0c0c; box-shadow: var(--rf-shadow); }
.rf-demo-video { display: block; width: 100%; aspect-ratio: 16 / 9; border: 1px solid rgba(255, 255, 255, 0.12); border-radius: 24px; background: #080808; object-fit: cover; }
.rf-video-copy { position: absolute; left: 28px; bottom: 24px; z-index: 2; max-width: 520px; }
.rf-video-copy h3 { margin-bottom: 10px; font-size: clamp(30px, 4.8vw, 50px); }
.rf-video-copy p { margin: 0; color: var(--rf-muted); font-size: 15px; line-height: 1.5; }
.rf-compare { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.rf-panel { padding: 26px; border: 1px solid var(--rf-line); border-radius: 28px; background: var(--rf-card); }
.rf-panel.is-blue { border-color: rgba(26, 126, 251, 0.54); background: linear-gradient(180deg, rgba(26, 126, 251, 0.16), rgba(255, 255, 255, 0.035)); }
.rf-panel h3 { margin-bottom: 18px; font-size: 25px; }
.rf-list { display: grid; gap: 14px; margin: 0; padding: 0; list-style: none; }
.rf-list li { display: flex; gap: 12px; color: var(--rf-muted); line-height: 1.45; }
.rf-list strong { color: var(--rf-white); }
.rf-pricing { display: grid; grid-template-columns: 0.9fr 1.1fr; align-items: stretch; gap: 16px; }
.rf-price-card { position: relative; overflow: hidden; padding: 34px; border: 1px solid rgba(26, 126, 251, 0.52); border-radius: 34px; background: radial-gradient(circle at top right, rgba(26, 126, 251, 0.24), transparent 22rem), linear-gradient(180deg, rgba(255, 255, 255, 0.09), rgba(255, 255, 255, 0.035)); box-shadow: var(--rf-shadow); }
.rf-price { display: flex; align-items: end; gap: 8px; margin: 24px 0 8px; font-family: var(--rf-headline); font-size: clamp(68px, 11vw, 124px); font-weight: 700; letter-spacing: -0.08em; line-height: 0.82; }
.rf-price small { margin-bottom: 10px; color: var(--rf-muted); font-family: var(--rf-base); font-size: 16px; letter-spacing: 0; }
.rf-price-card p { max-width: 500px; margin: 0 0 24px; color: var(--rf-muted); font-size: 16px; line-height: 1.5; }
.rf-faq { display: grid; gap: 12px; }
.rf-faq-item { border: 1px solid var(--rf-line); border-radius: 22px; background: rgba(255, 255, 255, 0.04); overflow: hidden; }
.rf-faq-q { display: flex; align-items: center; justify-content: space-between; gap: 18px; width: 100%; padding: 20px 22px; border: 0; background: transparent; color: var(--rf-white); text-align: left; font-family: var(--rf-nav); font-size: 16px; font-weight: 700; cursor: pointer; }
.rf-faq-icon { flex: 0 0 auto; color: var(--rf-blue); font-size: 22px; transition: transform 0.15s ease; }
.rf-faq-a { height: 0; overflow: hidden; transition: height 0.25s cubic-bezier(0.4, 0, 0.2, 1); }
.rf-faq-a p { margin: 0; padding: 0 22px 20px; color: var(--rf-muted); line-height: 1.55; }
.rf-faq-item.is-open .rf-faq-icon { transform: rotate(45deg); }
.rf-final { padding: 90px 0 110px; }
.rf-final-card { position: relative; overflow: hidden; padding: clamp(34px, 7vw, 76px); border: 1px solid rgba(26, 126, 251, 0.44); border-radius: 40px; background: radial-gradient(circle at 85% 20%, rgba(26, 126, 251, 0.28), transparent 26rem), linear-gradient(135deg, rgba(255, 255, 255, 0.11), rgba(255, 255, 255, 0.04)); text-align: center; box-shadow: var(--rf-shadow); }
.rf-final-card h2 { max-width: 800px; margin: 0 auto 18px; font-size: clamp(23px, 4.8vw, 50px); }
.rf-final-card p { max-width: 610px; margin: 0 auto 30px; color: var(--rf-muted); font-size: 18px; line-height: 1.5; }
.rf-footer { padding: 40px 0 28px; border-top: 1px solid var(--rf-line); color: rgba(255, 255, 255, 0.52); font-size: 14px; }
.rf-footer-col { display: flex; flex-direction: column; align-items: center; gap: 24px; width: 100%; }
.rf-footer-badges { display: flex; flex-wrap: wrap; align-items: center; justify-content: center; gap: 20px; }
.rf-footer-badges a { transition: transform 0.2s ease, opacity 0.2s ease; }
.rf-footer-badges a:hover { transform: translateY(-3px); opacity: 0.9; }
.rf-footer-row { display: flex; justify-content: center; gap: 20px; }
.rf-reveal { opacity: 0; transform: translateY(22px); transition: opacity 0.6s ease, transform 0.6s ease; }
.rf-reveal.is-visible { opacity: 1; transform: translateY(0); }
.rf-feedback-section { padding-top: 96px; padding-bottom: 90px; }
.rf-feedback-hero { display: none; }
.rf-form-card { max-width: 960px; margin: 0 auto; padding: 36px; border: 1px solid var(--rf-line); border-radius: 32px; background: rgba(255, 255, 255, 0.06); box-shadow: var(--rf-shadow); }
.rf-form-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 20px; }
.form-field { display: grid; gap: 10px; margin-bottom: 18px; }
.form-field span { font-family: var(--rf-nav); font-weight: 700; color: rgba(255, 255, 255, 0.88); font-size: 14px; }
.input-text,
.input-select,
.input-textarea {
  width: 100%;
  min-height: 50px;
  border: 1px solid rgba(255, 255, 255, 0.18);
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.05);
  color: var(--rf-white);
  font-family: var(--rf-base);
  font-size: 15px;
  padding: 14px 16px;
}
.input-text::placeholder,
.input-textarea::placeholder {
  color: rgba(255, 255, 255, 0.5);
}
.input-select {
  appearance: none;
  color: var(--rf-white);
  background-color: rgba(255, 255, 255, 0.05);
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%231a7efb' d='M6 9L1 4h10z'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 14px center;
  background-size: 12px;
  padding-right: 40px;
}
.input-select option {
  background-color: #1a1a1a;
  color: var(--rf-white);
}
.input-select option:checked {
  background-color: var(--rf-blue);
  color: var(--rf-white);
}
.input-textarea { min-height: 180px; resize: vertical; padding-top: 16px; padding-bottom: 16px; }
.file-field { position: relative; padding: 0; border: 1px solid rgba(255, 255, 255, 0.18); border-radius: 999px; background: rgba(255, 255, 255, 0.06); cursor: pointer; overflow: hidden; min-height: 50px; display: flex; align-items: center; justify-content: flex-start; transition: transform 0.2s ease, border-color 0.2s ease, background 0.2s ease, box-shadow 0.2s ease; }
.file-field span:first-of-type { display: none; }
.input-file { position: absolute; inset: 0; width: 100%; height: 100%; opacity: 0; cursor: pointer; }
.file-helper { display: flex; align-items: center; justify-content: center; width: 100%; min-height: 50px; padding: 0 18px; border-radius: 999px; background: transparent; color: var(--rf-white); font-family: var(--rf-nav); font-weight: 700; font-size: 15px; transition: transform 0.2s ease, letter-spacing 0.2s ease; }
.file-field:hover,
.file-field:focus-within { transform: translateY(-2px); border-color: rgba(26, 126, 251, 0.64); background: rgba(26, 126, 251, 0.14); box-shadow: 0 14px 34px rgba(26, 126, 251, 0.18); }
.file-field:hover .file-helper,
.file-field:focus-within .file-helper { transform: scale(1.02); letter-spacing: 0.01em; }
.file-field.is-selected { border-color: rgba(26, 126, 251, 0.8); background: rgba(26, 126, 251, 0.18); box-shadow: 0 16px 38px rgba(26, 126, 251, 0.22); }
.file-field.is-selected .file-helper { color: #d8ecff; }
.g-recaptcha { transform: scale(1); transform-origin: 0 0; margin: 12px 0; }
.field-error { color: #ff8fa3; font-size: 13px; }
.form-error { margin-bottom: 18px; padding: 16px 18px; border-radius: 18px; background: rgba(255, 82, 82, 0.12); border: 1px solid rgba(255, 82, 82, 0.2); color: #ffb3b3; }
.form-success { margin-bottom: 18px; padding: 16px 18px; border-radius: 18px; background: rgba(26, 126, 251, 0.14); border: 1px solid rgba(26, 126, 251, 0.35); color: #cfe8ff; }

/* Legal pages (Privacy Policy / Terms of Use) */
.rf-legal { color: rgba(255, 255, 255, 0.82); font-size: 15px; line-height: 1.65; }
.rf-legal h3 { margin: 38px 0 14px; font-size: 22px; letter-spacing: -0.03em; color: var(--rf-white); }
.rf-legal h4 { margin: 22px 0 10px; font-size: 16px; font-family: var(--rf-nav); color: var(--rf-white); }
.rf-legal p { margin: 0 0 14px; }
.rf-legal ul { margin: 0 0 18px; padding-left: 22px; }
.rf-legal li { margin-bottom: 8px; }
.rf-legal a { color: var(--rf-blue); text-decoration: underline; text-underline-offset: 3px; }
.rf-legal a:hover { opacity: 0.85; }
.rf-legal strong { color: var(--rf-white); }

@media (min-width: 981px) {
  .rf-section h2 { white-space: nowrap; }
}

@media (max-width: 980px) {
  .rf-nav { width: calc(100% - 20px); padding: 8px 8px 8px 12px; gap: 10px; border-radius: 24px; flex-wrap: wrap; }
  .rf-brand { display: inline-flex; align-items: center; flex: 1 1 auto; min-width: 0; font-size: 14px; gap: 8px; }
  .rf-logo-img { display: block; width: 26px; height: 26px; border-radius: 9px; object-fit: contain; flex: 0 0 auto; }
  .rf-nav-links { position: static; flex: 1 0 100%; order: 4; display: none; flex-direction: column; align-items: stretch; max-height: calc(100vh - 120px); overflow-y: auto; margin: 8px 0 2px; padding: 10px; border: 1px solid var(--rf-line); border-radius: 18px; background: #080808; box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.06); }
  .rf-nav-links.is-open { display: flex; }
  .rf-nav-links a { display: flex; align-items: center; width: 100%; min-height: 46px; padding: 0 14px; }
  .rf-menu-btn { display: inline-flex; align-items: center; justify-content: center; flex: 0 0 auto; width: 42px; height: 42px; padding: 0; line-height: 1; }
  .rf-nav-cta { display: none; }
  .rf-hero-grid, .rf-pricing, .rf-compare { grid-template-columns: 1fr; }
  .rf-feature-grid, .rf-steps { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .rf-section-head { align-items: center; flex-direction: column; }
  .rf-floating-badge { right: 10px; top: -30px; max-width: 170px; }
  .rf-form-grid { grid-template-columns: 1fr; }
}
@media (max-width: 640px) {
  .rf-container { width: min(100% - 28px, 1180px); }
  .rf-nav { width: calc(100% - 16px); padding: 7px 7px 7px 10px; border-radius: 20px; }
  .rf-logo-img { width: 24px; height: 24px; border-radius: 8px; }
  .rf-menu-btn { width: 38px; height: 38px; font-size: 18px; }
  .rf-nav-links { border-radius: 16px; }
  .rf-hero { padding: 46px 0 56px; }
  .rf-hero-grid { text-align: center; justify-items: center; }
  .rf-hero-grid > div:first-child { display: flex; flex-direction: column; align-items: center; }
  .rf-hero h1 { font-size: clamp(23px, 4.8vw, 40px); line-height: 1.04; max-width: 100%; }
  .rf-hero-copy { font-size: 15px; line-height: 1.55; margin-left: auto; margin-right: auto; }
  .rf-actions, .rf-trust { align-items: center; justify-content: center; flex-direction: column; }
  .rf-btn { width: 100%; }
  .rf-feature-grid, .rf-steps, .rf-demo-controls { grid-template-columns: 1fr; }
  .rf-before, .rf-after { min-height: 158px; }
  .rf-text { height: 90px; }
  .rf-floating-badge { position: static; max-width: none; margin: 12px 8px 0 auto; transform: rotate(-1deg); pointer-events: none; }
  .rf-section { padding: 58px 0; }
  .rf-section h2 { font-size: clamp(20px, 4.8vw, 50px); line-height: 1.05; }
  .rf-section-lead { font-size: 15px; }
  .rf-video-card { padding: 8px; border-radius: 24px; }
  .rf-demo-video { border-radius: 18px; }
  .rf-footer-row { flex-direction: column; align-items: center; text-align: center; }
}
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration: 0.01ms !important; animation-iteration-count: 1 !important; scroll-behavior: auto !important; transition-duration: 0.01ms !important; }
}

/* ── Discover Page ─────────────────────────────── */
.rf-discover-hero { padding: 70px 0 34px; }
.rf-discover-stats { display: flex; align-items: center; justify-content: center; gap: 18px; margin-top: 22px; color: var(--rf-muted); font-family: var(--rf-nav); font-size: 14px; font-weight: 700; }
.rf-discover-stats strong { color: var(--rf-white); font-family: var(--rf-headline); font-size: 22px; letter-spacing: -0.04em; }
.rf-discover-stat-sep { color: rgba(255,255,255,0.24); }
.rf-discover-controls { display: flex; flex-direction: column; gap: 18px; margin-bottom: 28px; }
.rf-discover-search { position: relative; }
.rf-discover-search-icon { position: absolute; left: 16px; top: 50%; transform: translateY(-50%); width: 18px; height: 18px; color: rgba(255,255,255,0.45); pointer-events: none; }
.rf-discover-search-input { width: 100%; min-height: 52px; padding: 0 18px 0 46px; border: 1px solid var(--rf-line); border-radius: 999px; background: rgba(255,255,255,0.04); color: var(--rf-white); font-family: var(--rf-base); font-size: 15px; outline: none; transition: border-color 0.2s ease, background 0.2s ease; }
.rf-discover-search-input::placeholder { color: rgba(255,255,255,0.4); }
.rf-discover-search-input:focus { border-color: rgba(26,126,251,0.6); background: rgba(255,255,255,0.06); }
.rf-discover-filters { display: flex; flex-wrap: wrap; gap: 10px; }
.rf-discover-filter { min-height: 38px; padding: 0 18px; border: 1px solid var(--rf-line); border-radius: 999px; background: rgba(255,255,255,0.04); color: var(--rf-muted); font-family: var(--rf-nav); font-size: 13px; font-weight: 700; cursor: pointer; transition: color 0.2s ease, background 0.2s ease, border-color 0.2s ease, transform 0.15s ease; }
.rf-discover-filter:hover { color: var(--rf-white); background: rgba(255,255,255,0.08); border-color: rgba(255,255,255,0.22); }
.rf-discover-filter.is-active { background: var(--rf-btn); color: var(--rf-white); border-color: var(--rf-btn); box-shadow: 0 10px 28px rgba(18,98,211,0.28); }
.rf-discover-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 18px; }
.rf-discover-card { display: flex; flex-direction: column; padding: 0; border: 1px solid var(--rf-line); border-radius: 28px; background: linear-gradient(180deg, rgba(255,255,255,0.07), rgba(255,255,255,0.035)); overflow: hidden; transition: transform 0.25s ease, border-color 0.25s ease, box-shadow 0.25s ease; }
.rf-discover-card:hover { transform: translateY(-5px); border-color: rgba(26,126,251,0.45); box-shadow: 0 24px 60px rgba(0,0,0,0.35); }
.rf-discover-card.is-hidden { display: none; }
.rf-discover-card-top { padding: 22px 22px 16px; }
.rf-discover-badge { display: inline-block; padding: 5px 11px; border-radius: 999px; font-family: var(--rf-nav); font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.07em; margin-bottom: 14px; }
.rf-discover-badge.prod { border: 1px solid rgba(245,158,11,0.45); color: rgba(245,158,11,0.95); background: rgba(245,158,11,0.1); }
.rf-discover-badge.writing { border: 1px solid rgba(236,72,153,0.45); color: rgba(236,72,153,0.95); background: rgba(236,72,153,0.1); }
.rf-discover-badge.coding { border: 1px solid rgba(34,197,94,0.45); color: rgba(34,197,94,0.95); background: rgba(34,197,94,0.1); }
.rf-discover-badge.social { border: 1px solid rgba(139,92,246,0.45); color: rgba(139,92,246,0.95); background: rgba(139,92,246,0.1); }
.rf-discover-badge.comm { border: 1px solid rgba(6,182,212,0.45); color: rgba(6,182,212,0.95); background: rgba(6,182,212,0.1); }
.rf-discover-badge.creative { border: 1px solid rgba(249,115,22,0.45); color: rgba(249,115,22,0.95); background: rgba(249,115,22,0.1); }
.rf-page .rf-discover-title { font-family: var(--rf-headline); font-size: 20px; font-weight: 700; letter-spacing: -0.04em; color: var(--rf-white); margin: 0 0 14px; }
.rf-page .rf-discover-desc { margin: 0; color: var(--rf-muted); font-size: 14px; line-height: 1.5; }
.rf-discover-prompt-wrap { padding: 0 22px 18px; flex: 1 1 auto; }
.rf-discover-prompt-label { font-family: var(--rf-nav); font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.1em; color: rgba(255,255,255,0.35); margin-bottom: 8px; }
.rf-discover-prompt { margin: 0; padding: 14px 16px; border: 1px solid rgba(255,255,255,0.08); border-radius: 16px; background: rgba(0,0,0,0.35); color: rgba(255,255,255,0.78); font-family: var(--rf-base); font-size: 13px; line-height: 1.6; white-space: pre-wrap; overflow-wrap: break-word; max-height: 220px; overflow-y: auto; }
.rf-discover-card-bottom { padding: 0 22px 22px; }
.rf-discover-copy { display: inline-flex; align-items: center; gap: 8px; min-height: 40px; padding: 0 18px; border: 1px solid var(--rf-line); border-radius: 999px; background: rgba(255,255,255,0.05); color: var(--rf-white); font-family: var(--rf-nav); font-size: 13px; font-weight: 700; cursor: pointer; transition: background 0.2s ease, border-color 0.2s ease, transform 0.15s ease; }
.rf-discover-copy:hover { background: rgba(26,126,251,0.18); border-color: rgba(26,126,251,0.55); transform: translateY(-1px); }
.rf-discover-copy.is-copied { background: rgba(34,197,94,0.18); border-color: rgba(34,197,94,0.55); color: rgba(34,197,94,1); }
.rf-discover-copy-icon { width: 15px; height: 15px; }
.rf-discover-empty { text-align: center; padding: 60px 20px; color: var(--rf-muted); }
.rf-discover-empty-icon { font-size: 40px; margin-bottom: 12px; }
.rf-discover-empty h3 { font-family: var(--rf-headline); font-size: 24px; color: var(--rf-white); margin: 0 0 6px; }
.rf-discover-empty p { margin: 0; font-size: 15px; }
.rf-discover-toast { position: fixed; bottom: 28px; left: 50%; transform: translateX(-50%) translateY(20px); z-index: 2000; display: inline-flex; align-items: center; gap: 10px; padding: 12px 20px; border: 1px solid rgba(34,197,94,0.45); border-radius: 999px; background: rgba(8,8,8,0.92); backdrop-filter: blur(14px); color: rgba(34,197,94,1); font-family: var(--rf-nav); font-size: 13px; font-weight: 700; opacity: 0; pointer-events: none; transition: opacity 0.3s ease, transform 0.3s ease; box-shadow: 0 14px 40px rgba(0,0,0,0.35); }
.rf-discover-toast.is-visible { opacity: 1; transform: translateX(-50%) translateY(0); }
.rf-discover-toast svg { width: 18px; height: 18px; flex-shrink: 0; }
@media (max-width: 980px) {
  .rf-discover-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .rf-discover-hero { padding: 50px 0 24px; }
}
@media (max-width: 640px) {
  .rf-discover-grid { grid-template-columns: 1fr; }
  .rf-discover-stats { flex-wrap: wrap; gap: 10px 18px; }
  .rf-discover-search-input { min-height: 48px; font-size: 16px; }
  .rf-discover-prompt { font-size: 13px; }
}
