/* =========================================================
   NOIR & BLADE — dizajn
   Paleta: olejovaný orech / mosadz / oxblood koža / krém
   Typografia: Bebas Neue (display) + Space Grotesk (text)
   Podpis: „barber pole" pruh ako deliaci prvok
   ========================================================= */

:root{
  --ink:      #141210;
  --coal:     #1c1916;
  --coal-2:   #24201b;
  --cream:    #efe7d8;
  --smoke:    #a79c8a;
  --brass:    #c9a24b;
  --brass-hi: #e3be63;
  --oxblood:  #8e3b2f;
  --line:     rgba(201,162,75,.16);
  --shadow:   0 24px 60px rgba(0,0,0,.45);
  --r:        14px;
  --disp:     "Bebas Neue", "Arial Narrow", sans-serif;
  --body:     "Space Grotesk", system-ui, sans-serif;
}

*,*::before,*::after{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; }
body{
  font-family:var(--body);
  background:var(--ink);
  color:var(--cream);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
/* jemné filmové zrno */
body::after{
  content:""; position:fixed; inset:0; z-index:80; pointer-events:none; opacity:.05;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='140' height='140' filter='url(%23n)' opacity='0.55'/%3E%3C/svg%3E");
}
img{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }
button{ font:inherit; color:inherit; background:none; border:0; cursor:pointer; }
::selection{ background:var(--brass); color:var(--ink); }

.wrap{ width:min(1180px, calc(100% - 2.5rem)); margin-inline:auto; }

/* ---------- typografia ---------- */
.eyebrow{
  font-size:.78rem; letter-spacing:.32em; text-transform:uppercase;
  color:var(--brass); font-weight:500; margin-bottom:.9rem;
}
.h2{
  font-family:var(--disp); font-weight:400;
  font-size:clamp(2.5rem, 5.2vw, 4.1rem);
  line-height:.96; letter-spacing:.015em; text-transform:uppercase;
}
.h3{
  font-family:var(--disp); font-weight:400; letter-spacing:.03em;
  font-size:clamp(1.35rem, 2.4vw, 1.7rem); text-transform:uppercase;
  margin-bottom:.8rem;
}
p{ color:var(--smoke); }
p + p{ margin-top:.9rem; }
strong{ color:var(--cream); }

/* ---------- barber pole (podpisový prvok) ---------- */
.pole{
  height:7px; width:100%;
  background:repeating-linear-gradient(-55deg,
    var(--oxblood) 0 14px,
    var(--cream)   14px 22px,
    var(--brass)   22px 36px,
    var(--ink)     36px 44px);
  background-size:200% 100%;
  animation:poleSpin 26s linear infinite;
  opacity:.85;
}
.pole--top{ position:fixed; top:0; left:0; z-index:60; }
@keyframes poleSpin{ to{ background-position:-620px 0; } }

/* ---------- tlačidlá ---------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:.5rem;
  font-weight:500; font-size:.95rem; letter-spacing:.02em;
  padding:.85rem 1.7rem; border-radius:999px;
  transition:transform .18s ease, background .18s ease, color .18s ease, border-color .18s ease;
}
.btn:active{ transform:scale(.97); }
.btn--gold{ background:var(--brass); color:var(--ink); }
.btn--gold:hover{ background:var(--brass-hi); transform:translateY(-1px); }
.btn--ghost{ border:1px solid rgba(239,231,216,.35); color:var(--cream); }
.btn--ghost:hover{ border-color:var(--brass); color:var(--brass-hi); }
.btn--sm{ padding:.55rem 1.15rem; font-size:.85rem; }
.btn--danger{ border:1px solid rgba(142,59,47,.7); color:#e0a196; }
.btn--danger:hover{ background:var(--oxblood); color:var(--cream); }
.btn[disabled]{ opacity:.45; cursor:not-allowed; transform:none; }

/* ---------- navigácia ---------- */
.nav{
  position:fixed; top:7px; left:0; right:0; z-index:50;
  transition:background .25s ease, box-shadow .25s ease;
}
.nav.scrolled{
  background:rgba(20,18,16,.86); backdrop-filter:blur(14px);
  box-shadow:0 10px 30px rgba(0,0,0,.35);
}
.nav__in{ display:flex; align-items:center; gap:2rem; padding:.9rem 0; }
.logo{ display:flex; align-items:center; gap:.6rem; }
.logo__mark{ fill:var(--brass); stroke:var(--brass); }
.logo__txt{
  font-family:var(--disp); font-size:1.5rem; letter-spacing:.06em;
  text-transform:uppercase; color:var(--cream); line-height:1;
}
.logo__txt em{ font-style:normal; color:var(--brass); }
.nav__links{ display:flex; gap:1.6rem; margin-left:auto; }
.nav__links a{
  font-size:.88rem; letter-spacing:.06em; color:var(--smoke);
  padding:.3rem 0; position:relative; transition:color .18s;
}
.nav__links a::after{
  content:""; position:absolute; left:0; bottom:0; height:1px; width:0;
  background:var(--brass); transition:width .22s ease;
}
.nav__links a:hover{ color:var(--cream); }
.nav__links a:hover::after{ width:100%; }
.nav__right{ display:flex; align-items:center; gap:.9rem; }
.openchip{
  font-size:.72rem; letter-spacing:.14em; text-transform:uppercase;
  color:var(--smoke); display:flex; align-items:center; gap:.45rem; white-space:nowrap;
}
.openchip::before{
  content:""; width:7px; height:7px; border-radius:50%;
  background:var(--smoke);
}
.openchip.is-open{ color:var(--brass-hi); }
.openchip.is-open::before{ background:#7fb069; box-shadow:0 0 8px rgba(127,176,105,.8); }
.burger{ display:none; flex-direction:column; gap:5px; padding:.4rem; }
.burger span{ width:22px; height:2px; background:var(--cream); transition:.25s; }
.burger[aria-expanded="true"] span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
.burger[aria-expanded="true"] span:nth-child(2){ opacity:0; }
.burger[aria-expanded="true"] span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }

/* ---------- hero ---------- */
.hero{
  position:relative; min-height:100svh;
  display:flex; align-items:center;
  padding:8rem 0 5rem;
}
.hero__bg{
  position:absolute; inset:0; z-index:-1;
  background:
    linear-gradient(100deg, rgba(20,18,16,.96) 22%, rgba(20,18,16,.72) 55%, rgba(20,18,16,.45)),
    linear-gradient(to top, var(--ink) 4%, transparent 40%),
    url("https://images.unsplash.com/photo-1503951914875-452162b0f3f1?q=80&w=1800&auto=format&fit=crop")
    center 30% / cover no-repeat var(--coal);
}
.hero__eyebrow{ animation:fadeUp .8s .15s both; }
.hero__title{
  font-family:var(--disp); font-weight:400; text-transform:uppercase;
  font-size:clamp(4rem, 12.5vw, 9.5rem);
  line-height:.92; letter-spacing:.01em; margin:.4rem 0 1.4rem;
}
.hero__title .line{ display:block; overflow:hidden; }
.hero__title .line span{ display:inline-block; animation:riseIn .9s cubic-bezier(.2,.8,.2,1) both; }
.hero__title .line:nth-child(2) span{ animation-delay:.14s; }
.line--gold span{ color:var(--brass); }
.hero__lead{
  max-width:34rem; font-size:1.06rem; animation:fadeUp .8s .4s both;
}
.hero__cta{ display:flex; gap:.9rem; flex-wrap:wrap; margin-top:2rem; animation:fadeUp .8s .55s both; }
.hero__meta{
  display:flex; align-items:center; gap:.9rem; flex-wrap:wrap;
  margin-top:3.2rem; font-size:.85rem; color:var(--smoke);
  letter-spacing:.04em; animation:fadeUp .8s .7s both;
}
.hero__meta .dot{ width:4px; height:4px; border-radius:50%; background:var(--brass); }
.hero__scroll{
  position:absolute; bottom:2rem; left:50%; transform:translateX(-50%);
  width:26px; height:44px; border:1px solid rgba(239,231,216,.35); border-radius:14px;
}
.hero__scroll span{
  position:absolute; top:8px; left:50%; width:3px; height:9px; margin-left:-1.5px;
  border-radius:2px; background:var(--brass); animation:scrollHint 1.8s ease-in-out infinite;
}
@keyframes scrollHint{ 0%,100%{ transform:translateY(0); opacity:1;} 60%{ transform:translateY(14px); opacity:0;} }
@keyframes riseIn{ from{ transform:translateY(110%);} to{ transform:translateY(0);} }
@keyframes fadeUp{ from{ opacity:0; transform:translateY(16px);} to{ opacity:1; transform:translateY(0);} }

/* ---------- sekcie ---------- */
.section{ padding:clamp(4.5rem, 9vw, 7.5rem) 0; }
.section--tint{ background:var(--coal); }
.section__head{ max-width:44rem; margin-bottom:3rem; }
.section__lead{ margin-top:1rem; }
.grid2{
  display:grid; grid-template-columns:1.05fr .95fr;
  gap:clamp(2.5rem, 6vw, 5.5rem); align-items:center;
}

/* o nás */
.about__imgs{ position:relative; min-height:460px; }
.about__img{ position:absolute; border-radius:var(--r); overflow:hidden; box-shadow:var(--shadow); }
.about__img img{ width:100%; height:100%; object-fit:cover; }
.about__img--a{ inset:0 18% 16% 0; }
.about__img--b{
  right:0; bottom:0; width:56%; aspect-ratio:4/5;
  border:6px solid var(--ink); z-index:1;
}
.stats{
  display:grid; grid-template-columns:repeat(4,1fr); gap:1rem;
  margin-top:2.4rem; padding-top:1.8rem; border-top:1px solid var(--line);
}
.stat strong{
  display:block; font-family:var(--disp); font-size:2.1rem;
  color:var(--brass); line-height:1;
}
.stat span{ font-size:.78rem; letter-spacing:.1em; text-transform:uppercase; color:var(--smoke); }

/* ---------- cenník (menu) ---------- */
.menu{
  display:grid; grid-template-columns:1fr 1fr;
  gap:0 clamp(2.5rem, 6vw, 5rem);
}
.mrow{
  display:grid; grid-template-columns:1fr auto;
  gap:.2rem 1rem; align-items:baseline;
  padding:1.15rem 0; border-bottom:1px dashed rgba(167,156,138,.28);
  transition:padding-left .2s ease;
}
.mrow:hover{ padding-left:.5rem; }
.mrow__name{
  font-weight:700; font-size:1.02rem; color:var(--cream);
  display:flex; align-items:center; gap:.6rem; flex-wrap:wrap;
}
.mrow__badge{
  font-size:.62rem; letter-spacing:.14em; text-transform:uppercase;
  background:var(--oxblood); color:var(--cream);
  padding:.2rem .55rem; border-radius:999px;
}
.mrow__price{
  font-family:var(--disp); font-size:1.75rem; color:var(--brass);
  line-height:1; white-space:nowrap;
}
.mrow__desc{ font-size:.86rem; grid-column:1; }
.mrow__time{
  grid-column:2; font-size:.72rem; letter-spacing:.1em;
  color:var(--smoke); text-align:right;
}
.menu__note{
  margin-top:2rem; font-size:.8rem; letter-spacing:.05em;
  color:var(--smoke); text-align:center;
}

/* ---------- barberi ---------- */
.barbers{ display:grid; grid-template-columns:repeat(3,1fr); gap:1.6rem; }
.bcard{
  background:var(--ink); border:1px solid var(--line); border-radius:var(--r);
  overflow:hidden; display:flex; flex-direction:column;
  transition:transform .25s ease, border-color .25s ease, box-shadow .25s ease;
  cursor:pointer;
}
.bcard:hover{ transform:translateY(-6px); border-color:rgba(201,162,75,.45); box-shadow:var(--shadow); }
.bcard__photo{ aspect-ratio:4/4.6; overflow:hidden; position:relative; }
.bcard__photo img{
  width:100%; height:100%; object-fit:cover;
  filter:grayscale(.85) contrast(1.04);
  transition:filter .45s ease, transform .45s ease;
}
.bcard:hover .bcard__photo img{ filter:grayscale(0); transform:scale(1.045); }
.bcard__rate{
  position:absolute; top:.9rem; right:.9rem;
  background:rgba(20,18,16,.82); backdrop-filter:blur(6px);
  border:1px solid var(--line); border-radius:999px;
  padding:.32rem .7rem; font-size:.8rem; display:flex; gap:.4rem; align-items:center;
}
.bcard__body{ padding:1.4rem 1.4rem 1.6rem; display:flex; flex-direction:column; gap:.7rem; flex:1; }
.bcard__name{ font-family:var(--disp); font-size:1.65rem; letter-spacing:.03em; line-height:1; }
.bcard__role{ font-size:.75rem; letter-spacing:.2em; text-transform:uppercase; color:var(--brass); }
.bcard__bio{ font-size:.9rem; flex:1; }
.tags{ display:flex; flex-wrap:wrap; gap:.4rem; }
.tag{
  font-size:.7rem; letter-spacing:.08em; color:var(--smoke);
  border:1px solid rgba(167,156,138,.35); border-radius:999px; padding:.25rem .65rem;
}
.bcard .btn{ width:100%; margin-top:.4rem; }
.bcard__gcal{
  font-size:.72rem; color:var(--smoke); text-align:center; letter-spacing:.04em;
}

/* ---------- typy strihov ---------- */
.cuts{ display:grid; grid-template-columns:repeat(4,1fr); gap:1.3rem; }
.cut{
  background:var(--coal); border:1px solid transparent; border-radius:var(--r);
  overflow:hidden; transition:transform .22s ease, border-color .22s ease;
}
.cut:hover{ transform:translateY(-5px); border-color:var(--line); }
.cut__img{ aspect-ratio:4/3.4; overflow:hidden; }
.cut__img img{ width:100%; height:100%; object-fit:cover; transition:transform .45s ease; }
.cut:hover .cut__img img{ transform:scale(1.06); }
.cut__body{ padding:1rem 1.1rem 1.25rem; }
.cut__name{ font-family:var(--disp); font-size:1.3rem; letter-spacing:.04em; }
.cut__desc{ font-size:.83rem; margin-top:.35rem; }

/* ---------- galéria ---------- */
.gallery{
  display:grid; grid-template-columns:repeat(4,1fr);
  grid-auto-rows:220px; gap:.9rem;
}
.gitem{
  position:relative; border-radius:10px; overflow:hidden; cursor:zoom-in;
}
.gitem:nth-child(1){ grid-row:span 2; }
.gitem:nth-child(4){ grid-row:span 2; }
.gitem:nth-child(6){ grid-column:span 2; }
.gitem img{
  width:100%; height:100%; object-fit:cover;
  transition:transform .5s ease;
}
.gitem:hover img{ transform:scale(1.06); }
.gitem figcaption{
  position:absolute; inset:auto 0 0 0; padding:2rem .9rem .8rem;
  font-size:.8rem; letter-spacing:.06em; color:var(--cream);
  background:linear-gradient(to top, rgba(20,18,16,.85), transparent);
  opacity:0; transform:translateY(8px); transition:.3s ease;
}
.gitem:hover figcaption{ opacity:1; transform:translateY(0); }

/* ---------- recenzie ---------- */
.reviews{ display:grid; grid-template-columns:repeat(3,1fr); gap:1.3rem; margin-bottom:3rem; }
.rcard{
  background:var(--coal); border:1px solid var(--line); border-radius:var(--r);
  padding:1.5rem 1.5rem 1.3rem; position:relative;
  display:flex; flex-direction:column; gap:.8rem;
}
.rcard::before{
  content:"„"; position:absolute; top:.2rem; right:1.1rem;
  font-family:var(--disp); font-size:4.5rem; color:rgba(201,162,75,.16); line-height:1;
}
.rcard__text{ font-size:.92rem; color:var(--cream); flex:1; }
.rcard__meta{ display:flex; justify-content:space-between; align-items:center; gap:.6rem; flex-wrap:wrap; }
.rcard__who strong{ display:block; font-size:.9rem; }
.rcard__who span{ font-size:.74rem; color:var(--smoke); letter-spacing:.05em; }
.stars{ display:inline-flex; gap:2px; }
.stars .star path{ fill:#3b362e; }
.stars .star.on path{ fill:var(--brass); }

/* formulár recenzie */
.review-form{
  max-width:640px; margin-inline:auto;
  background:var(--coal); border:1px solid rgba(201,162,75,.3);
  border-radius:var(--r); padding:2rem;
}
.form-row{ display:grid; grid-template-columns:1fr 1fr; gap:1rem; }
.field{ display:flex; flex-direction:column; gap:.4rem; margin-bottom:1rem; }
.field > span{
  font-size:.72rem; letter-spacing:.16em; text-transform:uppercase; color:var(--smoke);
}
.field input, .field select, .field textarea{
  font:inherit; color:var(--cream);
  background:var(--ink); border:1px solid rgba(167,156,138,.3);
  border-radius:10px; padding:.7rem .9rem; outline:none;
  transition:border-color .18s ease;
}
.field input:focus, .field select:focus, .field textarea:focus{ border-color:var(--brass); }
.field select option{ background:var(--ink); }
.field textarea{ resize:vertical; }
.starpick{ display:flex; gap:.35rem; }
.starpick button{ padding:.15rem; transition:transform .15s; }
.starpick button:hover{ transform:scale(1.15); }
.starpick svg path{ fill:#3b362e; transition:fill .15s; }
.starpick button.on svg path{ fill:var(--brass); }

/* ---------- kontakt ---------- */
.contact{ display:grid; grid-template-columns:.9fr 1.1fr; gap:1.6rem; }
.contact__card{
  background:var(--ink); border:1px solid var(--line); border-radius:var(--r);
  padding:2rem; display:flex; flex-direction:column; gap:1rem;
}
.contact__line a{ color:var(--cream); border-bottom:1px solid rgba(201,162,75,.35); }
.contact__line a:hover{ color:var(--brass-hi); }
.hours{ width:100%; border-collapse:collapse; font-size:.9rem; }
.hours td{ padding:.45rem 0; border-bottom:1px dashed rgba(167,156,138,.22); color:var(--smoke); }
.hours td:last-child{ text-align:right; color:var(--cream); }
.hours tr.today td{ color:var(--brass-hi); font-weight:500; }
.contact__map{ border-radius:var(--r); overflow:hidden; min-height:420px; border:1px solid var(--line); }
.contact__map iframe{ width:100%; height:100%; border:0; filter:grayscale(.35) contrast(1.05); }

/* ---------- footer ---------- */
.footer{ background:var(--coal); border-top:1px solid var(--line); }
.footer__in{
  display:grid; grid-template-columns:1.2fr 1fr auto;
  gap:2rem; padding:3.2rem 0 2.2rem; align-items:start;
}
.logo__txt--foot{ font-size:1.9rem; }
.footer__claim{ margin-top:.6rem; font-size:.9rem; }
.footer__links{ display:flex; flex-direction:column; gap:.5rem; }
.footer__links a{ color:var(--smoke); font-size:.9rem; }
.footer__links a:hover{ color:var(--brass-hi); }
.footer__admin p{ font-size:.75rem; letter-spacing:.16em; text-transform:uppercase; margin-bottom:.6rem; }
.footer__bar{
  display:flex; justify-content:space-between; gap:1rem; flex-wrap:wrap;
  padding:1.1rem 0; border-top:1px solid rgba(167,156,138,.14);
  font-size:.75rem; color:var(--smoke); letter-spacing:.04em;
}

/* ---------- modal (rezervácia) ---------- */
.modal{ position:fixed; inset:0; z-index:100; display:none; }
.modal.open{ display:block; }
.modal__backdrop{ position:absolute; inset:0; background:rgba(10,9,8,.78); backdrop-filter:blur(5px); }
.modal__card{
  position:relative; z-index:1;
  width:min(660px, calc(100% - 2rem));
  max-height:calc(100dvh - 3rem); overflow:auto;
  margin:1.5rem auto; background:var(--coal);
  border:1px solid var(--line); border-radius:18px;
  padding:2rem; animation:fadeUp .3s ease both;
}
.modal__x{
  position:absolute; top:1rem; right:1rem; color:var(--smoke);
  font-size:1rem; padding:.5rem; z-index:2;
}
.modal__x:hover{ color:var(--cream); }
.modal__head{ margin-bottom:1.4rem; padding-right:2rem; }
.steps{
  display:flex; gap:.4rem; list-style:none; margin-top:1.1rem; flex-wrap:wrap;
}
.steps li{
  font-size:.7rem; letter-spacing:.12em; text-transform:uppercase;
  color:var(--smoke); padding:.35rem .7rem; border-radius:999px;
  border:1px solid rgba(167,156,138,.25); counter-increment:step;
}
.steps li.active{ color:var(--ink); background:var(--brass); border-color:var(--brass); font-weight:700; }
.steps li.donee{ color:var(--brass); border-color:rgba(201,162,75,.5); }
.modal__foot{ display:flex; justify-content:space-between; gap:.8rem; margin-top:1.6rem; flex-wrap:wrap; }

/* výber barbera / služby v modáli */
.choice{ display:grid; gap:.7rem; }
.choice--barbers{ grid-template-columns:repeat(3,1fr); }
.chip-barber{
  border:1px solid rgba(167,156,138,.3); border-radius:12px;
  padding:.9rem .6rem; text-align:center; transition:.18s ease;
  display:flex; flex-direction:column; align-items:center; gap:.55rem;
}
.chip-barber img{ width:64px; height:64px; border-radius:50%; object-fit:cover; filter:grayscale(.6); }
.chip-barber strong{ font-size:.9rem; line-height:1.2; }
.chip-barber span{ font-size:.68rem; color:var(--smoke); letter-spacing:.08em; text-transform:uppercase; }
.chip-barber:hover{ border-color:var(--brass); transform:translateY(-2px); }
.chip-barber.sel{ border-color:var(--brass); background:rgba(201,162,75,.08); }
.chip-barber.sel img{ filter:none; }

.srow{
  display:flex; align-items:center; gap:1rem; text-align:left;
  border:1px solid rgba(167,156,138,.3); border-radius:12px;
  padding:.85rem 1rem; transition:.18s ease; width:100%;
}
.srow:hover{ border-color:var(--brass); }
.srow.sel{ border-color:var(--brass); background:rgba(201,162,75,.08); }
.srow__info{ flex:1; }
.srow__info strong{ display:block; font-size:.95rem; }
.srow__info small{ color:var(--smoke); font-size:.78rem; }
.srow__price{ font-family:var(--disp); font-size:1.4rem; color:var(--brass); }

/* termín */
.datebar{ display:flex; gap:.5rem; overflow-x:auto; padding-bottom:.6rem; margin-bottom:1.1rem; }
.datebar::-webkit-scrollbar{ height:6px; }
.datebar::-webkit-scrollbar-thumb{ background:rgba(167,156,138,.3); border-radius:3px; }
.dchip{
  min-width:74px; text-align:center; border:1px solid rgba(167,156,138,.3);
  border-radius:10px; padding:.55rem .5rem; transition:.18s ease; flex-shrink:0;
}
.dchip small{ display:block; font-size:.66rem; letter-spacing:.1em; text-transform:uppercase; color:var(--smoke); }
.dchip strong{ font-family:var(--disp); font-size:1.15rem; letter-spacing:.04em; }
.dchip:hover:not(:disabled){ border-color:var(--brass); }
.dchip.sel{ border-color:var(--brass); background:rgba(201,162,75,.1); }
.dchip:disabled{ opacity:.35; cursor:not-allowed; }
.slots{ display:grid; grid-template-columns:repeat(auto-fill, minmax(84px,1fr)); gap:.55rem; }
.slot{
  border:1px solid rgba(167,156,138,.3); border-radius:9px;
  padding:.55rem 0; text-align:center; font-size:.9rem; transition:.15s ease;
}
.slot:hover:not(:disabled){ border-color:var(--brass); color:var(--brass-hi); }
.slot.sel{ background:var(--brass); color:var(--ink); border-color:var(--brass); font-weight:700; }
.slot:disabled{ opacity:.32; text-decoration:line-through; cursor:not-allowed; }
.slots-empty{ color:var(--smoke); font-size:.9rem; padding:.6rem 0; }

/* zhrnutie + úspech */
.sumbox{
  background:var(--ink); border:1px dashed rgba(201,162,75,.4);
  border-radius:12px; padding:1.1rem 1.2rem; margin-bottom:1.2rem;
  display:grid; gap:.35rem; font-size:.92rem;
}
.sumbox div{ display:flex; justify-content:space-between; gap:1rem; }
.sumbox span{ color:var(--smoke); }
.sumbox b{ color:var(--cream); text-align:right; }
.success{ text-align:center; padding:1rem 0 .4rem; }
.success__icon{
  width:64px; height:64px; margin:0 auto 1rem; border-radius:50%;
  background:rgba(127,176,105,.15); border:1px solid rgba(127,176,105,.5);
  display:flex; align-items:center; justify-content:center;
  color:#9ccc85; font-size:1.7rem;
}
.success p{ max-width:26rem; margin-inline:auto; }
.success .btn{ margin-top:1.2rem; }
.success__hint{ font-size:.78rem !important; margin-top:1rem !important; }

/* ---------- stavové odznaky (zdieľané s adminom) ---------- */
.badge{
  display:inline-flex; align-items:center; gap:.35rem;
  font-size:.68rem; letter-spacing:.1em; text-transform:uppercase;
  padding:.28rem .65rem; border-radius:999px; border:1px solid; white-space:nowrap;
}
.st-pending{   color:#e9c46a; border-color:rgba(233,196,106,.5); background:rgba(233,196,106,.08); }
.st-confirmed{ color:#9ccc85; border-color:rgba(156,204,133,.5); background:rgba(156,204,133,.08); }
.st-done{      color:var(--brass-hi); border-color:rgba(201,162,75,.5); background:rgba(201,162,75,.08); }
.st-declined{  color:#e0a196; border-color:rgba(224,161,150,.5); background:rgba(142,59,47,.14); }
.st-cancelled{ color:var(--smoke); border-color:rgba(167,156,138,.4); background:rgba(167,156,138,.08); }
.st-moved{     color:#a4c3e3; border-color:rgba(164,195,227,.5); background:rgba(164,195,227,.08); }

/* ---------- toasty ---------- */
#toasts{
  position:fixed; bottom:1.2rem; left:50%; transform:translateX(-50%);
  display:flex; flex-direction:column; gap:.6rem; z-index:200; width:min(420px, 92vw);
}
.toast{
  background:var(--coal); border:1px solid var(--line); border-left:3px solid var(--brass);
  color:var(--cream); border-radius:10px; padding:.85rem 1.1rem;
  font-size:.9rem; box-shadow:var(--shadow);
  opacity:0; transform:translateY(12px); transition:.3s ease;
}
.toast--err{ border-left-color:var(--oxblood); }
.toast.in{ opacity:1; transform:translateY(0); }

/* ---------- lightbox ---------- */
.lightbox{
  position:fixed; inset:0; z-index:150; display:none;
  align-items:center; justify-content:center; gap:1rem;
  background:rgba(10,9,8,.92); padding:2rem;
}
.lightbox.open{ display:flex; }
.lightbox figure{ max-width:min(900px, 88vw); text-align:center; }
.lightbox img{ max-height:78vh; width:auto; max-width:100%; margin-inline:auto; border-radius:10px; }
.lightbox figcaption{ margin-top:.8rem; color:var(--smoke); font-size:.85rem; letter-spacing:.06em; }
.lightbox__x{ position:absolute; top:1.2rem; right:1.5rem; font-size:1.3rem; color:var(--smoke); }
.lightbox__x:hover{ color:var(--cream); }
.lightbox__nav{
  font-size:2.6rem; color:var(--smoke); padding:1rem .6rem; line-height:1; flex-shrink:0;
}
.lightbox__nav:hover{ color:var(--brass); }

/* ---------- reveal on scroll ---------- */
.reveal{ opacity:0; transform:translateY(26px); transition:opacity .7s ease, transform .7s ease; }
.reveal.in{ opacity:1; transform:none; }

/* ---------- prístupnosť ---------- */
:focus-visible{ outline:2px solid var(--brass); outline-offset:2px; border-radius:4px; }
@media (prefers-reduced-motion: reduce){
  *, *::before, *::after{ animation:none !important; transition:none !important; }
  html{ scroll-behavior:auto; }
  .reveal{ opacity:1; transform:none; }
}

/* ---------- responzivita ---------- */
@media (max-width: 1020px){
  .barbers{ grid-template-columns:repeat(3,1fr); gap:1rem; }
  .cuts{ grid-template-columns:repeat(3,1fr); }
  .reviews{ grid-template-columns:repeat(2,1fr); }
  .gallery{ grid-template-columns:repeat(3,1fr); }
  .gitem:nth-child(6){ grid-column:auto; }
}
@media (max-width: 860px){
  .nav__links{
    position:fixed; inset:0 0 auto 0; top:0; padding:5.5rem 2rem 2.2rem;
    background:rgba(20,18,16,.97); backdrop-filter:blur(16px);
    flex-direction:column; gap:1.1rem; font-size:1.1rem;
    transform:translateY(-105%); transition:transform .3s ease; z-index:-1;
  }
  .nav__links.open{ transform:translateY(0); }
  .burger{ display:flex; }
  .openchip{ display:none; }
  .grid2{ grid-template-columns:1fr; }
  .about__imgs{ min-height:380px; }
  .menu{ grid-template-columns:1fr; }
  .barbers{ grid-template-columns:1fr; max-width:440px; margin-inline:auto; }
  .contact{ grid-template-columns:1fr; }
  .contact__map{ min-height:320px; }
  .footer__in{ grid-template-columns:1fr; gap:1.6rem; }
  .choice--barbers{ grid-template-columns:1fr; }
  .chip-barber{ flex-direction:row; text-align:left; }
  .chip-barber div{ display:flex; flex-direction:column; }
}
@media (max-width: 620px){
  .cuts{ grid-template-columns:repeat(2,1fr); }
  .reviews{ grid-template-columns:1fr; }
  .gallery{ grid-template-columns:repeat(2,1fr); grid-auto-rows:170px; }
  .stats{ grid-template-columns:repeat(2,1fr); gap:1.2rem; }
  .form-row{ grid-template-columns:1fr; }
  .hero__meta{ font-size:.78rem; }
  .modal__card{ padding:1.4rem; }
}
