/* ── ZeTravel Public CSS ── */
:root {
  --bg:#0a0a0a; --bg2:#111; --bg3:#161616; --bg4:#1c1c1c;
  --border:#1e1e1e; --border2:#2a2a2a;
  --text:#f0f0f0; --text2:#aaa; --text3:#666;
  --accent:#c4935a; --accent-dark:#a87840;
  --nav-h:58px;
}
[data-theme=light] {
  --bg:#faf9f7; --bg2:#fff; --bg3:#f3efe8; --bg4:#ede9e2;
  --border:#e8e3db; --border2:#d5cfc5;
  --text:#111; --text2:#555; --text3:#999;
  --accent:#b8843e; --accent-dark:#9a6e30;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Segoe UI',system-ui,sans-serif;background:var(--bg);color:var(--text);line-height:1.6;transition:background .25s,color .25s}
a{text-decoration:none;color:inherit}
img{max-width:100%}
/* ── Buttons ── */
.zt-btn{display:inline-flex;align-items:center;justify-content:center;padding:.6rem 1.4rem;border-radius:4px;font-size:.88rem;font-weight:500;cursor:pointer;transition:.2s;border:1.5px solid transparent;letter-spacing:.5px;white-space:nowrap;font-family:inherit}
.zt-btn.primary{background:var(--accent);color:#fff;border-color:var(--accent)}
.zt-btn.primary:hover{background:var(--accent-dark);border-color:var(--accent-dark)}
.zt-btn.outline{border-color:var(--accent);color:var(--accent);background:transparent}
.zt-btn.outline:hover{background:var(--accent);color:#fff}
.zt-btn.full{width:100%}
.zt-btn.sm{padding:.4rem .9rem;font-size:.8rem}
/* ── Navbar ── */
.zt-nav{position:fixed;top:0;left:0;right:0;z-index:200;background:var(--bg2);border-bottom:0.5px solid var(--border);height:var(--nav-h)}
.zt-nav-inner{max-width:1240px;margin:0 auto;padding:0 1.5rem;height:100%;display:flex;align-items:center;gap:1.5rem}
.zt-logo{display:flex;align-items:center;gap:.6rem}
.zt-z{width:32px;height:32px;border:2px solid var(--accent);display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:700;color:var(--accent);font-style:italic;border-radius:3px;flex-shrink:0}
.zt-brand-wrap{display:flex;flex-direction:column;line-height:1.1}
.zt-brand-name{font-size:13px;letter-spacing:3px;color:var(--text);font-weight:300}
.zt-brand-name b{color:var(--accent);font-weight:600}
.zt-brand-sub{font-size:7px;letter-spacing:2px;color:var(--text3);text-transform:uppercase}
.zt-navl{display:flex;gap:1.4rem;flex:1;justify-content:center}
.zt-navl a{color:var(--text3);font-size:.8rem;letter-spacing:1.5px;transition:.2s;padding:.2rem 0;border-bottom:1.5px solid transparent}
.zt-navl a:hover,.zt-navl a.on{color:var(--accent);border-bottom-color:var(--accent)}
.zt-nav-controls{display:flex;align-items:center;gap:.5rem}
.zt-lang-sw{display:flex;border:0.5px solid var(--border2);border-radius:3px;overflow:hidden}
.zt-lang-sw a,.zt-lang-lnk{padding:4px 8px;font-size:.72rem;color:var(--text3);letter-spacing:1px;transition:.15s;text-decoration:none}
.zt-lang-sw a:hover,.zt-lang-lnk:hover{color:var(--accent)}
.zt-lang-sw a.on,.zt-lang-lnk.on{background:var(--accent);color:#fff}
.zt-theme-btn{background:transparent;border:0.5px solid var(--border2);color:var(--text2);width:30px;height:26px;cursor:pointer;border-radius:3px;display:flex;align-items:center;justify-content:center;padding:0}
.zt-theme-btn svg{transition:.3s}
/* ── Hero ── */
.zt-hero{position:relative;min-height:100vh;display:flex;align-items:center;justify-content:center;overflow:hidden}
.zt-hero-img{position:absolute;inset:0;background-size:cover;background-position:center top;background-repeat:no-repeat}
.zt-hero-overlay{position:absolute;inset:0;background:linear-gradient(to bottom,rgba(5,5,10,.65) 0%,rgba(5,5,10,.78) 60%,rgba(5,5,10,.92) 100%)}
[data-theme=light] .zt-hero-overlay{background:rgba(20,15,5,.55)}
.zt-hero-content{position:relative;z-index:1;text-align:center;color:#fff;padding:2rem;max-width:960px;padding-top:var(--nav-h)}
.zt-eyebrow{display:flex;align-items:center;gap:.7rem;margin-bottom:.8rem;justify-content:flex-start}
.zt-eyebrow.center{justify-content:center}
.zt-hero-content .zt-eyebrow{justify-content:center}
.zt-eline{width:28px;height:1px;background:var(--accent);flex-shrink:0}
.zt-eyebrow span:not(.zt-eline){font-size:.72rem;letter-spacing:3px;color:var(--accent);text-transform:uppercase}
.zt-hero-content h1{font-size:3.2rem;font-weight:200;line-height:1.15;margin-bottom:.8rem;color:#fff}
.zt-hero-content h1 em{font-style:normal;color:var(--accent)}
.zt-hero-sub{font-size:1rem;color:rgba(255,255,255,.7);margin-bottom:2.5rem;max-width:600px;margin-left:auto;margin-right:auto}
/* ── Search box ── */
.zt-search-box{background:rgba(10,10,10,.7);border:0.5px solid rgba(196,147,90,.3);border-radius:8px;padding:1.2rem 1.5rem;backdrop-filter:blur(10px)}
[data-theme=light] .zt-search-box{background:rgba(255,255,255,.92);border-color:var(--border2)}
.zt-search-form{display:flex;gap:.8rem;align-items:flex-end;flex-wrap:wrap;justify-content:center}
.zt-sf{display:flex;flex-direction:column;gap:.25rem;flex:1;min-width:130px}
.zt-sf.sm{flex:0 0 140px}
.zt-sf label{font-size:.68rem;color:rgba(255,255,255,.6);letter-spacing:1.5px;text-transform:uppercase}
.zt-search-form .zt-sf label{color:rgba(255,255,255,.6)}
[data-theme=light] .zt-search-form .zt-sf label{color:var(--text3)}
.zt-sf input,.zt-sf select,.zt-sf textarea{background:rgba(255,255,255,.1);border:0.5px solid rgba(255,255,255,.15);color:#fff;padding:.6rem .9rem;border-radius:4px;font-size:.88rem;width:100%;font-family:inherit;transition:.2s}
[data-theme=light] .zt-sf input,[data-theme=light] .zt-sf select,[data-theme=light] .zt-sf textarea{background:var(--bg4);border-color:var(--border2);color:var(--text)}
.zt-sf input:focus,.zt-sf select:focus,.zt-sf textarea:focus{outline:none;border-color:var(--accent)}
/* Outside hero — standard forms */
.zt-section .zt-sf label,.zt-page-hero~section .zt-sf label{color:var(--text3);font-size:.75rem;letter-spacing:1px;text-transform:uppercase}
.zt-section .zt-sf input,.zt-section .zt-sf select,.zt-section .zt-sf textarea{background:var(--bg2);border:0.5px solid var(--border2);color:var(--text);padding:.65rem .9rem;border-radius:4px;font-size:.9rem;width:100%;font-family:inherit;transition:.2s}
.zt-section .zt-sf input:focus,.zt-section .zt-sf select:focus,.zt-section .zt-sf textarea:focus{border-color:var(--accent);outline:none}
.zt-form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:.2rem}
/* ── Stats bar ── */
.zt-stats-bar{background:var(--bg2);border-top:0.5px solid var(--border);border-bottom:0.5px solid var(--border)}
.zt-stats-grid{display:grid;grid-template-columns:repeat(4,1fr)}
.zt-stat{padding:1.1rem 1.5rem;border-right:0.5px solid var(--border);display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:.3rem}
.zt-stat:last-child{border-right:none}
.zt-icon{font-size:1.3rem;flex-shrink:0}
.zt-stat b{display:block;font-size:1.3rem;color:var(--accent);font-weight:500;line-height:1}
.zt-stat span{font-size:.7rem;color:var(--text3);letter-spacing:1px;text-transform:uppercase}
/* ── Container / Section ── */
.page-body{padding-top:var(--nav-h)}
.zt-container{max-width:1240px;margin:0 auto;padding:0 1.5rem}
.zt-section{padding:4rem 0}
.zt-sec-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:2rem}
.zt-view-all{font-size:.75rem;color:var(--accent);letter-spacing:1.5px}
/* ── Room cards ── */
.zt-rooms-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.zt-rooms-grid.sm{grid-template-columns:repeat(3,1fr);gap:1rem}
.zt-room-card{background:var(--bg2);border-radius:8px;overflow:hidden;border:0.5px solid var(--border);transition:.25s}
.zt-room-card:hover{border-color:var(--accent);transform:translateY(-4px)}
.zt-card-img{height:200px;background-size:cover;background-position:center;background-color:var(--bg3);position:relative;display:flex;align-items:flex-end;justify-content:space-between;padding:.7rem}
.zt-card-img.sm{height:140px}
.zt-card-type{background:var(--bg);color:var(--accent);font-size:.65rem;padding:.25rem .7rem;border-radius:2px;letter-spacing:1.5px;text-transform:uppercase;border:0.5px solid var(--border2)}
.zt-card-price{background:var(--accent);color:#fff;font-size:.85rem;font-weight:600;padding:.3rem .7rem;border-radius:3px}
.zt-card-price span{font-size:.65rem;font-weight:400}
.zt-card-body{padding:1rem 1.1rem}
.zt-card-body h3{font-size:1rem;margin-bottom:.4rem;font-weight:500}
.zt-card-body p{color:var(--text2);font-size:.85rem;margin-bottom:.8rem;line-height:1.5}
.zt-card-meta{display:flex;gap:.8rem;flex-wrap:wrap;font-size:.78rem;color:var(--text3);margin-bottom:.8rem}
.zt-card-meta.light{color:rgba(255,255,255,.7)}
/* ── Room list (rooms page) ── */
.zt-rooms-list{display:flex;flex-direction:column;gap:1rem}
.zt-room-row{background:var(--bg2);border-radius:8px;border:0.5px solid var(--border);display:grid;grid-template-columns:220px 1fr auto;overflow:hidden;transition:.2s}
.zt-room-row:hover{border-color:var(--accent)}
.zt-row-img{height:170px;background-size:cover;background-position:center;background-color:var(--bg3);position:relative;display:flex;align-items:flex-start;padding:.6rem}
.zt-unavail-badge{position:absolute;bottom:.5rem;right:.5rem;background:#e74c3c;color:#fff;font-size:.65rem;padding:.2rem .5rem;border-radius:2px;letter-spacing:1px}
.zt-row-body{padding:1.1rem 1.2rem;display:flex;flex-direction:column;gap:.5rem}
.zt-row-body h3{font-size:1.05rem;font-weight:500}
.zt-row-body p{color:var(--text2);font-size:.85rem;line-height:1.5}
.zt-ams{display:flex;gap:.4rem;flex-wrap:wrap;margin-top:.3rem}
.zt-am{font-size:.72rem;color:var(--text3);background:var(--bg3);padding:.2rem .6rem;border-radius:3px}
.zt-row-right{padding:1.1rem 1.2rem;display:flex;flex-direction:column;justify-content:center;align-items:flex-end;gap:.6rem;border-left:0.5px solid var(--border);min-width:150px}
.zt-big-price{font-size:1.6rem;color:var(--text);font-weight:300;text-align:right}
.zt-big-price span{font-size:.75rem;color:var(--text3);display:block;text-align:right}
/* ── Filter bar ── */
.zt-filter-bar{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.8rem;margin-bottom:1.5rem;padding:.8rem 1rem;background:var(--bg2);border-radius:6px;border:0.5px solid var(--border)}
.zt-filter-form{display:flex;gap:.5rem;flex-wrap:wrap;align-items:center}
.zt-filter-form select,.zt-filter-form input{background:var(--bg3);border:0.5px solid var(--border2);color:var(--text);padding:.45rem .7rem;border-radius:4px;font-size:.83rem;font-family:inherit}
.zt-results-count{font-size:.8rem;color:var(--text3);letter-spacing:.5px}
/* ── Page hero ── */
.zt-page-hero{background:var(--bg2);border-bottom:0.5px solid var(--border);padding:3.5rem 0 2rem}
.zt-page-hero h1{font-size:2rem;font-weight:300;margin:.5rem 0 .3rem}
.zt-page-hero p{color:var(--text2);font-size:.9rem}
.zt-page-hero.sm{padding:2.5rem 0 1.5rem}
/* ── Detail page ── */
.zt-detail-hero{min-height:320px;background-size:cover;background-position:center;background-color:var(--bg3);position:relative;display:flex;align-items:flex-end;padding-top:var(--nav-h)}
.zt-detail-hero h1{font-size:2rem;font-weight:300;color:#fff;margin:.4rem 0 .5rem}
.zt-detail-grid{display:grid;grid-template-columns:1fr 320px;gap:2.5rem;align-items:start}
.zt-detail-main h3{font-size:1.05rem;font-weight:500;color:var(--accent);margin:1.5rem 0 .8rem;letter-spacing:.5px}
.zt-room-desc{color:var(--text2);line-height:1.8;margin-bottom:1.5rem}
.zt-ams-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.4rem}
.zt-am-item{padding:.5rem .7rem;background:var(--bg2);border:0.5px solid var(--border);border-radius:4px;font-size:.83rem;color:var(--text2)}
.zt-gallery{margin-bottom:1.5rem}
.zt-gallery-main{height:320px;background-size:cover;background-position:center;border-radius:6px;margin-bottom:.6rem;background-color:var(--bg3)}
.zt-gallery-thumbs{display:flex;gap:.5rem}
.zt-thumb{flex:1;height:72px;background-size:cover;background-position:center;border-radius:4px;cursor:pointer;border:1.5px solid transparent;transition:.2s;background-color:var(--bg3)}
.zt-thumb.sel,.zt-thumb:hover{border-color:var(--accent)}
/* ── Book widget ── */
.zt-book-widget{background:var(--bg2);border-radius:8px;border:0.5px solid var(--border);padding:1.4rem;position:sticky;top:calc(var(--nav-h) + 1rem)}
.zt-widget-price{font-size:1.8rem;font-weight:300;margin-bottom:1.2rem;color:var(--text)}
.zt-widget-price span{font-size:.78rem;color:var(--text3);font-weight:400}
.zt-price-prev,.zt-summary-total{background:var(--bg3);border-radius:4px;padding:.6rem .8rem;margin:.6rem 0;font-size:.85rem}
.zt-price-row,.zt-total-row{display:flex;justify-content:space-between}
.zt-total-row{border-top:0.5px solid var(--border);padding-top:.5rem;margin-top:.4rem}
/* ── Booking page ── */
.zt-booking-grid{display:grid;grid-template-columns:1.6fr 1fr;gap:2.5rem;align-items:start}
.zt-book-form h2{font-size:1.1rem;font-weight:500;margin-bottom:1.5rem;color:var(--text)}
.zt-book-summary{background:var(--bg2);border-radius:8px;border:0.5px solid var(--border);padding:1.3rem;position:sticky;top:calc(var(--nav-h)+1rem)}
.zt-book-summary h3{font-size:1rem;margin-bottom:1rem}
.zt-summary-img{height:150px;background-size:cover;background-position:center;border-radius:6px;margin-bottom:.8rem;background-color:var(--bg3)}
.zt-summary-rows div{display:flex;justify-content:space-between;padding:.45rem 0;border-bottom:0.5px solid var(--border);font-size:.85rem}
.zt-summary-rows div span:first-child{color:var(--text3)}
.zt-type-label{font-size:.75rem;color:var(--accent);letter-spacing:1px;margin-bottom:.8rem}
.zt-pay-note{font-size:.78rem;color:var(--text3);text-align:center;margin-top:.8rem}
/* ── Confirmation ── */
.zt-conf-card{background:var(--bg2);border-radius:12px;border:0.5px solid var(--border);padding:2.5rem;text-align:center}
.zt-conf-icon{font-size:3.5rem;margin-bottom:1rem}
.zt-conf-card h1{font-size:1.8rem;font-weight:300;margin-bottom:.5rem}
.zt-conf-sub{color:var(--text2);margin-bottom:1.5rem;font-size:.92rem}
.zt-conf-ref{background:var(--accent);color:#fff;display:inline-block;padding:.4rem 1.4rem;border-radius:3px;font-size:.78rem;letter-spacing:2px;margin-bottom:1.5rem}
.zt-conf-rows{text-align:left;border-top:0.5px solid var(--border);margin-top:1rem}
.zt-conf-rows div{display:flex;justify-content:space-between;padding:.7rem 0;border-bottom:0.5px solid var(--border);font-size:.9rem}
.zt-conf-rows div span:first-child{color:var(--text3)}
.zt-conf-rows div.total{border-bottom:none;font-size:1.05rem}
.zt-conf-rows div.total strong{color:var(--accent)}
.zt-conf-btns{display:flex;gap:.8rem;justify-content:center;margin-top:1.5rem}
/* ── Why section ── */
.zt-why-section{background:var(--bg2);border-top:0.5px solid var(--border);border-bottom:0.5px solid var(--border);padding:3rem 0}
.zt-why-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-top:1.5rem}
.zt-why-card{padding:1.5rem;border:0.5px solid var(--border);border-radius:6px;background:var(--bg3)}
.zt-why-icon{font-size:1.8rem;margin-bottom:.7rem}
.zt-why-card h4{font-size:.95rem;margin-bottom:.4rem;font-weight:500;color:var(--accent)}
.zt-why-card p{font-size:.85rem;color:var(--text2);line-height:1.6}
/* ── About ── */
.zt-about-grid{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:center}
.zt-about-grid h2{font-size:1.8rem;font-weight:300;margin:.5rem 0 .8rem;color:var(--text)}
.zt-about-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-top:1.5rem}
.zt-about-stats div{text-align:center;background:var(--bg2);border:0.5px solid var(--border);border-radius:6px;padding:1rem}
.zt-about-stats b{display:block;font-size:1.6rem;color:var(--accent);font-weight:400}
.zt-about-stats span{font-size:.7rem;color:var(--text3);letter-spacing:1px;text-transform:uppercase}
/* ── Contact ── */
.zt-contact-grid{display:grid;grid-template-columns:1fr 1.5fr;gap:3rem}
.zt-contact-item{display:flex;gap:.8rem;margin-bottom:1.3rem;align-items:flex-start}
.ci{font-size:1.2rem;flex-shrink:0;margin-top:.1rem}
.zt-contact-item h4{font-size:.88rem;font-weight:500;margin-bottom:.15rem;color:var(--accent)}
.zt-contact-item p{font-size:.85rem;color:var(--text2)}
/* ── Alerts ── */
.zt-alert{padding:.8rem 1.1rem;border-radius:6px;margin-bottom:1.2rem;font-size:.88rem}
.zt-alert.error{background:rgba(231,76,60,.1);border:0.5px solid rgba(231,76,60,.3);color:#e74c3c}
.zt-alert.success{background:rgba(39,174,96,.1);border:0.5px solid rgba(39,174,96,.3);color:#27ae60}
/* ── Footer ── */
.zt-footer{background:var(--bg2);border-top:0.5px solid var(--border);padding:2.5rem 0 1.2rem}
.zt-footer-inner{max-width:1240px;margin:0 auto;padding:0 1.5rem;display:flex;justify-content:space-between;align-items:flex-start;gap:2rem;margin-bottom:1.5rem}
.zt-footer-brand{display:flex;align-items:center;gap:.7rem}
.zt-z.sm{width:26px;height:26px;font-size:13px}
.zt-brand-name.sm{font-size:11px;letter-spacing:2px}
.zt-brand-name.sm b{color:var(--accent)}
.zt-brand-name.sm span{color:var(--text3)}
.zt-footer-tagline{font-size:.7rem;color:var(--text3);letter-spacing:1.5px;text-transform:uppercase}
.zt-footer-cols{display:flex;gap:3rem}
.zt-footer-cols p{font-size:.82rem;color:var(--text3);margin-bottom:.3rem}
.zt-footer-links{display:flex;flex-direction:column;gap:.3rem}
.zt-footer-links a{font-size:.82rem;color:var(--text3);transition:.15s}
.zt-footer-links a:hover{color:var(--accent)}
.zt-footer-bottom{max-width:1240px;margin:0 auto;padding:.8rem 1.5rem 0;border-top:0.5px solid var(--border);font-size:.75rem;color:var(--text3)}
.zt-footer-social{display:flex;gap:12px;align-items:center;margin-top:8px}.zt-footer-social a{color:var(--text3);transition:.2s;display:flex;align-items:center}.zt-footer-social a:hover{color:var(--accent)}
/* ── Empty ── */
.zt-empty{text-align:center;padding:3rem;color:var(--text3)}
.err404 body,.err404{display:flex;align-items:center;justify-content:center;min-height:100vh;text-align:center}
.err404 h1{font-size:5rem;color:var(--accent);font-weight:200}
/* ── Responsive ── */

/* ── Square Room Cards Grid ── */
.zt-sq-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.zt-sq-card{background:var(--bg2);border-radius:10px;overflow:hidden;border:0.5px solid var(--border);transition:.25s;display:flex;flex-direction:column}
.zt-sq-card:hover{transform:translateY(-3px);border-color:var(--accent);box-shadow:0 8px 32px rgba(196,147,90,.12)}
.zt-sq-card .zt-row-img{aspect-ratio:1/1;background-size:cover;background-position:center;background-color:var(--bg3);position:relative;flex-shrink:0}
.zt-sq-card .zt-row-body{padding:1.1rem;display:flex;flex-direction:column;flex:1}
.zt-sq-card h3{font-size:1rem;font-weight:600;margin:0 0 .4rem;color:var(--text)}
.zt-sq-card h3 a{color:inherit;text-decoration:none}
.zt-sq-card h3 a:hover{color:var(--accent)}
.zt-sq-card p{font-size:.8rem;color:var(--text3);margin:0 0 .7rem;line-height:1.5;flex:1}
.zt-sq-card .zt-card-meta{display:flex;gap:.5rem;flex-wrap:wrap;margin-bottom:.6rem}
.zt-sq-card .zt-card-meta span{font-size:.72rem;color:var(--text2);background:var(--bg3);padding:2px 8px;border-radius:20px;border:0.5px solid var(--border)}
.zt-sq-card .zt-card-ams{display:flex;gap:.3rem;flex-wrap:wrap;margin-bottom:.8rem}
.zt-sq-card .zt-row-footer{display:flex;align-items:center;justify-content:space-between;margin-top:auto;padding-top:.7rem;border-top:0.5px solid var(--border)}
.zt-price-big{font-size:1.15rem;font-weight:600;color:var(--accent)}
.zt-price-big .zt-per{font-size:.72rem;font-weight:400;color:var(--text3)}
.zt-card-type{position:absolute;top:.6rem;left:.6rem;background:var(--accent);color:#000;font-size:.6rem;font-weight:800;letter-spacing:1px;padding:3px 8px;border-radius:3px;text-transform:uppercase}

/* ── Home featured cards (also square) ── */
.zt-cards-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.zt-card{background:var(--bg2);border-radius:10px;overflow:hidden;border:0.5px solid var(--border);transition:.25s;display:flex;flex-direction:column}
.zt-card:hover{transform:translateY(-3px);border-color:var(--accent);box-shadow:0 8px 32px rgba(196,147,90,.12)}
.zt-card-img-wrap{display:block;aspect-ratio:1/1;overflow:hidden}
.zt-card-img{width:100%;height:100%;background-size:cover;background-position:center;background-color:var(--bg3);transition:transform .4s}
.zt-card:hover .zt-card-img{transform:scale(1.04)}
.zt-card-body{padding:1rem;display:flex;flex-direction:column;flex:1}
.zt-card-body h3{font-size:.95rem;font-weight:600;margin:0 0 .4rem}
.zt-card-body h3 a{color:var(--text);text-decoration:none}
.zt-card-body h3 a:hover{color:var(--accent)}
.zt-card-meta{display:flex;gap:.4rem;flex-wrap:wrap;margin-bottom:.5rem}
.zt-card-meta span{font-size:.7rem;color:var(--text2);background:var(--bg3);padding:2px 8px;border-radius:20px;border:0.5px solid var(--border)}
.zt-card-ams{display:flex;gap:.3rem;flex-wrap:wrap;margin-bottom:.7rem}
.zt-card-footer{display:flex;align-items:center;justify-content:space-between;margin-top:auto;padding-top:.6rem;border-top:0.5px solid var(--border)}

/* ── Burger button ── */
.zt-burger{display:none;flex-direction:column;justify-content:center;gap:5px;background:none;border:none;cursor:pointer;padding:6px;width:36px;height:36px}
.zt-burger span{display:block;height:2px;background:var(--text);border-radius:2px;transition:.3s}
.zt-burger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.zt-burger.open span:nth-child(2){opacity:0}
.zt-burger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* Overlay */
.zt-nav-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:99}
.zt-nav-overlay.show{display:block}

/* Mobile-only lang in drawer */
.zt-nav-mob-bottom{display:none}

@media(max-width:900px){
  .zt-rooms-grid,.zt-rooms-grid.sm,.zt-why-grid{grid-template-columns:1fr 1fr}
  .zt-detail-grid,.zt-booking-grid{grid-template-columns:1fr}
  .zt-room-row{grid-template-columns:1fr}
  .zt-row-right{border-left:none;border-top:0.5px solid var(--border);flex-direction:row;align-items:center}
  .zt-about-grid,.zt-contact-grid{grid-template-columns:1fr}
  .zt-footer-inner{flex-direction:column;gap:1.5rem;text-align:center}
  .zt-hero-content h1{font-size:2.2rem}
  .zt-search-form{flex-direction:column;gap:.6rem}
  .zt-sf.sm{flex:unset;width:100%}
  .zt-search-form .zt-btn{width:100%;justify-content:center}
}

@media(max-width:768px){
  /* Show burger, hide desktop nav + desktop lang */
  .zt-burger{display:flex}
  .zt-lang-desk{display:none!important}

  /* Slide-in drawer */
  .zt-navl{
    display:flex!important;
    flex-direction:column;
    position:fixed;
    top:0;right:-280px;
    width:270px;height:100vh;
    background:var(--bg2);
    border-left:1px solid var(--border);
    z-index:100;
    padding:72px 0 24px;
    gap:0;
    transition:right .3s ease;
    overflow-y:auto;
  }
  .zt-navl.open{right:0}
  .zt-navl a{
    padding:14px 24px;
    font-size:15px;
    border-bottom:1px solid var(--border);
    display:block;
    color:var(--text);
    text-decoration:none;
    letter-spacing:.5px;
  }
  .zt-navl a.on,.zt-navl a:hover{color:var(--accent);background:var(--bg3)}

  /* Lang switcher inside drawer */
  .zt-nav-mob-bottom{display:block;padding:20px 24px;margin-top:auto}
  .zt-nav-mob-bottom .zt-lang-sw{justify-content:flex-start}

  /* Layout fixes */
  .zt-rooms-grid,.zt-rooms-grid.sm,.zt-why-grid,.zt-about-stats,.zt-form-row{grid-template-columns:1fr}
  .zt-stats-grid{grid-template-columns:1fr 1fr}
  .zt-hero-content{padding:1rem 1rem;padding-top:calc(var(--nav-h) + 1rem)}
  .zt-hero-content h1{font-size:1.8rem}
  .zt-hero-sub{font-size:.88rem}
  .zt-search-box{padding:.8rem 1rem}
  .zt-container{padding:0 1rem}
  .zt-section{padding:2.5rem 0}
  .zt-cards-grid{grid-template-columns:1fr}
  .zt-sq-grid{grid-template-columns:1fr}
  .zt-conf-card{padding:20px}
  .zt-footer-inner{flex-direction:column;gap:2rem;text-align:center}
  .zt-detail-hero{min-height:200px}
  .zt-gallery-thumbs{grid-template-columns:repeat(4,1fr)}
}

@media(max-width:400px){
  .zt-hero-content h1{font-size:1.5rem}
  .zt-stats-grid{grid-template-columns:1fr 1fr}
  .zt-stat{padding:.8rem .5rem}
}

.zt-stat-n{font-size:1.8rem;font-weight:300;color:var(--accent);line-height:1}
.zt-stat-l{font-size:.68rem;color:var(--text3);letter-spacing:1.5px;text-transform:uppercase}
/* WhatsApp float button */
.zt-wa-float{position:fixed;bottom:24px;right:24px;z-index:999;background:#25D366;color:#fff;width:54px;height:54px;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px rgba(37,211,102,.4);transition:.25s;text-decoration:none}
.zt-wa-float:hover{background:#1ebe5d;transform:scale(1.1);box-shadow:0 6px 24px rgba(37,211,102,.5)}
@media(max-width:768px){.zt-wa-float{bottom:16px;right:16px;width:48px;height:48px}}

/* ── Currency switcher ── */
.zt-curr-sw{display:flex;gap:2px;align-items:center}
.zt-curr-btn{background:none;border:1px solid var(--border);border-radius:4px;color:var(--text3);cursor:pointer;font-size:.7rem;font-weight:600;letter-spacing:.5px;padding:3px 6px;transition:.2s;font-family:inherit}
.zt-curr-btn:hover{color:var(--accent);border-color:var(--accent)}
.zt-curr-btn.on{background:var(--accent);color:#fff;border-color:var(--accent)}
.zt-curr-desk{margin-right:4px}
@media(max-width:768px){
  .zt-curr-desk{display:none}
  .zt-curr-sw{gap:4px}
  .zt-curr-btn{font-size:.75rem;padding:5px 10px}
}

/* ── City badge ── */
.zt-city-badge{display:inline-flex;align-items:center;gap:4px;font-size:.75rem;color:var(--accent);font-weight:600;letter-spacing:.5px;margin-bottom:6px}
.zt-sf-select{width:100%;background:var(--bg2);border:1px solid var(--border);border-radius:6px;color:var(--text);padding:10px 12px;font-size:.9rem;font-family:inherit;cursor:pointer}
.zt-sf-select:focus{outline:none;border-color:var(--accent)}

/* ── Gallery grid ── */
.zt-gallery-grid{columns:3 220px;gap:12px}
.zt-gallery-item{break-inside:avoid;position:relative;margin-bottom:12px;border-radius:10px;overflow:hidden;cursor:pointer}
.zt-gallery-item img{width:100%;display:block;transition:transform .3s}
.zt-gallery-item:hover img{transform:scale(1.04)}
.zt-gallery-caption{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(transparent,rgba(0,0,0,.7));color:#fff;padding:20px 12px 10px;font-size:.8rem;opacity:0;transition:opacity .2s}
.zt-gallery-item:hover .zt-gallery-caption{opacity:1}
@media(max-width:600px){.zt-gallery-grid{columns:2 150px}}

/* ── Blog ── */
.zt-blog-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem}
.zt-blog-card{background:var(--bg2);border:0.5px solid var(--border);border-radius:12px;overflow:hidden;text-decoration:none;display:flex;flex-direction:column;transition:border-color .2s,transform .2s}
.zt-blog-card:hover{border-color:var(--accent);transform:translateY(-2px)}
.zt-blog-img{height:200px;overflow:hidden;background:var(--bg3)}
.zt-blog-img img{width:100%;height:100%;object-fit:cover;transition:transform .3s}
.zt-blog-card:hover .zt-blog-img img{transform:scale(1.04)}
.zt-blog-img-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:3rem}
.zt-blog-body{padding:1.2rem;display:flex;flex-direction:column;flex:1}
.zt-blog-date{font-size:.72rem;color:var(--accent);letter-spacing:1px;font-weight:600;margin-bottom:6px}
.zt-blog-title{font-size:1.05rem;font-weight:700;color:var(--text);margin:0 0 8px;line-height:1.4}
.zt-blog-excerpt{font-size:.85rem;color:var(--text2);margin:0 0 12px;line-height:1.6;flex:1}
.zt-blog-more{font-size:.8rem;color:var(--accent);font-weight:600;margin-top:auto}
.zt-blog-post-wrap{max-width:740px;margin:0 auto}
.zt-blog-lead{font-size:1.1rem;color:var(--text2);line-height:1.8;margin:0 0 2rem;padding-bottom:1.5rem;border-bottom:1px solid var(--border)}
.zt-blog-content{font-size:.95rem;color:var(--text);line-height:1.85}
.zt-blog-content h2{font-size:1.3rem;margin:2rem 0 .8rem;color:var(--text)}
.zt-blog-content h3{font-size:1.1rem;margin:1.5rem 0 .6rem;color:var(--text)}
.zt-blog-content p{margin:0 0 1rem}
.zt-blog-content img{width:100%;border-radius:8px;margin:1rem 0}
.zt-blog-content ul,.zt-blog-content ol{padding-left:1.4rem;margin:0 0 1rem}
.zt-blog-content li{margin-bottom:.4rem}
.zt-blog-content a{color:var(--accent)}
.zt-blog-content blockquote{border-left:3px solid var(--accent);padding:.6rem 1rem;margin:1.2rem 0;background:var(--bg2);border-radius:0 6px 6px 0;color:var(--text2)}

/* ---- Room card star ratings ---- */
.zt-card-stars{display:flex;align-items:center;gap:3px;margin:.2rem 0 .5rem;font-size:.95rem;line-height:1}
.zts{color:#e0d0b0}
.zts-full{color:#f5a623}
.zts-half{color:#f5a623;opacity:.6}
.zts-empty{color:#ddd}
.zt-card-rcount{font-size:.72rem;color:var(--text3);margin-left:4px;font-weight:500}

/* ── Leave a Review CTA banner ── */
.zt-review-cta{background:linear-gradient(135deg,var(--accent) 0%,#a87444 100%);padding:2.8rem 0;margin-top:1rem}
.zt-review-cta-inner{display:flex;align-items:center;justify-content:space-between;gap:2rem;flex-wrap:wrap}
.zt-review-cta-text{color:#fff}
.zt-review-cta-stars{font-size:1.5rem;letter-spacing:3px;display:block;margin-bottom:.5rem}
.zt-review-cta-text h3{font-size:1.3rem;font-weight:700;margin:0 0 .3rem;color:#fff}
.zt-review-cta-text p{font-size:.9rem;opacity:.88;margin:0;max-width:420px;line-height:1.5;color:#fff}
.zt-btn.lg{padding:.75rem 2rem;font-size:1rem;white-space:nowrap}
.zt-review-cta .zt-btn.primary{background:#fff;color:var(--accent);font-weight:700;border:none}
.zt-review-cta .zt-btn.primary:hover{background:#f5f5f5}
@media(max-width:600px){.zt-review-cta-inner{flex-direction:column;text-align:center}.zt-review-cta .zt-btn{width:100%}}

/* ── Nav "Leave a Review" button ── */
.zt-nav-review-btn{background:var(--accent)!important;color:#fff!important;border-radius:20px;padding:4px 14px!important;font-size:.78rem!important;font-weight:700;letter-spacing:.3px;transition:.2s!important;white-space:nowrap}
.zt-nav-review-btn:hover{background:#a87444!important;color:#fff!important}

/* ════════════════════════════════════════════
   PHOTO CAROUSEL  (room detail page)
════════════════════════════════════════════ */
.ztc-wrap{position:relative;width:100%;height:520px;overflow:hidden;background:var(--bg2)}
.ztc-slides{display:flex;height:100%;transition:transform .45s cubic-bezier(.4,0,.2,1)}
.ztc-slide{flex:0 0 100%;background-size:cover;background-position:center;position:relative}
.ztc-overlay{position:absolute;inset:0;background:linear-gradient(to bottom,rgba(0,0,0,.1) 0%,rgba(0,0,0,.55) 100%)}

/* Prev / Next buttons */
.ztc-btn{position:absolute;top:50%;transform:translateY(-50%);background:rgba(0,0,0,.45);border:none;color:#fff;font-size:2.2rem;width:48px;height:48px;border-radius:50%;cursor:pointer;z-index:10;transition:.2s;display:flex;align-items:center;justify-content:center;backdrop-filter:blur(4px)}
.ztc-btn:hover{background:var(--accent)}
.ztc-prev{left:16px}
.ztc-next{right:16px}

/* Info overlay */
.ztc-info{position:absolute;bottom:90px;left:0;right:0;padding:0 2rem;z-index:5;color:#fff}
.ztc-info h1{font-size:2rem;font-weight:700;margin:.2rem 0 .5rem;text-shadow:0 2px 8px rgba(0,0,0,.5)}

/* Dots */
.ztc-dots{position:absolute;bottom:62px;left:50%;transform:translateX(-50%);display:flex;gap:6px;z-index:10}
.ztc-dot{width:8px;height:8px;border-radius:50%;background:rgba(255,255,255,.4);cursor:pointer;transition:.2s}
.ztc-dot.on{background:#fff;transform:scale(1.3)}

/* Counter */
.ztc-counter{position:absolute;top:16px;right:16px;background:rgba(0,0,0,.5);color:#fff;font-size:.8rem;padding:3px 10px;border-radius:20px;z-index:10;backdrop-filter:blur(4px)}

/* Thumbnails strip */
.ztc-thumbs{position:absolute;bottom:0;left:0;right:0;height:56px;display:flex;gap:4px;padding:4px 8px;background:rgba(0,0,0,.55);backdrop-filter:blur(6px);overflow-x:auto;z-index:10;scrollbar-width:none}
.ztc-thumbs::-webkit-scrollbar{display:none}
.ztc-thumb{flex:0 0 72px;height:46px;border-radius:5px;background-size:cover;background-position:center;cursor:pointer;border:2px solid transparent;transition:.2s;opacity:.65}
.ztc-thumb.on{border-color:var(--accent);opacity:1}
.ztc-thumb:hover{opacity:1}

@media(max-width:640px){
  .ztc-wrap{height:320px}
  .ztc-info h1{font-size:1.3rem}
  .ztc-info{bottom:70px;padding:0 1rem}
  .ztc-btn{width:36px;height:36px;font-size:1.6rem}
}
