/* ============================================================
   KONTAKT — samostatná stránka
   ============================================================ */

/* Hero */
.kontakt-hero{
  background:#1a1216;
  color:var(--paper);position:relative;overflow:hidden;
  isolation:isolate;
}
.kontakt-hero::before{
  content:"";position:absolute;inset:0;z-index:-2;
  background:#1a1216 url('./assets/contact-hero-bg.png') bottom right/cover no-repeat;
}
/* Top fade so the nav stays legible on the pink */
.kontakt-hero::after{
  content:"";position:absolute;left:0;right:0;top:0;height:240px;z-index:-1;
  background:linear-gradient(to bottom, rgba(14,14,14,.55) 0%, rgba(14,14,14,.25) 45%, rgba(14,14,14,0) 100%);
  pointer-events:none;
}
.kontakt-hero__title{
  font-family:"Hubot Sans",sans-serif;font-weight:500;
  font-size:clamp(56px,7.2vw,128px);letter-spacing:-.025em;line-height:.95;
  margin:0;max-width:14ch;
  color:#fff;
  text-shadow:0 2px 30px rgba(60,18,28,.35);
}
.kontakt-hero__title em{
  font-style:italic;font-weight:300;color:#fff;opacity:.92;
  text-shadow:0 2px 30px rgba(60,18,28,.45);
}
.kontakt-hero__lede{
  margin-top:32px;max-width:46ch;
  font-size:20px;line-height:1.5;color:rgba(255,255,255,.92);
  text-shadow:0 1px 16px rgba(60,18,28,.35);
}

/* Persons */
.kontakt-persons{background:var(--ink);color:var(--paper)}
.kontakt-persons__head{margin-bottom:48px}
.kontakt-persons__grid{
  display:grid;grid-template-columns:repeat(2,1fr);gap:24px;
}
.kontakt-person{
  display:grid;grid-template-columns:160px 1fr;gap:28px;
  padding:28px;border-radius:20px;
  background:rgba(243,243,243,.04);border:1px solid var(--line);
  text-decoration:none;color:inherit;
  transition:transform .35s ease, border-color .35s ease, background .35s ease;
}
.kontakt-person:hover{transform:translateY(-4px);border-color:var(--coral);background:rgba(243,243,243,.06)}
.kontakt-person__photo{
  width:160px;height:160px;border-radius:16px;
  background:#222 center/cover no-repeat;border:2px solid var(--coral);
}
.kontakt-person__body{display:flex;flex-direction:column;gap:6px;justify-content:center;min-width:0}
.kontakt-person__role{
  font-size:11px;letter-spacing:.14em;color:var(--coral);text-transform:uppercase;
}
.kontakt-person__name{
  font-family:"Hubot Sans",sans-serif;font-weight:500;
  font-size:32px;letter-spacing:-.02em;line-height:1;margin-top:6px;color:var(--paper);
}
.kontakt-person__title{font-size:14px;color:var(--muted);margin-bottom:14px}
.kontakt-person__contact{
  display:flex;flex-direction:column;gap:6px;
  padding-top:14px;border-top:1px solid var(--line);
}
.kontakt-person__email{
  display:inline-flex;align-items:center;justify-content:space-between;gap:8px;
  font-family:"JetBrains Mono",monospace;font-size:13px;color:var(--coral);
}
.kontakt-person__arrow{transition:transform .25s ease}
.kontakt-person:hover .kontakt-person__arrow{transform:translate(2px,-2px)}
.kontakt-person__phone{
  font-family:"JetBrains Mono",monospace;font-size:13px;color:#cfcfcf;
  text-decoration:none;
}
.kontakt-person__phone:hover{color:var(--paper)}

/* Locations */
.kontakt-loc{background:#0a0a0a;color:var(--paper)}
.kontakt-loc__head{margin-bottom:48px}
.kontakt-loc__grid{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.kontakt-loc__card{
  display:flex;flex-direction:column;
  border-radius:20px;overflow:hidden;
  background:rgba(243,243,243,.03);border:1px solid var(--line);
}
.kontakt-loc__map{
  position:relative;aspect-ratio:16/10;background:#111;
}
.kontakt-loc__map-frame{
  position:absolute;inset:0;width:100%;height:100%;border:0;
  filter:invert(.92) hue-rotate(180deg) saturate(.55) brightness(.95) contrast(.95);
}
.kontakt-loc__map-overlay{
  position:absolute;inset:0;pointer-events:none;
  background:
    radial-gradient(ellipse at 50% 30%, rgba(247,63,0,.06), transparent 60%),
    linear-gradient(180deg, rgba(0,0,0,0) 60%, rgba(0,0,0,.45));
}
.kontakt-loc__map-cta{
  position:absolute;right:16px;bottom:16px;z-index:2;
  display:inline-flex;align-items:center;gap:6px;
  padding:9px 14px;border-radius:999px;
  background:rgba(14,14,14,.85);border:1px solid var(--line);backdrop-filter:blur(8px);
  color:var(--paper);text-decoration:none;
  font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:.06em;
  transition:background .25s ease, border-color .25s ease;
}
.kontakt-loc__map-cta:hover{background:var(--coral);color:var(--ink-2);border-color:var(--coral)}
.kontakt-loc__info{padding:32px 32px 36px;display:flex;flex-direction:column;gap:8px}
.kontakt-loc__note{
  font-size:11px;letter-spacing:.14em;color:var(--coral);text-transform:uppercase;
}
.kontakt-loc__city{
  font-family:"Hubot Sans",sans-serif;font-weight:500;
  font-size:56px;letter-spacing:-.025em;line-height:1;margin:6px 0 14px;
}
.kontakt-loc__addr{display:flex;flex-direction:column;gap:2px;font-style:normal;color:#dcdcdc;font-size:15px;line-height:1.5}
.kontakt-loc__legal{
  display:flex;flex-wrap:wrap;gap:16px;margin-top:16px;padding-top:16px;
  border-top:1px solid var(--line);
  font-family:"JetBrains Mono",monospace;font-size:11px;color:var(--muted);
}

/* FAQ — white card grid */
.kfaq{background:var(--paper);color:var(--ink-2);position:relative}
.kfaq::before{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:
    radial-gradient(circle at 12% 18%, rgba(247,63,0,.06), transparent 38%),
    radial-gradient(circle at 88% 82%, rgba(247,63,0,.05), transparent 42%);
}
.kfaq .shell{position:relative;z-index:1}
.kfaq__head{
  display:grid;grid-template-columns:1.1fr 1fr;gap:48px;align-items:end;
  margin-bottom:64px;
}
.eyebrow--dark{color:var(--ink-2)}
.eyebrow--dark::before{background:var(--ink-2)}
.kfaq__title{margin:0;color:var(--ink-2)}
.kfaq__title em{font-style:italic;font-weight:300;color:var(--coral)}
.kfaq__lede{
  font-size:18px;line-height:1.55;color:rgba(38,15,15,.72);
  max-width:42ch;margin:0;justify-self:end;
}

.kfaq__grid{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.kfaq__col{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:14px}

.kfaq__card{
  background:#fff;border:1px solid rgba(38,15,15,.08);
  border-radius:18px;
  box-shadow:0 1px 0 rgba(38,15,15,.04);
  transition:border-color .3s ease, box-shadow .3s ease, transform .3s ease;
  overflow:hidden;
}
.kfaq__card:hover{border-color:rgba(38,15,15,.18);box-shadow:0 12px 32px rgba(38,15,15,.06);transform:translateY(-1px)}
.kfaq__card.is-open{
  background:var(--ink);color:var(--paper);
  border-color:var(--ink);
  box-shadow:0 24px 60px rgba(38,15,15,.18);
  transform:translateY(-1px);
}

.kfaq__btn{
  width:100%;background:transparent;border:0;cursor:pointer;color:inherit;
  display:grid;grid-template-columns:auto 1fr auto;gap:18px;align-items:center;
  padding:22px 24px;text-align:left;
}
.kfaq__num{
  font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:.1em;
  color:rgba(38,15,15,.45);transition:color .3s ease;
}
.kfaq__card.is-open .kfaq__num{color:var(--coral)}
.kfaq__q{
  font-family:"Hubot Sans",sans-serif;font-weight:500;font-size:18px;
  letter-spacing:-.012em;line-height:1.3;color:inherit;
}
.kfaq__plus{
  width:32px;height:32px;border-radius:999px;
  background:rgba(38,15,15,.06);
  position:relative;flex-shrink:0;
  transition:background .3s ease, transform .35s cubic-bezier(.2,.7,.2,1);
}
.kfaq__card.is-open .kfaq__plus{background:var(--coral);transform:rotate(45deg)}
.kfaq__plus-h, .kfaq__plus-v{
  position:absolute;background:currentColor;
  left:50%;top:50%;transform:translate(-50%,-50%);
}
.kfaq__plus-h{width:12px;height:1.5px}
.kfaq__plus-v{width:1.5px;height:12px}
.kfaq__card.is-open .kfaq__plus-h, .kfaq__card.is-open .kfaq__plus-v{background:var(--ink-2)}

.kfaq__a-wrap{
  max-height:0;overflow:hidden;
  transition:max-height .45s cubic-bezier(.2,.7,.2,1);
}
.kfaq__card.is-open .kfaq__a-wrap{max-height:560px}
.kfaq__a-inner{
  opacity:0;transform:translateY(-6px);
  transition:opacity .35s ease .05s, transform .35s ease .05s;
}
.kfaq__card.is-open .kfaq__a-inner{opacity:1;transform:translateY(0)}
.kfaq__a-inner > p{
  margin:0;padding:0 24px 24px 64px;
  font-size:15px;line-height:1.65;color:rgba(243,243,243,.82);max-width:54ch;
}

.kfaq__foot{
  margin-top:48px;padding-top:32px;
  border-top:1px solid rgba(38,15,15,.1);
  display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:16px;
}
.kfaq__foot-kicker{font-size:12px;letter-spacing:.14em;color:rgba(38,15,15,.55);text-transform:uppercase}
.kfaq__foot-cta{
  display:inline-flex;align-items:center;gap:10px;
  padding:14px 22px;border-radius:999px;
  background:var(--ink);color:var(--paper);text-decoration:none;
  font-size:15px;font-weight:500;
  transition:background .25s ease, transform .25s ease;
}
.kfaq__foot-cta:hover{background:var(--coral);color:var(--ink-2);transform:translateY(-1px)}

@media (max-width:900px){
  .kfaq__head{grid-template-columns:1fr;gap:24px}
  .kfaq__lede{justify-self:start}
  .kfaq__grid{grid-template-columns:1fr}
  .kfaq__q{font-size:16px}
  .kfaq__a-inner > p{padding:0 20px 20px 56px;font-size:14px}
}

/* Socials */
.kontakt-soc{background:var(--ink);color:var(--paper)}
.kontakt-soc__inner{
  display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:24px;
  padding:32px 0;border-top:1px solid var(--line);
}
.kontakt-soc__kicker{
  font-size:11px;letter-spacing:.14em;color:var(--muted);text-transform:uppercase;
}
.kontakt-soc__list{
  list-style:none;padding:0;margin:0;
  display:flex;flex-wrap:wrap;gap:8px 12px;
}
.kontakt-soc__list a{
  display:inline-flex;align-items:center;gap:6px;
  padding:10px 18px;border-radius:999px;
  background:rgba(243,243,243,.04);border:1px solid var(--line);
  color:var(--paper);text-decoration:none;font-size:14px;
  transition:background .25s ease, border-color .25s ease, color .25s ease;
}
.kontakt-soc__list a:hover{background:var(--coral);color:var(--ink-2);border-color:var(--coral)}

@media (max-width:900px){
  .kontakt-persons__grid{grid-template-columns:1fr}
  .kontakt-loc__grid{grid-template-columns:1fr}
  .kontakt-person{grid-template-columns:96px 1fr;gap:18px;padding:20px}
  .kontakt-person__photo{width:96px;height:96px}
  .kontakt-person__name{font-size:24px}
  .kontakt-loc__city{font-size:42px}
  .kontakt-faq__q{font-size:17px;gap:14px;padding:22px 4px}
  .kontakt-faq__a > p{padding:0 20px 22px 38px}
}
