/* ============================================
   SugarDaddyBudapest.com — Pest Retro Theme
   Unique hand-coded CSS, pest- prefix
   display:table layout, CSS variables
   ============================================ */

:root {
  --pest-danube: #4a90d9;
  --pest-thermal: #c8102e;
  --pest-empire: #d4a843;
  --pest-bg-alap: #0d1117;
  --pest-bg-masodlagos: #161b22;
  --pest-bg-kartya: #1c2333;
  --pest-bg-emelt: #222b3a;
  --pest-danube-mely: #1a3a5c;
  --pest-danube-kozep: #2563a0;
  --pest-danube-ragyogas: #6bb3f0;
  --pest-empire-vilagos: #f0d078;
  --pest-empire-tompa: #b8922e;
  --pest-hungary-piros: #c8102e;
  --pest-hungary-zold: #00843d;
  --pest-szoveg-alap: #e6edf3;
  --pest-szoveg-masodlagos: #8b949e;
  --pest-szoveg-halvany: #6e7681;
  --pest-szegel: #30363d;
  --pest-szegel-vilagos: #3d4450;
  --pest-betutipus-cim: 'Playfair Display', Georgia, 'Times New Roman', serif;
  --pest-betutipus-torzs: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Helvetica, Arial, sans-serif;
  --pest-lekerekites: 8px;
  --pest-lekerekites-nagy: 16px;
  --pest-arnyek: 0 4px 24px rgba(0, 0, 0, 0.4);
  --pest-arnyek-fenyes: 0 0 30px rgba(74, 144, 217, 0.15);
  --pest-max-szelesseg: 1200px;
  --pest-atmenet: 0.3s ease;
}

/* Reset & Base */
*, *::before, *::after {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
  font-size: 16px;
}

body {
  font-family: var(--pest-betutipus-torzs);
  background-color: var(--pest-bg-alap);
  color: var(--pest-szoveg-alap);
  line-height: 1.75;
  min-height: 100vh;
  -webkit-font-smoothing: antialiased;
}

a {
  color: var(--pest-danube);
  text-decoration: none;
  transition: color var(--pest-atmenet);
}

a:hover {
  color: var(--pest-empire-vilagos);
}

img {
  max-width: 100%;
  height: auto;
  display: block;
}

/* Presentation list wrappers */
ul[role="presentation"] {
  list-style: none;
  margin: 0;
  padding: 0;
}

ul[role="presentation"] > li {
  list-style: none;
  margin: 0;
  padding: 0;
}

/* Typography */
h1, h2, h3, h4, h5, h6 {
  font-family: var(--pest-betutipus-cim);
  color: var(--pest-szoveg-alap);
  line-height: 1.3;
  margin-bottom: 0.75em;
}

h1 { font-size: 2.5rem; letter-spacing: -0.02em; }
h2 { font-size: 2rem; letter-spacing: -0.01em; }
h3 { font-size: 1.5rem; }
h4 { font-size: 1.25rem; }

p {
  margin-bottom: 1.25em;
  color: var(--pest-szoveg-masodlagos);
}

/* Signature samp elements */
samp {
  display: block;
  background: var(--pest-bg-kartya);
  border-left: 3px solid var(--pest-empire);
  padding: 1rem 1.5rem;
  margin: 1.5rem 0;
  border-radius: 0 var(--pest-lekerekites) var(--pest-lekerekites) 0;
  font-family: var(--pest-betutipus-torzs);
  font-size: 0.95rem;
  color: var(--pest-szoveg-masodlagos);
  font-style: italic;
}

/* ---- Header ---- */
.pest-fejlec {
  background: linear-gradient(180deg, var(--pest-bg-masodlagos) 0%, var(--pest-bg-alap) 100%);
  border-bottom: 1px solid var(--pest-szegel);
  position: sticky;
  top: 0;
  z-index: 1000;
  backdrop-filter: blur(12px);
}

.pest-fejlec-belso {
  max-width: var(--pest-max-szelesseg);
  margin: 0 auto;
  padding: 0 1.5rem;
  display: table;
  width: 100%;
  height: 72px;
}

.pest-logo {
  display: table-cell;
  vertical-align: middle;
  width: 50%;
  font-family: var(--pest-betutipus-cim);
  font-size: 1.35rem;
  color: var(--pest-szoveg-alap);
  font-weight: 700;
}

.pest-logo:hover {
  color: var(--pest-empire);
}

.pest-logo-ikon {
  width: 40px;
  height: 40px;
  vertical-align: middle;
  margin-right: 0.75rem;
}

.pest-nav {
  display: table-cell;
  vertical-align: middle;
  text-align: right;
}

.pest-nav a {
  padding: 0.5rem 1rem;
  border-radius: var(--pest-lekerekites);
  color: var(--pest-szoveg-masodlagos);
  font-size: 0.9rem;
  font-weight: 500;
  transition: all var(--pest-atmenet);
}

.pest-nav a:hover,
.pest-nav a.pest-aktiv {
  color: var(--pest-szoveg-alap);
  background: var(--pest-bg-emelt);
}

.pest-nav-valto {
  display: none;
  flex-direction: column;
  gap: 5px;
  background: none;
  border: none;
  cursor: pointer;
  padding: 0.5rem;
}

.pest-nav-valto span {
  display: block;
  width: 24px;
  height: 2px;
  background: var(--pest-szoveg-alap);
  border-radius: 2px;
  transition: var(--pest-atmenet);
}

/* ---- Hero (banner) ---- */
.pest-hosszakasz {
  position: relative;
  padding: 6rem 1.5rem 5rem;
  text-align: center;
  overflow: hidden;
  background: linear-gradient(135deg, var(--pest-bg-alap) 0%, var(--pest-danube-mely) 50%, var(--pest-bg-alap) 100%);
}

.pest-hosszakasz::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background:
    radial-gradient(ellipse at 30% 80%, rgba(37, 99, 160, 0.2) 0%, transparent 60%),
    radial-gradient(ellipse at 70% 20%, rgba(212, 168, 67, 0.1) 0%, transparent 50%);
  pointer-events: none;
}

.pest-hosszakasz-tartalom {
  position: relative;
  z-index: 2;
  max-width: 800px;
  margin: 0 auto;
}

.pest-hosszakasz h1 {
  font-size: 3.2rem;
  margin-bottom: 0.5em;
  background: linear-gradient(135deg, var(--pest-empire-vilagos) 0%, var(--pest-empire) 50%, var(--pest-empire-tompa) 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.pest-hosszakasz-alcim {
  font-size: 1.2rem;
  color: var(--pest-szoveg-masodlagos);
  margin-bottom: 2rem;
  max-width: 600px;
  margin-left: auto;
  margin-right: auto;
}

.pest-zaszlo {
  display: inline-block;
  margin-bottom: 2rem;
  border-radius: 4px;
  overflow: hidden;
  box-shadow: var(--pest-arnyek);
}

.pest-zaszlo span {
  display: block;
  width: 120px;
  height: 8px;
}

.pest-zaszlo-piros { background: var(--pest-hungary-piros); }
.pest-zaszlo-feher { background: #ffffff; }
.pest-zaszlo-zold { background: var(--pest-hungary-zold); }

.pest-gombok-sor {
  display: table;
  margin: 0 auto;
}

.pest-gombok-sor .pest-gomb {
  display: table-cell;
  margin: 0 0.5rem;
}

/* ---- Buttons ---- */
.pest-gomb {
  display: inline-block;
  padding: 0.875rem 2rem;
  border-radius: var(--pest-lekerekites);
  font-weight: 600;
  font-size: 1rem;
  cursor: pointer;
  border: none;
  transition: all var(--pest-atmenet);
  text-decoration: none;
  margin: 0 0.5rem;
}

.pest-gomb-elsodleges {
  background: linear-gradient(135deg, var(--pest-empire) 0%, var(--pest-empire-tompa) 100%);
  color: var(--pest-bg-alap);
  box-shadow: 0 4px 16px rgba(212, 168, 67, 0.3);
}

.pest-gomb-elsodleges:hover {
  transform: translateY(-2px);
  box-shadow: 0 6px 24px rgba(212, 168, 67, 0.45);
  color: var(--pest-bg-alap);
}

.pest-gomb-korvonal {
  background: transparent;
  color: var(--pest-danube);
  border: 1px solid var(--pest-danube);
}

.pest-gomb-korvonal:hover {
  background: var(--pest-danube);
  color: var(--pest-bg-alap);
}

/* ---- Sections ---- */
.pest-szakasz {
  max-width: var(--pest-max-szelesseg);
  margin: 0 auto;
  padding: 4rem 1.5rem;
}

.pest-szakasz-fejlec {
  text-align: center;
  margin-bottom: 3rem;
}

.pest-szakasz-fejlec h2 {
  position: relative;
  display: inline-block;
}

.pest-szakasz-fejlec h2::after {
  content: '';
  display: block;
  width: 60px;
  height: 3px;
  background: linear-gradient(90deg, var(--pest-empire), var(--pest-danube));
  margin: 0.75rem auto 0;
  border-radius: 2px;
}

.pest-elvalaszto {
  border: none;
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--pest-szegel), transparent);
  margin: 0;
}

/* ---- District Table ---- */
.pest-kerulet-tabla {
  border-collapse: separate;
  border-spacing: 1.5rem;
  width: 100%;
  table-layout: fixed;
}

.pest-kerulet-tabla caption {
  font-family: var(--pest-betutipus-cim);
  font-size: 2rem;
  color: var(--pest-szoveg-alap);
  margin-bottom: 1.5rem;
  text-align: center;
  caption-side: top;
}

.pest-kerulet-cella {
  background: var(--pest-bg-kartya);
  border: 1px solid var(--pest-szegel);
  border-radius: var(--pest-lekerekites-nagy);
  padding: 2rem;
  vertical-align: top;
  transition: all var(--pest-atmenet);
  position: relative;
  overflow: hidden;
}

.pest-kerulet-cella:hover {
  border-color: var(--pest-szegel-vilagos);
  box-shadow: var(--pest-arnyek-fenyes);
  transform: translateY(-4px);
}

.pest-kerulet-cella h3 {
  margin-bottom: 0.5em;
}

.pest-kerulet-cella h3 a {
  color: var(--pest-szoveg-alap);
}

.pest-kerulet-cella h3 a:hover {
  color: var(--pest-empire);
}

/* ---- Card Layout (display:table) ---- */
.pest-racsok {
  display: table;
  width: 100%;
  border-spacing: 1.5rem 0;
}

.pest-racsok-sor {
  display: table-row;
}

.pest-kartya {
  background: var(--pest-bg-kartya);
  border: 1px solid var(--pest-szegel);
  border-radius: var(--pest-lekerekites-nagy);
  padding: 2rem;
  transition: all var(--pest-atmenet);
  position: relative;
  overflow: hidden;
}

.pest-kartya::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 3px;
  background: linear-gradient(90deg, var(--pest-danube-kozep), var(--pest-empire));
  opacity: 0;
  transition: opacity var(--pest-atmenet);
}

.pest-kartya:hover {
  border-color: var(--pest-szegel-vilagos);
  box-shadow: var(--pest-arnyek-fenyes);
  transform: translateY(-4px);
}

.pest-kartya:hover::before {
  opacity: 1;
}

.pest-kartya h3 {
  margin-bottom: 0.5em;
}

.pest-kartya h3 a {
  color: var(--pest-szoveg-alap);
}

.pest-kartya h3 a:hover {
  color: var(--pest-empire);
}

.pest-kartya-meta {
  font-size: 0.85rem;
  color: var(--pest-szoveg-halvany);
  margin-bottom: 0.75rem;
  display: block;
}

/* ---- Blog list inside nav ---- */
.pest-blog-lista {
  display: table;
  width: 100%;
  border-spacing: 1.5rem;
  list-style: none;
}

.pest-blog-lista > li {
  display: table-cell;
  width: 33.33%;
  vertical-align: top;
}

/* ---- Stat Boxes ---- */
.pest-statisztikak {
  display: table;
  width: 100%;
  border-spacing: 1.5rem 0;
  margin: 3rem 0;
}

.pest-adat {
  display: table-cell;
  text-align: center;
  padding: 2rem 1rem;
  background: var(--pest-bg-kartya);
  border-radius: var(--pest-lekerekites-nagy);
  border: 1px solid var(--pest-szegel);
  width: 25%;
}

.pest-adat-szam {
  font-family: var(--pest-betutipus-cim);
  font-size: 2.5rem;
  color: var(--pest-empire);
  display: block;
  line-height: 1;
  margin-bottom: 0.5rem;
}

.pest-adat-cimke {
  font-size: 0.85rem;
  color: var(--pest-szoveg-halvany);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

/* ---- Danube Wave Separator ---- */
.pest-hullam {
  width: 100%;
  height: 60px;
  background: var(--pest-bg-alap);
  position: relative;
  overflow: hidden;
}

.pest-hullam::before {
  content: '';
  position: absolute;
  bottom: 0;
  left: -50%;
  width: 200%;
  height: 40px;
  background:
    radial-gradient(ellipse at 25% 100%, var(--pest-danube-mely) 0%, transparent 50%),
    radial-gradient(ellipse at 75% 100%, var(--pest-danube-kozep) 0%, transparent 50%);
  opacity: 0.3;
}

/* ---- Content Layout ---- */
.pest-tartalom {
  max-width: 800px;
  margin: 0 auto;
  padding: 3rem 1.5rem;
}

.pest-tartalom h2 {
  margin-top: 2.5rem;
  padding-top: 1.5rem;
  border-top: 1px solid var(--pest-szegel);
}

.pest-tartalom h2:first-of-type {
  border-top: none;
  padding-top: 0;
}

.pest-tartalom ul, .pest-tartalom ol {
  padding-left: 1.5rem;
  margin-bottom: 1.5rem;
  color: var(--pest-szoveg-masodlagos);
}

.pest-tartalom li {
  margin-bottom: 0.5rem;
}

.pest-tartalom blockquote {
  border-left: 3px solid var(--pest-empire);
  padding: 1rem 1.5rem;
  margin: 1.5rem 0;
  background: var(--pest-bg-kartya);
  border-radius: 0 var(--pest-lekerekites) var(--pest-lekerekites) 0;
  font-style: italic;
  color: var(--pest-szoveg-masodlagos);
}

.pest-tartalom strong {
  color: var(--pest-szoveg-alap);
}

/* ---- How It Works (ordered list) ---- */
.pest-lepes {
  max-width: 800px;
  margin: 0 auto;
  padding-left: 2rem;
  list-style: decimal;
  counter-reset: pest-lepesszam;
}

.pest-lepes > li {
  margin-bottom: 2.5rem;
  padding: 2rem;
  background: var(--pest-bg-kartya);
  border: 1px solid var(--pest-szegel);
  border-radius: var(--pest-lekerekites-nagy);
  counter-increment: pest-lepesszam;
}

.pest-lepes > li h3 {
  color: var(--pest-empire);
  margin-bottom: 0.75rem;
}

.pest-lepes > li h3::before {
  content: counter(pest-lepesszam) ". lepes — ";
  color: var(--pest-danube);
  font-size: 0.85em;
}

/* ---- CTA Banner ---- */
.pest-cta-banner {
  background: linear-gradient(135deg, var(--pest-danube-mely) 0%, var(--pest-bg-emelt) 100%);
  border: 1px solid var(--pest-szegel);
  border-radius: var(--pest-lekerekites-nagy);
  padding: 3rem;
  text-align: center;
  margin: 3rem 0;
  position: relative;
  overflow: hidden;
}

.pest-cta-banner::before {
  content: '';
  position: absolute;
  top: -50%;
  right: -20%;
  width: 300px;
  height: 300px;
  background: radial-gradient(circle, rgba(212, 168, 67, 0.08), transparent 70%);
  pointer-events: none;
}

.pest-cta-banner h2 {
  margin-bottom: 0.5em;
  border-top: none;
  padding-top: 0;
}

.pest-cta-banner p {
  max-width: 500px;
  margin-left: auto;
  margin-right: auto;
}

.pest-cta-gomb {
  margin-top: 1.5rem;
}

/* ---- FAQ Accordion ---- */
.pest-gyik-doboz {
  max-width: 800px;
  margin: 0 auto;
}

.pest-gyik-elem {
  border: 1px solid var(--pest-szegel);
  border-radius: var(--pest-lekerekites);
  margin-bottom: 0.75rem;
  overflow: hidden;
}

.pest-gyik-kerdes {
  width: 100%;
  background: var(--pest-bg-kartya);
  color: var(--pest-szoveg-alap);
  border: none;
  padding: 1.25rem 1.5rem;
  text-align: left;
  font-size: 1rem;
  font-weight: 600;
  cursor: pointer;
  display: table;
  transition: background var(--pest-atmenet);
  font-family: var(--pest-betutipus-torzs);
}

.pest-gyik-kerdes:hover {
  background: var(--pest-bg-emelt);
}

.pest-gyik-kerdes::after {
  content: '+';
  font-size: 1.4rem;
  color: var(--pest-empire);
  float: right;
  margin-left: 1rem;
  transition: transform var(--pest-atmenet);
}

.pest-gyik-elem.pest-nyitva .pest-gyik-kerdes::after {
  content: '\2212';
}

.pest-gyik-valasz {
  display: none;
  padding: 0 1.5rem 1.25rem;
  background: var(--pest-bg-kartya);
}

.pest-gyik-elem.pest-nyitva .pest-gyik-valasz {
  display: block;
}

/* ---- Utility ---- */
.pest-kozepre {
  text-align: center;
  margin-top: 2rem;
}

.pest-szoveg-masodlagos {
  color: var(--pest-szoveg-masodlagos);
  max-width: 600px;
  margin: 1rem auto 0;
}

/* ---- Footer ---- */
.pest-labec {
  background: var(--pest-bg-masodlagos);
  border-top: 1px solid var(--pest-szegel);
  padding: 3rem 1.5rem 2rem;
  margin-top: 4rem;
}

.pest-labec-belso {
  max-width: var(--pest-max-szelesseg);
  margin: 0 auto;
  display: table;
  width: 100%;
}

.pest-labec-belso > div {
  display: table-cell;
  vertical-align: top;
  padding: 0 1.5rem;
}

.pest-labec-belso > div:first-child {
  width: 50%;
}

.pest-labec h4 {
  color: var(--pest-szoveg-alap);
  margin-bottom: 1rem;
  font-size: 1rem;
}

.pest-labec p {
  font-size: 0.9rem;
  color: var(--pest-szoveg-halvany);
}

.pest-labec-linkek {
  list-style: none;
}

.pest-labec-linkek li {
  margin-bottom: 0.5rem;
}

.pest-labec-linkek a {
  color: var(--pest-szoveg-halvany);
  font-size: 0.9rem;
}

.pest-labec-linkek a:hover {
  color: var(--pest-danube);
}

.pest-labec-alj {
  max-width: var(--pest-max-szelesseg);
  margin: 2rem auto 0;
  padding-top: 1.5rem;
  border-top: 1px solid var(--pest-szegel);
  text-align: center;
  font-size: 0.8rem;
  color: var(--pest-szoveg-halvany);
}

/* ---- Breadcrumb ---- */
.pest-morzsak {
  max-width: var(--pest-max-szelesseg);
  margin: 0 auto;
  padding: 1rem 1.5rem;
  font-size: 0.85rem;
  color: var(--pest-szoveg-halvany);
}

.pest-morzsak a {
  color: var(--pest-szoveg-halvany);
}

.pest-morzsak a:hover {
  color: var(--pest-danube);
}

.pest-morzsak span {
  margin: 0 0.5rem;
}

/* ---- Page Hero (inner pages) ---- */
.pest-oldal-hosszakasz {
  padding: 4rem 1.5rem 3rem;
  text-align: center;
  background: linear-gradient(180deg, var(--pest-danube-mely) 0%, var(--pest-bg-alap) 100%);
  border-bottom: 1px solid var(--pest-szegel);
}

.pest-oldal-hosszakasz h1 {
  font-size: 2.4rem;
  max-width: 700px;
  margin: 0 auto 0.5rem;
}

.pest-oldal-hosszakasz p {
  font-size: 1.05rem;
  max-width: 550px;
  margin: 0 auto;
}

/* ---- Table of Contents ---- */
.pest-toc {
  background: var(--pest-bg-kartya);
  border: 1px solid var(--pest-szegel);
  border-radius: var(--pest-lekerekites-nagy);
  padding: 1.5rem 2rem;
  margin: 2rem 0;
}

.pest-toc h4 {
  margin-bottom: 0.75rem;
  color: var(--pest-empire);
  font-size: 0.95rem;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.pest-toc ol {
  padding-left: 1.25rem;
}

.pest-toc li {
  margin-bottom: 0.4rem;
}

.pest-toc a {
  color: var(--pest-szoveg-masodlagos);
  font-size: 0.95rem;
}

.pest-toc a:hover {
  color: var(--pest-danube);
}

/* ---- Contact Form ---- */
.pest-urlap {
  max-width: 600px;
  margin: 0 auto;
}

.pest-urlap-csoport {
  margin-bottom: 1.5rem;
}

.pest-urlap-csoport label {
  display: block;
  margin-bottom: 0.5rem;
  font-weight: 500;
  color: var(--pest-szoveg-masodlagos);
  font-size: 0.9rem;
}

.pest-urlap-csoport input,
.pest-urlap-csoport textarea,
.pest-urlap-csoport select {
  width: 100%;
  padding: 0.875rem 1rem;
  background: var(--pest-bg-kartya);
  border: 1px solid var(--pest-szegel);
  border-radius: var(--pest-lekerekites);
  color: var(--pest-szoveg-alap);
  font-family: var(--pest-betutipus-torzs);
  font-size: 1rem;
  transition: border-color var(--pest-atmenet);
}

.pest-urlap-csoport input:focus,
.pest-urlap-csoport textarea:focus,
.pest-urlap-csoport select:focus {
  outline: none;
  border-color: var(--pest-danube);
  box-shadow: 0 0 0 3px rgba(74, 144, 217, 0.15);
}

.pest-urlap-csoport textarea {
  min-height: 150px;
  resize: vertical;
}

/* ---- Responsive ---- */
@media (max-width: 968px) {
  .pest-blog-lista {
    display: block;
  }
  .pest-blog-lista > li {
    display: block;
    width: 100%;
    margin-bottom: 1.5rem;
  }
  .pest-kerulet-tabla {
    display: block;
  }
  .pest-kerulet-tabla tbody,
  .pest-kerulet-tabla tr {
    display: block;
  }
  .pest-kerulet-cella {
    display: block;
    margin-bottom: 1.5rem;
  }
  .pest-labec-belso {
    display: block;
  }
  .pest-labec-belso > div {
    display: block;
    width: 100%;
    padding: 0 0 2rem;
  }
  .pest-statisztikak {
    display: block;
  }
  .pest-adat {
    display: block;
    width: 100%;
    margin-bottom: 1rem;
  }
}

@media (max-width: 768px) {
  h1 { font-size: 2rem; }
  .pest-hosszakasz h1 { font-size: 2.4rem; }
  .pest-oldal-hosszakasz h1 { font-size: 1.8rem; }

  .pest-nav {
    display: none;
    position: absolute;
    top: 72px;
    left: 0;
    right: 0;
    background: var(--pest-bg-masodlagos);
    border-bottom: 1px solid var(--pest-szegel);
    padding: 1rem;
  }

  .pest-nav a {
    display: block;
    padding: 0.75rem 1rem;
  }

  .pest-nav.pest-nav-nyitva {
    display: block;
  }

  .pest-nav-valto {
    display: block;
    position: absolute;
    right: 1.5rem;
    top: 50%;
    transform: translateY(-50%);
  }

  .pest-fejlec-belso {
    position: relative;
  }

  .pest-szakasz {
    padding: 3rem 1rem;
  }
}

@media (max-width: 480px) {
  html { font-size: 15px; }
  .pest-hosszakasz { padding: 4rem 1rem 3rem; }
  .pest-hosszakasz h1 { font-size: 1.8rem; }
  .pest-cta-banner { padding: 2rem 1.5rem; }
}
