/* Product card fixes: white bg, no underline */
.product-card {
  background: #20487a !important; /* sötétebb, mint --bg */
  color: #fff !important;
  text-decoration: none !important;
  border: 1px solid var(--border);
  border-radius: 16px;
  padding: 16px;
  transition: transform .15s ease, background .2s ease, box-shadow .2s ease;
  display: block;
}
.product-card:hover {
  background: #18345a !important; /* még sötétebb hover */
  color: #fff !important;
  text-decoration: none !important;
  box-shadow: 0 6px 20px rgba(0,0,0,.10);
}
.product-card h3, .product-card .price {
  color: #fff !important;
}
:root{
  --bg:#2b5ea7; /* sötétebb kék háttér */
  --text:#ffffff;
  --muted:#eaf4ff;
  --card: rgba(255,255,255,0.12);
  --card-hover: rgba(255,255,255,0.18);
  --btn: rgba(255,255,255,0.18);
  --btn-hover: rgba(255,255,255,0.28);
  --border: rgba(255,255,255,0.25);
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family: ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,Cantarell,Noto Sans,Helvetica,Arial,sans-serif;
  color:var(--text);
  background:var(--bg);
}

/* Animációk */
@keyframes fadeUp{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
.fade-up{ animation: fadeUp .6s ease both; }

.container{ max-width: 1100px; margin: 0 auto; padding: 24px; }

/* Nav + hamburger */
.nav{ padding:16px 0; border-bottom:1px solid var(--border); }
.hamburger{
  display:none;
  font-size:22px; line-height:1;
  padding:8px 12px; border-radius:10px; border:1px solid var(--border);
  background:var(--btn); color:var(--text);
}
.menu{ display:flex; gap:14px; align-items:center; justify-content:center; flex-wrap:wrap; }
.menu a{ color:var(--text); text-decoration:none; padding:8px 12px; border-radius:10px; background:var(--btn); transition: transform .15s ease, background .2s ease; }
.menu a:hover{ background:var(--btn-hover); transform: translateY(-1px); }

@media (max-width: 768px){
  .nav{ display:flex; gap:10px; justify-content:space-between; align-items:center; padding:12px 16px; }
  .hamburger{ display:inline-block; margin-left:6px; }
  .menu{ display:none; flex-direction:column; align-items:stretch; gap:8px; padding:10px; border:1px solid var(--border); border-radius:12px; background: rgba(255,255,255,0.10); }
  .menu.open{ display:flex; }
}

/* Hero & grid */
.hero{ text-align:center; padding:32px 0 8px; }
.hero h1{ margin:0 0 8px; font-size: 36px; letter-spacing: .3px; }
.hero p{ margin:0; color:var(--muted) }
.grid{ display:grid; grid-template-columns: repeat(auto-fill,minmax(240px,1fr)); gap:14px; margin-top:18px; }
.card{ background: var(--card); border:1px solid var(--border); border-radius:16px; padding:16px; transition: transform .15s ease, background .2s ease, box-shadow .2s ease; }
.card:hover{ background:var(--card-hover); transform: translateY(-2px); box-shadow:0 6px 20px rgba(0,0,0,.15); }
.card h3{ margin:0 0 6px; font-size:18px }
.card .price{ opacity:.95; font-weight:600; }

.btn{ display:inline-block; color:var(--text); text-decoration:none; padding:10px 14px; border-radius:12px; background:var(--btn); border:1px solid var(--border); transition: transform .15s ease, background .2s ease, box-shadow .2s ease; }
.btn:hover{ background:var(--btn-hover); transform: translateY(-1px); box-shadow:0 8px 20px rgba(0,0,0,.12); }

/* Forms */
.form{ display:grid; gap:10px; margin-top:8px; }
input,button{ font:inherit; }
input[type=text], input[type=email], input[type=tel]{
  width:100%; padding:10px 12px; border-radius:12px; border:1px solid var(--border);
  background: rgba(255,255,255,0.12); color:var(--text);
}
label{ font-size:14px; color:#f8fbff; }
.small{ font-size:12px; color:var(--muted); }

/* Phone input combo */
.phone-input{ display:flex; align-items:center; gap:8px; }
.phone-input .prefix{
  padding:10px 12px; border:1px solid var(--border);
  background: rgba(255,255,255,0.12);
  color:var(--text);
  border-radius:12px;
  font-variant-numeric: tabular-nums;
}

/* Reviews */
.reviews{ display:grid; gap:14px; }
.review{ background:var(--card); border:1px solid var(--border); border-radius:14px; padding:14px; }
.stars{ color:#FFD54F; letter-spacing:2px; font-size:20px; text-shadow: 0 1px 0 rgba(0,0,0,.3), 0 2px 6px rgba(0,0,0,.25); }

/* Flash */
@keyframes fadeOut{ from{opacity:1} to{opacity:0; height:0; margin:0; padding-top:0; padding-bottom:0} }
.flash-hide{ animation: fadeOut .6s ease forwards; }

footer{ text-align:center; padding:32px 0; color:var(--muted); }
