:root{
  --navy:#1A1C2E;
  --navy-900:#131525;
  --gold:#C8A14A;
  --gold-700:#B38E3D;
  --beige:#FFF3DE;
  --white:#ffffff;
  /* dopočítaš v JS podľa výšky topbaru, default 0 */
  --topbar-h: 0px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:'Poppins',sans-serif;
  font-size:16px;
  line-height:1.5;
  color:var(--beige);
  background:#0f111a;
  padding-top:0;
}

/* ===== TOPBAR ===== */
.topbar{position:fixed;inset:0 0 auto 0;z-index:1000;
  background:linear-gradient(180deg,var(--gold),var(--gold-700));
  color:var(--navy);border-bottom:1px solid rgba(0,0,0,.08)}
.topbar__inner{max-width:1200px;margin:0 auto;padding:6px 20px;display:flex;align-items:center;justify-content:space-between;gap:12px}
.topbar__left,.topbar__right{display:flex;align-items:center;gap:18px}
.contact{display:inline-flex;align-items:center;gap:8px;color:var(--navy);text-decoration:none;font-weight:700;letter-spacing:.02em}
.contact svg{width:18px;height:18px;fill:var(--navy)}
.social{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:8px;background:rgba(26,28,46,.08);text-decoration:none}
.social:hover{background:rgba(26,28,46,.18)}
.social svg{width:16px;height:16px;fill:var(--navy)}
@media (max-width:720px){.contact span{display:none}.topbar__inner{padding:6px 12px}}

/* ===== HEADER ===== */
.site-header{
  position:fixed;left:0;right:0;top:var(--topbar-h);
  z-index:999;background:var(--navy);
  border-bottom:1px solid rgba(255,255,255,.06);
  backdrop-filter:saturate(120%) blur(4px);
  transition:background .25s ease,box-shadow .25s ease;
}
.site-header.scrolled{background:var(--navy-900);box-shadow:0 6px 20px rgba(0,0,0,.25)}

.nav{max-width:1200px;margin:0 auto;padding:14px 20px;display:flex;align-items:center;justify-content:space-between;gap:16px}

/* Logo */
.brand{display:flex;align-items:center;gap:12px;text-decoration:none;color:var(--beige)}
.brand .mark{width:36px;height:36px;display:block;flex:0 0 auto}

/* Desktop menu */
.nav-links{display:flex;gap:28px;align-items:center;list-style:none;margin:0;padding:0}
.nav-links a{text-decoration:none;color:var(--beige);font-weight:600;padding:8px 2px;border-bottom:2px solid transparent;transition:border-color .2s ease,color .2s ease}
.nav-links a:hover,.nav-links a:focus{color:var(--white);border-color:var(--gold);outline:none}

/* Hamburger */
.nav-toggle{
  appearance:none;-webkit-appearance:none;background:transparent;border:0;padding:8px;line-height:0;
  display:grid;place-items:center;cursor:pointer;position:relative;z-index:1200;outline:none
}
.nav-toggle:focus-visible{outline:2px solid #fff4;outline-offset:2px}
.nav-toggle svg{width:28px;height:28px;display:block;stroke:#fff}
@media (min-width:769px){.nav-toggle{display:none}}  /* ← FIX: uzavreté media query */

/* --- Mobil: pravý off-canvas panel --- */
@media (max-width:768px){
  .nav{position:relative}
  .brand img{max-width:140px !important}

  .nav-links{
    position:fixed;
    top:calc(var(--topbar-h) + 64px);        /* 64px ≈ výška headera */
    right:0;
    width:78vw;max-width:360px;
    height:calc(100vh - (var(--topbar-h) + 64px));
    padding:2rem 1.5rem;
    background:#151826;
    box-shadow:-12px 0 24px rgba(0,0,0,.35);
    display:flex;flex-direction:column;align-items:flex-start;gap:1.25rem;
    transform:translateX(100%);              /* skryté vpravo */
    transition:transform .28s ease-in-out;
    z-index:1100;
  }
  .nav.is-open .nav-links{transform:translateX(0)}  /* JS prepína .nav.is-open */

  .nav-links li{width:100%}
  .nav-links a{display:block;font-size:1.2rem;font-weight:700;padding:.5rem 0;text-decoration:none}
}

/* nelám „O nás“ */
.nav-links a,.nav-links a *{white-space:nowrap}

/* HERO / DEMO SEKCIE */
.hero{width:100%;max-width:none;margin:0;padding:0;position:relative;min-height:calc(100vh - var(--topbar-h) - 80px);display:flex;align-items:center;background-image:url('./bg.png') !important;background-position:center;background-size:cover;background-repeat:no-repeat}
.hero::before{content:"";position:absolute;inset:0;background:rgba(0,0,0,.45);z-index:0}
.hero__inner{max-width:1200px;margin:0 auto;padding:60px 20px;position:relative;z-index:1;display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:center}
.hero__text h1{font-size:clamp(2rem,5vw,3.5rem);font-weight:700;color:var(--beige);margin-bottom:20px;line-height:1.2}
.hero__text h1 span{color:var(--gold)}
.hero__text p{font-size:1.1rem;max-width:500px;margin-bottom:30px;color:#ddd}
.cta-btn{display:inline-block;padding:14px 26px;font-weight:600;font-size:1rem;color:var(--navy);background:linear-gradient(180deg,var(--gold),var(--gold-700));border-radius:8px;text-decoration:none;transition:transform .25s ease,box-shadow .25s ease}
.cta-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(0,0,0,.3)}
@media (max-width:900px){
  .hero__inner{grid-template-columns:1fr;text-align:center}
  .hero__text p{margin-left:auto;margin-right:auto}
}

/* Sekcie */
section{max-width:1100px;margin:0 auto;padding:96px 20px;color:#EAEAF0}
section:nth-of-type(odd){background:#0f111a}
section:nth-of-type(even){background:#121423}

/* z-index vrstvy */
.topbar{z-index:1000}
.site-header{z-index:999}


@media (max-width: 768px) {
  .nav-links {
    position: fixed;
    top: 114px; /* prispôsob podľa výšky topbaru + headera */
    right: 0;
    width: 78vw;
    max-width: 360px;
    height: calc(100vh - 114px);
    padding: 2rem 1.5rem;
    background: #151826;
    box-shadow: -12px 0 24px rgba(0,0,0,.35);
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 1.25rem;
    transform: translateX(100%); /* skryté */
    transition: transform .28s ease-in-out;
    z-index: 1100;
  }

  /* keď JS pridá .is-open na .nav → vysuň menu */
  .nav.is-open .nav-links {
    transform: translateX(0);
  }

  .nav-links li {
    width: 100%;
  }
  .nav-links a {
    display: block;
    font-size: 1.2rem;
    font-weight: 700;
    white-space: nowrap;
    padding: .5rem 0;
  }
}

/* ===== ABOUT (O nás) – Advokát 2.0 ===== */
.about{
  position: relative;
  isolation: isolate;
  padding: 120px 20px;
  background: radial-gradient(1200px 600px at 15% 10%, rgba(200,161,74,.08) 0%, rgba(0,0,0,0) 55%),
              radial-gradient(900px 500px at 85% 20%, rgba(200,161,74,.06) 0%, rgba(0,0,0,0) 60%),
              #0f111a;
}
.about::before{
  content:"";
  position:absolute; inset:0; z-index:-1;
  background:
    linear-gradient(120deg, rgba(255,255,255,.06) 1px, transparent 1px) 0 0/28px 28px,
    linear-gradient(0deg,   rgba(255,255,255,.03) 1px, transparent 1px) 0 0/28px 28px;
  mask: radial-gradient(900px 480px at 50% 0%, #000 20%, transparent 70%);
  opacity:.35;
}
.about__inner{
  max-width:1200px; margin:0 auto;
  display:grid; grid-template-columns: 1fr 1.1fr; gap:56px; align-items:center;
}

/* photo card with shine/glow */
.about__photo{
  position:relative; margin:0; border-radius:18px; overflow:hidden;
  background:#11131e; border:1px solid rgba(255,255,255,.08);
  box-shadow:0 20px 50px rgba(0,0,0,.45), 0 0 0 1px rgba(200,161,74,.15) inset;
  transform:translateZ(0);
}
.about__photo img{
  display:block; width:100%; height:auto; aspect-ratio:3/4; object-fit:cover;
  filter:saturate(.85) contrast(1.05);
  transition:transform .6s cubic-bezier(.2,.7,.2,1);
}
.about__photo::after{
  /* zlatý okrajový glow */
  content:""; position:absolute; inset:-1px;
  background: linear-gradient(180deg, rgba(200,161,74,.35), rgba(200,161,74,0) 40%);
  mix-blend-mode:screen; pointer-events:none;
}
.about__photo::before{
  /* shine pri hover */
  content:""; position:absolute; inset:-40% -60%;
  background: linear-gradient(115deg, rgba(255,255,255,.0) 40%, rgba(255,255,255,.25) 50%, rgba(255,255,255,.0) 60%);
  transform: translateX(-80%);
  transition: transform .8s ease;
}
.about__photo:hover::before{ transform: translateX(40%); }
.about__photo:hover img{ transform: scale(1.04); }
.about__photo figcaption{
  position:absolute; left:14px; bottom:12px; padding:6px 10px;
  background:rgba(26,28,46,.7); border:1px solid rgba(255,255,255,.08);
  color:var(--beige); font-weight:600; border-radius:10px; font-size:.8rem; letter-spacing:.04em;
}

/* content */
.about__content h2{
  font-size: clamp(1.8rem, 2.6vw, 2.6rem);
  margin:0 0 12px 0; color:var(--beige); line-height:1.15;
}
.about__content h2 span{ color: var(--gold); }
.about__content .lead{
  color:#E8E6F0; opacity:.9; font-size:1.05rem; margin:0 0 18px 0;
}

/* badges (chips) */
.badges{ display:flex; flex-wrap:wrap; gap:10px 12px; list-style:none; padding:0; margin:0 0 18px 0; }
.badges li{
  padding:8px 12px; border-radius:999px; font-weight:600; letter-spacing:.02em;
  background: rgba(200,161,74,.12); color:var(--beige);
  border:1px solid rgba(200,161,74,.28);
  transition: transform .2s ease, background .2s ease, border-color .2s ease;
}
.badges li:hover{ transform: translateY(-2px); background:rgba(200,161,74,.18); border-color:rgba(200,161,74,.45); }

/* bio text */
.bio p{ margin:.35rem 0; color:#d9d7e1; }

/* stats */
.stats{ display:flex; gap:22px; margin:22px 0 10px 0; flex-wrap:wrap; }
.stat{ padding:14px 16px; border-radius:14px; border:1px solid rgba(255,255,255,.08);
       background:linear-gradient(180deg, rgba(255,255,255,.04), rgba(0,0,0,0));
       min-width:150px; transition: transform .25s ease, box-shadow .25s ease; }
.stat:hover{ transform:translateY(-3px); box-shadow:0 10px 26px rgba(0,0,0,.35); }
.stat__num{ font-weight:800; font-size:1.6rem; color:var(--gold); line-height:1; }
.stat__label{ font-size:.9rem; color:#cfcbdc; opacity:.9; }

/* CTA */
.about__cta{ display:flex; align-items:center; gap:16px; margin-top:14px; }
.btn-gold{
  display:inline-block; padding:12px 18px; font-weight:700; color:#11131e;
  background:linear-gradient(180deg, var(--gold), var(--gold-700));
  border-radius:10px; text-decoration:none;
  transition: transform .2s ease, box-shadow .25s ease;
}
.btn-gold:hover{ transform:translateY(-2px); box-shadow:0 10px 24px rgba(0,0,0,.35); }
.link-ghost{
  color:var(--beige); text-decoration:none; font-weight:600; position:relative;
}
.link-ghost::after{
  content:""; position:absolute; left:0; right:0; bottom:-3px; height:2px;
  background:linear-gradient(90deg, var(--gold), transparent 60%);
  transform:scaleX(0); transform-origin:left; transition:transform .25s ease;
}
.link-ghost:hover::after{ transform:scaleX(1); }

.note{ display:block; color:#9b97ab; margin-top:8px; }

/* responsive */
@media (max-width: 980px){
  .about__inner{ grid-template-columns:1fr; gap:32px; }
  .about__photo{ order:2; }
  .about__content{ order:1; }
}
/* === Širší layout === */
:root{
  --container: 1320px;   /* skús 1320, alebo 1440 ak chceš ešte viac */
  --gutter: 24px;        /* vnútorné okraje */
}

/* zvýš max-width na všetkých hlavných wrapoch */
@media (min-width: 1200px){
  .topbar__inner,
  .nav,
  .hero__inner,
  .about__inner{
    max-width: var(--container);
    padding-left: var(--gutter);
    padding-right: var(--gutter);
  }
  /* sekcie mali 1100px – zväčšíme */
  section{
    max-width: var(--container);
    padding-left: var(--gutter);
    padding-right: var(--gutter);
  }
}

/* voliteľné: extra wide na 1536+ displejoch */
@media (min-width: 1536px){
  :root{ --container: 1440px; }  /* pokojne 1600, ak chceš veľmi široké */
}

/* ===== SLUŽBY ===== */
.services{
  position:relative; isolation:isolate;
  padding: 120px 20px;
  background:
    radial-gradient(1200px 600px at 90% 10%, rgba(200,161,74,.07) 0, transparent 60%),
    linear-gradient(180deg, #121423, #0f111a);
}
.services__head{
  max-width: var(--container);
  margin: 0 auto 32px;
  padding: 0 var(--gutter);
}
.services__head h2{
  font-size: clamp(1.8rem, 2.6vw, 2.6rem);
  margin: 0 0 8px; color: var(--beige);
}
.services__head h2 span{ color: var(--gold); }
.services__head p{ color:#d9d7e1; opacity:.9; margin:0 }

.services__grid{
  max-width: var(--container);
  margin: 28px auto 0;
  padding: 0 var(--gutter);
  display:grid;
  grid-template-columns: repeat(12, 1fr);
  gap: 22px;
}
.svc{
  grid-column: span 6;   /* 2 v riadku na desktop */
  background: linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.02));
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 18px;
  padding: 20px 20px 18px;
  box-shadow: 0 10px 30px rgba(0,0,0,.25);
  transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease;
  will-change: transform;
  perspective: 800px;
}
.svc:hover{
  transform: translateY(-4px);
  box-shadow: 0 22px 48px rgba(0,0,0,.35);
  border-color: rgba(200,161,74,.35);
}
.svc__icon{
  width:48px;height:48px;border-radius:12px;
  display:grid;place-items:center;
  background: rgba(200,161,74,.15);
  border:1px solid rgba(200,161,74,.35);
  font-size:24px;color:var(--beige);
  margin-bottom:12px;
}
.svc h3{
  margin:0 0 6px;color:var(--beige);font-size:1.35rem;
}
.svc__lead{ margin:0 0 10px; color:#cfcbdc; }
.svc__list{ margin:0 0 12px 0; padding-left:18px; color:#ddd; }
.svc__list li{ margin:4px 0; }

.svc__cta{ display:flex; gap:12px; align-items:center; }
.svc__more{ background:none; border:0; padding:0; cursor:pointer; }

.svc__morebox{
  margin-top:10px; padding:10px 12px;
  border:1px dashed rgba(200,161,74,.35);
  border-radius:12px; color:#d9d7e1; background:rgba(255,255,255,.03);
}

.services .badge{
  display:inline-flex; align-items:center; justify-content:center;
  width:42px; height:28px; border-radius:999px; font-weight:800; color:#11131e;
  background:linear-gradient(180deg, var(--gold), var(--gold-700));
  margin-right:8px;
}
.services__note{
  max-width: var(--container);
  padding: 14px var(--gutter) 0;
  margin: 8px auto 0;
  color:#cfcbdc;
}

/* responzívne */
@media (max-width: 980px){
  .svc{ grid-column: span 12; } /* 1 v riadku na mobile */
}
/* ===== TESTIMONIALS ===== */
.testimonials{
  position:relative; isolation:isolate;
  padding: 120px 20px;
  background:
    radial-gradient(1100px 600px at 15% 20%, rgba(200,161,74,.07) 0, transparent 60%),
    linear-gradient(180deg, #0f111a, #121423);
}
.testi__head{
  max-width: var(--container);
  margin: 0 auto 26px;
  padding: 0 var(--gutter);
}
.testi__head h2{
  font-size: clamp(1.8rem, 2.6vw, 2.6rem);
  margin:0 0 8px; color: var(--beige);
}
.testi__head h2 span{ color: var(--gold); }
.testi__head p{ color:#d9d7e1; opacity:.9; margin:0 }

.testi__grid{
  max-width: var(--container);
  margin: 20px auto 0; padding: 0 var(--gutter);
  display: grid; grid-template-columns: repeat(12,1fr); gap: 22px;
  scroll-snap-type: x mandatory; overflow-x: auto; -webkit-overflow-scrolling: touch;
}
.testi{
  grid-column: span 6;
  background: linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.02));
  border:1px solid rgba(255,255,255,.08);
  border-radius:18px;
  padding:20px;
  box-shadow:0 12px 30px rgba(0,0,0,.25);
  transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease;
  position:relative;
  scroll-snap-align: start;
}
.testi:hover{
  transform: translateY(-4px);
  border-color: rgba(200,161,74,.35);
  box-shadow: 0 22px 50px rgba(0,0,0,.35);
}
.testi__stars{
  display:flex; gap:6px; margin-bottom:10px;
}
.testi__stars svg{ width:18px; height:18px; fill: var(--gold); opacity:.95 }
.testi__quote{
  margin:0 0 14px 0; color:#e9e7f1; font-size:1.05rem;
}
.testi__meta{ display:flex; align-items:center; gap:12px; }
.avatar{ width:40px; height:40px; border-radius:50%; border:1px solid rgba(255,255,255,.18) }
.testi__name{ font-weight:700; color:var(--beige); line-height:1 }
.testi__role{ font-size:.9rem; color:#cfcbdc; opacity:.9 }

.testi__note{
  max-width: var(--container);
  margin: 10px auto 0;
  padding: 12px var(--gutter) 0;
  color:#cfcbdc;
}
.testimonials .badge{
  display:inline-flex; align-items:center; justify-content:center;
  width:56px; height:28px; border-radius:999px; font-weight:800; color:#11131e;
  background:linear-gradient(180deg, var(--gold), var(--gold-700));
  margin-right:8px;
}

/* 1 v riadku na mobile */
@media (max-width: 980px){
  .testi{ grid-column: span 12; }
}
.kontakt-section {
  padding: 80px 20px;
  background: #0e0e15;
  color: #fff;
}

.kontakt-section h2 {
  text-align: center;
  font-size: 2.5rem;
  color: #C89943;
  margin-bottom: 10px;
}

.kontakt-section .subtitle {
  text-align: center;
  margin-bottom: 50px;
  font-size: 1.1rem;
  color: #ccc;
}

.kontakt-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 40px;
  align-items: start;
}

.kontakt-info p, .kontakt-info a {
  font-size: 1rem;
  color: #fff;
  margin-bottom: 8px;
}

.kontakt-info a:hover {
  color: #C89943;
}

.social-links a {
  display: inline-block;
  margin-right: 15px;
  color: #C89943;
  text-decoration: none;
  font-weight: bold;
}

.kontakt-form {
  display: flex;
  flex-direction: column;
}

.kontakt-form input,
.kontakt-form textarea {
  padding: 12px;
  margin-bottom: 15px;
  border: 1px solid #444;
  border-radius: 6px;
  background: #1b1b27;
  color: #fff;
}

.kontakt-form input:focus,
.kontakt-form textarea:focus {
  outline: none;
  border-color: #C89943;
}

.kontakt-form button {
  padding: 12px;
  background: #C89943;
  border: none;
  color: #0e0e15;
  font-weight: bold;
  border-radius: 6px;
  cursor: pointer;
  transition: background 0.3s ease;
}

.kontakt-form button:hover {
  background: #a87b33;
}

.mapa {
  margin-top: 40px;
}

@media (max-width: 768px) {
  .kontakt-grid {
    grid-template-columns: 1fr;
  }
}
