/* ================================================================
   Jonáš Dvorský — fotograf · ukázkový web od webpj.cz
   Tmavé galerijní portfolio: uhlová čerň / slonovina / zlatavý okr
   Typografie: Syne (display) + Manrope (text)
   ================================================================ */
*{margin:0;padding:0;box-sizing:border-box}
:root{
  --bg:#0f0e0c;
  --bg2:#171512;
  --ink:#f1ede4;
  --muted:#9d968a;
  --gold:#c8a06a;
  --gold-d:#a37f4e;
  --line:rgba(241,237,228,.12);
}
html{scroll-behavior:smooth}
body{font-family:'Manrope',system-ui,sans-serif;color:var(--ink);background:var(--bg);line-height:1.7;font-size:16px;-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{font-family:'Syne',sans-serif;font-weight:700;line-height:1.12;letter-spacing:-.01em}
.wrap{max-width:1180px;margin:0 auto;padding:0 26px}
.eyebrow{display:inline-flex;align-items:center;gap:12px;text-transform:uppercase;letter-spacing:.3em;font-size:11px;font-weight:700;color:var(--gold);margin-bottom:18px}
.eyebrow::before{content:"";width:34px;height:1px;background:var(--gold)}
.btn{display:inline-flex;align-items:center;gap:10px;font-weight:700;font-size:14px;letter-spacing:.06em;text-transform:uppercase;padding:16px 32px;transition:.22s;cursor:pointer;border:0}
.btn-p{background:var(--gold);color:#171512}
.btn-p:hover{background:var(--gold-d)}
.btn-o{background:transparent;color:var(--ink);border:1px solid var(--line)}
.btn-o:hover{border-color:var(--gold);color:var(--gold)}

/* ---------- ribbon ---------- */
.ribbon{background:#000;color:#d9d2c4;font-size:13px;padding:9px 16px;display:flex;gap:14px;align-items:center;justify-content:center;flex-wrap:wrap;text-align:center;position:relative;z-index:60;border-bottom:1px solid var(--line)}
.ribbon b{color:var(--gold)}
.ribbon a{background:var(--gold);color:#171512;padding:5px 15px;border-radius:999px;font-weight:800;white-space:nowrap;transition:.2s}
.ribbon a:hover{background:var(--gold-d)}

/* ---------- nav ---------- */
header.nav{position:sticky;top:0;z-index:50;background:rgba(15,14,12,.92);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.nav-in{display:flex;align-items:center;justify-content:space-between;padding:18px 0}
.brand{display:flex;align-items:center;gap:13px}
.brand .mk{width:40px;height:40px;border:1px solid var(--gold);color:var(--gold);display:grid;place-items:center}
.brand .tx b{display:block;font-family:'Syne',sans-serif;font-size:17px;font-weight:800;letter-spacing:.12em;text-transform:uppercase;line-height:1.15}
.brand .tx span{display:block;font-size:10px;text-transform:uppercase;letter-spacing:.34em;color:var(--muted)}
.nav-links{display:flex;gap:28px;list-style:none;align-items:center}
.nav-links a{font-size:13px;font-weight:600;color:var(--muted);letter-spacing:.12em;text-transform:uppercase;padding-bottom:3px;border-bottom:1px solid transparent;transition:.2s}
.nav-links a:hover{color:var(--ink)}
.nav-links a.active{color:var(--gold);border-bottom-color:var(--gold)}
.nav-links a.nav-cta{background:var(--gold);color:#171512;padding:12px 22px;border-bottom:0}
.nav-links a.nav-cta:hover{background:var(--gold-d);color:#171512}
.burger{display:none;font-size:25px;background:none;border:0;cursor:pointer;color:var(--ink)}
#mnav{display:none;background:#000;border-bottom:1px solid var(--line);padding:8px 0 14px}
#mnav a{display:block;padding:11px 26px;font-weight:600;color:var(--muted);letter-spacing:.1em;text-transform:uppercase;font-size:13px}
#mnav a.active{color:var(--gold)}
#mnav a.m-cta{margin:10px 26px 0;background:var(--gold);color:#171512;text-align:center}

/* ---------- hero ---------- */
.hero{position:relative;min-height:660px;display:flex;align-items:flex-end;overflow:hidden}
.hero .bg{position:absolute;inset:0;z-index:0}
.hero .bg img{width:100%;height:100%;object-fit:cover}
.hero .bg::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(15,14,12,.55) 0%,rgba(15,14,12,.15) 40%,rgba(15,14,12,.92) 100%)}
.hero-in{position:relative;z-index:1;padding:110px 0 70px;width:100%}
.hero h1{font-size:clamp(40px,7vw,86px);text-transform:uppercase;letter-spacing:.02em;line-height:1.02;margin-bottom:18px}
.hero h1 em{font-style:normal;color:var(--gold)}
.hero p{font-size:17.5px;color:var(--muted);max-width:520px;margin-bottom:30px}
.hero .row{display:flex;gap:14px;flex-wrap:wrap}
.hero-meta{position:relative;z-index:1;display:flex;gap:34px;flex-wrap:wrap;margin-top:36px;border-top:1px solid var(--line);padding-top:22px}
.hero-meta .it b{font-family:'Syne';font-size:22px;color:var(--gold);display:block}
.hero-meta .it span{font-size:11.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted)}

/* ---------- sections ---------- */
section{padding:88px 0}
.sec-h{display:flex;align-items:flex-end;justify-content:space-between;gap:30px;margin-bottom:48px;flex-wrap:wrap}
.sec-h h2{font-size:clamp(28px,3.6vw,46px);text-transform:uppercase}
.sec-h p{color:var(--muted);font-size:16px;max-width:440px}
.alt{background:var(--bg2)}

/* ---------- galerie ---------- */
.gal{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.gal a{display:block;overflow:hidden;position:relative;background:#000}
.gal img{width:100%;aspect-ratio:4/5;object-fit:cover;transition:.5s;opacity:.92}
.gal a:hover img{transform:scale(1.05);opacity:1}
.gal .tag{position:absolute;left:16px;bottom:14px;font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:#fff;background:rgba(0,0,0,.55);padding:6px 12px;backdrop-filter:blur(4px)}
.gal.wide img{aspect-ratio:4/3}

/* filtry portfolia */
.filters{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:34px}
.filters button{background:transparent;border:1px solid var(--line);color:var(--muted);padding:10px 20px;font-family:'Manrope';font-weight:700;font-size:12.5px;letter-spacing:.14em;text-transform:uppercase;cursor:pointer;transition:.2s}
.filters button:hover{border-color:var(--gold);color:var(--ink)}
.filters button.on{background:var(--gold);border-color:var(--gold);color:#171512}

/* ---------- služby ---------- */
.srv-g{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line)}
.srv{background:var(--bg);padding:38px 32px;transition:.25s;position:relative}
.srv:hover{background:var(--bg2)}
.srv .no{font-family:'Syne';font-size:13px;color:var(--gold);letter-spacing:.2em;display:block;margin-bottom:16px}
.srv h3{font-size:20px;margin-bottom:10px;text-transform:uppercase;letter-spacing:.04em}
.srv p{font-size:14.5px;color:var(--muted)}
.srv .pr{margin-top:18px;font-family:'Syne';font-size:17px;color:var(--gold)}

/* ---------- split / o mně ---------- */
.split{display:grid;grid-template-columns:.9fr 1.1fr;gap:60px;align-items:center}
.split .ph{position:relative}
.split .ph img{width:100%;aspect-ratio:4/5;object-fit:cover;filter:grayscale(18%)}
.split .ph::after{content:"";position:absolute;top:16px;left:-16px;right:16px;bottom:-16px;border:1px solid var(--gold);z-index:-1}
.split h2{font-size:clamp(26px,3.4vw,40px);text-transform:uppercase;margin-bottom:18px}
.split p{color:var(--muted);margin-bottom:14px;font-size:16px}
.split p b{color:var(--ink)}

/* ---------- balíčky / ceník ---------- */
.pk-g{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.pk{background:var(--bg2);border:1px solid var(--line);padding:36px 32px;position:relative}
.pk.hl{border-color:var(--gold)}
.pk .tag{position:absolute;top:-12px;left:28px;background:var(--gold);color:#171512;font-size:10.5px;font-weight:800;letter-spacing:.2em;text-transform:uppercase;padding:5px 13px}
.pk h3{font-size:19px;text-transform:uppercase;letter-spacing:.05em;margin-bottom:4px}
.pk .pr{font-family:'Syne';font-size:32px;color:var(--gold);margin:12px 0 4px}
.pk .pr small{font-size:13px;color:var(--muted);font-family:'Manrope'}
.pk p{font-size:14px;color:var(--muted);margin-bottom:18px}
.pk ul{list-style:none;display:grid;gap:9px}
.pk ul li{font-size:14px;padding-left:22px;position:relative;color:var(--ink)}
.pk ul li::before{content:"—";color:var(--gold);position:absolute;left:0}

/* ---------- proces ---------- */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:30px;counter-reset:st}
.step::before{counter-increment:st;content:"0" counter(st);font-family:'Syne';font-size:42px;color:transparent;-webkit-text-stroke:1px var(--gold);display:block;margin-bottom:12px}
.step h3{font-size:16.5px;text-transform:uppercase;letter-spacing:.06em;margin-bottom:8px}
.step p{font-size:14px;color:var(--muted)}

/* ---------- citát ---------- */
.quote{text-align:center;max-width:740px;margin:0 auto}
.quote p{font-family:'Syne';font-size:clamp(20px,2.7vw,28px);font-weight:600;line-height:1.4}
.quote p em{color:var(--gold);font-style:normal}
.quote cite{display:block;margin-top:18px;font-style:normal;font-size:12.5px;color:var(--muted);letter-spacing:.2em;text-transform:uppercase}

/* ---------- CTA band ---------- */
.cta-band{background:var(--gold);color:#171512;padding:72px 0;text-align:center}
.cta-band h2{font-size:clamp(27px,3.6vw,44px);text-transform:uppercase;margin-bottom:14px}
.cta-band p{max-width:540px;margin:0 auto 28px;font-size:16.5px;font-weight:600}
.cta-band .btn{background:#171512;color:var(--ink)}
.cta-band .btn:hover{background:#000}

/* ---------- page head ---------- */
.phead{padding:76px 0 56px;border-bottom:1px solid var(--line);position:relative;overflow:hidden}
.phead::after{content:"◉";position:absolute;right:4%;bottom:-60px;font-size:260px;color:rgba(200,160,106,.05);line-height:1}
.crumb{font-size:11px;letter-spacing:.26em;text-transform:uppercase;color:var(--muted);margin-bottom:18px;display:block;font-weight:700}
.crumb a:hover{color:var(--gold)}
.phead h1{font-size:clamp(32px,4.8vw,58px);text-transform:uppercase;margin-bottom:14px}
.phead p{color:var(--muted);max-width:620px;font-size:16.5px}

/* ---------- rezervace ---------- */
.res{max-width:860px;margin:0 auto;background:var(--bg2);border:1px solid var(--line);padding:40px}
.res h3{font-size:17px;text-transform:uppercase;letter-spacing:.08em;margin-bottom:18px;display:flex;gap:12px;align-items:center}
.res h3 .stp{width:30px;height:30px;background:var(--gold);color:#171512;display:grid;place-items:center;font-size:14px;font-family:'Manrope';font-weight:800;flex:0 0 auto}
.type-g{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:30px}
.type{border:1px solid var(--line);padding:18px 14px;cursor:pointer;transition:.2s;text-align:center}
.type:hover{border-color:var(--gold)}
.type.on{border-color:var(--gold);background:rgba(200,160,106,.1)}
.type b{display:block;font-family:'Syne';font-size:15px;text-transform:uppercase;letter-spacing:.04em;margin-bottom:4px}
.type span{font-size:12.5px;color:var(--muted)}
.cal-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;max-width:620px}
.cal-head b{font-family:'Syne';font-size:17px;text-transform:uppercase;letter-spacing:.06em}
.cal-head button{background:var(--bg);border:1px solid var(--line);width:34px;height:34px;cursor:pointer;font-size:16px;color:var(--ink)}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:6px;margin-bottom:28px;max-width:620px}
.cal-grid .dow{text-align:center;font-size:10.5px;text-transform:uppercase;letter-spacing:.1em;color:var(--muted);font-weight:800;padding:4px 0}
.cal-grid .d{aspect-ratio:1;display:grid;place-items:center;font-size:14px;font-weight:600;cursor:pointer;border:1px solid transparent;transition:.15s}
.cal-grid .d:hover{border-color:var(--gold)}
.cal-grid .d.off{color:#4d493f;cursor:default;pointer-events:none}
.cal-grid .d.on{background:var(--gold);color:#171512}
.res .fg{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:14px}
.res input,.res textarea{width:100%;padding:13px 16px;border:1px solid var(--line);font-size:15px;font-family:inherit;background:var(--bg);color:var(--ink)}
.res input:focus,.res textarea:focus{outline:none;border-color:var(--gold)}
.res textarea{min-height:100px;resize:vertical;margin-bottom:18px}
.res .ok{display:none;margin-top:18px;background:rgba(200,160,106,.12);border:1px solid var(--gold);color:var(--gold);padding:16px;text-align:center;font-weight:700}

/* ---------- kontakt ---------- */
.k-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:50px;align-items:start}
.k-info h3{font-size:15px;text-transform:uppercase;letter-spacing:.14em;margin:26px 0 8px;color:var(--gold)}
.k-info h3:first-child{margin-top:0}
.k-info p,.k-info a{color:var(--ink);font-size:15.5px}
.k-info a:hover{color:var(--gold)}
.k-info .mut{color:var(--muted);font-size:14px}

/* ---------- footer ---------- */
footer{background:#000;color:var(--muted);padding:62px 0 0;font-size:14.5px}
footer .cols{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:44px;padding-bottom:44px}
footer .brand .tx b{color:var(--ink)}
footer p{margin-top:16px;line-height:1.7;max-width:330px}
footer h4{color:var(--ink);font-family:'Manrope';font-size:11.5px;letter-spacing:.24em;text-transform:uppercase;margin-bottom:16px}
footer a{display:block;padding:5px 0;transition:.2s}
footer a:hover{color:var(--gold)}
.fbar{border-top:1px solid var(--line);padding:20px 0;text-align:center;font-size:13px;color:#6d675c}
.fbar a{display:inline;color:var(--gold)}

/* ================= RESPONSIVE ================= */
@media(max-width:980px){
  .gal{grid-template-columns:1fr 1fr}
  .srv-g,.pk-g{grid-template-columns:1fr}
  .pk-g{max-width:520px;margin:0 auto}
  .steps{grid-template-columns:1fr 1fr;gap:34px}
  .type-g{grid-template-columns:1fr 1fr}
}
@media(max-width:860px){
  .nav-links{display:none}
  .burger{display:block}
  footer .cols{grid-template-columns:1fr;gap:30px}
  footer p{max-width:100%}
  .split,.k-grid{grid-template-columns:1fr;gap:44px}
  .split .ph{max-width:480px}
  section{padding:64px 0}
  .hero{min-height:560px}
  .res{padding:26px}
  .sec-h{flex-direction:column;align-items:flex-start}
}
@media(max-width:620px){
  .gal{grid-template-columns:1fr}
  .steps,.type-g{grid-template-columns:1fr}
  .res .fg{grid-template-columns:1fr}
  .hero-in{padding:84px 0 56px}
  .phead::after{font-size:170px;bottom:-40px}
}
html,body{overflow-x:hidden;max-width:100%}
