/* Oáza — wellness & masáže (demo webpj.cz) */
*{margin:0;padding:0;box-sizing:border-box}
:root{
  --dark:#111b19;--dark2:#17221f;--card:#1c2825;
  --txt:#e8e4dc;--mut:#a9a396;--line:#2c3a36;
  --brass:#cbb08a;--brass-d:#b39668;--brass-l:rgba(203,176,138,.14);
  --euka:#a9c3b6;
}
html,body{overflow-x:hidden;max-width:100%}
body{font-family:'Nunito Sans',sans-serif;background:var(--dark);color:var(--txt);line-height:1.7;font-size:16px}
h1,h2,h3,h4{font-family:'DM Serif Display',serif;font-weight:400;line-height:1.18;letter-spacing:.01em}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
.wrap{max-width:1140px;margin:0 auto;padding:0 26px}

/* ribbon */
.ribbon{background:#0b1210;color:#b9b3a6;font-size:13.5px;padding:9px 0;text-align:center}
.ribbon b{color:#fff}
.ribbon a{display:inline-block;margin-left:12px;background:var(--brass);color:#1a1408;font-weight:700;padding:3px 15px;border-radius:99px;font-size:13px}
.ribbon a:hover{background:var(--brass-d)}

/* nav */
.nav{background:rgba(17,27,25,.92);backdrop-filter:blur(10px);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:50}
.nav-in{display:flex;align-items:center;justify-content:space-between;padding-top:16px;padding-bottom:16px}
.brand{display:flex;align-items:center;gap:12px}
.brand .mk{width:42px;height:42px;border-radius:50%;border:1px solid var(--brass);color:var(--brass);display:flex;align-items:center;justify-content:center}
.brand .mk svg{width:22px;height:22px}
.brand .tx b{display:block;font-family:'DM Serif Display';font-weight:400;font-size:22px;letter-spacing:.06em;color:#fff}
.brand .tx span{display:block;font-size:10.5px;letter-spacing:.26em;text-transform:uppercase;color:var(--mut)}
.nav-links{display:flex;list-style:none;gap:28px;align-items:center}
.nav-links a{font-size:14.5px;font-weight:600;color:var(--mut);letter-spacing:.03em}
.nav-links a:hover,.nav-links a.active{color:#fff}
.nav-links a.nav-cta{background:var(--brass);color:#1a1408;padding:11px 24px;border-radius:99px;font-weight:700}
.nav-links a.nav-cta:hover{background:var(--brass-d)}
.burger{display:none;background:none;border:1px solid var(--line);border-radius:99px;font-size:19px;padding:5px 13px;cursor:pointer;color:var(--txt)}
#mnav{display:none;background:var(--dark);border-top:1px solid var(--line);padding:10px 26px 18px}
#mnav a{display:block;padding:11px 0;border-bottom:1px solid var(--dark2);font-weight:600}
#mnav a.m-cta{background:var(--brass);color:#1a1408;text-align:center;border-radius:99px;margin-top:12px;border:0;font-weight:700}

/* hero */
.hero{position:relative;overflow:hidden}
.hero .bg{position:absolute;inset:0}
.hero .bg img{width:100%;height:100%;object-fit:cover;opacity:.6}
.hero .bg::after{content:"";position:absolute;inset:0;background:linear-gradient(100deg,rgba(11,18,16,.94) 0%,rgba(11,18,16,.66) 50%,rgba(11,18,16,.3) 100%)}
.hero .in{position:relative;z-index:2;padding:120px 0 130px;max-width:620px}
.eyebrow{display:inline-block;font-size:11.5px;letter-spacing:.3em;text-transform:uppercase;color:var(--brass);font-weight:700;margin-bottom:20px}
.hero h1{font-size:52px;color:#fff;margin-bottom:20px}
.hero h1 em{font-style:italic;color:var(--brass)}
.hero p{font-size:17.5px;color:#cfc9bd;margin-bottom:32px;max-width:30em}
.row{display:flex;gap:14px;flex-wrap:wrap}
.btn{display:inline-block;padding:14px 30px;border-radius:99px;font-weight:700;font-size:14.5px;transition:.15s;letter-spacing:.04em}
.btn-p{background:var(--brass);color:#1a1408}
.btn-p:hover{background:var(--brass-d)}
.btn-o{border:1px solid rgba(232,228,220,.5);color:#fff}
.btn-o:hover{border-color:var(--brass);color:var(--brass)}

/* strip */
.strip{border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:22px 0;background:var(--dark2)}
.strip .in{display:flex;justify-content:center;gap:36px;flex-wrap:wrap;font-size:12.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--mut)}
.strip i{font-style:normal;color:var(--brass)}

section{padding:76px 0}
.sec-h{max-width:620px;margin-bottom:46px}
.sec-h.center{margin-left:auto;margin-right:auto;text-align:center}
.sec-h h2{font-size:36px;margin-bottom:14px;color:#fff}
.sec-h p{color:var(--mut);font-size:16.5px}
.alt{background:var(--dark2)}

/* menu masáží */
.mlist{max-width:760px;margin:0 auto}
.mrow{display:flex;justify-content:space-between;align-items:baseline;gap:20px;padding:20px 0;border-bottom:1px solid var(--line)}
.mrow .n{font-family:'DM Serif Display';font-size:20px;color:#fff}
.mrow .d{font-size:14px;color:var(--mut);margin-top:4px;font-family:'Nunito Sans'}
.mrow .p{font-family:'DM Serif Display';font-size:19px;color:var(--brass);white-space:nowrap}
.mrow .p small{display:block;font-family:'Nunito Sans';font-size:12px;color:var(--mut);text-align:right}

/* karty */
.svc-g{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.svc{background:var(--card);border:1px solid var(--line);border-radius:18px;overflow:hidden;transition:.2s}
.svc:hover{border-color:var(--brass);transform:translateY(-4px)}
.svc img{width:100%;height:220px;object-fit:cover}
.svc .b{padding:26px 26px 28px}
.svc h3{font-size:21px;color:#fff;margin-bottom:10px}
.svc p{font-size:14.5px;color:var(--mut)}
.svc .more{display:inline-block;margin-top:16px;font-weight:700;font-size:13px;letter-spacing:.1em;text-transform:uppercase;color:var(--brass)}

/* split */
.split{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.split .ph{position:relative}
.split .ph::before{content:"";position:absolute;inset:14px -14px -14px 14px;border:1px solid var(--brass);border-radius:18px}
.split .ph img{position:relative;border-radius:18px}
.split h2{font-size:33px;margin-bottom:16px;color:#fff}
.split p{color:var(--mut);margin-bottom:14px}
.checks{list-style:none;margin:20px 0 28px}
.checks li{padding:8px 0 8px 32px;position:relative;font-size:15px;color:var(--txt)}
.checks li::before{content:"✦";position:absolute;left:2px;top:8px;color:var(--brass);font-size:13px}

/* poukazy konfigurátor */
.gift{background:var(--card);border:1px solid var(--line);border-radius:22px;padding:40px;max-width:860px;margin:0 auto}
.gift h3{font-size:24px;color:#fff;margin-bottom:24px}
.gstep{margin-bottom:28px}
.gstep>label{display:block;font-weight:700;font-size:14px;margin-bottom:12px;letter-spacing:.08em;text-transform:uppercase;color:var(--euka)}
.seg{display:flex;gap:10px;flex-wrap:wrap}
.seg button{flex:1;min-width:160px;border:1px solid var(--line);background:var(--dark2);border-radius:14px;padding:15px 16px;font-family:'Nunito Sans';font-size:14px;font-weight:600;cursor:pointer;color:var(--mut);transition:.15s;text-align:left}
.seg button b{display:block;color:#fff;font-size:15px;margin-bottom:2px}
.seg button.on{border-color:var(--brass);background:var(--brass-l);color:var(--txt)}
.seg button.on b{color:var(--brass)}
.voucher{margin-top:10px;border:1px solid var(--brass);border-radius:18px;padding:30px 34px;background:linear-gradient(135deg,#1d2926,#141f1c);position:relative;overflow:hidden}
.voucher::after{content:"OÁZA";position:absolute;right:-14px;bottom:-30px;font-family:'DM Serif Display';font-size:100px;color:rgba(203,176,138,.07);letter-spacing:.1em}
.voucher .vt{font-size:11px;letter-spacing:.3em;text-transform:uppercase;color:var(--brass);margin-bottom:10px}
.voucher .vn{font-family:'DM Serif Display';font-size:27px;color:#fff;margin-bottom:6px}
.voucher .vd{font-size:14px;color:var(--mut)}
.voucher .vp{font-family:'DM Serif Display';font-size:30px;color:var(--brass);margin-top:14px}
.gnote{font-size:13px;color:var(--mut);margin-top:16px}

/* quote */
.quote{max-width:720px;margin:0 auto;text-align:center}
.quote p{font-family:'DM Serif Display';font-size:26px;line-height:1.5;color:#fff;margin-bottom:18px}
.quote cite{font-style:normal;color:var(--mut);font-size:14.5px;letter-spacing:.06em}

/* cta band */
.cta-band{background:linear-gradient(120deg,#1d2926,#141f1c);border-top:1px solid var(--line);border-bottom:1px solid var(--line);text-align:center;padding:78px 0}
.cta-band h2{font-size:36px;color:#fff;margin-bottom:14px}
.cta-band p{color:var(--mut);max-width:32em;margin:0 auto 30px}

/* phead */
.phead{background:var(--dark2);border-bottom:1px solid var(--line);padding:60px 0 56px}
.phead .crumb{font-size:11px;letter-spacing:.28em;text-transform:uppercase;color:var(--brass);font-weight:700;margin-bottom:14px}
.phead h1{font-size:44px;color:#fff;margin-bottom:14px}
.phead p{color:var(--mut);max-width:36em;font-size:16.5px}

/* kontakt */
.kgrid{display:grid;grid-template-columns:.9fr 1.1fr;gap:46px;align-items:start}
.kinfo .item{display:flex;gap:16px;margin-bottom:24px}
.kinfo .ic{width:42px;height:42px;border-radius:50%;border:1px solid var(--brass);color:var(--brass);display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0}
.kinfo h3{font-size:18px;color:#fff;margin-bottom:3px}
.kinfo p,.kinfo a{font-size:14.5px;color:var(--mut)}
.kinfo a:hover{color:var(--brass)}
.kmap{border-radius:18px;overflow:hidden;border:1px solid var(--line);margin-top:8px;filter:grayscale(.4)}
.kmap iframe{display:block;width:100%;height:250px;border:0}
.kform{background:var(--card);border:1px solid var(--line);border-radius:22px;padding:38px}
.kform h3{font-size:24px;color:#fff;margin-bottom:6px}
.kform .sub{color:var(--mut);font-size:14.5px;margin-bottom:26px}
.f2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.kform label{display:block;font-size:12px;font-weight:700;margin-bottom:6px;letter-spacing:.12em;text-transform:uppercase;color:var(--euka)}
.kform input,.kform select,.kform textarea{width:100%;border:1px solid var(--line);border-radius:12px;padding:12px 16px;font-family:'Nunito Sans';font-size:15px;background:var(--dark2);margin-bottom:16px;color:var(--txt)}
.kform input:focus,.kform select:focus,.kform textarea:focus{outline:none;border-color:var(--brass)}
.kform textarea{min-height:100px;resize:vertical}
.kform button{width:100%;border:0;cursor:pointer}
.kok{display:none;background:var(--brass-l);border:1px solid var(--brass);color:var(--brass);border-radius:14px;padding:18px 20px;font-weight:600;margin-top:16px}

/* footer */
footer{background:#0b1210;color:var(--mut);padding:58px 0 26px}
footer .cols{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px;margin-bottom:38px}
footer p{font-size:14px;margin-top:14px}
footer h4{color:#fff;font-family:'Nunito Sans';font-weight:700;font-size:12.5px;letter-spacing:.2em;text-transform:uppercase;margin-bottom:16px}
footer .cols a{display:block;font-size:14.5px;padding:5px 0;color:var(--mut)}
footer .cols a:hover{color:#fff}
.fbar{border-top:1px solid #22302c;padding-top:22px;font-size:13px}
.fbar a{color:var(--brass)}

/* responsive */
@media(max-width:1020px){
  .hero h1{font-size:42px}
  .svc-g{grid-template-columns:1fr;max-width:520px;margin:0 auto}
}
@media(max-width:900px){
  .nav-links{display:none}
  .burger{display:block}
  .split{grid-template-columns:1fr;gap:40px}
  .kgrid{grid-template-columns:1fr}
}
@media(max-width:860px){
  footer .cols{grid-template-columns:1fr;gap:30px}
}
@media(max-width:620px){
  .hero .in{padding:70px 0 84px}
  .hero h1{font-size:33px}
  section{padding:54px 0}
  .sec-h h2{font-size:28px}
  .phead h1{font-size:31px}
  .f2{grid-template-columns:1fr}
  .gift{padding:26px 20px}
  .voucher{padding:24px}
  .quote p{font-size:20px}
  .mrow{flex-wrap:wrap}
  .split .ph::before{inset:8px -8px -8px 8px}
}
