/* Brand color tokens — override via Live Edit Style Editor */
:root {
  --primary-color: #3b82f6;
  --accent-color: #f97316;
  --bg-color: #ffffff;
  --text-color: #1f2937;
}


  :root{
    --blue:#1E90D6;
    --blue-deep:#1478B8;
    --orange:#F08A2C;
    --orange-deep:#D97519;
    --ink:#1E2430;
    --ink-2:#2A2F3A;
    --ink-3:#363C48;
    --paper:#FFFFFF;
    --mist:#F5F7FA;
    --line:#E4E8EE;
    --muted:#6B7380;
    --ok:#2BB673;
    --max:1240px;
  }
  *{box-sizing:border-box}
  html{scroll-behavior:smooth}
  body{
    margin:0;font-family:'Inter',system-ui,sans-serif;color:var(--ink);
    background:var(--paper);-webkit-font-smoothing:antialiased;line-height:1.55;
  }
  h1,h2,h3,h4{font-family:'Archivo Black',sans-serif;font-weight:900;letter-spacing:-.01em;line-height:1.02;margin:0;text-transform:uppercase}
  h1{font-size:clamp(42px,6.4vw,92px)}
  h2{font-size:clamp(32px,4.4vw,58px)}
  h3{font-size:clamp(20px,1.6vw,24px);letter-spacing:.02em}
  p{margin:0}
  a{color:inherit;text-decoration:none}
  .mono{font-family:'JetBrains Mono',ui-monospace,monospace;font-size:12px;letter-spacing:.12em;text-transform:uppercase}
  .wrap{max-width:var(--max);margin:0 auto;padding:0 32px}
  @media (max-width:720px){.wrap{padding:0 20px}}

  /* ---------- HEADER ---------- */
  .nav{
    position:sticky;top:0;z-index:40;background:rgba(30,36,48,.72);
    backdrop-filter:saturate(140%) blur(14px);-webkit-backdrop-filter:saturate(140%) blur(14px);
    border-bottom:1px solid rgba(255,255,255,.06);color:#fff;transition:background .3s;
  }
  .nav.scrolled{background:rgba(30,36,48,.94)}
  .nav-inner{display:flex;align-items:center;gap:24px;height:72px;max-width:var(--max);margin:0 auto;padding:0 32px}
  .brand{display:flex;align-items:center;gap:12px;font-family:'Archivo Black';font-size:18px;letter-spacing:.04em}
  .brand-mark{width:36px;height:36px;border:1.5px solid var(--orange);border-radius:4px;display:grid;place-items:center;color:var(--blue);font-family:'Archivo Black';font-size:14px;position:relative}
  .brand-mark::after{content:"";position:absolute;inset:auto 4px -1.5px 4px;border-bottom:1.5px solid var(--orange)}
  .brand small{display:block;font-family:'JetBrains Mono';font-size:9px;letter-spacing:.22em;color:#9AA4B2;margin-top:3px;font-weight:400}
  .nav-links{display:flex;gap:28px;margin-left:auto;align-items:center}
  .nav-links a{font-size:13.5px;font-weight:500;color:#D5DBE4;position:relative;padding:6px 0;letter-spacing:.02em}
  .nav-links a:hover{color:#fff}
  .nav-links a::after{content:"";position:absolute;left:0;right:0;bottom:-2px;height:2px;background:var(--orange);transform:scaleX(0);transform-origin:left;transition:transform .25s}
  .nav-links a:hover::after{transform:scaleX(1)}
  .btn{
    display:inline-flex;align-items:center;gap:10px;padding:12px 20px;border-radius:2px;
    font-weight:600;font-size:13.5px;letter-spacing:.04em;text-transform:uppercase;
    cursor:pointer;border:none;transition:transform .15s, background .2s, color .2s, border-color .2s;
    font-family:'Inter',sans-serif;
  }
  .btn-primary{background:var(--orange);color:#fff}
  .btn-primary:hover{background:var(--orange-deep);transform:translateY(-1px)}
  .btn-ghost{background:transparent;color:#fff;border:1.5px solid var(--blue)}
  .btn-ghost:hover{background:var(--blue);border-color:var(--blue)}
  .btn-dark{background:var(--ink);color:#fff}
  .btn-dark:hover{background:#000}
  .burger{display:none;width:40px;height:40px;border:1px solid rgba(255,255,255,.2);background:transparent;border-radius:2px;cursor:pointer;padding:0;margin-left:auto;flex-direction:column;justify-content:center;align-items:center;gap:4px}
  .burger span{display:block;width:18px;height:1.5px;background:#fff;transition:.2s}
  .burger.open span:nth-child(1){transform:translateY(5.5px) rotate(45deg)}
  .burger.open span:nth-child(2){opacity:0}
  .burger.open span:nth-child(3){transform:translateY(-5.5px) rotate(-45deg)}
  @media (max-width:980px){
    .nav-links{display:none}
    .burger{display:flex}
    .nav-links.open{display:flex;position:absolute;top:72px;left:0;right:0;flex-direction:column;gap:0;background:var(--ink);padding:8px 0;border-bottom:1px solid rgba(255,255,255,.08)}
    .nav-links.open a{padding:16px 32px;border-bottom:1px solid rgba(255,255,255,.04)}
    .nav-links.open .btn{margin:14px 32px}
  }

  /* ---------- HERO ---------- */
  .hero{
    position:relative;background:var(--ink);color:#fff;overflow:hidden;
    min-height:calc(100vh - 72px);display:flex;align-items:center;
    padding:0;
  }
  .hero-photo{
    position:absolute;inset:0;width:100%;height:100%;background:#1a1f28;z-index:0;
  }
  .hero-photo img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;filter:saturate(.95) contrast(1.05)}
  .hero-photo::before{
    content:"";position:absolute;inset:0;z-index:1;pointer-events:none;
    background:
      linear-gradient(90deg, rgba(15,18,24,.92) 0%, rgba(15,18,24,.55) 55%, rgba(15,18,24,.15) 100%),
      linear-gradient(180deg, rgba(15,18,24,.45) 0%, transparent 25%, rgba(15,18,24,.55) 100%);
  }
  .hero-photo::after{
    content:"FA + ÜVEG · KULCSRAKÉSZ KIVITELEZÉS";
    position:absolute;right:32px;bottom:24px;z-index:2;font-family:'JetBrains Mono';font-size:11px;letter-spacing:.18em;color:rgba(255,255,255,.85);
  }
  .hero-photo .scope{
    position:absolute;right:32px;top:32px;padding:6px 10px;border:1px solid rgba(255,255,255,.3);font-family:'JetBrains Mono';font-size:10px;letter-spacing:.2em;color:rgba(255,255,255,.85);text-transform:uppercase;z-index:2;background:rgba(0,0,0,.35);backdrop-filter:blur(4px);
  }
  .hero-inner{position:relative;z-index:2;display:flex;justify-content:flex-start;align-items:center;width:100%;min-height:calc(100vh - 72px);padding:80px 0;margin-left:120px}
  .hero-content{max-width:560px}
  @media (max-width:980px){
    .hero-inner{padding:120px 0 80px}
    .hero-photo::before{background:linear-gradient(180deg, rgba(15,18,24,.55) 0%, rgba(15,18,24,.85) 100%)}
    .hero-photo::after{display:none}
    .hero-photo .scope{display:none}
  }
  .eyebrow{display:inline-flex;align-items:center;gap:10px;padding:7px 12px;border:1px solid rgba(255,255,255,.18);border-radius:2px;background:rgba(255,255,255,.03)}
  .eyebrow .dot{width:6px;height:6px;background:var(--orange);border-radius:50%;box-shadow:0 0 0 4px rgba(240,138,44,.18)}
  .eyebrow span{font-family:'JetBrains Mono';font-size:11px;letter-spacing:.22em;color:#C2CCD9}
  .hero h1{margin:24px 0 22px}
  .hero h1 .accent{color:var(--orange);-webkit-text-stroke:0}
  .hero h1 .blue{color:var(--blue)}
  .hero-sub{max-width:540px;font-size:17px;color:#B9C2CE;line-height:1.65}
  .hero-cta{display:flex;gap:14px;flex-wrap:wrap;margin-top:34px}
  .hero-meta{display:flex;gap:24px;margin-top:46px;flex-wrap:wrap}
  .hero-meta .item{padding-left:14px;border-left:2px solid var(--orange)}
  .hero-meta .item .num{font-family:'Archivo Black';font-size:28px;color:#fff;line-height:1}
  .hero-meta .item .lbl{font-family:'JetBrains Mono';font-size:10.5px;letter-spacing:.2em;color:#8892A0;margin-top:6px;text-transform:uppercase}
  .scroll-ind{position:absolute;left:50%;bottom:24px;transform:translateX(-50%);z-index:3;display:flex;flex-direction:column;align-items:center;gap:8px;color:#8892A0}
  .scroll-ind .line{width:1px;height:40px;background:linear-gradient(#8892A0,transparent);animation:scroll 2s ease-in-out infinite}
  @keyframes scroll{0%{transform:scaleY(0);transform-origin:top}60%{transform:scaleY(1);transform-origin:top}60.01%{transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}

  /* ---------- SECTION BASE ---------- */
  section{padding:120px 0;position:relative}
  .section-head{display:flex;align-items:flex-end;justify-content:space-between;gap:40px;margin-bottom:56px;flex-wrap:wrap}
  .section-head .label{color:var(--orange)}
  .section-head h2{max-width:720px}
  .section-head p{max-width:420px;color:var(--muted);font-size:15.5px}
  .lbl-row{display:flex;align-items:center;gap:12px;margin-bottom:14px}
  .lbl-row .bar{width:32px;height:2px;background:var(--orange)}
  .lbl-row .mono{color:var(--orange)}

  /* ---------- ABOUT ---------- */
  .about{background:var(--paper)}
  .about-grid{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
  @media (max-width:980px){.about-grid{grid-template-columns:1fr;gap:40px}}
  .about-photo{position:relative;aspect-ratio:4/5;background:#E4E8EE;border:1px solid var(--line);overflow:hidden}
  .about-photo img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
  .about-photo .tag{position:absolute;left:16px;top:16px;padding:6px 10px;background:var(--ink);color:#fff}
  .about-photo .caption{position:absolute;left:16px;bottom:16px;color:#6B7380}
  .about-photo .stamp{position:absolute;right:-28px;bottom:40px;background:var(--orange);color:#fff;padding:22px;width:160px;text-align:center;font-family:'Archivo Black';line-height:1}
  .about-photo .stamp .big{font-size:38px;display:block}
  .about-photo .stamp .small{font-family:'JetBrains Mono';font-weight:400;font-size:10px;letter-spacing:.18em;display:block;margin-top:8px}
  .about-body p{color:#3B4250;font-size:16px;margin-bottom:18px}
  .about-body p.lead{font-size:19px;color:var(--ink);font-weight:500;line-height:1.5}
  .stats{display:grid;grid-template-columns:repeat(4,1fr);gap:0;margin-top:36px;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
  @media (max-width:720px){.stats{grid-template-columns:repeat(2,1fr)}}
  .stat{padding:22px 18px;border-right:1px solid var(--line)}
  .stat:last-child{border-right:none}
  @media (max-width:720px){.stat:nth-child(2){border-right:none}.stat:nth-child(1),.stat:nth-child(2){border-bottom:1px solid var(--line)}}
  .stat .n{font-family:'Archivo Black';font-size:34px;color:var(--blue);line-height:1}
  .stat .l{font-family:'JetBrains Mono';font-size:10.5px;letter-spacing:.18em;color:var(--muted);margin-top:8px;text-transform:uppercase}

  /* ---------- SERVICES ---------- */
  .services{background:var(--mist);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
  .svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border:1px solid var(--line);background:#fff}
  @media (max-width:980px){.svc-grid{grid-template-columns:1fr}}
  .svc{position:relative;padding:44px 36px;border-right:1px solid var(--line);transition:background .2s}
  .svc:last-child{border-right:none}
  @media (max-width:980px){.svc{border-right:none;border-bottom:1px solid var(--line)}.svc:last-child{border-bottom:none}}
  .svc:hover{background:#FAFBFD}
  .svc .num{font-family:'JetBrains Mono';font-size:11px;letter-spacing:.2em;color:var(--muted)}
  .svc .ico{width:56px;height:56px;margin:22px 0 22px;display:grid;place-items:center;color:var(--blue);background:#EAF4FB;border-radius:2px}
  .svc.feat{background:var(--ink);color:#fff}
  .svc.feat:hover{background:#171C26}
  .svc.feat .num{color:#9AA4B2}
  .svc.feat .ico{background:rgba(240,138,44,.15);color:var(--orange)}
  .svc.feat .desc{color:#B9C2CE}
  .svc .badge{position:absolute;top:24px;right:28px;padding:4px 10px;background:var(--orange);color:#fff;font-family:'JetBrains Mono';font-size:10px;letter-spacing:.18em;text-transform:uppercase}
  .svc h3{font-size:22px;letter-spacing:.01em}
  .svc .desc{color:#525A68;font-size:14.5px;margin-top:12px;line-height:1.6}
  .svc .more{margin-top:24px;display:inline-flex;align-items:center;gap:8px;font-family:'JetBrains Mono';font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--blue);padding-bottom:4px;border-bottom:1px solid currentColor;cursor:pointer}
  .svc.feat .more{color:var(--orange)}
  .svc .more:hover{color:var(--orange-deep)}
  .machines{margin-top:28px;padding:20px;border:1px dashed rgba(255,255,255,.2);background:rgba(255,255,255,.03)}
  .machines .tt{font-family:'JetBrains Mono';font-size:10.5px;letter-spacing:.2em;color:#9AA4B2;text-transform:uppercase;margin-bottom:14px}
  .machines ul{list-style:none;padding:0;margin:0;display:grid;grid-template-columns:1fr 1fr;gap:10px 18px}
  .machines li{font-size:13.5px;color:#E2E7EE;display:flex;align-items:center;gap:10px}
  .machines li::before{content:"";width:6px;height:6px;background:var(--orange);flex:none}

  /* ---------- REFERENCES ---------- */
  .refs{background:#fff}
  .filters{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:28px}
  .filter{padding:8px 16px;border:1px solid var(--line);background:#fff;cursor:pointer;font-family:'JetBrains Mono';font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:#525A68;transition:.2s}
  .filter:hover{border-color:var(--ink)}
  .filter.active{background:var(--ink);color:#fff;border-color:var(--ink)}
  .ref-grid{display:grid;grid-template-columns:repeat(3,1fr);grid-auto-rows:240px;gap:16px}
  @media (max-width:980px){.ref-grid{grid-template-columns:repeat(2,1fr)}}
  @media (max-width:620px){.ref-grid{grid-template-columns:1fr}}
  .ref{position:relative;overflow:hidden;cursor:pointer;border:1px solid var(--line);background:#0d0f14}
  .ref img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .5s cubic-bezier(.4,0,.2,1)}
  .ref:hover img{transform:scale(1.06)}
  .ref.tall{grid-row:span 2}
  @media (max-width:980px){.ref.tall{grid-row:span 1}}
  .ref .cam{position:absolute;inset:0;display:grid;place-items:center;color:#8892A0}
  .ref .cam svg{width:32px;height:32px;opacity:.6}
  .ref .label{position:absolute;left:0;right:0;bottom:0;padding:14px;display:flex;justify-content:space-between;align-items:end;gap:12px;background:linear-gradient(transparent, rgba(0,0,0,.75));z-index:1}
  .ref .label .t{font-family:'JetBrains Mono';font-size:10.5px;letter-spacing:.18em;color:#fff;text-transform:uppercase;font-weight:500}
  .ref .label .c{font-family:'JetBrains Mono';font-size:10px;letter-spacing:.18em;color:#fff;text-transform:uppercase;background:var(--orange);padding:5px 9px;flex:none}
  .ref .hover{position:absolute;inset:0;background:rgba(30,36,48,.92);color:#fff;opacity:0;transition:.25s;display:grid;place-items:center;padding:24px;text-align:center;z-index:2}
  .ref:hover .hover{opacity:1}
  .ref .hover .h3{font-family:'Archivo Black';font-size:20px;letter-spacing:.02em;text-transform:uppercase;margin-bottom:8px}
  .ref .hover .m{font-family:'JetBrains Mono';font-size:10.5px;letter-spacing:.18em;color:var(--orange);text-transform:uppercase}
  .ref .hover .view{margin-top:18px;padding:9px 14px;border:1px solid var(--orange);color:var(--orange);font-family:'JetBrains Mono';font-size:10.5px;letter-spacing:.18em;text-transform:uppercase}

  /* Lightbox */
  .lb{position:fixed;inset:0;background:rgba(15,18,24,.94);z-index:100;display:none;align-items:center;justify-content:center;padding:40px;overflow-y:auto}
  .lb.open{display:flex}
  .lb-inner{max-width:1080px;width:100%;background:#1E2430;border:1px solid rgba(255,255,255,.08);padding:24px;margin:auto}
  @media (max-width:620px){.lb{padding:16px}.lb-inner{padding:16px}}
  .lb-stage{aspect-ratio:3/2;background:#0d0f14;position:relative;border:1px solid rgba(255,255,255,.06);overflow:hidden}
  .lb-stage img{position:absolute;inset:0;width:100%;height:100%;object-fit:contain;background:#0d0f14}
  .lb-stage .stage-nav{position:absolute;top:50%;transform:translateY(-50%);width:46px;height:46px;border:1px solid rgba(255,255,255,.25);background:rgba(15,18,24,.55);backdrop-filter:blur(6px);color:#fff;cursor:pointer;display:grid;place-items:center;transition:.2s;z-index:2}
  .lb-stage .stage-nav:hover{background:var(--orange);border-color:var(--orange)}
  .lb-stage .stage-nav.prev{left:12px}
  .lb-stage .stage-nav.next{right:12px}
  .lb-stage .stage-counter{position:absolute;left:14px;top:14px;padding:6px 10px;background:rgba(15,18,24,.6);border:1px solid rgba(255,255,255,.18);font-family:'JetBrains Mono';font-size:10.5px;letter-spacing:.18em;color:#fff;z-index:2}
  .lb-meta{display:grid;grid-template-columns:1fr auto;gap:24px;margin-top:18px;color:#fff;align-items:start}
  @media (max-width:620px){.lb-meta{grid-template-columns:1fr}}
  .lb-meta .desc{color:#B7C0CC;font-size:14.5px;line-height:1.6;margin-top:10px;max-width:680px}
  .lb-thumbs{display:grid;grid-template-columns:repeat(auto-fill, minmax(96px, 1fr));gap:8px;margin-top:18px}
  .lb-thumbs button{aspect-ratio:1;border:1px solid rgba(255,255,255,.1);background:#0d0f14;cursor:pointer;padding:0;overflow:hidden;position:relative;transition:.2s}
  .lb-thumbs button img{width:100%;height:100%;object-fit:cover;display:block;opacity:.65;transition:.2s}
  .lb-thumbs button:hover img{opacity:1}
  .lb-thumbs button.on{border-color:var(--orange);box-shadow:0 0 0 1px var(--orange)}
  .lb-thumbs button.on img{opacity:1}
  .lb-close{position:fixed;top:20px;right:20px;width:42px;height:42px;border:1px solid rgba(255,255,255,.25);background:rgba(15,18,24,.6);color:#fff;cursor:pointer;font-size:22px;z-index:101}
  .lb-close:hover{background:var(--orange);border-color:var(--orange)}
  .lb-nav{display:flex;gap:8px}
  .lb-nav button{width:42px;height:42px;border:1px solid rgba(255,255,255,.2);background:transparent;color:#fff;cursor:pointer;display:grid;place-items:center;transition:.2s}
  .lb-nav button:hover{background:rgba(255,255,255,.06)}
  .lb-projlabel{font-family:'JetBrains Mono';font-size:10px;letter-spacing:.2em;color:var(--orange);text-transform:uppercase;margin-bottom:8px}

  /* ---------- TESTIMONIALS ---------- */
  .quotes{background:var(--ink);color:#fff}
  .quotes h2{color:#fff}
  .q-viewport{overflow:hidden;position:relative}
  .q-track{display:flex;transition:transform .55s cubic-bezier(.4,0,.2,1);will-change:transform}
  .q-page{flex:0 0 100%;display:grid;grid-template-columns:repeat(3,1fr);gap:24px;padding:2px}
  @media (max-width:980px){.q-page{grid-template-columns:1fr}}
  .q{background:#252A36;border:1px solid rgba(255,255,255,.06);padding:32px;position:relative;display:flex;flex-direction:column}
  .q .mark{font-family:'Archivo Black';font-size:64px;color:var(--orange);line-height:.6;margin-bottom:12px;display:block}
  .q p{font-size:16px;color:#D5DBE4;line-height:1.65;margin-bottom:24px;flex:1}
  .q .who{display:flex;align-items:center;gap:14px;border-top:1px solid rgba(255,255,255,.08);padding-top:18px}
  .q .avatar{width:44px;height:44px;border-radius:50%;background:var(--blue);color:#fff;display:grid;place-items:center;font-family:'Archivo Black';font-size:14px;flex:none}
  .q .name{font-size:14.5px;font-weight:600}
  .q .role{font-family:'JetBrains Mono';font-size:10.5px;letter-spacing:.16em;color:#9AA4B2;text-transform:uppercase;margin-top:3px}
  .q-controls{display:flex;align-items:center;justify-content:space-between;gap:24px;margin-top:36px;flex-wrap:wrap}
  .q-dots{display:flex;gap:8px}
  .q-dots button{width:28px;height:4px;border:none;background:rgba(255,255,255,.18);cursor:pointer;padding:0;transition:.2s}
  .q-dots button.on{background:var(--orange);width:44px}
  .q-arrows{display:flex;gap:8px}
  .q-arrows button{width:46px;height:46px;border:1px solid rgba(255,255,255,.18);background:transparent;color:#fff;cursor:pointer;display:grid;place-items:center;transition:.2s}
  .q-arrows button:hover{background:var(--orange);border-color:var(--orange)}
  .q-arrows button:disabled{opacity:.3;cursor:not-allowed}
  .q-arrows button:disabled:hover{background:transparent;border-color:rgba(255,255,255,.18)}
  .q-counter{font-family:'JetBrains Mono';font-size:11px;letter-spacing:.2em;color:#9AA4B2;text-transform:uppercase}

  /* ---------- PARTNERS ---------- */
  .partners{background:#fff}
  .p-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:0;border:1px solid var(--line)}
  @media (max-width:980px){.p-grid{grid-template-columns:repeat(3,1fr)}}
  @media (max-width:560px){.p-grid{grid-template-columns:repeat(2,1fr)}}
  .partner{aspect-ratio:3/2;border-right:1px solid var(--line);border-bottom:1px solid var(--line);display:grid;place-items:center;filter:grayscale(1);opacity:.55;transition:.25s;padding:20px;font-family:'Archivo Black';font-size:16px;letter-spacing:.06em;color:#525A68}
  .partner:nth-child(6n){border-right:none}
  .partner:nth-last-child(-n+6){border-bottom:none}
  @media (max-width:980px){.partner:nth-child(6n){border-right:1px solid var(--line)}.partner:nth-child(3n){border-right:none}.partner:nth-last-child(-n+6){border-bottom:1px solid var(--line)}.partner:nth-last-child(-n+3){border-bottom:none}}
  .partner:hover{filter:none;opacity:1;color:var(--blue)}
  .partner .s{font-family:'JetBrains Mono';font-size:10px;letter-spacing:.2em;font-weight:400;display:block;margin-top:6px;color:var(--muted);text-transform:uppercase}

  /* ---------- CONTACT ---------- */
  .contact{background:var(--mist);border-top:1px solid var(--line)}
  .c-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:48px}
  @media (max-width:980px){.c-grid{grid-template-columns:1fr}}
  .c-info{background:var(--ink);color:#fff;padding:40px}
  .c-info h3{color:#fff;margin-bottom:28px}
  .c-row{display:flex;gap:14px;padding:18px 0;border-top:1px solid rgba(255,255,255,.08)}
  .c-row:first-of-type{border-top:none;padding-top:0}
  .c-row .ic{width:36px;height:36px;background:rgba(30,144,214,.15);color:var(--blue);display:grid;place-items:center;flex:none;border-radius:2px}
  .c-row .k{font-family:'JetBrains Mono';font-size:10.5px;letter-spacing:.18em;color:#9AA4B2;text-transform:uppercase;margin-bottom:4px}
  .c-row .v{font-size:15px;color:#fff}
  .c-map{margin-top:24px;aspect-ratio:16/9;background:repeating-linear-gradient(135deg,#2A2F3A 0 14px,#232832 14px 28px);position:relative;border:1px solid rgba(255,255,255,.06)}
  .c-map .pin{position:absolute;left:50%;top:50%;transform:translate(-50%,-100%)}
  .c-map .pin .dot{width:14px;height:14px;background:var(--orange);border-radius:50%;border:2px solid #fff;box-shadow:0 0 0 6px rgba(240,138,44,.25)}
  .c-map::after{content:"GOOGLE MAPS · BUDAPEST";position:absolute;right:14px;bottom:12px;font-family:'JetBrains Mono';font-size:10px;letter-spacing:.2em;color:rgba(255,255,255,.4)}

  .form{background:#fff;padding:40px;border:1px solid var(--line)}
  .form h3{margin-bottom:8px}
  .form .sub{color:var(--muted);font-size:14px;margin-bottom:28px}
  .field{margin-bottom:18px}
  .field label{display:block;font-family:'JetBrains Mono';font-size:10.5px;letter-spacing:.18em;color:#525A68;text-transform:uppercase;margin-bottom:8px}
  .field input,.field textarea,.field select{
    width:100%;padding:14px 16px;border:1px solid var(--line);background:#FAFBFD;font-family:'Inter',sans-serif;font-size:15px;color:var(--ink);
    border-radius:0;transition:.2s;
  }
  .field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--blue);background:#fff;box-shadow:inset 0 -2px 0 var(--blue)}
  .field textarea{resize:vertical;min-height:120px}
  .field.invalid input,.field.invalid textarea{border-color:#D23F3F;background:#FDF3F3}
  .field .err{color:#D23F3F;font-size:12px;margin-top:6px;display:none}
  .field.invalid .err{display:block}
  .two{display:grid;grid-template-columns:1fr 1fr;gap:16px}
  @media (max-width:560px){.two{grid-template-columns:1fr}}
  .form-foot{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-top:8px;flex-wrap:wrap}
  .checkbox{display:flex;align-items:center;gap:10px;font-size:13px;color:var(--muted)}
  .checkbox input{width:16px;height:16px;accent-color:var(--orange)}
  .submit{padding:16px 28px;font-size:14px}
  .form .ok{display:none;padding:20px;background:#EAF7EF;border:1px solid #2BB673;color:#197B4D;font-size:14.5px;align-items:center;gap:12px}
  .form.sent .ok{display:flex}
  .form.sent .form-body{display:none}

  /* ---------- FOOTER ---------- */
  footer{background:#141923;color:#A6B0BE;padding:72px 0 0}
  .f-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:40px}
  @media (max-width:980px){.f-grid{grid-template-columns:1fr 1fr;gap:32px}}
  @media (max-width:560px){.f-grid{grid-template-columns:1fr}}
  .f-brand .logo{display:flex;align-items:center;gap:12px;color:#fff;font-family:'Archivo Black';font-size:18px;margin-bottom:18px}
  .f-brand p{font-size:14px;line-height:1.7;max-width:320px}
  .f-col h4{font-family:'JetBrains Mono';font-size:11px;letter-spacing:.2em;color:#6C7684;text-transform:uppercase;margin-bottom:18px;font-weight:500}
  .f-col a,.f-col li{display:block;color:#D5DBE4;font-size:14px;padding:5px 0;cursor:pointer}
  .f-col a:hover{color:var(--orange)}
  /* MW social_links module styling — dark outlined (matches mco-kft footer theme) */
  .f-brand .mw-social-links{height:auto;display:flex;gap:10px;flex-wrap:wrap;margin-top:18px}
  .f-brand .mw-social-links a{width:38px;height:38px;background:transparent;color:#A6B0BE;border:1px solid rgba(255,255,255,.12);border-radius:0;margin:0;padding:0;display:grid;place-items:center;text-align:center}
  .f-brand .mw-social-links a:hover{background:var(--orange);border-color:var(--orange);color:#fff}
  .f-brand .mw-social-links a span{font-size:16px;line-height:1}
  .f-bot{margin-top:56px;padding:22px 0;border-top:1px solid rgba(255,255,255,.06);display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap;font-family:'JetBrains Mono';font-size:11px;letter-spacing:.14em;color:#6C7684;text-transform:uppercase}
  .f-bot .links{display:flex;gap:20px}
  .f-bot .links a:hover{color:#fff}

  /* Cookie bar */
  .cookies{position:fixed;left:20px;right:20px;bottom:20px;max-width:720px;margin:0 auto;background:var(--ink);color:#fff;padding:18px 22px;z-index:50;display:flex;align-items:center;gap:18px;border:1px solid rgba(255,255,255,.08);box-shadow:0 20px 60px -20px rgba(0,0,0,.6);transition:.3s}
  .cookies.hidden{transform:translateY(200%);opacity:0;pointer-events:none}
  .cookies p{font-size:13px;color:#C2CCD9;flex:1}
  .cookies .ck-btns{display:flex;gap:8px;flex:none}
  .cookies button{padding:9px 14px;font-family:'JetBrains Mono';font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;cursor:pointer;border:none}
  .cookies .ck-accept{background:var(--orange);color:#fff}
  .cookies .ck-deny{background:transparent;color:#C2CCD9;border:1px solid rgba(255,255,255,.16)}
  @media (max-width:560px){.cookies{flex-direction:column;align-items:stretch}.cookies .ck-btns{justify-content:flex-end}}

  /* Reveal on scroll */
  .reveal{opacity:0;transform:translateY(24px);transition:opacity .7s ease, transform .7s ease}
  .reveal.in{opacity:1;transform:none}


/* === MW Live Edit overrides (auto-generated) === */

.mw-live-edit [data-layout-container] { min-height: 0 !important; }

.brand img, .nav-logo img, .logo img { max-width: 48px; max-height: 48px; width: auto; height: auto; object-fit: contain; }
.f-brand .logo img, footer .logo img { max-width: 40px; max-height: 40px; }

.mw-live-edit .reveal {
  opacity: 1 !important;
  transform: none !important;
  animation: none !important;
}

.mw-live-edit .hero-sub,
.mw-live-edit .hero-photo {
  opacity: 1 !important;
  transform: none !important;
  animation: none !important;
}

/* MDI icon sizing inside containers (replaced raw <svg>) */
.svc .ico .mdi{font-size:28px;line-height:1}
.c-row .ic .mdi{font-size:18px;line-height:1}
.socials a .mdi{font-size:16px;line-height:1}

/* ============================================================
   LEGAL-PAGES + COOKIE BANNER (added 2026-05-20)
   pro-revizio 2026-05-20 prod-verified pattern re-tokenized for mco-kft
   Brand: --blue #1E90D6 (primary) + --orange #F08A2C (accent)
   ============================================================ */

/* Missing-token bridge: pro-revizio CSS uses --primary/--accent/etc.
   Map them to mco-kft's brand tokens so the impresszum-CSS works as-is. */
:root {
  --primary: var(--blue);
  --accent: var(--orange);
  --accent-soft: var(--mist);
  --bg: var(--paper);
  --text: var(--ink);
  --surface: var(--paper);
  --radius: 8px;
  --ease: cubic-bezier(.4,0,.2,1);
  --gutter: 24px;
  --section-y: 60px;
  --font-head: 'Inter', system-ui, sans-serif;
  --font-body: 'Inter', system-ui, sans-serif;
}

/* Static-page header-clearance — inner.php bypass fix (universal 3-selector)
   Reference: reference_mw_static_page_inner_bypass.md */
body.page-impresszum > .main-content,
body.page-impresszum > .edit.main-content,
body.page-impresszum > .edit[field="content"],
body.page-adatvedelmi > .main-content,
body.page-adatvedelmi > .edit.main-content,
body.page-adatvedelmi > .edit[field="content"] {
  padding: 112px var(--gutter) var(--section-y);
  max-width: 100%;
  background: var(--bg);
}

/* ───── Impresszum / Adatvedelmi wrap ───── */
.impresszum-wrap {
  display: flex;
  flex-direction: column;
  gap: 56px;
  max-width: 920px;
  margin: 0 auto;
}
.impresszum-lead {
  font-size: 1.02rem;
  color: var(--muted);
  line-height: 1.7;
  padding: 24px 28px;
  background: var(--accent-soft);
  border-left: 4px solid var(--accent);
  border-radius: var(--radius);
  margin: 0;
}
.impresszum-section h2 {
  font-family: var(--font-head);
  color: var(--primary);
  font-size: 1.5rem;
  font-weight: 700;
  margin: 0 0 24px;
  padding-bottom: 14px;
  border-bottom: 1px solid var(--line);
  display: flex;
  align-items: center;
  gap: 12px;
}
.impresszum-section h2 .mdi {
  color: var(--accent);
  font-size: 1.4em;
  line-height: 1;
}
.impresszum-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 16px;
}
.impresszum-grid-3 {
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
}
.impresszum-item {
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 18px 22px;
  display: flex;
  flex-direction: column;
  gap: 6px;
  transition: border-color .2s var(--ease), box-shadow .2s var(--ease);
}
.impresszum-item:hover {
  border-color: var(--accent);
  box-shadow: 0 4px 14px rgba(30, 144, 214, 0.08);
}
.impresszum-label {
  font-size: 0.74rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--muted);
  font-weight: 600;
}
.impresszum-value {
  font-size: 1rem;
  color: var(--text);
  font-weight: 500;
  line-height: 1.5;
}
.impresszum-todo {
  color: #c2410c;
  font-style: italic;
  font-weight: 500;
}
.impresszum-person-card {
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 22px 24px;
  display: flex;
  flex-direction: column;
  gap: 8px;
  text-align: center;
  transition: transform .2s var(--ease), border-color .2s var(--ease), box-shadow .2s var(--ease);
}
.impresszum-person-card:hover {
  border-color: var(--accent);
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(30, 144, 214, 0.1);
}
.impresszum-person-card-highlight {
  background: linear-gradient(135deg, var(--primary) 0%, var(--blue-deep) 100%);
  border-color: transparent;
}
.impresszum-person-card-highlight .impresszum-role { color: var(--accent); }
.impresszum-person-card-highlight .impresszum-name { color: #fff; }
.impresszum-person-card-highlight .impresszum-note { color: rgba(255,255,255,0.75); }
.impresszum-person-card-highlight:hover {
  box-shadow: 0 12px 32px rgba(30, 144, 214, 0.25);
}
.impresszum-role {
  font-size: 0.74rem;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--accent);
  font-weight: 700;
}
.impresszum-name {
  font-size: 1.05rem;
  color: var(--text);
  font-weight: 600;
  font-family: var(--font-head);
}
.impresszum-note {
  font-size: 0.82rem;
  color: var(--muted);
  font-style: italic;
}
.impresszum-contact-row {
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
}
.impresszum-contact-link {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 14px 22px;
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  color: var(--text);
  font-weight: 500;
  text-decoration: none;
  transition: background .2s var(--ease), border-color .2s var(--ease), color .2s var(--ease);
}
.impresszum-contact-link:hover {
  background: var(--primary);
  border-color: var(--primary);
  color: #fff;
}
.impresszum-contact-link .mdi {
  color: var(--accent);
  font-size: 1.2em;
}
.impresszum-contact-link:hover .mdi { color: #fff; }
.impresszum-section-text p {
  font-size: 1rem;
  line-height: 1.75;
  color: var(--text);
  margin: 0;
}
.impresszum-cta-btn {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 14px 26px;
  background: var(--primary);
  color: #fff !important;
  border-radius: var(--radius);
  font-weight: 600;
  font-size: 0.95rem;
  text-decoration: none;
  margin-top: 18px;
  transition: background .2s var(--ease), transform .2s var(--ease), box-shadow .2s var(--ease);
}
.impresszum-cta-btn:hover {
  background: var(--blue-deep);
  transform: translateY(-1px);
  box-shadow: 0 6px 16px rgba(30, 144, 214, 0.22);
}
.impresszum-cta-btn .mdi { font-size: 1.3em; line-height: 1; }
@media (max-width: 991px) {
  .impresszum-wrap { gap: 44px; }
  .impresszum-section h2 { font-size: 1.35rem; }
}
@media (max-width: 767px) {
  .impresszum-wrap { gap: 36px; }
  .impresszum-lead { padding: 18px 20px; font-size: 0.96rem; }
  .impresszum-section h2 { font-size: 1.2rem; gap: 10px; padding-bottom: 10px; margin-bottom: 18px; }
  .impresszum-section h2 .mdi { font-size: 1.3em; }
  .impresszum-grid { grid-template-columns: 1fr; gap: 12px; }
  .impresszum-grid-3 { grid-template-columns: repeat(2, 1fr); gap: 12px; }
  .impresszum-item { padding: 14px 18px; }
  .impresszum-person-card { padding: 18px 16px; gap: 6px; }
  .impresszum-name { font-size: 0.98rem; }
  .impresszum-contact-row { flex-direction: column; gap: 10px; }
  .impresszum-contact-link { width: 100%; justify-content: center; padding: 12px 18px; }
  .impresszum-section-text p { font-size: 0.96rem; line-height: 1.65; }
}
@media (max-width: 479px) {
  .impresszum-grid-3 { grid-template-columns: 1fr; }
}

/* ───── Cookie notice (scwCookie) — flex-bar layout, mco-kft brand ───── */
.scw-cookie {
  background: var(--blue) !important;
  color: #fff !important;
  font-family: var(--font-body) !important;
  font-size: 14px !important;
  border-top: none !important;
  box-shadow: 0 -8px 32px rgba(0, 0, 0, 0.2) !important;
  bottom: 0 !important;
  left: 0 !important;
  right: 0 !important;
  width: 100% !important;
  position: fixed !important;
  z-index: 9999999999 !important;
}
.scw-cookie a { color: #fff !important; text-decoration: none !important; }
.scw-cookie .scw-cookie-bar {
  display: flex !important;
  align-items: center !important;
  gap: 24px !important;
  padding: 14px 32px !important;
  max-width: 100% !important;
  width: 100% !important;
  margin: 0 !important;
  box-sizing: border-box !important;
}
.scw-cookie-message {
  flex: 1 1 auto !important;
  min-width: 0 !important;
  line-height: 1.55 !important;
  font-size: 14px !important;
  color: rgba(255,255,255,0.97) !important;
  float: none !important;
  width: auto !important;
  text-align: left !important;
}
.scw-cookie-actions {
  display: flex !important;
  align-items: center !important;
  gap: 8px !important;
  flex-shrink: 0 !important;
}
.scw-cookie-accept {
  background: var(--orange) !important;
  color: #fff !important;
  border: none !important;
  padding: 10px 22px !important;
  border-radius: var(--radius) !important;
  font-family: var(--font-body) !important;
  font-weight: 600 !important;
  font-size: 14px !important;
  line-height: 1.3 !important;
  cursor: pointer !important;
  white-space: nowrap !important;
  transition: background .2s var(--ease), transform .2s var(--ease), box-shadow .2s var(--ease) !important;
}
.scw-cookie-accept:hover {
  background: var(--orange-deep) !important;
  transform: translateY(-1px) !important;
  box-shadow: 0 6px 16px rgba(0, 0, 0, 0.2) !important;
}
.scw-cookie-icon-btn {
  background: transparent !important;
  border: none !important;
  width: 38px !important;
  height: 38px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  border-radius: var(--radius) !important;
  color: #fff !important;
  cursor: pointer !important;
  padding: 0 !important;
  transition: background .2s var(--ease) !important;
  text-decoration: none !important;
}
.scw-cookie-icon-btn:hover { background: rgba(255,255,255,0.14) !important; }
.scw-cookie-icon-btn .mdi { font-size: 20px !important; color: #fff !important; line-height: 1 !important; }
.scw-cookie-icon-btn.scw-cookie-close .mdi { color: #ffe5e5 !important; }
.scw-cookie-icon-btn.scw-cookie-close:hover .mdi { color: #fff !important; }
.scw-cookie-panel-toggle {
  background: var(--blue) !important;
  border-top: 3px solid var(--blue-deep) !important;
  border-radius: 4px 4px 0 0 !important;
  color: #fff !important;
  padding: 10px 14px !important;
}
.scw-cookie-panel-toggle:hover { border-top-color: rgba(255,255,255,0.5) !important; }
.scw-cookie-panel-toggle .mdi-cookie { color: #fff !important; font-size: 22px !important; }
.scw-cookie-details {
  padding: 18px 32px 24px !important;
  border-top: 1px solid rgba(255,255,255,0.18) !important;
  background: rgba(0,0,0,0.06) !important;
}
.scw-cookie-details-title { font-weight: 700 !important; color: #fff !important; margin-bottom: 12px !important; font-size: 15px !important; }
.scw-cookie-toggle { background: rgba(255,255,255,0.08) !important; border: 1px solid rgba(255,255,255,0.16) !important; border-radius: var(--radius) !important; padding: 10px 14px !important; }
.scw-cookie-name { font-size: 13px !important; color: rgba(255,255,255,0.97) !important; }
.scw-cookie-tooltip { background: #fff !important; border: none !important; color: var(--ink) !important; border-radius: var(--radius) !important; font-size: 12px !important; font-weight: 500 !important; padding: 6px 12px !important; box-shadow: 0 4px 12px rgba(0,0,0,0.18) !important; width: auto !important; white-space: nowrap !important; }
.scw-cookie-content, .scw-cookie-decision { display: none !important; }
@media (max-width: 767px) {
  .scw-cookie .scw-cookie-bar { flex-direction: column !important; gap: 14px !important; align-items: stretch !important; padding: 16px 20px !important; }
  .scw-cookie-message { text-align: center !important; }
  .scw-cookie-accept { width: 100% !important; }
}


/* === Ingatlanok feature CSS appended 2026-05-21 === */
.ingatlanok-cta-section {
  padding: 80px 0;
  background: linear-gradient(135deg, var(--blue) 0%, var(--blue-deep) 100%);
  color: #fff;
  overflow: hidden;
}
.ingatlanok-cta-section .icta-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 60px;
  align-items: center;
}
.ingatlanok-cta-section .lbl-row {
  display: flex; align-items: center; gap: 12px;
  color: rgba(255,255,255,0.8);
  margin-bottom: 16px;
}
.ingatlanok-cta-section .lbl-row .bar {
  width: 40px; height: 2px; background: var(--orange);
}
.ingatlanok-cta-section .lbl-row .mono {
  font-family: 'JetBrains Mono', monospace;
  font-size: 0.78rem;
  letter-spacing: 0.18em;
  font-weight: 600;
}
.ingatlanok-cta-section h2 {
  font-size: clamp(28px, 4vw, 44px);
  font-weight: 700;
  line-height: 1.15;
  margin: 0 0 20px;
  color: #fff;
}
.ingatlanok-cta-section .icta-content > .edit p {
  font-size: 1.05rem;
  line-height: 1.7;
  color: rgba(255,255,255,0.92);
  margin: 0 0 24px;
}
.ingatlanok-cta-section .icta-bullets ul {
  list-style: none; padding: 0; margin: 0 0 32px;
  display: flex; flex-direction: column; gap: 12px;
}
.ingatlanok-cta-section .icta-bullets li {
  display: flex; align-items: center; gap: 12px;
  font-size: 0.98rem; color: rgba(255,255,255,0.95);
}
.ingatlanok-cta-section .icta-bullets li .mdi {
  color: var(--orange);
  font-size: 1.4em;
}
.btn-icta {
  display: inline-flex; align-items: center; gap: 12px;
  padding: 14px 28px;
  background: var(--orange);
  color: #fff !important;
  border-radius: 8px;
  font-weight: 600;
  font-size: 1rem;
  text-decoration: none;
  transition: background .2s ease, transform .2s ease, box-shadow .2s ease;
  box-shadow: 0 6px 18px rgba(0,0,0,0.18);
}
.btn-icta:hover {
  background: var(--orange-deep);
  transform: translateY(-2px);
  box-shadow: 0 10px 28px rgba(0,0,0,0.25);
}
.btn-icta .mdi { font-size: 1.3em; line-height: 1; }
.ingatlanok-cta-section .icta-visual {
  border-radius: 12px;
  overflow: hidden;
  box-shadow: 0 20px 60px rgba(0,0,0,0.35);
}
.ingatlanok-cta-section .icta-visual img {
  width: 100%; height: 100%; object-fit: cover;
  display: block;
  aspect-ratio: 4/3;
}

@media (max-width: 991px) {
  .ingatlanok-cta-section { padding: 56px 0; }
  .ingatlanok-cta-section .icta-grid { grid-template-columns: 1fr; gap: 36px; }
  .ingatlanok-cta-section .icta-visual { order: -1; aspect-ratio: 16/9; }
}

/* ───── /ingatlanok lista oldal ───── */
.ingatlanok-page {
  padding: 100px 0 80px;
  background: var(--mist);
  min-height: 60vh;
}
.ingatlanok-page .wrap {
  max-width: var(--max);
  margin: 0 auto;
  padding: 0 24px;
}
.ingatlanok-banner {
  text-align: center;
  margin-bottom: 40px;
}
.ingatlanok-banner .lbl-row {
  display: inline-flex; align-items: center; gap: 12px;
  color: var(--muted);
  margin-bottom: 16px;
}
.ingatlanok-banner .lbl-row .bar { width: 40px; height: 2px; background: var(--orange); }
.ingatlanok-banner .lbl-row .mono {
  font-family: 'JetBrains Mono', monospace;
  font-size: 0.78rem;
  letter-spacing: 0.18em;
  font-weight: 600;
}
.ingatlanok-banner h1 {
  font-size: clamp(32px, 5vw, 52px);
  font-weight: 700;
  margin: 0 0 16px;
  color: var(--ink);
  letter-spacing: -0.01em;
}
.ingatlanok-banner .lead {
  font-size: 1.08rem;
  line-height: 1.7;
  color: var(--muted);
  max-width: 720px;
  margin: 0 auto;
}

/* Filter pills */
.ingatlanok-filters {
  display: flex; justify-content: center; flex-wrap: wrap; gap: 10px;
  margin-bottom: 40px;
}
.ifilter {
  background: var(--paper);
  border: 1px solid var(--line);
  color: var(--ink);
  font-weight: 500;
  font-size: 0.94rem;
  padding: 10px 22px;
  border-radius: 999px;
  cursor: pointer;
  transition: background .2s ease, border-color .2s ease, color .2s ease;
}
.ifilter:hover {
  border-color: var(--blue);
  color: var(--blue);
}
.ifilter.active {
  background: var(--blue);
  border-color: var(--blue);
  color: #fff;
}

/* Kártya-grid */
.ingatlanok-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
  gap: 28px;
}
.ingatlan-card {
  position: relative;
  background: var(--paper);
  border: 1px solid var(--line);
  border-radius: 12px;
  overflow: hidden;
  transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease, opacity .3s ease, max-height .3s ease;
  max-height: 800px;
  opacity: 1;
}
.ingatlan-card.ihidden {
  opacity: 0;
  max-height: 0;
  overflow: hidden;
  margin: 0;
  pointer-events: none;
}
.ingatlan-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 18px 40px rgba(30, 144, 214, 0.18);
  border-color: var(--blue);
}
.ingatlan-card-link {
  display: block;
  text-decoration: none;
  color: var(--ink);
}
.ingatlan-card-image {
  position: relative;
  aspect-ratio: 4/3;
  overflow: hidden;
  background: var(--mist);
}
.ingatlan-card-image img {
  width: 100%; height: 100%; object-fit: cover;
  transition: transform .35s ease;
}
.ingatlan-card:hover .ingatlan-card-image img {
  transform: scale(1.06);
}
.ingatlan-status-pill {
  position: absolute;
  top: 14px; left: 14px;
  padding: 6px 14px;
  border-radius: 999px;
  font-size: 0.76rem;
  font-weight: 600;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  background: rgba(255,255,255,0.94);
  color: var(--ink);
  backdrop-filter: blur(6px);
}
.ingatlan-status-pill.ingatlan-status-kesz {
  background: var(--ok, #2BB673);
  color: #fff;
}
.ingatlan-status-pill.ingatlan-status-epites-alatt {
  background: var(--blue);
  color: #fff;
}
.ingatlan-status-pill.ingatlan-status-foglalt {
  background: var(--muted);
  color: #fff;
}
.ingatlan-akcio-badge {
  position: absolute;
  top: 14px; right: 14px;
  background: var(--orange);
  color: #fff;
  padding: 7px 14px;
  border-radius: 6px;
  font-size: 0.8rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  z-index: 2;
  box-shadow: 0 4px 12px rgba(240, 138, 44, 0.4);
}
.ingatlan-card-body {
  padding: 22px 22px 20px;
}
.ingatlan-card-title {
  font-size: 1.2rem;
  font-weight: 600;
  margin: 0 0 14px;
  color: var(--ink);
  line-height: 1.3;
}
.ingatlan-params {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 12px;
}
.ipill {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: var(--mist);
  color: var(--ink);
  padding: 6px 12px;
  border-radius: 6px;
  font-size: 0.82rem;
  font-weight: 500;
}
.ipill .mdi {
  color: var(--blue);
  font-size: 1.1em;
  line-height: 1;
}
.ingatlan-delivery {
  display: flex; align-items: center; gap: 8px;
  font-size: 0.86rem;
  color: var(--muted);
  margin-bottom: 14px;
}
.ingatlan-delivery .mdi {
  color: var(--orange);
  font-size: 1.15em;
}
.ingatlan-delivery strong { color: var(--ink); font-weight: 600; }
.ingatlan-price {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-top: 14px;
  border-top: 1px solid var(--line);
}
.ingatlan-price-text {
  font-size: 1.1rem;
  font-weight: 700;
  color: var(--blue);
}
.ingatlan-card-more {
  display: inline-flex; align-items: center; gap: 4px;
  font-size: 0.88rem;
  color: var(--orange);
  font-weight: 600;
  transition: gap .2s ease;
}
.ingatlan-card:hover .ingatlan-card-more {
  gap: 8px;
}
.ingatlan-card-more .mdi { font-size: 1.1em; }

.ingatlanok-empty {
  grid-column: 1 / -1;
  text-align: center;
  padding: 60px 20px;
  color: var(--muted);
}
.ingatlanok-empty .mdi {
  font-size: 4rem;
  color: var(--line);
  margin-bottom: 16px;
  display: block;
}

/* Bottom CTA */
.ingatlanok-cta-bottom {
  margin-top: 60px;
  padding: 40px;
  background: var(--paper);
  border: 1px solid var(--line);
  border-radius: 12px;
  text-align: center;
}
.ingatlanok-cta-bottom p {
  font-size: 1.05rem;
  color: var(--muted);
  margin: 0 0 20px;
  line-height: 1.7;
}
.btn-primary {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 14px 28px;
  background: var(--blue);
  color: #fff !important;
  border-radius: 8px;
  font-weight: 600;
  text-decoration: none;
  transition: background .2s ease, transform .2s ease;
}
.btn-primary:hover { background: var(--blue-deep); transform: translateY(-2px); }
.btn-primary .mdi { font-size: 1.3em; }

/* ───── /ingatlanok/<slug> detail page (post.content rich HTML) ───── */
body.page-ingatlanok > .main-content,
body.page-ingatlanok > .edit.main-content,
body.page-ingatlanok > .edit[field="content"] {
  padding: 112px 24px 80px;
  max-width: 100%;
  background: var(--mist);
}
.ingatlan-detail {
  max-width: 1100px;
  margin: 0 auto;
  background: var(--paper);
  border-radius: 12px;
  overflow: hidden;
  box-shadow: 0 10px 40px rgba(30,144,214,0.08);
}
.ingatlan-detail-hero {
  position: relative;
  aspect-ratio: 16/9;
  overflow: hidden;
}
.ingatlan-detail-hero img {
  width: 100%; height: 100%; object-fit: cover;
}
.ingatlan-akcio-banner {
  background: linear-gradient(135deg, var(--orange) 0%, var(--orange-deep) 100%);
  color: #fff;
  padding: 16px 32px;
  display: flex; align-items: center; gap: 14px;
  font-size: 1rem;
  font-weight: 600;
}
.ingatlan-akcio-banner .mdi { font-size: 1.6em; }
.ingatlan-detail-body {
  padding: 40px 48px 48px;
}
.ingatlan-detail-title {
  font-size: clamp(28px, 4vw, 40px);
  font-weight: 700;
  color: var(--ink);
  margin: 0 0 24px;
  line-height: 1.2;
}
.ingatlan-detail-params {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 16px;
  margin-bottom: 36px;
  padding: 24px;
  background: var(--mist);
  border-radius: 8px;
  border-left: 4px solid var(--blue);
}
.ingatlan-detail-params .iparam {
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.ingatlan-detail-params .ilabel {
  font-size: 0.74rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--muted);
  font-weight: 600;
}
.ingatlan-detail-params .ivalue {
  font-size: 1.1rem;
  color: var(--ink);
  font-weight: 600;
}
.ingatlan-detail-params .ivalue.iprice {
  color: var(--blue);
  font-size: 1.2rem;
}
.ingatlan-detail-section {
  margin-bottom: 36px;
}
.ingatlan-detail-section h2 {
  font-size: 1.4rem;
  font-weight: 700;
  color: var(--ink);
  margin: 0 0 18px;
  padding-bottom: 12px;
  border-bottom: 1px solid var(--line);
  display: flex;
  align-items: center;
  gap: 10px;
}
.ingatlan-detail-section h2 .mdi {
  color: var(--blue);
  font-size: 1.3em;
}
.ingatlan-detail-section p {
  font-size: 1rem;
  line-height: 1.75;
  color: var(--ink);
  margin: 0 0 14px;
}
.ingatlan-floorplans,
.ingatlan-galeria {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 16px;
}
.ingatlan-floorplans img,
.ingatlan-galeria img {
  width: 100%;
  border-radius: 8px;
  border: 1px solid var(--line);
  cursor: pointer;
  transition: transform .2s ease, box-shadow .2s ease;
}
.ingatlan-floorplans img:hover,
.ingatlan-galeria img:hover {
  transform: scale(1.02);
  box-shadow: 0 8px 24px rgba(30,144,214,0.18);
}
.ingatlan-detail-cta {
  margin-top: 40px;
  padding: 28px 32px;
  background: linear-gradient(135deg, var(--blue) 0%, var(--blue-deep) 100%);
  border-radius: 12px;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
  color: #fff;
}
.ingatlan-detail-cta-text {
  flex: 1 1 auto;
  font-size: 1.05rem;
  line-height: 1.5;
}
.ingatlan-detail-cta-text strong { color: #fff; }
.ingatlan-detail-cta .btn-erdeklodom {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 14px 28px;
  background: var(--orange);
  color: #fff !important;
  border-radius: 8px;
  font-weight: 600;
  text-decoration: none;
  white-space: nowrap;
  transition: background .2s ease, transform .2s ease, box-shadow .2s ease;
}
.ingatlan-detail-cta .btn-erdeklodom:hover {
  background: var(--orange-deep);
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(0,0,0,0.18);
}
.ingatlan-detail-cta .btn-erdeklodom .mdi { font-size: 1.3em; }

@media (max-width: 767px) {
  .ingatlanok-page { padding: 80px 0 60px; }
  .ingatlanok-grid { grid-template-columns: 1fr; gap: 20px; }
  .ingatlan-detail-body { padding: 24px 20px 32px; }
  .ingatlan-detail-cta { flex-direction: column; align-items: stretch; text-align: center; padding: 24px; }
  .ingatlan-detail-cta .btn-erdeklodom { justify-content: center; }
  .ingatlan-detail-params { grid-template-columns: repeat(2, 1fr); padding: 18px; }
  .ingatlanok-cta-bottom { padding: 30px 20px; margin-top: 40px; }
}
@media (max-width: 479px) {
  .ingatlan-detail-params { grid-template-columns: 1fr; }
}

/* ───── Ingatlan modal overlay (lightbox-style detail) ───── */
.ingatlan-modal {
  position: fixed;
  inset: 0;
  z-index: 99999;
  display: none;
  align-items: flex-start;
  justify-content: center;
  overflow-y: auto;
  padding: 40px 20px;
}
.ingatlan-modal-backdrop {
  position: fixed;
  inset: 0;
  background: rgba(15, 22, 30, 0.78);
  backdrop-filter: blur(4px);
}
.ingatlan-modal-container {
  position: relative;
  z-index: 1;
  width: 100%;
  max-width: 1100px;
  background: var(--paper);
  border-radius: 12px;
  overflow: hidden;
  box-shadow: 0 30px 80px rgba(0,0,0,0.4);
  animation: imodalIn .3s cubic-bezier(.4,0,.2,1);
}
@keyframes imodalIn {
  from { opacity: 0; transform: translateY(20px) scale(0.98); }
  to   { opacity: 1; transform: translateY(0)    scale(1); }
}
.ingatlan-modal-close {
  position: absolute;
  top: 16px; right: 16px;
  z-index: 2;
  width: 44px; height: 44px;
  border-radius: 50%;
  background: rgba(255,255,255,0.92);
  border: none;
  cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  font-size: 1.6rem;
  color: var(--ink);
  transition: background .2s ease, transform .2s ease;
  box-shadow: 0 4px 14px rgba(0,0,0,0.2);
}
.ingatlan-modal-close:hover {
  background: #fff;
  transform: scale(1.08);
}
.ingatlan-modal-close .mdi { line-height: 1; }
.ingatlan-modal-content {
  /* The .ingatlan-detail markup from post.content lives here */
}
.ingatlan-modal-content .ingatlan-detail {
  border-radius: 0;
  box-shadow: none;
}
@media (max-width: 767px) {
  .ingatlan-modal { padding: 20px 10px; }
  .ingatlan-modal-close { top: 10px; right: 10px; width: 38px; height: 38px; }
}

/* ───── DSP (Demján Sándor Program) — pályázati arculati compliance ───── */
.mco-dsp {
  padding: 0 0 48px;
  margin-bottom: 48px;
  border-bottom: 1px solid rgba(166,176,190,0.18);
  text-align: center;
}
.mco-dsp .dsp-statement {
  font-family: 'Inter', Arial, sans-serif;
  font-size: 14px;
  color: #D5DBE4;
  margin-bottom: 24px;
  line-height: 1.5;
}
.mco-dsp .dsp-logos {
  display: flex;
  gap: 50px;
  justify-content: center;
  align-items: center;
  flex-wrap: wrap;
  padding: 10px;
}
.mco-dsp .dsp-logo,
.mco-dsp .neum-logo {
  height: 141px;
  width: auto;
  display: block;
  transition: opacity 0.2s ease;
}
.mco-dsp .dsp-logos a:hover .dsp-logo { opacity: 0.85; }

@media (max-width: 1024px) {
  .mco-dsp .dsp-logo, .mco-dsp .neum-logo { height: 100px; }
}
@media (max-width: 768px) {
  .mco-dsp { padding-bottom: 32px; margin-bottom: 32px; }
  .mco-dsp .dsp-logos { gap: 24px; padding: 8px; }
  .mco-dsp .dsp-logo, .mco-dsp .neum-logo { height: 64px; }
  .mco-dsp .dsp-statement { font-size: 13px; margin-bottom: 18px; }
}/* ═══ MW Live Edit Icon-Picker SVG-inflate fix ═══
   A Live Edit JS futás-időben átalakítja <i class="mdi mdi-X"></i> →
   <i class="mdi mdi-X"><svg viewBox="0 0 24 24">...</svg></i>.
   Az SVG-nek nincs default width/height attribute, ezért a parent-konténer
   méretéig nyúlik. Korlátozzuk 1em-re hogy a font-glyph-méretet matchelje. */
.mdi svg,
i.mdi svg,
i.mdi > svg {
  width: 1em !important;
  height: 1em !important;
  max-width: 1em !important;
  max-height: 1em !important;
  vertical-align: -0.125em;
  display: inline-block;
  fill: currentColor;
}
/* Some ipill/badge contexts use larger sizing — preserve em-relative scale */
.ipill .mdi svg,
.ingatlan-delivery .mdi svg,
.ingatlan-card-more .mdi svg,
.btn-erdeklodom .mdi svg,
.ingatlan-akcio-banner .mdi svg,
.icta-bullets li .mdi svg,
.ing-admin-fab .mdi svg {
  width: 1.1em !important;
  height: 1.1em !important;
}
