:root{
  --bg: #0b1020;
  --card: rgba(255,255,255,0.08);
  --muted: #9aa4b2;
  --brand: #60a5fa;
  --brand-2: #a78bfa;
  --text: #e5e7eb;
  --accent: #22d3ee;
  --ring: rgba(96,165,250,.5);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;height:100%;scroll-behavior:smooth}
body {
  font-family: Inter, -apple-system, BlinkMacSystemFont, Segoe UI, Roboto, Helvetica, Arial, sans-serif;
  color: var(--text);

  /* Egységes, selymes gradient háttér */
  background: radial-gradient(1800px 1200px at 50% 20%, #0c1635 0%, #0a1b3a 40%, #0b1020 100%) fixed;
  background-attachment: fixed;
  background-repeat: no-repeat;
  background-size: cover;
  
  line-height: 1.49;
}
.container{width:100%;max-width:1200px;margin:0 auto;padding:0 20px}
.nav{
  position:sticky; top:0; z-index:50;
  backdrop-filter: blur(10px);
  background: rgba(12, 17, 35, 0.6);
  border-bottom: 1px solid rgba(255,255,255,.08);
}
.nav-inner{display:flex;align-items:center;justify-content:space-between;padding:14px 0}
.brand{display:flex;align-items:center;gap:12px;text-decoration:none;color:var(--text)}
.brand img{height:70px;width:auto}
.brand span{font-weight:700;letter-spacing:.4px}
.menu{display:flex;gap:18px;align-items:center}
.menu a{
  text-decoration:none;color:var(--text);opacity:.9;padding:8px 12px;border-radius:12px;
}
.menu a:hover, .menu a.active{background:var(--card)}
.btn{
  display:inline-flex;align-items:center;justify-content:center;
  padding:12px 18px;border-radius:14px;
  color:#0b1020; background: linear-gradient(135deg, var(--brand), var(--brand-2));
  text-decoration:none;font-weight:600;box-shadow: 0 10px 30px rgba(96,165,250,.25);
  border:0; cursor:pointer;
}
.btn:hover{transform:translateY(-1px)}
.hero{
  position:relative; padding:100px 0 60px; overflow:hidden;
}
.hero-grid{display:grid;grid-template-columns:1.15fr 0.85fr;gap:32px;align-items:center}
h1{
  font-size:clamp(34px, 6vw, 64px);line-height:1.05;margin:0 0 16px;
  letter-spacing:-.02em;
}
.lead{font-size:clamp(16px,2.4vw,20px);color:var(--muted);margin:0 0 26px}
.kickers{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:18px}
.kicker{
  font-size:12px; letter-spacing:.12em; text-transform:uppercase; color:#a3b2c2;
  background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.08);
  padding:6px 10px; border-radius:999px;
}
.hero-card{
  background: linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.04));
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 22px; padding:22px; display:grid; gap:12px;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.08), 0 10px 30px rgba(0,0,0,.25);
  padding-bottom: 28px;
}
.hero-card img{width:100%;height:auto;border-radius:16px;border:1px solid rgba(255,255,255,.12)}
.pills{display:flex; gap:10px; flex-wrap:wrap}
.pill{background:rgba(34,211,238,.1); border:1px solid rgba(34,211,238,.35); color:#c3f0ff; padding:8px 12px; border-radius:999px; font-size:13px}
.section{padding:70px 0;border-top:1px solid rgba(255,255,255,.06)}
.section h2{font-size:clamp(26px,4.5vw,40px);margin:0 0 14px}
.section p.lead{margin-bottom:32px}
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.card{
  background:var(--card);border:1px solid rgba(255,255,255,.08);border-radius:18px;padding:22px
}
.card h3{margin:0 0 8px}
.grid-portfolio{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.grid-portfolio img{width:100%;height:auto;border-radius:14px;border:1px solid rgba(255,255,255,.12)}
.badge{font-size:16px;color:#9bd7ff}
blockquote{
  margin:0;padding:18px 18px 18px 22px;border-left:3px solid var(--brand);
  background:rgba(255,255,255,.05);border-radius:10px
}
.form{
  background:linear-gradient(180deg, rgba(255,255,255,.07), rgba(255,255,255,.04));
  border:1px solid rgba(255,255,255,.12);border-radius:18px;padding:20px
}
.input{
  width:100%;padding:14px 14px;border-radius:12px;background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.14);color:var(--text);outline:none
}
.input:focus{border-color:var(--ring);box-shadow:0 0 0 4px var(--ring)}
label{display:block;margin:10px 0 6px;color:#b8c1cc;font-weight:500}
footer{
  padding:40px 0;color:#a3b2c2;
  background: linear-gradient(to top, rgba(255,255,255,0.03), transparent);
  border-top: 1px solid rgba(255,255,255,0.05);
}
small.muted{color:#7f8b98}
.cta-row{display:flex;gap:12px;flex-wrap:wrap}
hr.sep{border:0;border-top:1px solid rgba(255,255,255,.08);margin:22px 0}
@media (max-width: 960px){
  .hero-grid{grid-template-columns:1fr}
  .cards, .grid-portfolio{grid-template-columns:1fr 1fr}
}
@media (max-width: 640px){
  .cards, .grid-portfolio {
    grid-template-columns: 1fr;
  }

  /* Menü kisebb képernyőn – ne tűnjön el, csak zsugorodjon */
  .menu {
    gap: 10px;
  }

  .menu a {
    font-size: 14px;
    padding: 6px 8px;
  }

  .brand img {
    height: 48px;  /* kisebb logó */
  }

  .nav-inner {
    flex-wrap: wrap;              /* ha nem fér el, sorba törik */
    justify-content: center;      /* középre igazítás */
    gap: 8px;
  }

  /* 🔹 Mobil margó beállítás */
  .container {
    padding-left: 16px;
    padding-right: 16px;
  }

  section, .hero, footer {
    padding-left: 24px;
    padding-right: 24px;
  }
}
.btn {
  box-shadow: 0 0 20px rgba(96,165,250,0.35);
  transition: all 0.3s ease;
}
.btn:hover {
  transform: translateY(-2px);
  box-shadow: 0 0 25px rgba(96,165,250,0.6);
}

/* ===== Finom animációk, egységes időzítéssel ===== */
:root{
  --easing: cubic-bezier(.22,.61,.36,1);
  --t-fast: .18s;
  --t-med:  .35s;
}

/* CTA gomb – enyhe pulzáló fény + hover emelés */
.btn{
  transform: translateZ(0);
  transition: transform var(--t-fast) var(--easing), box-shadow var(--t-med) var(--easing), filter var(--t-med);
  box-shadow: 0 8px 24px rgba(96,165,250,.18);
}
.btn:hover{
  transform: translateY(-2px);
  box-shadow: 0 14px 36px rgba(96,165,250,.32);
  filter: saturate(1.06);
}

/* Linkek – lágy, „felnövő” aláhúzás */
.menu a{
  position: relative;
  overflow: hidden;
}
.menu a::after{
  content:"";
  position:absolute; left:12px; right:12px; bottom:6px; height:2px;
  background: linear-gradient(90deg, var(--brand), var(--brand-2));
  transform: scaleX(0);
  transform-origin: left;
  transition: transform var(--t-med) var(--easing);
  border-radius: 2px;
  opacity:.9;
}
.menu a:hover::after, .menu a.active::after{ transform: scaleX(1); }

/* Kártyák – finom „lift” + fény */
.card, .hero-card{
  transition: transform var(--t-med) var(--easing), box-shadow var(--t-med) var(--easing), border-color var(--t-med);
  will-change: transform;
}
.card:hover, .hero-card:hover{
  transform: translateY(-4px);
  box-shadow: 0 18px 40px rgba(0,0,0,.28);
  border-color: rgba(255,255,255,.16);
}

/* Hero kép – nagyon enyhe lebegés */
.hero-card img{
  animation: floaty 8s var(--easing) infinite alternate;
  will-change: transform;
}
@keyframes floaty{
  from{ transform: translateY(0) scale(1.00); }
  to  { transform: translateY(-4px) scale(1.01); }
}

/* Scroll-reveal: sima felúszás és halvány beúszás */
.reveal{ opacity:0; transform: translateY(14px); transition: opacity .6s var(--easing), transform .6s var(--easing); }
.reveal.in{ opacity:1; transform: translateY(0); }

/* Preferált csökkentett mozgás – kímélő mód */
@media (prefers-reduced-motion: reduce){
  .btn, .card, .hero-card, .menu a::after, .hero-card img{ transition: none !important; animation: none !important; }
  .reveal{ opacity:1 !important; transform:none !important; }
}
textarea {
  resize: vertical;
}
.form-toast{
  position: fixed;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  pointer-events: none;
  opacity: 0;
  transform: translateY(8px);
  transition: opacity .25s cubic-bezier(.22,.61,.36,1),
              transform .25s cubic-bezier(.22,.61,.36,1);
  z-index: 100;
  background: radial-gradient(600px 400px at center, rgba(15,23,42,.8), rgba(15,23,42,.4));
}

.form-toast-inner{
  background: linear-gradient(180deg, rgba(30,64,175,.85), rgba(15,23,42,.95));
  border-radius: 20px;
  border: 1px solid rgba(191,219,254,.35);
  box-shadow: 0 22px 60px rgba(0,0,0,.6);
  padding: 24px 24px 20px;
  max-width: 420px;
  width: calc(100% - 40px);
  text-align: left;
}

.form-toast-inner h3{
  margin: 0 0 8px;
  font-size: 20px;
}

.form-toast-inner p{
  margin: 0 0 18px;
  color: var(--muted);
}

/* Popup látható állapotban */
.form-toast.show{
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}

/* Halványabb, „üveges” gomb a bezáráshoz */
.btn.btn-ghost{
  background: transparent;
  color: var(--text);
  border: 1px solid rgba(148,163,184,.7);
  box-shadow: none;
  padding-inline: 14px;
}
.btn.btn-ghost:hover{
  background: rgba(15,23,42,.9);
  border-color: rgba(191,219,254,.9);
}
