/* ============================================
   PULZ BARBERSHOP — styles.css
   ============================================ */

:root{
  --c-bg:#0a0a0a;
  --c-bg-2:#101010;
  --c-surface:#141414;
  --c-line:#1f1f1f;
  --c-line-2:#2a2a2a;
  --c-text:#f4f4f4;
  --c-muted:#8a8a8a;
  --c-accent:#d9d9d9;
  --c-accent-2:#5ef0c8;
  --c-accent-3:#ff2e63;
  --f-display:'Bebas Neue', system-ui, sans-serif;
  --f-body:'Space Grotesk', system-ui, sans-serif;
  --f-mono:'JetBrains Mono', monospace;
  --maxw:1280px;
  --pad:clamp(20px,4vw,64px);
  --r:4px;
  --ease:cubic-bezier(.7,.05,.2,1);

  --z-nav: 100;
  --z-noise: 1000;
  --z-loader: 2000;
  --z-toast: 2500;
  --z-modal: 3000;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}

body{
  background:transparent;
  color:var(--c-text);
  font-family:var(--f-body);
  font-size:16px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
html{background:var(--c-bg)}
body.is-loading{overflow:hidden;height:100vh}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font:inherit;background:none;border:0;color:inherit}
::selection{background:var(--c-accent-2);color:#000}

/* ===== NOISE & BG ===== */
.noise{
  position:fixed;inset:0;z-index:var(--z-noise);pointer-events:none;opacity:.05;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/></filter><rect width='100%' height='100%' filter='url(%23n)' opacity='.6'/></svg>");
  mix-blend-mode:overlay;
}
.page-bg{
  position:fixed;inset:0;z-index:-1;pointer-events:none;
  background:linear-gradient(180deg, rgba(10,10,10,.92), rgba(5,5,5,.96)), url("img/719689368_27403698629268221_1496701153196642427_n.jpg") center/cover no-repeat fixed;
  filter: brightness(0.6); 
}
.page-bg::after{
  content:'';position:absolute;inset:0;
  background:radial-gradient(60% 50% at 50% 30%, transparent, rgba(0,0,0,.55) 80%);
}

/* ===== LOADER ===== */
.loader{
  position:fixed;inset:0;z-index:var(--z-loader);background:#000;
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:32px;
  transition:opacity .6s var(--ease), visibility .6s var(--ease);
}
.loader.is-hidden{opacity:0;visibility:hidden;pointer-events:none}
.loader__bar{ width:min(280px,60vw);height:2px;background:#222;overflow:hidden; }
.loader__bar span{ display:block;height:100%;width:0;background:#fff; animation:loaderFill 1.4s var(--ease) forwards; }
.loader__meta{ font-family:var(--f-mono);font-size:11px;letter-spacing:.3em;color:#666; }
@keyframes loaderFill{to{width:100%}}
.loader__logo-img { width: clamp(160px, 28vw, 360px); animation: razorSlice 2.5s cubic-bezier(0.77, 0, 0.175, 1) infinite; will-change: clip-path, transform, filter; }
@keyframes razorSlice {
  0% { clip-path: polygon(0 50%, 100% 50%, 100% 50%, 0 50%); transform: scale(1.1); filter: brightness(2) drop-shadow(0 0 20px #fff); }
  30%, 70% { clip-path: polygon(0 0, 100% 0, 100% 100%, 0 100%); transform: scale(1); filter: brightness(1) drop-shadow(0 0 15px var(--c-accent-2)); }
  100% { clip-path: polygon(0 50%, 100% 50%, 100% 50%, 0 50%); transform: scale(0.9); filter: brightness(0.2); }
}

/* ===== CUSTOM CURSOR ===== */
.cursor { display: none; }
@media (pointer: fine) {
  body.has-custom-cursor, body.has-custom-cursor * { cursor: none !important; }
  .cursor {
    display: block; position: fixed; top: 0; left: 0; width: 6px; height: 6px; background: #000;
    box-shadow: 0 0 12px 4px rgba(255, 255, 255, 0.9); border-radius: 50%; pointer-events: none; z-index: 99999;
    transform: translate(-50%, -50%); will-change: left, top; opacity: 0; transition: opacity 0.3s;
  }
  body.has-custom-cursor .cursor { opacity: 1; }
}

/* ===== NAV / MENU ===== */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:var(--z-nav);
  display:flex;align-items:center;justify-content:space-between;
  padding:18px var(--pad); background:rgba(10,10,10,.6);
  backdrop-filter:blur(12px); -webkit-backdrop-filter:blur(12px);
  border-bottom:1px solid transparent; transition:border-color .3s, background .3s;
}
.nav.is-scrolled{border-color:var(--c-line);background:rgba(10,10,10,.85)}
.nav__brand{ position:relative; display: flex; align-items: center; }
.nav__logo-img { height: 75px; width: auto; object-fit: contain; }
.nav__links{display:flex;gap:32px}
.nav__links a{ font-size:13px;letter-spacing:.12em;text-transform:uppercase; color:var(--c-muted); position:relative; transition:color .3s, text-shadow .3s; }
.nav__links a::after{ content:'';position:absolute;left:0;right:100%;bottom:-6px;height:1px; background:var(--c-text);transition:right .4s var(--ease); }
.nav__links a:hover{color:var(--c-accent-2); text-shadow:0 0 10px rgba(94,240,200,.45)}
.nav__links a:hover::after{right:0}
.nav__cta{ font-family:var(--f-mono);font-size:12px;letter-spacing:.14em;text-transform:uppercase; border:1px solid var(--c-line-2);padding:10px 18px;border-radius:var(--r); transition:all .35s var(--ease); }
.nav__cta:hover{ background:transparent; color:var(--c-accent-2); border-color:var(--c-accent-2); box-shadow:0 0 16px rgba(94,240,200,.35); text-shadow:0 0 10px rgba(94,240,200,.5); }
.nav__burger{display:none;flex-direction:column;gap:5px;padding:8px}
.nav__burger span{width:22px;height:2px;background:#fff;display:block}

/* ===== BUTTONS ===== */
.btn{ display:inline-flex;align-items:center;gap:10px; padding:16px 28px;border-radius:var(--r); font-family:var(--f-mono);font-size:13px;letter-spacing:.14em;text-transform:uppercase; transition:transform .35s var(--ease), box-shadow .35s var(--ease), border-color .35s var(--ease), color .35s var(--ease), background .35s var(--ease); position:relative; overflow:hidden; }
.btn::before{ content:''; position:absolute; inset:0; background:linear-gradient(120deg, transparent 0%, transparent 40%, rgba(94,240,200,.35) 50%, transparent 60%, transparent 100%); transform:translateX(-120%); transition:transform .8s var(--ease); pointer-events:none; }
.btn:hover::before{transform:translateX(120%)}
.btn--primary{background:#fff;color:#000}
.btn--primary:hover{ transform:translateY(-2px); box-shadow: 0 10px 30px rgba(94,240,200,.25), 0 0 0 1px rgba(94,240,200,.35), 0 0 22px rgba(94,240,200,.35); }
.btn--ghost{border:1px solid var(--c-line-2);color:#fff}
.btn--ghost:hover{ border-color:var(--c-accent-2); color:var(--c-accent-2); background:rgba(94,240,200,.06); box-shadow:0 0 18px rgba(94,240,200,.22), inset 0 0 12px rgba(94,240,200,.08); text-shadow:0 0 12px rgba(94,240,200,.45); }

/* ===== HERO ===== */
.hero{ position:relative;min-height:100vh; display:flex;align-items:center; padding:120px var(--pad) 60px; overflow:hidden; }
.hero__bg{ position:absolute;inset:0; background:radial-gradient(60% 50% at 70% 20%, rgba(94,240,200,.06), transparent 60%), radial-gradient(50% 60% at 20% 80%, rgba(255,46,99,.05), transparent 60%), linear-gradient(180deg, rgba(10,10,10,.55), rgba(5,5,5,.85)); }
.hero__grid{ position:absolute;inset:0;opacity:.14; background-image:linear-gradient(to right, #1a1a1a 1px, transparent 1px), linear-gradient(to bottom, #1a1a1a 1px, transparent 1px); background-size:80px 80px; -webkit-mask-image:radial-gradient(ellipse at 50% 40%, #000 30%, transparent 80%); mask-image:radial-gradient(ellipse at 50% 40%, #000 30%, transparent 80%); }
.hero__pulse-wave { position: absolute; left: 0; right: 0; bottom: 15%; height: 250px; z-index: 2; opacity: 0.6; pointer-events: none; }
.hero__pulse-wave path { fill: none; stroke: var(--c-accent-2); stroke-width: 2px; stroke-dasharray: 2000; stroke-dashoffset: 2000; animation: drawPulse 5s ease-in-out infinite; }
@keyframes drawPulse { 0% { stroke-dashoffset: 2000; } 50% { stroke-dashoffset: 0; } 100% { stroke-dashoffset: -2000; } }
.hero__image{ position:absolute;inset:0;overflow:hidden; -webkit-mask-image:linear-gradient(90deg, transparent 0%, #000 55%, #000 100%); mask-image:linear-gradient(90deg, transparent 0%, #000 55%, #000 100%); opacity:.6; }
.hero__image img{ 
  width:100%; height:100%; object-fit:cover; object-position: center;
  filter: contrast(1.05) brightness(0.6); 
}
.hero__content{position:relative;max-width:var(--maxw);margin:0 auto;width:100%; z-index:3;}
.hero__eyebrow{ font-family:var(--f-mono);font-size:12px;letter-spacing:.3em;color:var(--c-muted); margin-bottom:24px; }
.hero__title{ font-family:var(--f-display); font-size:clamp(64px,14vw,220px); line-height:1.02;letter-spacing:-.01em; margin-bottom:32px; color:#fff; }
.hero__line{display:block;padding-top:.08em}
.hero__sub{ max-width:560px;font-size:clamp(16px,1.4vw,19px);color:#bababa; margin-bottom:40px; }
.hero__actions{display:flex;gap:14px;flex-wrap:wrap;align-items:center;margin-bottom:80px}
.hero__meta{ display:flex;gap:48px;flex-wrap:wrap; padding-top:32px;max-width:600px; }
.hero__meta div{display:flex;flex-direction:column}
.hero__meta strong{font-family:var(--f-display);font-size:36px;letter-spacing:.02em}
.hero__meta span{font-family:var(--f-mono);font-size:11px;letter-spacing:.2em;color:var(--c-muted);text-transform:uppercase}
.hero__scroll{ position:absolute;bottom:24px;right:var(--pad); font-family:var(--f-mono);font-size:11px;letter-spacing:.3em;color:var(--c-muted); writing-mode:vertical-rl; animation:bob 2s ease-in-out infinite; }
@keyframes bob{50%{transform:translateY(8px)}}
.hero__call-badge { display: inline-flex; align-items: center; gap: 10px; margin-left: auto; padding: 16px 28px; border-radius: var(--r); font-family: var(--f-mono); font-size: 13px; letter-spacing: .14em; text-transform: uppercase; color: #000; background: #fff; border: none; position: relative; overflow: hidden; animation: heroBadgeGlow 3s ease-in-out infinite; text-decoration: none; transition: transform .35s var(--ease), background .35s var(--ease); }
.hero__call-badge:hover { transform: translateY(-2px); background: #f4f4f4; }
.hero__call-badge::after { content: ''; position: absolute; top: 0; left: -100%; width: 50%; height: 100%; background: linear-gradient(90deg, transparent, rgba(94, 240, 200, 0.4), transparent); animation: badgeShimmer 3s ease-in-out infinite; pointer-events: none; }
.hero__call-badge-dot { width: 10px; height: 10px; border-radius: 50%; background: var(--c-accent-2); box-shadow: 0 0 10px var(--c-accent-2); animation: pulse-dot 1.5s infinite; flex-shrink: 0; }
@keyframes heroBadgeGlow { 0%, 100% { box-shadow: 0 0 15px rgba(94, 240, 200, 0.3), 0 0 0 1px rgba(94, 240, 200, 0.1); } 50% { box-shadow: 0 0 40px rgba(94, 240, 200, 0.85), 0 0 70px rgba(94, 240, 200, 0.5), 0 0 0 2px rgba(94, 240, 200, 0.4); } }
@keyframes pulse-dot { 0% { transform: scale(0.95); box-shadow: 0 0 0 0 rgba(94, 240, 200, 0.8); } 70% { transform: scale(1); box-shadow: 0 0 0 10px rgba(94, 240, 200, 0); } 100% { transform: scale(0.95); box-shadow: 0 0 0 0 rgba(94, 240, 200, 0); } }

/* ===== MARQUEE ===== */
.marquee{ border-top:1px solid var(--c-line);border-bottom:1px solid var(--c-line); padding:20px 0;overflow:hidden;background:#070707; display:flex; }
.marquee__track{ display:flex;gap:40px;white-space:nowrap;flex-shrink:0;width:max-content; animation:marquee 30s linear infinite; font-family:var(--f-display);font-size:32px;letter-spacing:.08em;color:var(--c-muted); padding-right:40px; }
.marquee__track span:nth-child(odd){color:var(--c-text)}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-100%)}}

/* ===== SECTIONS ===== */
.section{ padding:clamp(80px,12vw,160px) var(--pad); max-width:var(--maxw);margin:0 auto; }
.section__head{margin-bottom:64px;max-width:720px}
.section__title{ font-family:var(--f-display); font-size:clamp(48px,8vw,112px); line-height:.95;letter-spacing:-.01em; margin-bottom:16px; }
.section__lead{color:var(--c-muted);font-size:18px;max-width:520px}

/* ===== SERVICES GRID ===== */
.services__grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 20px; background: transparent; border: none; }
.service { background: var(--c-bg-2); padding: 24px; display: flex; flex-direction: column; gap: 12px; border: 1px solid var(--c-line); border-radius: 12px; position: relative; overflow: hidden; transition: transform 0.4s var(--ease), border-color 0.4s, box-shadow 0.4s; height: 100%; will-change: transform; }
.service:hover { transform: translateY(-6px) scale(1.02); border-color: var(--c-accent-2); box-shadow: 0 16px 32px rgba(0, 0, 0, 0.4), 0 0 15px rgba(94, 240, 200, 0.08); z-index: 2; }
.service::before { content: ""; position: absolute; inset: 0; border-radius: 12px; padding: 1px; background: linear-gradient(90deg, rgba(255,255,255,0.03), rgba(94, 240, 200, 0.4), rgba(255,255,255,0.03)); background-size: 200% auto; -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0); mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0); -webkit-mask-composite: xor; mask-composite: exclude; animation: shimmerBorder 4s linear infinite; opacity: 0.4; pointer-events: none; transition: opacity 0.3s; }
.service:hover::before { opacity: 1; }
@keyframes shimmerBorder { to { background-position: 200% center; } }
.service__head { display: flex; justify-content: space-between; align-items: baseline; gap: 16px; }
.service__title { font-family: var(--f-display); font-size: 26px; letter-spacing: 0.02em; }
.service__price { font-family: var(--f-display); font-size: 22px; color: var(--c-accent-2); white-space: nowrap; }
.service__desc { color: #a8a8a8; font-size: 14px; line-height: 1.5; }
.service__list { list-style: none; display: flex; flex-wrap: wrap; gap: 16px; margin-top: auto; padding-top: 16px; border-top: 1px solid var(--c-line); }
.service__list li { font-family: var(--f-mono); font-size: 11px; color: var(--c-muted); letter-spacing: 0.06em; }
.service__list li::before { content: '✦ '; color: var(--c-accent-2); }
.service--bestseller { background: linear-gradient(145deg, #141414, #0a0a0a); border-color: var(--c-accent-2); box-shadow: 0 0 20px rgba(94, 240, 200, 0.1); transform: scale(1.02); }
.service--bestseller:hover { transform: translateY(-6px) scale(1.04); box-shadow: 0 20px 40px rgba(0, 0, 0, 0.6), 0 0 30px rgba(94, 240, 200, 0.2); }
.service--bestseller .service__title { color: var(--c-accent-2); }
.service__badge { position: absolute; top: -1px; right: 24px; background: var(--c-accent-2); color: #000; font-family: var(--f-mono); font-size: 10px; font-weight: 700; letter-spacing: 0.15em; text-transform: uppercase; padding: 4px 12px; border-bottom-left-radius: 8px; border-bottom-right-radius: 8px; box-shadow: 0 5px 15px rgba(94, 240, 200, 0.3); }

/* ===== ABOUT & TEAM ===== */
.about__head{margin-bottom:56px}
.about__grid{ display:grid;grid-template-columns:1.2fr 1fr;gap:64px;align-items:start; margin-bottom:120px; }
.about__lead{font-size:clamp(20px,2vw,28px);line-height:1.4;margin-bottom:24px;color:#fff}
.about__lead em{color:var(--c-accent-2);font-style:normal}
.about__text p{color:#b8b8b8;margin-bottom:16px}
.about__stats{ display:flex;gap:48px;margin-top:48px; padding-top:32px;border-top:1px solid var(--c-line); }
.about__stats div{display:flex;flex-direction:column}
.about__stats strong{font-family:var(--f-display);font-size:42px}
.about__stats span{font-family:var(--f-mono);font-size:11px;letter-spacing:.2em;color:var(--c-muted);text-transform:uppercase}
.about__visual{position:relative;aspect-ratio:4/5}
.about__frame{ position:absolute;inset:0; border:1px solid var(--c-line-2); overflow:hidden;background:#0a0a0a; }

.about__frame img { 
  width:100%; height:100%; object-fit:fill; object-position: center;
}
.about__frame::after{ content:'';position:absolute;inset:0;pointer-events:none; background: linear-gradient(180deg, transparent 40%, rgba(0,0,0,.55) 100%), radial-gradient(60% 60% at 50% 30%, rgba(94,240,200,.08), transparent 70%); }
.about__tag{ position:absolute;bottom:16px;left:16px;z-index:2; font-family:var(--f-mono);font-size:11px;letter-spacing:.2em;color:var(--c-accent-2); }
.team__head{display:flex;align-items:baseline;gap:16px;margin-bottom:32px}
.team__head h3{font-family:var(--f-display);font-size:48px;letter-spacing:.02em}
.team__head span{font-family:var(--f-mono);font-size:12px;color:var(--c-muted);letter-spacing:.2em}
.team__grid{ display:grid;grid-template-columns:repeat(4,1fr);gap:24px; }
.member { display: flex; flex-direction: column; height: 100%; }
.member__photo{ aspect-ratio:3/4;background:#0f0f0f;border:1px solid var(--c-line); position:relative;margin-bottom:16px;overflow:hidden; transition:border-color .4s; }

.member__photo img{ 
  width:100%; height:100%; 
  object-fit:cover; 
  object-position: center 20%; 
  transition:transform .6s var(--ease), filter .4s; 
}
.member__photo::after{ content:'';position:absolute;inset:0;pointer-events:none; background: linear-gradient(180deg, transparent 50%, rgba(0,0,0,.55) 100%), repeating-linear-gradient(0deg, rgba(255,255,255,.02) 0 2px, transparent 2px 4px); }
.member:hover:not(:has(.member__contacts:hover)) .member__photo{border-color:var(--c-accent-2)}

.member:hover:not(:has(.member__contacts:hover)) .member__photo img{
  transform:scale(1.04);
}

.member h4{font-family:var(--f-display);font-size:22px;letter-spacing:.03em}
.member span{font-family:var(--f-mono);font-size:11px;letter-spacing:.15em;color:var(--c-muted);text-transform:uppercase}
.member__bio { font-size: 14px; color: #a8a8a8; margin-top: 12px; margin-bottom: 20px; line-height: 1.5; }
.member__contacts { display: flex; flex-direction: column; align-items: flex-start; gap: 12px; border-top: 1px solid var(--c-line); padding-top: 16px; width: 100%; margin-top: auto; }
.member__contact-link { display: flex; align-items: center; gap: 12px; font-family: var(--f-mono); font-size: 13px; color: var(--c-text); transition: color 0.3s ease; }
.member__contact-link:hover { color: var(--c-accent-2); }
.member__contact-link svg { width: 18px; height: 18px; flex-shrink: 0; display: block; color: var(--c-muted); transition: color 0.3s ease; }
.member__contact-link:hover svg { color: var(--c-accent-2); }

/* ===== FAQ ===== */
.faq { padding-top: 80px; padding-bottom: 120px; }
.faq__list { max-width: 800px; display: flex; flex-direction: column; gap: 16px; }
.faq__item { background: var(--c-bg-2); border: 1px solid var(--c-line); border-radius: 12px; overflow: hidden; transition: border-color 0.4s var(--ease); }
.faq__item:hover { border-color: #3f3f46; }
.faq__item.is-active { border-color: var(--c-accent-2); }
.faq__question { width: 100%; text-align: left; padding: 24px; font-family: var(--f-body); font-weight: 700; font-size: 18px; color: #fff; display: flex; justify-content: space-between; align-items: center; }
@media (pointer: fine) { .faq__question { cursor: none !important; } }
.faq__icon { font-family: var(--f-mono); font-size: 24px; color: var(--c-accent-2); font-weight: 300; transition: transform 0.4s var(--ease); flex-shrink: 0; margin-left: 16px; }
.faq__item.is-active .faq__icon { transform: rotate(45deg); }
.faq__answer { max-height: 0; overflow: hidden; transition: max-height 0.4s var(--ease); }
.faq__answer p { padding: 0 24px 24px; color: #a8a8a8; font-size: 15px; line-height: 1.6; }

/* ===== GALERIE - ČTVERCOVÁ MŘÍŽKA ===== */
.gallery__grid { 
  display: grid; 
  grid-template-columns: repeat(4, 1fr); 
  gap: 12px; 
  grid-auto-flow: dense; 
}
.gallery__item { 
  background: #0a0a0a; 
  border: 1px solid var(--c-line); 
  position: relative; 
  overflow: hidden; 
  transition: transform .5s var(--ease); 
  aspect-ratio: 1 / 1; 
}

.gallery__item img { 
  position: absolute; inset: 0; width: 100%; height: 100%;
  object-fit: cover; 
  object-position: center; 
  transition: transform .8s var(--ease), filter .5s; 
}

.gallery__item:hover img {
  transform: scale(1.06);
}

.gallery__item--lg { grid-column: span 2; grid-row: span 2; }
.gallery__item--wide { grid-column: span 2; aspect-ratio: 2 / 1; }
.gallery__item--tall { grid-row: span 2; aspect-ratio: 1 / 2; }

/* ===== BOOKING ===== */
.booking{background:rgba(7,7,7,.7);max-width:none;border-top:1px solid var(--c-line);border-bottom:1px solid var(--c-line)}
.booking__inner{ max-width:var(--maxw);margin:0 auto; display:grid;grid-template-columns:1fr 1.3fr;gap:80px; align-items:start; }
.booking__intro p{color:var(--c-muted);margin:16px 0 32px;max-width:420px;font-size:18px}
.booking__actions{display:flex;gap:14px;flex-wrap:wrap;margin-top:8px}
.booking__cards{ display:grid;grid-template-columns:1fr 1fr;gap:16px; }
.contact-card{ display:flex;flex-direction:column;gap:8px; background:#0c0c0c;border:1px solid var(--c-line-2); padding:28px;border-radius:var(--r); transition:border-color .4s, transform .4s var(--ease), background .4s, box-shadow .4s; position:relative;overflow:hidden;min-height:170px; will-change: transform; }
.contact-card:hover{ border-color:var(--c-accent-2); transform:translateY(-6px) scale(1.02); background:#101010; box-shadow: 0 16px 32px rgba(0, 0, 0, 0.4), 0 0 15px rgba(94, 240, 200, 0.08); z-index: 2; }
.contact-card__label{ font-family:var(--f-mono);font-size:11px;letter-spacing:.25em;color:var(--c-muted);text-transform:uppercase; }
.contact-card__value{ font-family:var(--f-display);font-size:26px;letter-spacing:.02em;color:#fff;margin-top:auto; }
.contact-card__meta{ font-family:var(--f-mono);font-size:11px;letter-spacing:.15em;color:var(--c-muted);text-transform:uppercase; }
.contact-card--map{ grid-column:span 2;padding:0;min-height:220px; }

.contact-card--map img{ 
  position:absolute;inset:0;width:100%;height:100%;
  object-fit:cover; object-position: center;
  filter: brightness(0.5); 
}
.contact-card__overlay{ position:relative;z-index:2;padding:28px; display:flex;flex-direction:column;gap:6px;height:100%;justify-content:flex-end; background:linear-gradient(180deg, transparent 30%, rgba(0,0,0,.7) 100%); }

/* ===== FOOTER ===== */
.footer{ padding:80px var(--pad) 32px; border-top:1px solid var(--c-line); }
.footer__grid{ max-width:var(--maxw);margin:0 auto; display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:48px; }
.footer__logo-img { height: 70px; width: auto; object-fit: contain; margin-bottom: 12px; }
.footer__brand p{color:var(--c-muted);max-width:260px}
.footer h5{ font-family:var(--f-mono);font-size:11px;letter-spacing:.2em;color:var(--c-muted); text-transform:uppercase;margin-bottom:16px; }
.footer p, .footer a{color:#cfcfcf;font-size:14px;line-height:1.8}
.footer a:hover{color:var(--c-accent-2)}
.footer__social{list-style:none;display:flex;flex-direction:column;gap:6px}
.footer__bottom{ max-width:var(--maxw);margin:64px auto 0;padding-top:24px; border-top:1px solid var(--c-line); display:flex;justify-content:space-between; font-family:var(--f-mono);font-size:11px;letter-spacing:.15em;color:var(--c-muted);text-transform:uppercase; }

/* ===== OPENING STATUS BADGE ===== */
.status-wrapper { display: flex; align-items: center; gap: 12px; margin-top: 16px; }
.status-label { font-size: 14px; color: var(--c-muted); font-weight: 500; }
@keyframes statusBreatheOpen { 0%, 100% { transform: scale(1); box-shadow: 0 0 0 rgba(94, 240, 200, 0); } 50% { transform: scale(1.05); box-shadow: 0 0 15px rgba(94, 240, 200, 0.4); } }
@keyframes statusBreatheClosed { 0%, 100% { transform: scale(1); box-shadow: 0 0 0 rgba(255, 46, 99, 0); } 50% { transform: scale(1.05); box-shadow: 0 0 15px rgba(255, 46, 99, 0.4); } }
.status-badge { display: inline-flex; align-items: center; gap: 8px; padding: 6px 14px; border-radius: 999px; font-family: var(--f-mono); font-size: 13px; font-weight: 700; letter-spacing: .05em; border: 1px solid var(--c-line-2); transition: border-color 0.4s var(--ease), color 0.4s var(--ease); }
.status-badge__dot { width: 8px; height: 8px; border-radius: 50%; transition: background 0.4s var(--ease), box-shadow 0.4s var(--ease); }
.status-badge.is-open { border-color: rgba(94, 240, 200, 0.4); color: #fff; animation: statusBreatheOpen 3s ease-in-out infinite; }
.status-badge.is-open .status-badge__dot { background: var(--c-accent-2); box-shadow: 0 0 8px var(--c-accent-2); }
.status-badge.is-closed { border-color: rgba(255, 46, 99, 0.4); color: #fff; animation: statusBreatheClosed 3s ease-in-out infinite; }
.status-badge.is-closed .status-badge__dot { background: var(--c-accent-3); box-shadow: 0 0 8px var(--c-accent-3); }
.reveal{opacity:0;transform:translateY(24px);transition:opacity .8s var(--ease), transform .8s var(--ease)}
.reveal.is-visible{opacity:1;transform:none}

/* ===== MODAL & TOAST ===== */
.modal-backdrop{ position:fixed;inset:0;z-index:var(--z-modal); background:rgba(0,0,0,.72);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px); display:flex;align-items:center;justify-content:center; padding:24px; opacity:0;pointer-events:none;transition:opacity .35s var(--ease); }
.modal-backdrop.is-open{opacity:1;pointer-events:auto}
.modal{ background:#0d0d0d;border:1px solid var(--c-line-2);border-radius:14px; width:100%;max-width:480px;padding:28px; color:var(--c-text);box-shadow:0 30px 80px rgba(0,0,0,.6); transform:translateY(12px) scale(.98);transition:transform .35s var(--ease); position:relative; }
.modal-backdrop.is-open .modal{transform:translateY(0) scale(1)}
.modal__tag{ display:inline-flex;align-items:center;gap:8px; font-family:var(--f-mono);font-size:11px;letter-spacing:.25em; padding:6px 12px;border:1px solid var(--c-line-2);border-radius:999px; color:var(--c-accent-2);text-transform:uppercase; }
.modal__tag::before{content:'✦';font-size:12px}
.modal__eyebrow{margin-left:10px;color:var(--c-muted);font-family:var(--f-mono);font-size:11px;letter-spacing:.25em;text-transform:uppercase}
.modal__close{ position:absolute;top:18px;right:18px; width:32px;height:32px;border-radius:8px;color:var(--c-muted); display:flex;align-items:center;justify-content:center;font-size:18px; transition:background .2s,color .2s; }
.modal__close:hover{background:#1a1a1a;color:#fff}
.modal__title{ font-family:var(--f-display);font-size:clamp(28px,4vw,36px); line-height:1.05;letter-spacing:.02em;margin:18px 0 10px; }
.modal__lead{color:var(--c-muted);font-size:15px;margin-bottom:20px}
.modal__address{ display:flex;gap:14px;align-items:center; padding:14px 16px;border:1px solid var(--c-line-2);border-radius:10px; background:#0a0a0a; }
.modal__address-icon{ width:36px;height:36px;border-radius:8px;background:#141414;border:1px solid var(--c-line-2); display:flex;align-items:center;justify-content:center;color:var(--c-accent-2);flex-shrink:0; }
.modal__address-label{display:block;font-family:var(--f-mono);font-size:11px;letter-spacing:.2em;color:var(--c-muted);text-transform:uppercase}
.modal__address-value{display:block;font-weight:700;margin-top:2px}
.modal__actions{display:flex;gap:10px;justify-content:flex-end;margin-top:22px;flex-wrap:wrap}
.modal__btn{ padding:11px 18px;border-radius:9px;font-weight:600;font-size:14px; display:inline-flex;align-items:center;gap:8px;transition:transform .2s,background .2s,border-color .2s; border:1px solid var(--c-line-2); }
.modal__btn--ghost{background:#141414;color:var(--c-text)}
.modal__btn--ghost:hover{background:#1c1c1c}
.modal__btn--primary{background:#f4f4f4;color:#0a0a0a;border-color:#f4f4f4}
.modal__btn--primary:hover{transform:translateY(-1px);background:#fff}

/* UPRAVENÝ TOAST S TLAČÍTKEM ZAVŘÍT */
.toast{ position:fixed;bottom:24px;right:24px;z-index:var(--z-toast); background:#0d0d0d;border:1px solid var(--c-line-2);border-radius:12px; padding:6px;max-width:360px; display:flex;align-items:flex-start; box-shadow:0 20px 40px rgba(0,0,0,.5); transform:translateY(20px);opacity:0;pointer-events:none; transition:transform .35s var(--ease),opacity .35s var(--ease); }
.toast.is-visible{transform:translateY(0);opacity:1;pointer-events:auto}
.toast__inner{display:flex;gap:12px;align-items:flex-start;padding:12px 14px;cursor:pointer;flex-grow:1;border-radius:8px;transition:background .2s;}
.toast__inner:hover{background:#141414;}
.toast__dot{width:10px;height:10px;border-radius:50%;background:var(--c-accent-2);margin-top:6px;flex-shrink:0;box-shadow:0 0 12px var(--c-accent-2)}
.toast__title{font-weight:700;font-size:14px;line-height:1.3;margin-bottom:4px}
.toast__meta{font-family:var(--f-mono);font-size:11px;letter-spacing:.05em;color:var(--c-muted)}
.toast__close{flex-shrink:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;color:var(--c-muted);border-radius:8px;margin:6px 6px 0 0;transition:background .2s,color .2s;cursor:pointer;}
.toast__close:hover{background:#1a1a1a;color:#fff}

.cash-badge { display: inline-flex; align-items: center; gap: 10px; margin-top: 18px; padding: 10px 18px; border: 1px solid rgba(94, 240, 200, 0.3); border-radius: 999px; font-family: var(--f-mono); font-size: 12px; letter-spacing: .22em; text-transform: uppercase; color: #fff; background: rgba(94, 240, 200, 0.05); position: relative; overflow: hidden; animation: badgeBreathe 3.5s ease-in-out infinite; transform-origin: center; }
.cash-badge__icon { width: 18px; height: 18px; flex: none; color: var(--c-accent-2); animation: iconTilt 3.5s ease-in-out infinite; }
.cash-badge::after { content: ''; position: absolute; top: 0; left: -100%; width: 50%; height: 100%; background: linear-gradient(90deg, transparent, rgba(94, 240, 200, 0.2), transparent); animation: badgeShimmer 3.5s ease-in-out infinite; pointer-events: none; }
@keyframes badgeBreathe { 0%, 100% { transform: scale(1); box-shadow: 0 0 0 rgba(94, 240, 200, 0); border-color: rgba(94, 240, 200, 0.3); } 50% { transform: scale(1.04); box-shadow: 0 6px 20px rgba(94, 240, 200, 0.2), inset 0 0 10px rgba(94, 240, 200, 0.08); border-color: rgba(94, 240, 200, 0.8); } }
@keyframes iconTilt { 0%, 100% { transform: rotate(0deg); } 25% { transform: rotate(-8deg); } 75% { transform: rotate(8deg); } }
@keyframes badgeShimmer { 0% { left: -100%; } 30% { left: 200%; } 100% { left: 200%; } }

/* ===== RESPONSIVE ===== */
@media (max-width:1024px){
  .about__grid{grid-template-columns:1fr;gap:48px}
  .team__grid{grid-template-columns:repeat(2,1fr)}
  .gallery__grid{grid-template-columns:repeat(2,1fr)} 
  .gallery__item--lg,.gallery__item--wide{grid-column:span 2;grid-row:auto; aspect-ratio: 2 / 1;}
  .booking__inner{grid-template-columns:1fr;gap:48px}
  .footer__grid{grid-template-columns:1fr 1fr;gap:32px}
}

@media (max-width:860px){
  .services__grid { grid-template-columns: 1fr; }
  .hero__pulse-wave { top: 50%; bottom: auto; transform: translateY(-50%); height: clamp(100px, 20vh, 180px); opacity: 0.3; }
  .nav.is-open { background: rgba(10,10,10,0.95) !important; border-bottom-color: transparent !important; }
  .nav__links { position: absolute; top: 100%; left: 0; width: 100%; height: auto; padding: 10px 0 20px; flex-direction: column; background: rgba(10,10,10,0.95); backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px); border-bottom: 1px solid var(--c-line-2); gap: 0; transform: translateY(-20px); opacity: 0; visibility: hidden; pointer-events: none; transition: transform 0.35s var(--ease), opacity 0.35s var(--ease), visibility 0.35s var(--ease); z-index: -1; align-items: flex-start; }
  .nav__links a { font-family: var(--f-mono); font-size: 15px; letter-spacing: 0.1em; width: 100%; text-align: left; padding: 16px var(--pad); color: #fff; border: none; }
  .nav__links a::after { display: none; }
  .nav__links a:hover, .nav__links a:active { color: var(--c-accent-2); text-shadow: none; }
  .nav.is-open .nav__links { transform: translateY(0); opacity: 1; visibility: visible; pointer-events: auto; }
  .nav__cta { display: none; }
  .nav__burger { display: flex; flex-direction: column; gap: 5px; padding: 8px 10px; border: none; background: transparent; z-index: 100; position: relative; }
  .nav__burger span { width: 22px; height: 2px; background: #fff; display: block; transition: transform 0.3s var(--ease); transform-origin: center; }
  .nav.is-open .nav__burger span:nth-child(1) { transform: translateY(3.5px) rotate(45deg); }
  .nav.is-open .nav__burger span:nth-child(2) { transform: translateY(-3.5px) rotate(-45deg); }
  .hero{padding-top:160px; min-height:90vh}
  .hero__actions { justify-content: flex-start; }
  .hero__call-badge { margin-left: 0; width: 100%; justify-content: center; margin-top: 10px; }
  .hero__meta{gap:24px}
  .hero__meta strong{font-size:28px}
  .booking__cards{grid-template-columns:1fr}
  .contact-card--map{grid-column:span 1}
  .about__stats{gap:24px}
  .footer__grid{grid-template-columns:1fr}
  .footer__bottom{flex-direction:column;gap:8px;text-align:center}
  .marquee__track{font-size:24px}
}

@media (max-width:680px){
  .toast{left:16px;right:16px;bottom:16px;max-width:none}
}

@media (max-width:600px){
  .faq__question { font-size: 16px; padding: 20px; }
}

@media (max-width:520px){
  .gallery__grid{grid-template-columns:repeat(2,1fr); gap:8px}
  .gallery__item--lg{grid-column:span 2;grid-row:span 2; aspect-ratio: 1/1;}
  .gallery__item--wide{grid-column:span 2;grid-row:auto; aspect-ratio: 2/1;}
}