/* =========================================================
   Oscar Öltöny – Kezdőlap v2 (Heritage Tailoring System)
   Scoped design styles. Classes prefixed .oscar-*
   ========================================================= */

:root {
  --o-navy:        #141b2c;
  --o-navy-deep:   #0d1320;
  --o-gold:        #cca830;
  --o-gold-light:  #e9c349;
  --o-surface:     #f9f9f7;
  --o-surface-low: #f4f4f2;
  --o-white:       #ffffff;
  --o-ink:         #1a1c1b;
  --o-black:       #000000;
  --o-muted:       #5f5e5e;
  --o-outline:     #c6c6cd;
}

/* ---------- Generic helpers ---------- */
.oscar-wrap {
  max-width: 1280px;
  margin: 0 auto;
  padding-left: 64px;
  padding-right: 64px;
  width: 100%;
}
.oscar-font-serif { font-family: "Playfair Display", Georgia, serif !important; }
.oscar-font-sans  { font-family: "Montserrat", sans-serif !important; }

/* =========================================================
   HEADER
   ========================================================= */
.oscar-header {
  position: sticky;
  top: 0;
  z-index: 999;
  background: rgba(249,249,247,0.95);
  -webkit-backdrop-filter: blur(12px);
  backdrop-filter: blur(12px);
  border-bottom: 1px solid rgba(198,198,205,0.3);
  box-shadow: 0 1px 3px rgba(0,0,0,0.05);
}
.oscar-header-inner {
  max-width: 1280px;
  margin: 0 auto;
  width: 100%;
}
.oscar-logo .elementor-heading-title,
.oscar-logo {
  font-family: "Playfair Display", Georgia, serif !important;
  font-size: 28px !important;
  font-weight: 600 !important;
  letter-spacing: -0.02em !important;
  color: var(--o-black) !important;
  margin: 0 !important;
  line-height: 1.2 !important;
}
/* Nav menu typography override (Elementor inherits global primary typo) */
.oscar-nav .elementor-nav-menu .elementor-item,
.oscar-nav .elementor-nav-menu--main .elementor-item {
  font-family: "Montserrat", sans-serif !important;
  font-size: 14px !important;
  font-weight: 600 !important;
  letter-spacing: 0.1em !important;
  text-transform: uppercase !important;
  color: var(--o-black) !important;
  padding: 4px 20px !important;
  transition: color 0.3s ease-out;
}
.oscar-nav .elementor-nav-menu .elementor-item:hover {
  color: var(--o-gold-light) !important;
}
.oscar-nav .elementor-nav-menu .elementor-item.elementor-item-active {
  color: var(--o-black) !important;
  border-bottom: 2px solid var(--o-gold);
}

/* =========================================================
   BUTTONS
   ========================================================= */
.oscar-btn-gold .elementor-button,
.oscar-btn-gold a.elementor-button {
  background-color: var(--o-gold) !important;
  color: var(--o-navy) !important;
  font-family: "Montserrat", sans-serif !important;
  font-size: 14px !important;
  font-weight: 600 !important;
  letter-spacing: 0.05em !important;
  text-transform: uppercase !important;
  border-radius: 4px !important;
  padding: 18px 40px !important;
  border: none !important;
  transition: all 0.4s ease-out !important;
}
.oscar-btn-gold .elementor-button:hover {
  background-color: var(--o-gold-light) !important;
}
.oscar-btn-outline .elementor-button,
.oscar-btn-outline a.elementor-button {
  background-color: transparent !important;
  color: var(--o-white) !important;
  font-family: "Montserrat", sans-serif !important;
  font-size: 14px !important;
  font-weight: 600 !important;
  letter-spacing: 0.05em !important;
  text-transform: uppercase !important;
  border-radius: 4px !important;
  padding: 18px 40px !important;
  border: 1px solid var(--o-white) !important;
  transition: all 0.4s ease-out !important;
}
.oscar-btn-outline .elementor-button:hover {
  background-color: var(--o-white) !important;
  color: var(--o-navy) !important;
}
/* Ghost text link button (services) */
.oscar-btn-link .elementor-button,
.oscar-btn-link a.elementor-button {
  background: transparent !important;
  color: var(--o-ink) !important;
  font-family: "Montserrat", sans-serif !important;
  font-size: 14px !important;
  font-weight: 600 !important;
  letter-spacing: 0.05em !important;
  text-transform: uppercase !important;
  padding: 4px 0 !important;
  border: none !important;
  border-bottom: 2px solid var(--o-gold) !important;
  border-radius: 0 !important;
  transition: color 0.3s ease-out !important;
}
.oscar-btn-link .elementor-button:hover { color: var(--o-gold) !important; }

/* =========================================================
   HERO
   ========================================================= */
.oscar-hero {
  position: relative;
  min-height: 100vh;
}
/* Hero overlay is rendered by Elementor's container background-overlay
   (::before, opacity 0.6, color #141b2c) — no extra CSS overlay needed. */
.oscar-hero-content {
  position: relative;
  z-index: 2;
  max-width: 900px;
  margin: 0 auto;
  text-align: center;
}
.oscar-hero-title .elementor-heading-title,
.oscar-hero-title {
  font-family: "Playfair Display", Georgia, serif !important;
  font-weight: 700 !important;
  font-size: clamp(40px, 5.5vw, 64px) !important;
  line-height: 1.1 !important;
  letter-spacing: -0.02em !important;
  color: var(--o-white) !important;
  margin: 0 0 24px !important;
}
.oscar-hero-sub {
  font-family: "Montserrat", sans-serif !important;
  font-size: 18px !important;
  line-height: 1.6 !important;
  color: rgba(255,255,255,0.9) !important;
  max-width: 640px;
  margin: 0 auto 40px !important;
  text-align: center;
}
.oscar-hero-cta { display: flex; }

/* =========================================================
   STATS
   ========================================================= */
.oscar-stats { background-color: var(--o-navy); }
.oscar-stat .elementor-counter-number-wrapper {
  font-family: "Playfair Display", Georgia, serif !important;
  font-weight: 600 !important;
  font-size: 48px !important;
  line-height: 1.2 !important;
  color: var(--o-gold) !important;
  justify-content: center;
}
.oscar-stat .elementor-counter-title {
  font-family: "Montserrat", sans-serif !important;
  font-size: 12px !important;
  font-weight: 600 !important;
  letter-spacing: 0.1em !important;
  text-transform: uppercase !important;
  color: rgba(255,255,255,0.8) !important;
  margin-top: 8px !important;
}

/* =========================================================
   SECTION TITLES / LABELS
   ========================================================= */
.oscar-label .elementor-heading-title,
.oscar-label {
  font-family: "Montserrat", sans-serif !important;
  font-size: 12px !important;
  font-weight: 600 !important;
  letter-spacing: 0.1em !important;
  text-transform: uppercase !important;
  color: var(--o-gold) !important;
  margin: 0 0 16px !important;
}
.oscar-h2 .elementor-heading-title,
.oscar-h2 {
  font-family: "Playfair Display", Georgia, serif !important;
  font-weight: 600 !important;
  font-size: 48px !important;
  line-height: 1.2 !important;
  color: var(--o-ink) !important;
  margin: 0 0 24px !important;
}
.oscar-h3 .elementor-heading-title,
.oscar-h3 {
  font-family: "Playfair Display", Georgia, serif !important;
  font-weight: 600 !important;
  font-size: 32px !important;
  line-height: 1.3 !important;
  color: var(--o-ink) !important;
  margin: 0 0 12px !important;
}
.oscar-body {
  font-family: "Montserrat", sans-serif !important;
  font-size: 16px !important;
  line-height: 1.6 !important;
  color: var(--o-muted) !important;
}
.oscar-body-lg {
  font-family: "Montserrat", sans-serif !important;
  font-size: 18px !important;
  line-height: 1.6 !important;
  color: var(--o-muted) !important;
}

/* =========================================================
   FEATURES (3 columns)
   ========================================================= */
.oscar-features { background-color: var(--o-surface); }
.oscar-feature .elementor-widget-image img {
  aspect-ratio: 3 / 4;
  object-fit: cover;
  width: 100%;
  transition: transform 0.7s ease-out;
}
.oscar-feature:hover .elementor-widget-image img { transform: scale(1.05); }
.oscar-feature .elementor-widget-image { overflow: hidden; }

/* =========================================================
   SERVICES (Z pattern)
   ========================================================= */
.oscar-services { background-color: var(--o-surface-low); }
.oscar-service-img .elementor-widget-image img {
  width: 100%;
  height: 500px;
  object-fit: cover;
  display: block;
}
.oscar-frame { position: relative; }
.oscar-frame::before {
  content: "";
  position: absolute;
  top: 16px; left: 16px; right: -16px; bottom: -16px;
  border: 1px solid rgba(198,198,205,0.4);
  z-index: -1;
  transition: transform 0.5s ease-out;
}
.oscar-frame.oscar-frame-left::before { left: -16px; right: 16px; }
.oscar-frame:hover::before { transform: translate(-6px,-6px); }

/* =========================================================
   TESTIMONIALS
   ========================================================= */
.oscar-testimonials { background-color: var(--o-white); }
.oscar-divider {
  width: 96px;
  height: 4px;
  background-color: var(--o-gold);
  margin: 0 auto;
}
.oscar-testi-card {
  background-color: var(--o-surface);
  transition: transform 0.4s ease-out, box-shadow 0.4s ease-out;
}
.oscar-testi-card:hover {
  transform: translateY(-8px);
  box-shadow: 0 20px 40px rgba(20,27,44,0.06);
}
.oscar-stars { color: var(--o-gold) !important; font-size: 18px; letter-spacing: 2px; }
.oscar-stars .elementor-heading-title { color: var(--o-gold) !important; }
.oscar-quote {
  font-family: "Montserrat", sans-serif !important;
  font-size: 16px !important;
  line-height: 1.6 !important;
  font-style: italic !important;
  color: var(--o-muted) !important;
}
.oscar-name .elementor-heading-title,
.oscar-name {
  font-family: "Montserrat", sans-serif !important;
  font-size: 14px !important;
  font-weight: 600 !important;
  letter-spacing: 0.05em !important;
  text-transform: uppercase !important;
  color: var(--o-ink) !important;
  margin: 0 !important;
}
.oscar-role {
  font-family: "Montserrat", sans-serif !important;
  font-size: 12px !important;
  letter-spacing: 0.1em !important;
  color: var(--o-muted) !important;
}

/* =========================================================
   FINAL CTA + FORM
   ========================================================= */
.oscar-cta { background-color: var(--o-surface); }
.oscar-cta-inner { max-width: 768px; margin: 0 auto; text-align: center; }
.oscar-form-wrap {
  background-color: var(--o-surface-low);
  padding: 40px;
  border-radius: 4px;
  border: 1px solid rgba(198,198,205,0.2);
  box-shadow: 0 1px 3px rgba(0,0,0,0.05);
  text-align: left;
}
.oscar-form .elementor-field-group > label {
  font-family: "Montserrat", sans-serif !important;
  font-size: 12px !important;
  font-weight: 600 !important;
  letter-spacing: 0.1em !important;
  text-transform: uppercase !important;
  color: var(--o-ink) !important;
}
.oscar-form .elementor-field-textual {
  background: transparent !important;
  border: none !important;
  border-bottom: 1px solid var(--o-outline) !important;
  border-radius: 0 !important;
  padding: 8px 0 !important;
  box-shadow: none !important;
  font-family: "Montserrat", sans-serif !important;
}
.oscar-form .elementor-field-textual:focus {
  border-bottom-color: var(--o-gold) !important;
  outline: none !important;
}
.oscar-form .elementor-button[type="submit"] {
  background-color: var(--o-navy) !important;
  color: var(--o-white) !important;
  font-family: "Montserrat", sans-serif !important;
  font-size: 14px !important;
  font-weight: 600 !important;
  letter-spacing: 0.05em !important;
  text-transform: uppercase !important;
  border-radius: 4px !important;
  padding: 18px !important;
  transition: all 0.4s ease-out !important;
}
.oscar-form .elementor-button[type="submit"]:hover {
  background-color: var(--o-gold) !important;
  color: var(--o-navy) !important;
}

/* =========================================================
   FOOTER
   ========================================================= */
.oscar-footer { background-color: var(--o-white); border-top: 1px solid var(--o-outline); }
.oscar-footer-brand .elementor-heading-title,
.oscar-footer-brand {
  font-family: "Playfair Display", Georgia, serif !important;
  font-size: 28px !important;
  font-weight: 600 !important;
  color: var(--o-ink) !important;
  margin: 0 0 24px !important;
}
.oscar-footer-heading .elementor-heading-title,
.oscar-footer-heading {
  font-family: "Montserrat", sans-serif !important;
  font-size: 14px !important;
  font-weight: 600 !important;
  letter-spacing: 0.05em !important;
  text-transform: uppercase !important;
  color: var(--o-ink) !important;
  margin: 0 0 24px !important;
}
.oscar-footer .elementor-icon-list-item a,
.oscar-footer .elementor-icon-list-text {
  font-family: "Montserrat", sans-serif !important;
  font-size: 16px !important;
  color: var(--o-muted) !important;
  transition: color 0.3s ease-out, transform 0.3s ease-out;
}
.oscar-footer .elementor-icon-list-item:hover a,
.oscar-footer .elementor-icon-list-item:hover .elementor-icon-list-text {
  color: var(--o-ink) !important;
}
.oscar-footer .elementor-icon-list-icon i { color: var(--o-gold) !important; }
.oscar-footer-bottom {
  border-top: 1px solid rgba(198,198,205,0.3);
  text-align: center;
}
.oscar-footer-bottom .oscar-body { color: rgba(95,94,94,0.6) !important; }

/* =========================================================
   LAYOUT (forced flex rows — override Elementor .e-con-full width:100%)
   ========================================================= */
.oscar-stats-grid,
.oscar-features-grid,
.oscar-service-row,
.oscar-testi-grid,
.oscar-footer-grid {
  display: flex !important;
  flex-direction: row !important;
  flex-wrap: wrap !important;
  gap: 32px;
}
.oscar-service-row { gap: 48px; }
.oscar-stat { flex: 1 1 200px !important; width: auto !important; text-align: center; }
.oscar-feature { flex: 1 1 280px !important; width: auto !important; }
.oscar-service-col { flex: 1 1 360px !important; width: auto !important; }
.oscar-testi-card { flex: 1 1 280px !important; width: auto !important; padding: 40px; }
.oscar-footer-col { flex: 1 1 200px !important; width: auto !important; min-width: 180px; }

.oscar-stats > .e-con-inner,
.oscar-stats { padding-top: 64px; padding-bottom: 64px; }

.oscar-features { padding-top: 80px; padding-bottom: 80px; }

.oscar-services { padding-top: 80px; padding-bottom: 80px; }
.oscar-service-row { margin-bottom: 80px; align-items: center; }
.oscar-service-row:last-child { margin-bottom: 0; }

.oscar-testimonials { padding-top: 80px; padding-bottom: 80px; }
.oscar-testi-header { text-align: center; }

.oscar-cta { padding-top: 80px; padding-bottom: 80px; }

.oscar-footer-grid { padding-top: 80px; }
.oscar-footer-bottom { margin-top: 48px; padding-top: 32px; padding-bottom: 24px; }

.oscar-features-header { text-align: center; }

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media (max-width: 1024px) {
  .oscar-wrap { padding-left: 32px; padding-right: 32px; }
  .oscar-header-inner { padding-left: 32px; padding-right: 32px; }
}
@media (max-width: 767px) {
  .oscar-wrap { padding-left: 20px; padding-right: 20px; }
  .oscar-header-inner { padding-left: 20px; padding-right: 20px; }
  .oscar-h2 .elementor-heading-title, .oscar-h2 { font-size: 34px !important; }
  .oscar-hero-title .elementor-heading-title, .oscar-hero-title { font-size: 40px !important; }
  .oscar-frame::before { display: none; }
  
  /* Hide header CTA button on mobile (too wide for "IDŐPONTFOGLALÁS") */
  .oscar-header .oscar-btn-gold {
    display: none !important;
  }
  
  /* Hamburger dropdown menu styling */
  .oscar-nav .elementor-nav-menu--dropdown {
    position: absolute !important;
    top: 100% !important;
    right: 0 !important;
    left: auto !important;
    background-color: var(--o-white) !important;
    border: 1px solid var(--o-outline) !important;
    box-shadow: 0 4px 20px rgba(0,0,0,0.15) !important;
    min-width: 220px !important;
    max-width: calc(100vw - 40px) !important;
    padding: 12px 0 !important;
    z-index: 1000 !important;
  }
  .oscar-nav .elementor-nav-menu--dropdown .elementor-item {
    padding: 12px 24px !important;
    display: block !important;
    color: var(--o-ink) !important;
  }
  .oscar-nav .elementor-nav-menu--dropdown .elementor-item:hover {
    background-color: var(--o-surface) !important;
    color: var(--o-gold) !important;
  }
}

/* =========================================================
   DARK THEME VARIANT — scoped to "Kezdőlap v2 Dark" (page 612)
   Exclusive / luxury: deep charcoal-navy + champagne gold + ivory
   --o-d-bg #0b0f17 | --o-d-bg-alt #11151f | --o-d-card #181d29
   --o-d-ink #f4f1e9 | --o-d-muted #b0aca3 | gold #cca830/#e9c349
   ========================================================= */
body.page-id-612 { background-color: #0b0f17; }

/* Header */
body.page-id-612 .oscar-header {
  background: rgba(11, 15, 23, 0.92);
  border-bottom: 1px solid rgba(204, 168, 48, 0.22);
  box-shadow: 0 1px 20px rgba(0, 0, 0, 0.4);
}
body.page-id-612 .oscar-logo .elementor-heading-title,
body.page-id-612 .oscar-logo { color: #f4f1e9 !important; }
body.page-id-612 .oscar-nav .elementor-nav-menu .elementor-item { color: #e8e4da !important; }
body.page-id-612 .oscar-nav .elementor-nav-menu .elementor-item:hover { color: #e9c349 !important; }
body.page-id-612 .oscar-nav .elementor-nav-menu .elementor-item.elementor-item-active { color: #f4f1e9 !important; }

/* Headings & text */
body.page-id-612 .oscar-h2 .elementor-heading-title, body.page-id-612 .oscar-h2,
body.page-id-612 .oscar-h3 .elementor-heading-title, body.page-id-612 .oscar-h3 { color: #f4f1e9 !important; }
body.page-id-612 .oscar-body, body.page-id-612 .oscar-body-lg { color: #b0aca3 !important; }

/* Stats */
body.page-id-612 .oscar-stats { background-color: #0d1320 !important; border-top: 1px solid rgba(204,168,48,0.15); border-bottom: 1px solid rgba(204,168,48,0.15); }

/* Features */
body.page-id-612 .oscar-features { background-color: #0b0f17 !important; }

/* Services */
body.page-id-612 .oscar-services { background-color: #11151f !important; }
body.page-id-612 .oscar-frame::before { border-color: rgba(204, 168, 48, 0.35) !important; }

/* Testimonials */
body.page-id-612 .oscar-testimonials { background-color: #0b0f17 !important; }
body.page-id-612 .oscar-testi-card { background-color: #181d29 !important; border: 1px solid rgba(255,255,255,0.05); }
body.page-id-612 .oscar-testi-card:hover { box-shadow: 0 20px 50px rgba(0,0,0,0.5); }
body.page-id-612 .oscar-quote { color: #b0aca3 !important; }
body.page-id-612 .oscar-name .elementor-heading-title, body.page-id-612 .oscar-name { color: #f4f1e9 !important; }
body.page-id-612 .oscar-role { color: #8d8a82 !important; }

/* Final CTA + form */
body.page-id-612 .oscar-cta { background-color: #11151f !important; }
body.page-id-612 .oscar-form-wrap {
  background-color: #181d29 !important;
  border: 1px solid rgba(204, 168, 48, 0.18) !important;
  box-shadow: 0 20px 50px rgba(0,0,0,0.45) !important;
}
body.page-id-612 .oscar-form .elementor-field-group > label { color: #f4f1e9 !important; }
body.page-id-612 .oscar-form .elementor-field-textual {
  border-bottom: 1px solid #3a4150 !important;
  color: #f4f1e9 !important;
}
body.page-id-612 .oscar-form .elementor-field-textual::placeholder { color: #6f6d66 !important; }
body.page-id-612 .oscar-form .elementor-field-textual:focus { border-bottom-color: #cca830 !important; }
body.page-id-612 .oscar-form .elementor-button[type="submit"] {
  background-color: #cca830 !important;
  color: #0b0f17 !important;
}
body.page-id-612 .oscar-form .elementor-button[type="submit"]:hover {
  background-color: #e9c349 !important;
  color: #0b0f17 !important;
}

/* Footer */
body.page-id-612 .oscar-footer { background-color: #0b0f17 !important; border-top: 1px solid rgba(204, 168, 48, 0.2); }
body.page-id-612 .oscar-footer-brand .elementor-heading-title,
body.page-id-612 .oscar-footer-brand { color: #f4f1e9 !important; }
body.page-id-612 .oscar-footer-heading .elementor-heading-title,
body.page-id-612 .oscar-footer-heading { color: #f4f1e9 !important; }
body.page-id-612 .oscar-footer .elementor-icon-list-item a,
body.page-id-612 .oscar-footer .elementor-icon-list-text { color: #b0aca3 !important; }
body.page-id-612 .oscar-footer .elementor-icon-list-item:hover a,
body.page-id-612 .oscar-footer .elementor-icon-list-item:hover .elementor-icon-list-text { color: #f4f1e9 !important; }
body.page-id-612 .oscar-footer-bottom { border-top: 1px solid rgba(255,255,255,0.08); }
body.page-id-612 .oscar-footer-bottom .oscar-body { color: rgba(176,172,163,0.6) !important; }

/* Stronger hero overlay for a moodier, premium dark feel */
body.page-id-612 .oscar-hero::before { opacity: 0.72 !important; }

/* Dark theme mobile hamburger menu */
@media (max-width: 767px) {
  body.page-id-612 .oscar-nav .elementor-nav-menu--dropdown {
    background-color: #181d29 !important;
    border: 1px solid rgba(204, 168, 48, 0.25) !important;
    box-shadow: 0 8px 30px rgba(0,0,0,0.6) !important;
  }
  body.page-id-612 .oscar-nav .elementor-nav-menu--dropdown .elementor-item {
    color: #f4f1e9 !important;
  }
  body.page-id-612 .oscar-nav .elementor-nav-menu--dropdown .elementor-item:hover {
    background-color: rgba(204, 168, 48, 0.12) !important;
    color: #e9c349 !important;
  }
}
