/* Ruffnet marketing pages — shared styles
 * Used by CMS pages (/, /webtarhely, /wordpress, /email, /vm, /dedikalt, /domain).
 * Kept in a separate file because the Blesta H2O CMS parser uses single { } as
 * variable delimiters, so we can't put <style> blocks directly in CMS content.
 */

/* ============= HERO ============= */
.rfm-hero {
  background: linear-gradient(135deg, #0d0d0d 0%, #1a1a1a 60%, #0d2a55 100%);
  padding: 100px 20px 80px;
  text-align: center;
  color: #fff;
}
.rfm-hero.compact { padding: 80px 20px 60px; background: linear-gradient(135deg, #0d0d0d, #1a1a1a); }
.rfm-hero h1 { font-size: 3.2rem; margin: 0 0 18px 0; font-weight: 700; line-height: 1.15; }
.rfm-hero.compact h1 { font-size: 2.8rem; }
.rfm-hero p { font-size: 1.25rem; color: #b0b0b0; max-width: 720px; margin: 0 auto 32px; }
.rfm-hero .badges { display: flex; justify-content: center; gap: 28px; flex-wrap: wrap; color: #888; font-size: 0.95rem; }
.rfm-hero .badges span { display: flex; align-items: center; gap: 8px; }

/* ============= SEARCH HERO (domain page) ============= */
.rfm-search-hero {
  max-width: 640px;
  margin: 32px auto 0;
  display: flex;
  background: #1a1a1a;
  border: 2px solid #2a2a2a;
  border-radius: 10px;
  padding: 6px;
}
.rfm-search-hero input { flex: 1; background: transparent; border: none; color: #fff; padding: 14px 18px; font-size: 1.05rem; }
.rfm-search-hero input:focus { outline: none; }
.rfm-search-hero button { background: #1062FE; color: #fff; border: none; border-radius: 6px; padding: 12px 28px; font-weight: 600; cursor: pointer; }
.rfm-search-hero button:hover { background: #0d52d4; }

/* ============= SECTIONS ============= */
.rfm-section { max-width: 1200px; margin: 0 auto; padding: 60px 20px; }
.rfm-section h2 { font-size: 2rem; text-align: center; margin: 0 0 12px 0; color: #fff; }
.rfm-section .lead { text-align: center; color: #888; margin: 0 auto 48px; max-width: 640px; }

/* ============= SERVICES GRID (homepage) ============= */
.rfm-services { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: 24px; }
.rfm-card { background: #1a1a1a; border: 1px solid #2a2a2a; border-radius: 12px; padding: 32px 28px; transition: all 0.2s; display: flex; flex-direction: column; }
.rfm-card:hover { border-color: #1062FE; transform: translateY(-4px); }
.rfm-card-icon { font-size: 2.5rem; margin-bottom: 16px; }
.rfm-card h3 { margin: 0 0 10px 0; color: #fff; font-size: 1.3rem; }
.rfm-card p { color: #aaa; margin: 0 0 20px 0; line-height: 1.5; flex: 1; }
.rfm-card .price-from { color: #1062FE; font-weight: 600; font-size: 0.9rem; margin-bottom: 14px; }
.rfm-card a.cta { color: #fff !important; background: #1062FE; padding: 10px 22px; border-radius: 8px; text-decoration: none; font-weight: 600; text-align: center; display: block; transition: background 0.15s; }
.rfm-card a.cta:hover { background: #0d52d4; color: #fff !important; text-decoration: none; }

/* ============= FEATURES GRID ============= */
.rfm-features { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 32px; }
.rfm-feat { text-align: center; color: #aaa; }
.rfm-feat-icon { font-size: 2.5rem; margin-bottom: 14px; }
.rfm-feat h3 { color: #fff; margin: 0 0 8px 0; font-size: 1.1rem; }

/* ============= TRUST BAR (homepage) ============= */
.rfm-trust { background: #0a0a0a; padding: 80px 20px; }
.rfm-trust .row { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 40px; max-width: 1100px; margin: 0 auto; text-align: center; }
.rfm-trust .num { font-size: 3rem; color: #1062FE; font-weight: 700; }
.rfm-trust .label { color: #aaa; margin-top: 8px; }

/* ============= PACKAGES SECTION (where embed widget goes) ============= */
.rfm-pkgs { background: #0a0a0a; padding: 70px 20px; }
.rfm-pkgs .inner { max-width: 1200px; margin: 0 auto; }
.rfm-pkgs h2 { color: #fff; text-align: center; font-size: 2rem; margin: 0 0 12px 0; }
.rfm-pkgs .lead { color: #888; text-align: center; margin: 0 0 40px 0; }

/* ============= TLD PRICING TABLE (domain page) ============= */
.rfm-tld-table { background: #0a0a0a; padding: 60px 20px; }
.rfm-tld-table .inner { max-width: 800px; margin: 0 auto; }
.rfm-tld-table h2 { color: #fff; text-align: center; margin-bottom: 12px; }
.rfm-tld-table .lead { color: #888; text-align: center; margin: 0 0 40px 0; }
.rfm-tld-table table { width: 100%; color: #ebebeb; border-collapse: collapse; }
.rfm-tld-table th, .rfm-tld-table td { padding: 14px 18px; text-align: left; border-bottom: 1px solid #2a2a2a; }
.rfm-tld-table th { color: #888; font-weight: 600; font-size: 0.85rem; text-transform: uppercase; letter-spacing: 0.5px; }
.rfm-tld-table .more-link { text-align: center; margin-top: 30px; }
.rfm-tld-table .more-link a { color: #1062FE; text-decoration: underline; }

/* ============= FAQ ============= */
.rfm-faq { max-width: 800px; margin: 60px auto; padding: 0 20px; }
.rfm-faq h2 { text-align: center; color: #fff; }
.rfm-faq details { background: #1a1a1a; border: 1px solid #2a2a2a; border-radius: 8px; padding: 16px 20px; margin-bottom: 10px; color: #ebebeb; }
.rfm-faq summary { font-weight: 600; cursor: pointer; }
.rfm-faq p { color: #888; margin: 12px 0 0 0; line-height: 1.6; }

/* ============= CTA STRIP (bottom of each marketing page) ============= */
.rfm-cta-strip { background: linear-gradient(135deg, #1062FE, #0d52d4); padding: 60px 20px; text-align: center; color: #fff; }
.rfm-cta-strip h2 { font-size: 2rem; margin: 0 0 16px 0; }
.rfm-cta-strip p { font-size: 1.1rem; color: rgba(255,255,255,0.9); margin: 0 0 28px 0; }
.rfm-cta-strip a.btn-pri { background: #fff; color: #1062FE; padding: 16px 36px; border-radius: 8px; font-weight: 700; text-decoration: none; display: inline-block; }
.rfm-cta-strip a.btn-pri:hover { background: #f0f0f0; text-decoration: none; }

/* Responsive */
@media (max-width: 768px) {
  .rfm-hero h1 { font-size: 2.2rem; }
  .rfm-hero.compact h1 { font-size: 2rem; }
  .rfm-search-hero { flex-direction: column; }
  .rfm-search-hero button { width: 100%; margin-top: 6px; }
  .rfm-section { padding: 40px 16px; }
}
