/* =============================
   Liftkarbantartás – BLACK + ORANGE THEME
   ============================= */
:root{
  --bg:#111;           /* fő háttér (fekete) */
  --bg-2:#151515;      /* sötét panel */
  --panel:#1a1a1a;
  --text:#f1f1f1;      /* fő szöveg */
  --muted:#bdbdbd;     /* halvány szöveg */
  --accent:#FF7A00;    /* narancs */
  --accent-dark:#e66e00;
  --accent-25: rgba(255,122,0,.25);
  --accent-15: rgba(255,122,0,.15);
  --black:#000;
}

/* ===== Alap ===== */
body{
  background-color:var(--bg);
  color:var(--text);
  font-family:'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
}

/* ===== Navbar ===== */
.navbar{ background-color:var(--black); }

.navbar .navbar-brand{
  color:var(--accent) !important;
  font-weight:700;
}

/* modern, tiszta linkek */
.custom-navbar{ background-color:var(--black); padding:15px 0; }
.custom-navbar .navbar-brand{ font-size:1.4rem; letter-spacing:1px; }
.custom-navbar .nav-link{
  color:var(--text) !important;
  margin:0 10px;
  position:relative;
  transition:color .3s;
}
.custom-navbar .nav-link:hover{ color:var(--accent) !important; }
.custom-navbar .nav-link::after{
  content:""; position:absolute; left:0; bottom:-5px; height:2px; width:0%;
  background:var(--accent); transition:width .3s;
}
.custom-navbar .nav-link:hover::after{ width:100%; }

/* CTA a navban (ha van btn-cta a navbar.html-ben) */
.navbar .btn-cta{
  background:var(--accent) !important; color:#000 !important;
  font-weight:800; padding:8px 20px; border-radius:50px;
  text-decoration:none; display:inline-block; border:none;
  transition:all .25s ease;
}
.navbar .btn-cta:hover{ background:var(--accent-dark) !important; transform:scale(1.05); }

/* Hamburger: átlátszó háttér + fehér ikon */
.navbar-toggler{ background:transparent !important; border:none; outline:none; box-shadow:none; }
.navbar-toggler:focus{ outline:none; box-shadow:none; }
.navbar-dark .navbar-toggler-icon{
  background-image:url("data:image/svg+xml;charset=utf8,%3Csvg viewBox='0 0 30 30' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath stroke='rgba(255,255,255,0.95)' stroke-width='2' stroke-linecap='round' stroke-miterlimit='10' d='M4 7h22M4 15h22M4 23h22'/%3E%3C/svg%3E") !important;
}

/* ===== Hero (nagy képes fejléc) ===== */
.hero{
  background:
    linear-gradient(rgba(0,0,0,.78), rgba(0,0,0,.78)),
    url('images/hatter.jpg') center/cover no-repeat;
  color:#fff;
  padding:120px 20px;
  text-align:center;
}
.hero h1, .hero p{ text-shadow:2px 2px 6px rgba(0,0,0,.8); }

/* ===== Hero-small (más oldalakhoz) ===== */
.hero-small{
  background:
    linear-gradient(rgba(0,0,0,.78), rgba(0,0,0,.78)),
    url('images/lift3.jpg') center/cover no-repeat;
  padding:80px 20px; color:#fff;
}

/* ===== Gombok ===== */
.btn-custom{
  background:var(--accent) !important; color:#000 !important;
  font-weight:800; border-radius:999px; padding:12px 28px;
  transition:transform .25s ease, background-color .25s ease;
  text-decoration:none; display:inline-block; border:none !important;
  position:relative; overflow:hidden;
}
.btn-custom:hover{ background:var(--accent-dark) !important; transform:scale(1.05); }
/* finom fénycsík animáció */
.btn-custom::before{
  content:""; position:absolute; top:0; left:-75px; width:50px; height:100%;
  background:rgba(255,255,255,.45); transform:skewX(-20deg); transition:.5s;
}
.btn-custom:hover::before{ left:120%; }

/* ===== Szekciók ===== */
.section{ padding:60px 20px; }

/* ===== Kártyák ===== */
.card{
  border:1px solid var(--accent-25);
  border-radius:14px;
  background:var(--panel);
  box-shadow:0 4px 16px rgba(0,0,0,.25);
  transition:.3s;
  color:var(--text);
}
.card:hover{ transform:translateY(-5px); box-shadow:0 6px 28px rgba(255,122,0,.15); }
.card .card-title{ color:var(--accent); font-weight:800; }

/* ===== Referencia képek ===== */
.reference-img{
  width:100%; height:200px; object-fit:cover; border-radius:8px;
}

/* --- Referenciák: galéria kártya --- */
.gallery-card {
  position: relative;
  border-radius: 12px;
  overflow: hidden;
  background: var(--bg-2);
  border:1px solid var(--accent-25);
}
.gallery-card .reference-img {
  height: 230px;
  object-fit: cover;
  display: block;
}
.gallery-overlay {
  position: absolute;
  inset: auto 0 0 0;
  padding: 12px 14px;
  background: linear-gradient(180deg, rgba(0,0,0,0) 0%, rgba(0,0,0,.75) 60%, rgba(0,0,0,.92) 100%);
  color: #fff;
  transition: transform .25s ease, opacity .25s ease;
  transform: translateY(0);
}
.gallery-card:hover .gallery-overlay { transform: translateY(0); opacity: 1; }

.gallery-zoom {
  position: absolute;
  inset: 10px 10px auto auto;
  background: var(--accent);
  color: #000;
  border: none;
  border-radius: 999px;
  font-size: .85rem;
  padding: 6px 12px;
  cursor: pointer;
  transition: transform .2s ease, background-color .2s ease;
}
.gallery-zoom:hover { transform: scale(1.05); background:var(--accent-dark); }

/* Szűrő pill-ek (sötét alap, aktív narancs) */
.filter-pill {
  background: var(--panel);
  color: var(--text);
  border: 1px solid var(--accent-25);
  padding: 6px 14px;
  border-radius: 999px;
  font-weight: 700;
  cursor: pointer;
  transition: all .2s ease;
}
.filter-pill:hover { background:#1f1f1f; }
.filter-pill.active {
  background: var(--accent);
  color: #000;
  border-color: var(--accent);
}

/* Kerek ikon-buborék a fő szolgáltatásoknál */
.icon-circle{
  width:56px;height:56px;flex:0 0 56px;
  display:flex;align-items:center;justify-content:center;
  border-radius:50%;
  background: var(--bg);
  border:2px solid var(--accent);
  color:var(--accent); font-size:1.4rem;
  box-shadow:0 4px 12px rgba(0,0,0,.35);
}

/* Pipa listák egységesen (narancs akcentus) */
.feature-list{ padding-left:0; margin:0; list-style:none; }
.feature-list li{
  position:relative; padding-left:26px; margin-bottom:6px; color:#ddd;
}
.feature-list li::before{
  content:"✓";
  position:absolute; left:0; top:0; color:var(--accent); font-weight:900;
}

/* SLA: kiemelt (Standard) kártya */
.plan-popular{
  box-shadow:0 12px 36px rgba(255,122,0,.18);
  transform:translateY(-4px);
  border:1px solid var(--accent) !important;
}

/* Folyamat lépésszám */
.step-num{
  width:36px;height:36px;border-radius:50%;
  background:var(--accent);color:#000;font-weight:900;
  display:flex;align-items:center;justify-content:center;
}

/* Fejlécek egységes akcentus színnel */
.text-primary{ color:var(--accent) !important; }

/* Kapcsolat űrlap – sötét mezők, narancs fókusz */
.form-control, .form-select, textarea.form-control{
  background:#0f0f0f; color:#f1f1f1;
  border:1px solid var(--accent-25);
  border-radius:10px;
}
.form-control::placeholder{ color:#9a9a9a; }
.form-control:focus, .form-select:focus, textarea.form-control:focus{
  border-color:var(--accent);
  box-shadow:0 0 0 .2rem var(--accent-15);
}

/* kis kiegészítés a link-gombok közötti távolságra */
.card .btn-custom{ margin-top:.25rem; }
/* ===== Kártyák egységes magassággal + gombok egyforma méretben ===== */

/* 1) A kártya tartalma rugalmas oszlop, a gombsor az aljára kerül */
.card {
  display: flex;
  flex-direction: column;
}
.card .card-body {
  display: flex;
  flex-direction: column;
  gap: .5rem;
  flex: 1 1 auto;                /* kitölti a magasságot */
}

/* 2) Gombsor rács: két gomb egymás mellett, alulra tolva */
.card .card-cta,
.card .btn-row {
  margin-top: auto;              /* a kártya aljára tolja */
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: .6rem;
}
@media (max-width: 700px){
  .card .card-cta,
  .card .btn-row {
    grid-template-columns: 1fr;  /* mobilon egymás alatt */
  }
}

/* 3) Minden gomb azonos magasságú és középre igazított szöveggel */
.btn-custom,
.card .btn,
.card .btn-outline,
.card .btn-dark {
  display: inline-flex;           /* rugalmas központosítás */
  align-items: center;
  justify-content: center;
  inline-size: 100%;              /* nyúljon a rács cellájára */
  min-block-size: 48px;           /* egységes magasság (kb. 3rem) */
  line-height: 1.2;               /* több sor esetén szebb */
  white-space: normal;            /* törhet a hosszú felirat */
  word-break: break-word;
  text-align: center;
  padding: .75rem 1rem;           /* konzisztens belső margó */
}

/* ha van másodlagos gomb-típusod is, ugyanígy méretezzük */
.btn-outline-custom{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  inline-size: 100%;
  min-block-size: 48px;
  line-height: 1.2;
  white-space: normal;
  text-align: center;
  padding: .75rem 1rem;
}

/* 4) Opcionális: a kártyarács oszlopai egymás magasságát vegyék fel */
.row > [class*="col"] > .card,
.grid > .card {
  height: 100%;
}
/* Referenciák környéki vonalak kikapcsolása – HTML módosítás nélkül */

/* Hamburger (összecsukott) menüben NE legyen hover aláhúzás */
.custom-navbar .navbar-collapse.show .nav-link::after,
.custom-navbar .navbar-collapse.show .nav-link:hover::after{
  content: none !important;
  width: 0 !important;
  height: 0 !important;
  background: none !important;
}

/* Biztonsági: kis kijelzőn általában is kapcsold ki */
@media (max-width: 991.98px) {
  .custom-navbar .navbar-collapse .nav-link::after,
  .custom-navbar .navbar-collapse .nav-link:hover::after{
    content: none !important;
    width: 0 !important;
    height: 0 !important;
    background: none !important;
  }
}
/* ===== Inline linkek (pl. email) – téma szerint ===== */
a,
a:visited{
  color: var(--accent);
  text-decoration: none;
  transition: color .2s ease, text-shadow .2s ease;
}
a:hover{
  color: var(--accent-dark);
  text-shadow: 0 0 6px var(--accent-15);
}

/* csak mailto linkek finom kiemelése */
a[href^="mailto:"]{
  font-weight: 700;
}
a[href^="mailto:"]:hover{
  text-decoration: underline;
}

/* Ha szeretnél külön osztályt inline linkekhez: .link-accent */
.link-accent{ color: var(--accent); font-weight: 700; }
.link-accent:hover{ color: var(--accent-dark); text-decoration: underline; }

/* ===== Outline gomb (új elemekhez) – egységes dizájn ===== */
.btn-outline-custom{
  /* meglévő méretezéshez kiegészítés */
  border: 2px solid var(--accent);
  color: var(--accent);
  background: transparent;
  border-radius: 999px;
  font-weight: 800;
  text-decoration: none;
  transition: color .25s ease, background-color .25s ease, transform .25s ease, box-shadow .25s ease;
  box-shadow: 0 0 0 0 rgba(255,122,0,0);
}
.btn-outline-custom:hover{
  color: #000;
  background: var(--accent);
  transform: translateY(-1px);
  box-shadow: 0 6px 18px var(--accent-15);
}
.btn-outline-custom:active{
  transform: translateY(0);
  box-shadow: 0 0 0 0 rgba(0,0,0,0);
}
.btn-outline-custom:focus-visible{
  outline: none;
  box-shadow: 0 0 0 .2rem var(--accent-15);
}

/* Opcionális: kis ikon a gombok előtt – ha szeretnéd */
.btn-outline-custom .icon{ margin-right: .5rem; display: inline-flex; }

/* ===== Konzisztens tipó az új címekre/kártyákra ===== */
h1,h2,h3,h4,h5,h6{ letter-spacing:.2px; }
.card .card-title{ color: var(--accent); font-weight: 800; }

/* ===== Ne befolyásolja a logót/brand képet ===== */
.navbar .navbar-brand img{ filter: none; } /* csak explicit példának; nincs extra effekt */
/* ===== FAQ / Accordion – dark + orange theme ===== */
.accordion {
  --acc-border: var(--accent-25);
  --acc-bg: var(--panel);
  --acc-bg-hover: #1f1f1f;
  --acc-text: var(--text);
  --acc-muted: var(--muted);
}

.accordion-item {
  background: transparent;
  border: 1px solid var(--acc-border) !important;
  border-radius: 12px;
  overflow: hidden;
  backdrop-filter: saturate(110%);
  transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}
.accordion-item + .accordion-item { margin-top: .75rem; }

.accordion-item:hover {
  transform: translateY(-2px);
  box-shadow: 0 6px 22px rgba(255,122,0,.12);
  border-color: var(--accent-25);
}

/* Header button */
.accordion-button {
  background: var(--acc-bg);
  color: var(--acc-text);
  padding: 1rem 1.1rem;
  font-weight: 700;
  letter-spacing: .2px;
  border: 0;
  box-shadow: none !important;
  transition: background-color .2s ease, color .2s ease;
}

/* Remove Bootstrap default light bg on expand */
.accordion-button:not(.collapsed) {
  background: linear-gradient(0deg, rgba(255,122,0,.08), rgba(255,122,0,.08)), var(--acc-bg);
  color: #fff;
}

/* Hover states */
.accordion-button:hover { background: var(--acc-bg-hover); }

/* Focus ring in theme color */
.accordion-button:focus {
  outline: none;
  box-shadow: 0 0 0 .2rem var(--accent-15) !important;
}

/* Custom chevron in accent color */
.accordion-button::after {
  background-image: none !important;
  content: "";
  inline-size: 10px;
  block-size: 10px;
  border-right: 2px solid var(--accent);
  border-bottom: 2px solid var(--accent);
  transform: rotate(-45deg);
  transition: transform .25s ease, border-color .2s ease;
  margin-left: .75rem;
}
.accordion-button:not(.collapsed)::after {
  transform: rotate(45deg);
  border-color: var(--accent);
}

/* Body */
.accordion-body {
  background: #141414;
  color: var(--acc-muted);
  border-top: 1px solid var(--acc-border);
  padding: 1rem 1.1rem 1.15rem;
  line-height: 1.55;
}

/* Rounded corners stay pretty when open */
.accordion-item:first-of-type, .accordion-item:last-of-type {
  border-radius: 12px;
}
.accordion-item .accordion-collapse.collapse.show + .accordion-body,
.accordion-item .accordion-collapse.collapsing + .accordion-body {
  border-top-color: var(--accent-25);
}
/* ====== Univerzális tábladizájn – dark theme (asztali + mobil stacked) ====== */
.table-legal { 
  margin-block: 1.25rem; 
}

/* Alap (asztali) tábladizájn */
.table-legal table {
  width: 100%;
  border-collapse: collapse;
  background: var(--panel);
  color: var(--text);
  border: 1px solid var(--accent-25);
  border-radius: 12px;
  overflow: hidden; /* a lekerekítés működjön */
  box-shadow: 0 6px 24px rgba(0,0,0,.18);
}

.table-legal caption {
  caption-side: top;
  color: var(--muted);
  padding: .5rem .75rem .25rem;
  font-size: .95rem;
}

.table-legal thead th {
  background: #151515;
  color: var(--text);
  border-bottom: 1px solid var(--accent-25);
  padding: .8rem .9rem;
  text-align: left;
  font-weight: 800;
  letter-spacing: .2px;
}

.table-legal tbody th,
.table-legal tbody td {
  padding: .75rem .9rem;
  vertical-align: top;
  border-bottom: 1px solid rgba(255,255,255,.06);
}

/* Zebra és hover asztalin */
.table-legal tbody tr:nth-child(even) {
  background: rgba(255,255,255,.02);
}
.table-legal tbody tr:hover {
  background: rgba(255,122,0,.06);
}

/* Szövegkiegészítők */
.table-legal a { color: var(--text); text-decoration: underline; }
.table-legal a:hover { color: var(--accent); }
.table-legal code { color: var(--muted); background: rgba(255,255,255,.06); padding: .1rem .3rem; border-radius: 6px; }

/* Kompakt mód – ha kell: add hozzá a .table-legal--compact osztályt a wrapperhez */
.table-legal.table-legal--compact thead th,
.table-legal.table-legal--compact tbody th,
.table-legal.table-legal--compact tbody td {
  padding: .55rem .7rem;
  font-size: .95rem;
}
/* Small screens: tighter spacing */
@media (max-width: 576px){
  .accordion-button { padding: .9rem .95rem; }
  .accordion-body { padding: .9rem .95rem 1rem; }
}
/* ===== Mobil-barát "kártyás" táblák (stacked) ===== */
.table-legal { margin-block: 1rem; }
.table-legal table {
  width: 100%;
  border-collapse: collapse;
  color: var(--text);
}
.table-legal thead th {
  background: #151515;
  color: var(--text);
  border: 1px solid var(--accent-25);
  padding: .7rem .8rem;
  text-align: left;
}
.table-legal tbody td, 
.table-legal tbody th {
  border: 1px solid var(--accent-25);
  padding: .7rem .8rem;
  vertical-align: top;
}
.table-legal code, .table-legal em { color: var(--muted); }

/* — mobilon kártyásra törjük — */
@media (max-width: 640px) {
  .table-legal table, 
  .table-legal tbody, 
  .table-legal tr, 
  .table-legal td, 
  .table-legal th { display: block; width: 100%; }

  .table-legal thead { 
    display: none; 
  }

  .table-legal tbody tr {
    margin-bottom: .9rem;
    border: 1px solid var(--accent-25);
    border-radius: 12px;
    overflow: hidden;
    background: var(--panel);
    box-shadow: 0 4px 16px rgba(0,0,0,.15);
  }

  .table-legal tbody td, 
  .table-legal tbody th {
    border: none;
    border-bottom: 1px solid rgba(255,255,255,.06);
    padding: .75rem .9rem .6rem;
  }
  .table-legal tbody tr > :last-child {
    border-bottom: none;
  }

  /* címke a cella elején a thead-ból (JS adja a data-label-t) */
  .table-legal [data-label] {
    position: relative;
    padding-left: 9.5rem;      /* hely a címkének */
    min-height: 42px;
  }
  .table-legal [data-label]::before {
    content: attr(data-label);
    position: absolute;
    left: .9rem; top: .65rem;
    width: 8.6rem;
    color: #bbb;
    font-weight: 700;
    font-size: .875rem;
    text-transform: none;
    white-space: normal;
    line-height: 1.2;
  }
}

.logo-badge{
  display:inline-block;
  padding:16px 18px;
  border-radius:14px;
  background: rgba(0,0,0,.55);               /* sötét alátét */
  border:1px solid var(--accent-25);
  box-shadow:
    0 8px 24px rgba(0,0,0,.45),
    0 0 0 3px rgba(255,122,0,.10),           /* finom narancs-gyűrű */
    0 0 22px rgba(255,122,0,.18);            /* narancs glow */
  backdrop-filter: saturate(110%) blur(2px); /* üveges hatás */
}

/* kis kijelzőn legyen nagyobb (jobban látszik) */
@media (max-width: 576px){
  .logo-img{ max-width:280px; }
}

.hero img[src$="logo.png"] {
  max-width: 260px !important;
  opacity: 1 !important;
  filter: saturate(1.5) contrast(1.15) hue-rotate(-8deg);
}
/* ===== Cégadatok lista feldobása ===== */
.card ul.list-unstyled li {
  padding: .6rem .2rem;
  border-bottom: 1px dashed rgba(255,122,0,.25); /* finom elválasztó */
  display: flex;
  gap: .5rem;
  align-items: flex-start;
  transition: background-color .2s ease;
}
.card ul.list-unstyled li:last-child {
  border-bottom: none;
}

.card ul.list-unstyled li:hover {
  background: rgba(255,122,0,.05);
}

/* cím: narancs, félkövér */
.card ul.list-unstyled strong {
  min-width: 160px;  /* oszlopszerű hatás */
  color: var(--accent);
  font-weight: 700;
  display: inline-block;
}

/* értékek: világos szürke */
.card ul.list-unstyled li {
  color: var(--text);
  font-size: .95rem;
}

/* linkek (email, telefon) jobban kiemelve */
.card ul.list-unstyled a {
  color: var(--accent);
  font-weight: 600;
  text-decoration: none;
}
.card ul.list-unstyled a:hover {
  text-decoration: underline;
  color: var(--accent-dark);
}

/* kártya finom extra */
.card {
  position: relative;
  overflow: hidden;
}
.card::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background: linear-gradient(145deg, rgba(255,122,0,.08), transparent 70%);
  pointer-events: none;
}
/* kártya finom extra */
.card {
  position: relative;
  overflow: hidden;
}
.card::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background: linear-gradient(145deg, rgba(255,122,0,.08), transparent 70%);
  pointer-events: none;
}
.seg-badges{
  display:flex; flex-wrap:wrap; gap:.5rem;
  justify-content:center;       /* <-- középre */
}.badge-pill{
  background: var(--accent); color:#000; font-weight:800;
  padding:.45rem .8rem; border-radius:999px; font-size:.95rem;
  border:2px solid var(--accent); box-shadow:0 4px 14px var(--accent-15);
}
.badge-pill.badge-soft{
  background: transparent; color: var(--accent);
  border-color: var(--accent); box-shadow:none;
}

.illus-note {
  font-size: 0.75rem;       /* nagyon kicsi */
  color: rgba(255,255,255,.35); /* halvány */
  text-align: center;
  margin-top: .5rem;
}

/* emailek ne lógjanak ki */
a[href^="mailto:"],
footer a[href^="mailto:"],
.card ul.list-unstyled a[href^="mailto:"]{
  display:inline-block;
  max-width:100%;
  overflow-wrap:anywhere;   /* modern, legszebb */
  word-break:break-word;    /* fallback */
  line-height:1.3;
}
@media (max-width: 640px){
  .table-legal tbody td,
  .table-legal tbody th,
  .table-legal [data-label],
  .table-legal a {
    overflow-wrap:anywhere;
    word-break:break-word;
  }
}
