/* =========================================================
   DJ WILLY — system wizualny
   Czerń + złoto + krem · Cormorant Garamond + Hanken Grotesk
   ========================================================= */

:root{
  --ink:        #100c08;   /* ciepła czerń */
  --ink-2:      #1a130d;   /* karty na ciemnym */
  --ink-3:      #241a11;   /* hover / obwódki */
  --cream:      #f6f1e8;   /* sekcje jasne */
  --cream-2:    #efe7d8;   /* karty na jasnym */
  --paper-line: #e4d8c2;

  --gold:       #c6a052;
  --gold-soft:  #d8b977;
  --gold-bright:#ecd29a;
  --gold-deep:  #9c7a36;

  --txt-d:      #f4ede0;   /* tekst na ciemnym */
  --txt-d-mut:  #b6a88f;   /* przygaszony na ciemnym */
  --txt-l:      #2a2018;   /* tekst na jasnym */
  --txt-l-mut:  #6f6353;   /* przygaszony na jasnym */

  --maxw: 1240px;
  --r: 4px;
  --ease: cubic-bezier(.22,.61,.36,1);

  --serif: "Cormorant Garamond", Georgia, serif;
  --sans: "Hanken Grotesk", system-ui, sans-serif;
}

*{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  font-family:var(--sans);
  background:var(--ink);
  color:var(--txt-d);
  line-height:1.6;
  font-size:17px;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
img{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; cursor:pointer; border:none; background:none; color:inherit; }
::selection{ background:var(--gold); color:var(--ink); }

/* ---------- typografia ---------- */
.eyebrow{
  font-family:var(--sans);
  font-size:12.5px; font-weight:700;
  letter-spacing:.32em; text-transform:uppercase;
  color:var(--gold);
  display:inline-flex; align-items:center; gap:.7em;
}
.eyebrow::before{
  content:""; width:30px; height:1px; background:var(--gold); opacity:.6;
}
.eyebrow.center::after{
  content:""; width:30px; height:1px; background:var(--gold); opacity:.6;
}
h1,h2,h3,h4{ font-family:var(--serif); font-weight:600; line-height:1.04; letter-spacing:-.01em; }
.display{ font-size:clamp(44px, 7vw, 92px); font-weight:600; }
.h2{ font-size:clamp(34px, 4.6vw, 60px); }
.section-title{ font-size:clamp(32px,4.4vw,56px); }
.lead{ font-size:clamp(18px,2vw,21px); color:var(--txt-d-mut); font-weight:400; }

/* ---------- layout ---------- */
.wrap{ width:100%; max-width:var(--maxw); margin:0 auto; padding:0 28px; }
section{ position:relative; }
.section{ padding:clamp(72px,10vw,128px) 0; }
.light{ background:var(--cream); color:var(--txt-l); }
.light .lead{ color:var(--txt-l-mut); }
.light .eyebrow{ color:var(--gold-deep); }
.light .eyebrow::before,.light .eyebrow.center::after{ background:var(--gold-deep); }

.sec-head{ max-width:720px; }
.sec-head.center{ margin:0 auto; text-align:center; }
.sec-head .eyebrow{ margin-bottom:20px; }
.sec-head p{ margin-top:18px; }

/* ---------- buttons ---------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:.6em;
  font-weight:600; font-size:15px; letter-spacing:.02em;
  padding:16px 30px; border-radius:var(--r);
  transition:.35s var(--ease);
  white-space:nowrap;
}
.btn-gold{
  background:linear-gradient(180deg,var(--gold-soft),var(--gold));
  color:#15100a; box-shadow:0 10px 30px -12px rgba(198,160,82,.6);
}
.btn-gold:hover{ transform:translateY(-2px); box-shadow:0 16px 38px -12px rgba(198,160,82,.75); }
.btn-ghost{ border:1px solid rgba(198,160,82,.45); color:var(--txt-d); }
.btn-ghost:hover{ border-color:var(--gold); background:rgba(198,160,82,.08); }
.light .btn-ghost{ color:var(--txt-l); border-color:rgba(156,122,54,.4); }
.light .btn-ghost:hover{ background:rgba(156,122,54,.07); }
.btn .arr{ transition:transform .35s var(--ease); }
.btn:hover .arr{ transform:translateX(4px); }

/* =========================================================
   HEADER
   ========================================================= */
.header{
  position:fixed; top:0; left:0; right:0; z-index:60;
  transition:.4s var(--ease);
  padding:18px 0;
}
.header::before{
  content:""; position:absolute; inset:0;
  background:rgba(16,12,8,0); backdrop-filter:blur(0px);
  border-bottom:1px solid rgba(198,160,82,0);
  transition:.4s var(--ease); pointer-events:none;
}
.header.scrolled{ padding:11px 0; }
.header.scrolled::before{
  background:rgba(16,12,8,.82); backdrop-filter:blur(14px) saturate(1.2);
  border-bottom:1px solid rgba(198,160,82,.16);
}
.nav{ display:flex; align-items:center; justify-content:space-between; gap:24px; position:relative; }
.brand{ display:flex; align-items:center; gap:11px; flex-shrink:0; z-index:2; }
.brand-logo{ height:66px; width:auto; display:block; transition:.4s var(--ease); filter:drop-shadow(0 2px 6px rgba(0,0,0,.35)); }
.header.scrolled .brand-logo{ height:54px; }
.brand-foot{ margin-bottom:20px; }
.brand-foot .brand-logo{ height:78px; }
.nav-links{ display:flex; align-items:center; gap:34px; }
.nav-links a{
  font-size:14px; font-weight:500; letter-spacing:.02em; color:var(--txt-d);
  opacity:.82; transition:.25s; position:relative; padding:4px 0;
}
.nav-links a::after{
  content:""; position:absolute; left:0; bottom:-2px; width:0; height:1px;
  background:var(--gold); transition:width .3s var(--ease);
}
.nav-links a:hover{ opacity:1; }
.nav-links a:hover::after{ width:100%; }
.nav-cta{ display:flex; align-items:center; gap:16px; }
.nav-phone{ font-size:14px; font-weight:600; color:var(--gold-soft); display:flex; align-items:center; gap:7px; }
.nav-phone svg{ width:15px; height:15px; }
.header .btn{ padding:11px 22px; font-size:14px; }

.burger{ display:none; width:44px; height:44px; align-items:center; justify-content:center; z-index:2; }
.burger span{ display:block; width:24px; height:2px; background:var(--txt-d); position:relative; transition:.3s; }
.burger span::before,.burger span::after{ content:""; position:absolute; left:0; width:24px; height:2px; background:var(--txt-d); transition:.3s; }
.burger span::before{ top:-7px; } .burger span::after{ top:7px; }
.burger.open span{ background:transparent; }
.burger.open span::before{ top:0; transform:rotate(45deg); }
.burger.open span::after{ top:0; transform:rotate(-45deg); }

/* mobile menu */
.m-menu{
  position:fixed; inset:0; z-index:55;
  background:rgba(12,9,6,.97); backdrop-filter:blur(8px);
  display:flex; flex-direction:column; justify-content:center; align-items:center; gap:8px;
  opacity:0; pointer-events:none; transition:.4s var(--ease);
}
.m-menu.open{ opacity:1; pointer-events:auto; }
.m-menu a{ font-family:var(--serif); font-size:34px; padding:10px; opacity:.9; }
.m-menu .btn{ margin-top:24px; }
.m-menu .m-phone{ margin-top:28px; color:var(--gold-soft); font-weight:600; letter-spacing:.05em; }

/* =========================================================
   HERO
   ========================================================= */
.hero{ position:relative; min-height:100svh; display:flex; align-items:center; overflow:hidden; background:var(--ink); }
.hero-slides{ position:absolute; inset:0; z-index:0; }
.hero-slide{
  position:absolute; inset:0; opacity:0; transition:opacity 1.4s var(--ease);
  background-size:cover; background-position:center 28%; transform:scale(1.06);
}
.hero-slide.active{ opacity:1; animation:heroZoom 9s ease-out forwards; }
@keyframes heroZoom{ from{ transform:scale(1.12);} to{ transform:scale(1.0);} }
.hero-veil{
  position:absolute; inset:0; z-index:1;
  background:
    linear-gradient(90deg, rgba(13,10,7,.94) 0%, rgba(13,10,7,.72) 38%, rgba(13,10,7,.28) 66%, rgba(13,10,7,.55) 100%),
    linear-gradient(0deg, rgba(13,10,7,.92) 2%, rgba(13,10,7,0) 36%);
}
.hero-grain{ position:absolute; inset:0; z-index:2; opacity:.5; pointer-events:none;
  background-image:radial-gradient(rgba(255,255,255,.018) 1px, transparent 1px); background-size:3px 3px; }
.hero .wrap{ position:relative; z-index:3; width:100%; }
.hero-inner{ max-width:760px; padding:120px 0 64px; }
.hero .eyebrow{ margin-bottom:26px; }
.hero h1{ margin-bottom:8px; }
.hero h1 .it{ font-style:italic; color:var(--gold-bright); font-weight:500; }
.hero-sub{ font-size:clamp(18px,2.1vw,22px); color:var(--txt-d-mut); max-width:560px; margin:24px 0 38px; }
.hero-cta{ display:flex; flex-wrap:wrap; gap:14px; align-items:center; }
.hero-trust{ display:flex; align-items:center; gap:26px; margin-top:46px; flex-wrap:wrap; }
.hero-trust .stars{ color:var(--gold-soft); letter-spacing:2px; font-size:18px; }
.hero-trust .ht-item{ display:flex; flex-direction:column; gap:2px; }
.hero-trust .ht-num{ font-family:var(--serif); font-size:30px; line-height:1; color:var(--txt-d); }
.hero-trust .ht-lab{ font-size:12px; letter-spacing:.12em; text-transform:uppercase; color:var(--txt-d-mut); }
.hero-trust .divider{ width:1px; height:38px; background:rgba(198,160,82,.28); }

.hero-dots{ position:absolute; right:32px; bottom:38px; z-index:4; display:flex; gap:10px; }
.hero-dots button{ width:34px; height:3px; background:rgba(255,255,255,.25); border-radius:2px; transition:.3s; }
.hero-dots button.on{ background:var(--gold); }
.scroll-hint{ position:absolute; left:50%; bottom:26px; transform:translateX(-50%); z-index:4;
  font-size:11px; letter-spacing:.28em; text-transform:uppercase; color:var(--txt-d-mut);
  display:flex; flex-direction:column; align-items:center; gap:8px; }
.scroll-hint .line{ width:1px; height:34px; background:linear-gradient(var(--gold),transparent); animation:scrollLine 2s ease-in-out infinite; }
@keyframes scrollLine{ 0%,100%{ opacity:.3; transform:scaleY(.6);} 50%{ opacity:1; transform:scaleY(1);} }

/* =========================================================
   MARQUEE / liczby
   ========================================================= */
.stats-bar{ background:var(--ink-2); border-top:1px solid rgba(198,160,82,.14); border-bottom:1px solid rgba(198,160,82,.14); }
.stats-grid{ display:grid; grid-template-columns:repeat(4,1fr); }
.stat{ padding:42px 24px; text-align:center; border-right:1px solid rgba(198,160,82,.12); }
.stat:last-child{ border-right:none; }
.stat .num{ font-family:var(--serif); font-size:clamp(40px,5vw,58px); line-height:1; color:var(--gold-soft); }
.stat .lab{ margin-top:10px; font-size:13px; letter-spacing:.14em; text-transform:uppercase; color:var(--txt-d-mut); }

/* =========================================================
   ABOUT
   ========================================================= */
.about-grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(40px,6vw,90px); align-items:center; }
.about-figure{ position:relative; }
.about-figure img{ width:100%; border-radius:var(--r); filter:saturate(1.02); }
.about-figure .frame{ position:absolute; inset:-14px -14px 14px 14px; border:1px solid rgba(156,122,54,.5); border-radius:var(--r); z-index:-1; }
.about-figure .sig{ position:absolute; right:18px; bottom:18px; font-family:var(--serif); font-style:italic; font-size:34px; color:var(--cream);
  text-shadow:0 2px 18px rgba(0,0,0,.6); }
.about-body h2{ margin:18px 0 22px; }
.about-body p{ color:var(--txt-l-mut); margin-bottom:18px; font-size:18px; }
.about-quote{ font-family:var(--serif); font-style:italic; font-size:24px; line-height:1.4; color:var(--txt-l); padding-left:22px; border-left:2px solid var(--gold); margin:28px 0; }
.about-meta{ display:flex; gap:34px; flex-wrap:wrap; margin-top:30px; }
.about-meta .m .k{ font-family:var(--serif); font-size:26px; color:var(--gold-deep); }
.about-meta .m .v{ font-size:13px; letter-spacing:.1em; text-transform:uppercase; color:var(--txt-l-mut); }

/* =========================================================
   OFERTA / pakiety
   ========================================================= */
.pkg-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; margin-top:56px; align-items:stretch; }
.pkg{
  position:relative; display:flex; flex-direction:column;
  background:var(--ink-2); border:1px solid rgba(198,160,82,.16);
  border-radius:6px; padding:38px 30px; transition:.4s var(--ease);
}
.pkg:hover{ transform:translateY(-6px); border-color:rgba(198,160,82,.4); }
.pkg.featured{
  background:linear-gradient(180deg,#241a0f, #181009);
  border-color:rgba(198,160,82,.55); box-shadow:0 30px 70px -30px rgba(0,0,0,.7);
}
.pkg .ribbon{ position:absolute; top:-1px; right:24px; transform:translateY(-50%);
  background:linear-gradient(180deg,var(--gold-bright),var(--gold)); color:#15100a;
  font-size:11px; font-weight:700; letter-spacing:.14em; text-transform:uppercase;
  padding:7px 14px; border-radius:3px; }
.pkg .p-tag{ font-size:12px; letter-spacing:.18em; text-transform:uppercase; color:var(--gold-soft); }
.pkg .p-name{ font-family:var(--serif); font-size:42px; margin:8px 0 4px; }
.pkg .p-desc{ font-size:15px; color:var(--txt-d-mut); min-height:44px; }
.pkg .p-price{ display:flex; align-items:baseline; gap:8px; margin:24px 0 4px; padding-top:24px; border-top:1px solid rgba(198,160,82,.16); }
.pkg .p-price .from{ font-size:13px; color:var(--txt-d-mut); }
.pkg .p-price .amt{ font-family:var(--serif); font-size:46px; line-height:1; color:var(--txt-d); }
.pkg .p-price .cur{ font-size:18px; color:var(--gold-soft); align-self:flex-start; margin-top:6px; }
.pkg .p-note{ font-size:13px; color:var(--txt-d-mut); margin-bottom:26px; }
.pkg ul{ list-style:none; display:flex; flex-direction:column; gap:13px; margin-bottom:30px; flex:1; }
.pkg li{ display:flex; gap:11px; font-size:15px; align-items:flex-start; }
.pkg li svg{ width:18px; height:18px; flex-shrink:0; margin-top:2px; }
.pkg li.off{ color:var(--txt-d-mut); opacity:.55; }
.pkg .btn{ width:100%; }
.pkg-foot{ text-align:center; margin-top:30px; font-size:15px; color:var(--txt-d-mut); }
.pkg-foot b{ color:var(--gold-soft); font-weight:600; }

/* addons */
.addons{ display:grid; grid-template-columns:repeat(3,1fr); gap:1px; margin-top:60px; background:rgba(198,160,82,.16);
  border:1px solid rgba(198,160,82,.16); border-radius:6px; overflow:hidden; }
.addon{ background:var(--ink); padding:30px 26px; transition:.3s; }
.addon:hover{ background:var(--ink-2); }
.addon .a-ic{ width:34px; height:34px; color:var(--gold-soft); margin-bottom:16px; }
.addon h4{ font-size:21px; margin-bottom:7px; }
.addon p{ font-size:14.5px; color:var(--txt-d-mut); }

/* =========================================================
   GALERIA zdjęć
   ========================================================= */
.gal-grid{ display:grid; grid-template-columns:repeat(12,1fr); grid-auto-rows:170px; gap:14px; margin-top:54px; }
.gal-item{ position:relative; overflow:hidden; border-radius:5px; cursor:pointer; }
.gal-item img{ width:100%; height:100%; object-fit:cover; transition:transform .9s var(--ease); }
.gal-item::after{ content:""; position:absolute; inset:0; background:linear-gradient(0deg,rgba(16,12,8,.5),transparent 60%); opacity:0; transition:.4s; }
.gal-item:hover img{ transform:scale(1.07); }
.gal-item:hover::after{ opacity:1; }
.gal-item .zoom{ position:absolute; right:14px; bottom:14px; width:40px; height:40px; border:1px solid rgba(255,255,255,.5);
  border-radius:50%; display:flex; align-items:center; justify-content:center; color:#fff; opacity:0; transform:translateY(8px); transition:.4s; }
.gal-item:hover .zoom{ opacity:1; transform:none; }
.g-a{ grid-column:span 5; grid-row:span 2; }
.g-b{ grid-column:span 4; grid-row:span 2; }
.g-c{ grid-column:span 3; grid-row:span 2; }
.g-d{ grid-column:span 4; grid-row:span 2; }
.g-e{ grid-column:span 4; grid-row:span 2; }
.g-f{ grid-column:span 4; grid-row:span 2; }

/* =========================================================
   GALERIA video (pionowe)
   ========================================================= */
.vid-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:20px; margin-top:54px; }
.vid{ position:relative; aspect-ratio:9/16; border-radius:10px; overflow:hidden; cursor:pointer;
  background:var(--ink-3); border:1px solid rgba(198,160,82,.16); }
.vid img{ width:100%; height:100%; object-fit:cover; transition:transform .8s var(--ease); }
.vid::after{ content:""; position:absolute; inset:0; background:linear-gradient(0deg,rgba(16,12,8,.85),rgba(16,12,8,.05) 50%); }
.vid:hover img{ transform:scale(1.06); }
.vid .play{ position:absolute; top:50%; left:50%; transform:translate(-50%,-50%); z-index:2;
  width:62px; height:62px; border-radius:50%; background:rgba(198,160,82,.92); color:#15100a;
  display:flex; align-items:center; justify-content:center; transition:.35s; box-shadow:0 8px 30px rgba(0,0,0,.45); }
.vid:hover .play{ transform:translate(-50%,-50%) scale(1.1); background:var(--gold-bright); }
.vid .v-lab{ position:absolute; left:16px; right:16px; bottom:16px; z-index:2; font-size:14px; font-weight:600; color:#fff; }
.vid .v-tag{ position:absolute; top:14px; left:14px; z-index:2; font-size:10.5px; letter-spacing:.14em; text-transform:uppercase;
  color:var(--gold-bright); border:1px solid rgba(236,210,154,.4); padding:4px 9px; border-radius:20px; background:rgba(16,12,8,.4); }

/* =========================================================
   OPINIE
   ========================================================= */
.rev-top{ display:flex; align-items:flex-end; justify-content:space-between; gap:30px; flex-wrap:wrap; }
.rev-score{ display:flex; align-items:center; gap:20px; }
.rev-score .big{ font-family:var(--serif); font-size:72px; line-height:.9; color:var(--gold-deep); }
.rev-score .stars{ color:var(--gold); letter-spacing:3px; font-size:20px; }
.rev-score .sub{ font-size:14px; color:var(--txt-l-mut); margin-top:4px; }
.rev-grid{ columns:3; column-gap:22px; margin-top:50px; }
.rev{ break-inside:avoid; background:#fff; border:1px solid var(--paper-line); border-radius:8px; padding:28px 26px; margin-bottom:22px;
  box-shadow:0 14px 36px -28px rgba(60,40,10,.4); }
.rev .stars{ color:var(--gold); letter-spacing:2px; font-size:15px; margin-bottom:14px; }
.rev p{ font-size:15.5px; color:var(--txt-l); line-height:1.62; }
.rev .who{ display:flex; align-items:center; gap:12px; margin-top:20px; }
.rev .av{ width:40px; height:40px; border-radius:50%; background:linear-gradient(135deg,var(--gold-soft),var(--gold-deep)); color:#fff;
  display:flex; align-items:center; justify-content:center; font-family:var(--serif); font-size:19px; flex-shrink:0; }
.rev .nm{ font-weight:600; font-size:15px; color:var(--txt-l); }
.rev .sr{ font-size:12.5px; color:var(--txt-l-mut); }

/* =========================================================
   FAQ
   ========================================================= */
.faq-grid{ display:grid; grid-template-columns:1fr 1.3fr; gap:clamp(40px,6vw,80px); align-items:start; }
.faq-list{ border-top:1px solid rgba(198,160,82,.18); }
.faq-item{ border-bottom:1px solid rgba(198,160,82,.18); }
.faq-q{ width:100%; display:flex; align-items:center; justify-content:space-between; gap:20px; text-align:left;
  padding:24px 0; font-family:var(--serif); font-size:23px; color:var(--txt-d); transition:.3s; }
.faq-q:hover{ color:var(--gold-soft); }
.faq-q .ic{ width:26px; height:26px; flex-shrink:0; position:relative; }
.faq-q .ic::before,.faq-q .ic::after{ content:""; position:absolute; top:50%; left:50%; transform:translate(-50%,-50%); background:var(--gold); }
.faq-q .ic::before{ width:14px; height:1.5px; }
.faq-q .ic::after{ width:1.5px; height:14px; transition:.3s; }
.faq-item.open .ic::after{ transform:translate(-50%,-50%) scaleY(0); }
.faq-a{ max-height:0; overflow:hidden; transition:max-height .45s var(--ease); }
.faq-a p{ padding:0 0 26px; color:var(--txt-d-mut); font-size:16px; max-width:90%; }

/* =========================================================
   BOOKING / rezerwacja
   ========================================================= */
.book{ background:linear-gradient(180deg,#0c0906,#140d07); }
.book-card{ background:var(--ink-2); border:1px solid rgba(198,160,82,.2); border-radius:14px; overflow:hidden;
  box-shadow:0 50px 120px -50px rgba(0,0,0,.8); margin-top:54px; }
.steps-head{ display:grid; grid-template-columns:repeat(3,1fr); border-bottom:1px solid rgba(198,160,82,.16); }
.shead{ display:flex; align-items:center; gap:14px; padding:22px 26px; border-right:1px solid rgba(198,160,82,.12); transition:.3s; }
.shead:last-child{ border-right:none; }
.shead .n{ width:34px; height:34px; border-radius:50%; border:1px solid rgba(198,160,82,.4); color:var(--gold-soft);
  display:flex; align-items:center; justify-content:center; font-size:15px; font-weight:700; flex-shrink:0; transition:.3s; }
.shead .st{ font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:var(--txt-d-mut); }
.shead .sl{ font-family:var(--serif); font-size:19px; color:var(--txt-d); line-height:1.1; }
.shead.active{ background:rgba(198,160,82,.07); }
.shead.active .n{ background:var(--gold); color:#15100a; border-color:var(--gold); }
.shead.done .n{ background:rgba(198,160,82,.18); border-color:var(--gold); color:var(--gold-bright); }
.book-body{ padding:clamp(28px,4vw,48px); }
.step-pane{ display:none; }
.step-pane.active{ display:block; animation:fade .5s var(--ease); }
@keyframes fade{ from{ opacity:0; transform:translateY(10px);} to{ opacity:1; transform:none;} }
.pane-title{ font-family:var(--serif); font-size:clamp(26px,3vw,36px); margin-bottom:8px; }
.pane-sub{ color:var(--txt-d-mut); margin-bottom:32px; font-size:16px; }

/* calendar — widok roku */
.year-cal{ background:var(--ink); border:1px solid rgba(198,160,82,.16); border-radius:12px; padding:24px clamp(18px,2.4vw,28px); }
.year-nav{ display:flex; align-items:center; justify-content:center; gap:26px; margin-bottom:6px; }
.year-nav button{ width:42px; height:42px; border-radius:50%; border:1px solid rgba(198,160,82,.25); color:var(--gold-soft); display:flex; align-items:center; justify-content:center; transition:.3s; }
.year-nav button:hover:not(:disabled){ background:rgba(198,160,82,.12); border-color:var(--gold); }
.year-nav button:disabled{ opacity:.22; cursor:not-allowed; }
.year-nav .ylabel{ font-family:var(--serif); font-size:38px; letter-spacing:.02em; min-width:120px; text-align:center; }
.year-legend{ display:flex; align-items:center; justify-content:center; gap:22px; flex-wrap:wrap; font-size:12.5px; color:var(--txt-d-mut); margin-bottom:22px; }
.year-legend i{ width:11px; height:11px; border-radius:3px; display:inline-block; margin-right:6px; vertical-align:-1px; }
.lg-free i{ background:rgba(120,180,110,.55); }
.lg-busy i{ background:rgba(170,90,80,.5); position:relative; }
.lg-note{ opacity:.8; }
.lg-note::before{ content:""; display:inline-block; width:11px; height:11px; border-radius:3px; border:1px solid rgba(198,160,82,.35); margin-right:6px; vertical-align:-1px; }

.months-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:10px clamp(12px,1.6vw,22px); }
.mini{ padding:4px 2px; }
.mini-past{ opacity:.4; }
.mini-name{ font-family:var(--serif); font-size:18px; text-transform:capitalize; margin-bottom:8px; color:var(--gold-bright); }
.mini-dow{ display:grid; grid-template-columns:repeat(7,1fr); margin-bottom:4px; }
.mini-dow span{ text-align:center; font-size:9.5px; letter-spacing:.02em; text-transform:uppercase; color:#6a5c48; }
.mini-days{ display:grid; grid-template-columns:repeat(7,1fr); gap:2px; }
.md{ aspect-ratio:1; display:flex; align-items:center; justify-content:center; font-size:12px; border-radius:5px;
  position:relative; transition:.18s; color:var(--txt-d-mut); }
.md.empty{ visibility:hidden; }
.md.muted{ color:#4e4232; }
.md.request{ cursor:pointer; color:var(--txt-d); }
.md.request:hover{ background:rgba(198,160,82,.14); }
.md.free{ cursor:pointer; color:#c2d8b4; background:rgba(116,158,104,.18); font-weight:600; }
.md.free:hover{ background:rgba(126,172,112,.34); }
.md.busy{ color:#9c7167; cursor:not-allowed; background:rgba(150,72,62,.13); }
.md.busy::after{ content:""; position:absolute; width:64%; height:1px; background:rgba(176,96,84,.7); transform:rotate(-14deg); }
.md.sel{ background:var(--gold) !important; color:#15100a !important; font-weight:700; box-shadow:0 0 0 2px rgba(198,160,82,.4); }

/* podsumowanie wyboru + pakiet (pod kalendarzem) */
.cal-foot{ display:grid; grid-template-columns:1fr 1fr; gap:18px; margin-top:22px; align-items:stretch; }
.cal-foot-sel{ background:var(--ink); border:1px solid rgba(198,160,82,.16); border-radius:12px; padding:22px 24px; display:flex; flex-direction:column; justify-content:center; }
.cs-empty{ font-size:15px; color:var(--txt-d-mut); }
.cs-selected{ display:none; }
.cs-selected.show{ display:block; }
.cs-selected .cs-date{ font-family:var(--serif); font-size:27px; color:var(--gold-bright); text-transform:capitalize; line-height:1.1; }
.cs-selected .cs-status{ font-size:12.5px; color:#8fd28a; letter-spacing:.05em; text-transform:uppercase; margin-top:6px; }

/* picker pakietu w kroku 1 */
.pkg-pick{ background:var(--ink); border:1px solid rgba(198,160,82,.16); border-radius:12px; padding:22px 24px; }
.pp-label{ display:block; font-size:13px; letter-spacing:.05em; color:var(--txt-d-mut); font-weight:600; margin-bottom:14px; }
.pp-label .req{ color:var(--gold-soft); }
.pp-opt-tag{ font-weight:500; font-size:11px; letter-spacing:.1em; text-transform:uppercase; color:var(--gold-soft); border:1px solid rgba(198,160,82,.3); padding:2px 8px; border-radius:20px; margin-left:6px; }
.pp-opts{ display:flex; flex-direction:column; gap:10px; }
.pp-opt{ display:flex; align-items:center; gap:12px; width:100%; text-align:left;
  background:var(--ink-2); border:1px solid rgba(198,160,82,.2); border-radius:10px; padding:12px 15px; transition:.25s; }
.pp-opt:hover{ border-color:rgba(198,160,82,.5); }
.pp-opt.on{ border-color:var(--gold); background:rgba(198,160,82,.1); box-shadow:0 0 0 1px var(--gold) inset; }
.pp-dot{ width:16px; height:16px; border-radius:50%; border:1px solid rgba(198,160,82,.5); flex-shrink:0; position:relative; transition:.25s; }
.pp-opt.on .pp-dot{ border-color:var(--gold); }
.pp-opt.on .pp-dot::after{ content:""; position:absolute; inset:3px; border-radius:50%; background:var(--gold); }
.pp-name{ font-weight:600; font-size:15.5px; color:var(--txt-d); flex:1; }
.pp-price{ font-size:13px; color:var(--gold-soft); }

/* form */
.form-grid{ display:grid; grid-template-columns:1fr 1fr; gap:22px; }
.field{ display:flex; flex-direction:column; gap:8px; }
.field.full{ grid-column:1 / -1; }
.field label{ font-size:13px; letter-spacing:.05em; color:var(--txt-d-mut); font-weight:600; }
.field label .req{ color:var(--gold-soft); }
.field input,.field select{
  background:var(--ink); border:1px solid rgba(198,160,82,.2); border-radius:8px; color:var(--txt-d);
  padding:15px 16px; font-size:15.5px; font-family:inherit; transition:.25s; width:100%;
}
.field input::placeholder{ color:#6a5c48; }
.field input:focus,.field select:focus{ outline:none; border-color:var(--gold); background:#181009; }
.field select{ appearance:none; background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%23c6a052' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E"); background-repeat:no-repeat; background-position:right 16px center; padding-right:42px; }
.field .err{ font-size:12.5px; color:#e08a7a; display:none; }
.field .field-hint{ font-size:12.5px; color:var(--txt-d-mut); opacity:.85; }
.field.invalid input,.field.invalid select{ border-color:#c0604f; }
.field.invalid .err{ display:block; }
.field.invalid .field-hint{ display:none; }

/* meeting channel */
.chan-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:14px; margin-bottom:32px; }
.chan{ border:1px solid rgba(198,160,82,.22); border-radius:10px; padding:22px 16px; text-align:center; cursor:pointer; transition:.25s; background:var(--ink); }
.chan:hover{ border-color:rgba(198,160,82,.5); }
.chan.on{ border-color:var(--gold); background:rgba(198,160,82,.1); box-shadow:0 0 0 1px var(--gold) inset; }
.chan .ci{ width:34px; height:34px; margin:0 auto 12px; color:var(--gold-soft); }
.chan .cn{ font-weight:600; font-size:15px; }
.chan .cd{ font-size:12px; color:var(--txt-d-mut); margin-top:3px; }

.slot-wrap{ margin-top:8px; }
.slot-days{ display:flex; gap:10px; overflow-x:auto; padding-bottom:10px; margin-bottom:22px; }
.slot-day{ flex:0 0 auto; min-width:88px; text-align:center; padding:14px 10px; border-radius:9px; border:1px solid rgba(198,160,82,.2);
  cursor:pointer; transition:.25s; background:var(--ink); }
.slot-day:hover{ border-color:rgba(198,160,82,.5); }
.slot-day.on{ background:var(--gold); color:#15100a; border-color:var(--gold); }
.slot-day .sd-dow{ font-size:11px; letter-spacing:.1em; text-transform:uppercase; opacity:.8; }
.slot-day .sd-num{ font-family:var(--serif); font-size:24px; line-height:1.1; }
.slot-day .sd-mon{ font-size:11px; opacity:.8; }
.slot-times{ display:grid; grid-template-columns:repeat(auto-fill,minmax(96px,1fr)); gap:12px; }
.slot-time{ padding:13px; border-radius:8px; border:1px solid rgba(198,160,82,.2); text-align:center; cursor:pointer; transition:.25s; font-size:15px; background:var(--ink); }
.slot-time:hover{ border-color:rgba(198,160,82,.5); }
.slot-time.on{ background:var(--gold); color:#15100a; border-color:var(--gold); font-weight:600; }

/* nav buttons */
.book-nav{ display:flex; align-items:center; justify-content:space-between; gap:16px; margin-top:38px; padding-top:28px; border-top:1px solid rgba(198,160,82,.14); }
.book-nav .back{ font-size:14px; color:var(--txt-d-mut); display:flex; align-items:center; gap:8px; transition:.25s; }
.book-nav .back:hover{ color:var(--gold-soft); }
.book-nav .back.hide{ visibility:hidden; }
.summary{ display:flex; flex-direction:column; gap:14px; margin-bottom:14px; }
.sum-row{ display:flex; justify-content:space-between; gap:20px; padding:16px 20px; background:var(--ink); border:1px solid rgba(198,160,82,.16); border-radius:9px; }
.sum-row .k{ font-size:13px; letter-spacing:.06em; text-transform:uppercase; color:var(--txt-d-mut); }
.sum-row .v{ font-size:16px; color:var(--txt-d); text-align:right; }

/* confirmation */
.confirm{ text-align:center; padding:30px 0; display:none; }
.confirm.show{ display:block; animation:fade .6s var(--ease); }
.confirm .check{ width:84px; height:84px; margin:0 auto 26px; border-radius:50%;
  background:linear-gradient(135deg,var(--gold-soft),var(--gold-deep)); display:flex; align-items:center; justify-content:center; color:#15100a; }
.confirm h3{ font-family:var(--serif); font-size:clamp(30px,4vw,44px); margin-bottom:14px; }
.confirm p{ color:var(--txt-d-mut); max-width:480px; margin:0 auto 8px; font-size:17px; }
.confirm .cf-card{ max-width:440px; margin:30px auto 0; }

/* =========================================================
   FOOTER
   ========================================================= */
.footer{ background:#0a0705; padding:72px 0 34px; border-top:1px solid rgba(198,160,82,.14); }
.foot-top{ display:grid; grid-template-columns:1.4fr 1fr 1fr; gap:48px; }
.foot-brand img{ height:54px; margin-bottom:20px; }
.foot-brand p{ color:var(--txt-d-mut); font-size:15px; max-width:320px; }
.foot-col h5{ font-size:12px; letter-spacing:.18em; text-transform:uppercase; color:var(--gold-soft); margin-bottom:18px; }
.foot-col a,.foot-col p{ display:block; color:var(--txt-d-mut); font-size:15px; margin-bottom:11px; transition:.25s; }
.foot-col a:hover{ color:var(--gold-soft); }
.foot-cta{ background:var(--ink-2); border:1px solid rgba(198,160,82,.2); border-radius:12px; padding:30px; }
.foot-cta h4{ font-family:var(--serif); font-size:24px; margin-bottom:8px; }
.foot-cta p{ font-size:14px; color:var(--txt-d-mut); margin-bottom:18px; }
.foot-bot{ display:flex; align-items:center; justify-content:space-between; gap:20px; margin-top:54px; padding-top:24px;
  border-top:1px solid rgba(198,160,82,.12); flex-wrap:wrap; }
.foot-bot p{ font-size:13px; color:var(--txt-d-mut); }
.foot-social{ display:flex; gap:12px; }
.foot-social a{ width:38px; height:38px; border-radius:50%; border:1px solid rgba(198,160,82,.25); display:flex; align-items:center; justify-content:center; color:var(--txt-d-mut); transition:.3s; }
.foot-social a:hover{ border-color:var(--gold); color:var(--gold-soft); }
.foot-social svg{ width:17px; height:17px; }

/* popup weryfikacji dojazdu */
.modal{ position:fixed; inset:0; z-index:95; background:rgba(8,6,4,.8); backdrop-filter:blur(6px);
  display:none; align-items:center; justify-content:center; padding:24px; }
.modal.show{ display:flex; animation:fade .3s ease; }
.modal-card{ width:min(520px,100%); background:linear-gradient(180deg,#1d150d,#16100a);
  border:1px solid rgba(198,160,82,.3); border-radius:16px; padding:clamp(28px,4vw,42px); text-align:center;
  box-shadow:0 40px 100px -30px rgba(0,0,0,.8); animation:modalIn .4s var(--ease); }
@keyframes modalIn{ from{ opacity:0; transform:translateY(18px) scale(.97);} to{ opacity:1; transform:none;} }
.modal-ic{ width:64px; height:64px; margin:0 auto 20px; border-radius:50%; color:var(--gold-bright);
  background:rgba(198,160,82,.12); border:1px solid rgba(198,160,82,.3); display:flex; align-items:center; justify-content:center; }
.modal-card h3{ font-family:var(--serif); font-size:clamp(24px,3vw,32px); margin-bottom:14px; }
.modal-card p{ font-size:15.5px; color:var(--txt-d-mut); line-height:1.6; margin-bottom:12px; }
.modal-card .modal-q{ color:var(--txt-d); font-weight:500; margin-top:6px; }
.modal-venue{ font-family:var(--serif); font-size:22px; color:var(--gold-bright); padding:12px 18px; margin:4px 0 16px;
  background:rgba(198,160,82,.08); border:1px solid rgba(198,160,82,.22); border-radius:10px; }
.modal-actions{ display:flex; gap:12px; justify-content:center; margin-top:26px; flex-wrap:wrap; }
.modal-actions .btn{ flex:1; min-width:170px; }

/* =========================================================
   LIGHTBOX
   ========================================================= */
.lb{ position:fixed; inset:0; z-index:90; background:rgba(8,6,4,.96); display:none; align-items:center; justify-content:center; padding:30px; }
.lb.show{ display:flex; animation:fade .3s ease; }
.lb img{ max-width:92vw; max-height:88vh; border-radius:6px; box-shadow:0 30px 80px rgba(0,0,0,.7); }
.lb .vbox{ width:min(420px,90vw); aspect-ratio:9/16; max-height:88vh; border-radius:12px; overflow:hidden; background:#000; }
.lb .vbox iframe{ width:100%; height:100%; border:0; }
.lb .close{ position:absolute; top:24px; right:28px; width:48px; height:48px; border-radius:50%; border:1px solid rgba(255,255,255,.3);
  color:#fff; display:flex; align-items:center; justify-content:center; transition:.3s; }
.lb .close:hover{ background:rgba(255,255,255,.1); border-color:#fff; }
.lb .nav-btn{ position:absolute; top:50%; transform:translateY(-50%); width:54px; height:54px; border-radius:50%;
  border:1px solid rgba(255,255,255,.25); color:#fff; display:flex; align-items:center; justify-content:center; transition:.3s; }
.lb .nav-btn:hover{ background:rgba(255,255,255,.1); }
.lb .prev{ left:24px; } .lb .next{ right:24px; }

/* =========================================================
   reveal anim
   ========================================================= */
.reveal{ opacity:0; transform:translateY(28px); transition:opacity .9s var(--ease), transform .9s var(--ease); }
.reveal.in{ opacity:1; transform:none; }
.reveal.d1{ transition-delay:.08s; } .reveal.d2{ transition-delay:.16s; } .reveal.d3{ transition-delay:.24s; }

/* =========================================================
   RESPONSYWNOŚĆ
   ========================================================= */
@media (max-width:1080px){
  .pkg-grid{ grid-template-columns:1fr; max-width:520px; margin-left:auto; margin-right:auto; }
  .pkg.featured{ order:-1; }
  .addons{ grid-template-columns:repeat(2,1fr); }
  .vid-grid{ grid-template-columns:repeat(2,1fr); }
  .rev-grid{ columns:2; }
  .months-grid{ grid-template-columns:repeat(3,1fr); }
  .chan-grid{ grid-template-columns:repeat(2,1fr); }
}
@media (max-width:980px){
  .nav-links,.nav-cta .nav-phone,.nav-cta .btn{ display:none; }
  .burger{ display:flex; }
  .about-grid{ grid-template-columns:1fr; gap:40px; }
  .about-figure{ order:-1; max-width:460px; }
  .faq-grid{ grid-template-columns:1fr; gap:30px; }
  .foot-top{ grid-template-columns:1fr 1fr; }
  .foot-brand{ grid-column:1 / -1; }
  .steps-head{ grid-template-columns:1fr; }
  .shead{ border-right:none; border-bottom:1px solid rgba(198,160,82,.12); }
  .form-grid{ grid-template-columns:1fr; }
  .cal-foot{ grid-template-columns:1fr; }
  .months-grid{ grid-template-columns:repeat(2,1fr); gap:14px 18px; }
}
@media (max-width:680px){
  body{ font-size:16px; }
  .wrap{ padding:0 20px; }
  .stats-grid{ grid-template-columns:repeat(2,1fr); }
  .stat{ border-right:none; border-bottom:1px solid rgba(198,160,82,.12); }
  .stat:nth-child(odd){ border-right:1px solid rgba(198,160,82,.12); }
  .gal-grid{ grid-template-columns:repeat(2,1fr); grid-auto-rows:150px; }
  .g-a,.g-b,.g-c,.g-d,.g-e,.g-f{ grid-column:span 1; grid-row:span 1; }
  .g-a{ grid-column:span 2; grid-row:span 2; }
  .vid-grid{ grid-template-columns:repeat(2,1fr); gap:12px; }
  .rev-grid{ columns:1; }
  .addons{ grid-template-columns:1fr; }
  .months-grid{ grid-template-columns:repeat(2,1fr); }
  .year-nav .ylabel{ font-size:30px; }
  .hero-trust{ gap:16px; }
  .hero-trust .divider{ display:none; }
  .chan-grid{ grid-template-columns:1fr 1fr; }
  .foot-top{ grid-template-columns:1fr; }
  .hero-dots{ right:20px; }
  .about-meta{ gap:24px; }
  .sum-row{ flex-direction:column; gap:4px; }
  .sum-row .v{ text-align:left; }
}
@media (max-width:420px){
  .hero-inner{ padding-top:104px; }
  .chan-grid{ grid-template-columns:1fr; }
}
