/* =========================================
   ATLAS RIJUL — Premium Marrakech Platform
   ========================================= */
@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,500;1,400;1,500&family=Inter:wght@300;400;500&display=swap');

:root {
  --g:   #263322;   /* deep green */
  --g2:  #324229;
  --cr:  #ede8da;   /* warm cream */
  --cr2: #e4ddd0;
  --cr3: #f4efe6;
  --wh:  #faf8f3;
  --tx:  #1a1915;
  --tx2: #4a4840;
  --tx3: #8a8278;
  --au:  #a16207;   /* amber gold — UI PRO MAX recommended */
  --sd:  #c4a278;   /* sand */
  --bd:  rgba(26,25,21,.1);
  --bdd: rgba(237,232,218,.1);
  --fs:  'Playfair Display',Georgia,serif;
  --fn:  'Inter',sans-serif;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:16px;scroll-behavior:smooth}
body{font-family:var(--fn);background:var(--cr3);color:var(--tx);-webkit-font-smoothing:antialiased;overflow-x:hidden}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none;cursor:pointer}
button{cursor:pointer;font-family:inherit;border:none;background:none}
/* UI PRO MAX: cursor-pointer on all clickables */
a,button,[role="button"],.cat,.card,.btn-f,.btn-o,.btn-od,.btn-xs,.fsub,.fbtn,.ftab,.abt{cursor:pointer}
/* Hide scrollbar everywhere */
html,body{-ms-overflow-style:none;scrollbar-width:none}
html::-webkit-scrollbar,body::-webkit-scrollbar{display:none}
.hero-scroll{display:none!important}

/* UI PRO MAX: prefers-reduced-motion */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}
  .hero-bg img{transform:none!important}
}

/* ---- Layout ---- */
.wrap{max-width:1300px;margin:0 auto;padding:0 52px}
.wrap-sm{max-width:860px;margin:0 auto;padding:0 52px}

/* UI PRO MAX: Focus states for keyboard accessibility */
a:focus-visible,button:focus-visible,.fbtn:focus-visible,.cat:focus-visible{
  outline:2px solid var(--au);
  outline-offset:3px;
}

/* ---- Ticker ---- */
.ticker{background:var(--g);padding:11px 0;overflow:hidden}
.ticker__t{display:flex;white-space:nowrap;animation:tick 50s linear infinite;width:max-content}
.ticker__i{font-size:10px;letter-spacing:3px;text-transform:uppercase;color:rgba(237,232,218,.55);padding:0 48px}
.ticker__i b{color:var(--sd);font-weight:400;margin:0 10px}
@keyframes tick{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ---- Header ---- */
.hdr{position:fixed;top:0;left:0;right:0;z-index:999;transition:all .4s ease}
/* UI PRO MAX: Liquid Glass effect on scroll */
.hdr.solid{
  top:0;
  background:rgba(244,239,230,.82);
  backdrop-filter:blur(24px) saturate(180%);
  -webkit-backdrop-filter:blur(24px) saturate(180%);
  border-bottom:1px solid rgba(214,211,209,.5);
  box-shadow:0 1px 20px rgba(28,25,23,.05);
}
.hdr.always{position:sticky;top:0;background:var(--cr3);border-bottom:1px solid var(--bd)}
.hdr-in{display:flex;align-items:center;justify-content:space-between;padding:18px 52px;gap:24px}
.hdr.solid .hdr-in,.hdr.always .hdr-in{padding:14px 52px}

.logo{font-family:var(--fs);font-size:19px;font-weight:400;letter-spacing:4px;text-transform:uppercase;color:var(--wh);transition:color .3s}
.logo em{font-style:normal;color:var(--sd)}
.hdr.solid .logo,.hdr.always .logo{color:var(--tx)}
.hdr.solid .logo em,.hdr.always .logo em{color:var(--au)}

.nav{display:flex;gap:32px}
.nav a{font-size:11px;letter-spacing:2px;text-transform:uppercase;color:rgba(250,248,243,.6);transition:color .2s}
.hdr.solid .nav a,.hdr.always .nav a{color:var(--tx3)}
.nav a:hover,.hdr.solid .nav a:hover,.hdr.always .nav a:hover{color:var(--tx)}

.hdr-r{display:flex;align-items:center;gap:18px}
.cta-btn{font-size:10px;letter-spacing:2.5px;text-transform:uppercase;font-weight:500;color:var(--g);background:var(--cr);padding:11px 28px;transition:all .25s ease}
.cta-btn:hover{background:var(--wh)}
.hdr:not(.solid):not(.always) .cta-btn{background:rgba(237,232,218,.14);color:var(--cr);border:1px solid rgba(237,232,218,.3)}
.hdr:not(.solid):not(.always) .cta-btn:hover{background:rgba(237,232,218,.24)}

.ham{display:none;flex-direction:column;gap:5px;padding:4px}
.ham span{display:block;width:22px;height:1px;background:var(--wh);transition:.2s}
.hdr.solid .ham span,.hdr.always .ham span{background:var(--tx)}

/* ---- Mobile nav ---- */
.mob{
  position:fixed;inset:0;z-index:9998;
  background:var(--g);
  transform:translateX(100%);
  transition:transform .45s cubic-bezier(.25,.46,.45,.94);
  padding:40px 36px 40px;
  display:flex;flex-direction:column;
  overflow-y:auto;
}
.mob.on{transform:translateX(0)}
.mob-link{
  font-family:var(--fs);
  font-size:38px;
  font-weight:300;
  color:var(--cr);
  display:block;
  padding:10px 0;
  letter-spacing:.5px;
  border-bottom:1px solid rgba(237,232,218,.07);
  transition:color .2s,padding-left .2s;
  text-decoration:none;
}
.mob-link:hover{color:var(--sd);padding-left:8px}
.mob-link-sm{font-size:26px;padding:8px 0}
.mob-x{cursor:pointer}

/* ---- Hero ---- */
.hero{position:relative;height:100vh;min-height:700px;display:flex;align-items:flex-end;overflow:hidden}
.hero-bg{position:absolute;inset:0}
.hero-bg img{width:100%;height:100%;object-fit:cover;transform:scale(1.04);transition:transform 12s ease}
.hero.on .hero-bg img{transform:scale(1)}
.hero-shade{
  position:absolute;inset:0;
  background:
    linear-gradient(to bottom, rgba(18,24,16,.55) 0%, rgba(18,24,16,.05) 20%, rgba(18,24,16,0) 40%),
    linear-gradient(to top,   rgba(18,24,16,.92) 0%, rgba(18,24,16,.4)  45%, rgba(18,24,16,0) 70%);
}
.hero-body{position:relative;z-index:2;padding:0 52px 88px;max-width:900px}
.hero-tag{display:inline-flex;align-items:center;gap:18px;font-size:11px;letter-spacing:5px;text-transform:uppercase;color:rgba(212,180,130,.9);margin-bottom:28px;font-weight:400}
.hero-tag::before{content:'';display:block;width:40px;height:1px;background:var(--sd)}
.hero-h{font-family:var(--fs);font-size:clamp(68px,9vw,130px);font-weight:300;line-height:.95;letter-spacing:-2px;color:var(--wh);margin-bottom:36px}
.hero-h em{font-style:italic;color:rgba(212,180,130,1)}
.hero-h em{font-style:italic;color:rgba(196,162,120,.9)}
.hero-p{font-size:15px;font-weight:300;line-height:1.85;color:rgba(250,248,243,.52);max-width:440px;margin-bottom:48px}
.hero-btns{display:flex;gap:20px;flex-wrap:wrap}
.btn-f{display:inline-block;font-size:10px;letter-spacing:3px;text-transform:uppercase;font-weight:500;color:var(--g);background:var(--cr);padding:16px 40px;transition:all .25s ease}
.btn-f:hover{background:var(--wh);transform:translateY(-2px)}
.btn-o{display:inline-block;font-size:10px;letter-spacing:3px;text-transform:uppercase;color:var(--cr);border:1px solid rgba(237,232,218,.38);padding:16px 40px;transition:all .25s ease}
.btn-o:hover{border-color:var(--cr);background:rgba(237,232,218,.08)}
/* Hero floating featured cards */
.hero-cards{
  position:absolute;
  right:52px;
  top:50%;
  transform:translateY(-50%);
  z-index:3;
  display:flex;
  flex-direction:column;
  gap:14px;
  width:260px;
}
.hero-card{
  width:100%;
  background:rgba(244,239,230,.9);
  backdrop-filter:blur(24px);
  -webkit-backdrop-filter:blur(24px);
  border:1px solid rgba(237,232,218,.5);
  box-shadow:0 16px 48px rgba(18,24,16,.22);
  overflow:hidden;
  transition:transform .35s ease, box-shadow .35s ease;
}
.hero-card:hover{transform:translateY(-3px);box-shadow:0 24px 64px rgba(18,24,16,.3)}
.hero-card-tag{
  position:absolute;top:12px;left:12px;z-index:2;
  background:var(--g);color:var(--cr);
  font-size:9px;letter-spacing:2.5px;text-transform:uppercase;font-weight:600;
  padding:4px 12px;font-family:var(--fn);
}
.hero-card-img-wrap{display:block;height:160px;overflow:hidden}
.hero-card-img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .6s ease}
.hero-card:hover .hero-card-img{transform:scale(1.04)}
.hero-card-body{padding:20px 22px 22px}
.hero-card-cat{font-size:10px;letter-spacing:2px;text-transform:uppercase;color:var(--au);font-weight:500;margin-bottom:8px}
.hero-card-name{font-family:var(--fs);font-size:20px;font-weight:300;color:var(--tx);margin-bottom:8px;line-height:1.2}
.hero-card-meta{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--tx3);margin-bottom:18px;flex-wrap:wrap}
.hero-card-foot{display:flex;align-items:center;justify-content:space-between;border-top:1px solid var(--bd);padding-top:16px}
.hero-card-price{font-family:var(--fs);font-size:18px;font-weight:300;color:var(--tx)}
.hero-card-price small{font-family:var(--fn);font-size:11px;color:var(--tx3)}
.hero-card-btn{font-size:9px;letter-spacing:2px;text-transform:uppercase;font-weight:700;color:var(--cr);background:var(--g);padding:9px 18px;font-family:var(--fn);transition:background .2s;text-decoration:none;white-space:nowrap}
.hero-card-btn:hover{background:var(--g2)}
/* Hide on mobile */
@media(max-width:1100px){.hero-cards{display:none}}

/* Hero inline stats */
.hero-stats{display:flex;align-items:center;gap:0;margin-top:48px;padding-top:32px;border-top:1px solid rgba(237,232,218,.15);}
.hero-stat{display:flex;flex-direction:column;gap:4px;padding:0 32px;}
.hero-stat:first-child{padding-left:0}
.hero-stat-n{font-family:var(--fs);font-size:24px;font-weight:300;color:var(--wh);letter-spacing:.5px;}
.hero-stat-l{font-size:10px;letter-spacing:2.5px;text-transform:uppercase;color:rgba(237,232,220,.5);}
.hero-stat-sep{width:1px;height:36px;background:rgba(237,232,220,.2);}

.hero-scroll{position:absolute;right:52px;bottom:48px;z-index:2;writing-mode:vertical-rl;font-size:9px;letter-spacing:3px;text-transform:uppercase;color:rgba(237,232,218,.35);display:flex;align-items:center;gap:14px}
.hero-scroll::before{content:'';display:block;width:1px;height:52px;background:linear-gradient(to bottom,var(--sd),transparent)}

/* ---- Stats ---- */
.stats{background:var(--g);padding:0}
.stats-in{display:grid;grid-template-columns:repeat(4,1fr)}
.stat{padding:26px 40px;border-right:1px solid var(--bdd)}
.stat:first-child{padding-left:0}
.stat:last-child{border-right:none}
.stat-n{font-size:12px;font-weight:500;color:var(--cr);letter-spacing:.3px;margin-bottom:3px}
.stat-s{font-size:10px;color:rgba(237,232,218,.4);letter-spacing:.3px}

/* ---- Section headers ---- */
.sec-eye{display:inline-flex;align-items:center;gap:16px;font-size:10px;letter-spacing:4px;text-transform:uppercase;color:var(--au);margin-bottom:16px}
.sec-eye::before{content:'';display:block;width:28px;height:1px;background:currentColor}
.sec-h{font-family:var(--fs);font-size:clamp(36px,4vw,56px);font-weight:300;line-height:1.1;color:var(--tx);letter-spacing:-.5px}
.sec-h em{font-style:italic}
.sec-h.lt{color:var(--cr)}
.sec-p{font-size:14px;font-weight:300;line-height:1.85;color:var(--tx3);max-width:380px;margin-top:12px}
.sec-p.lt{color:rgba(237,232,218,.5)}

/* ---- Categories ---- */
.cats{padding:96px 0 80px;background:var(--cr3)}
.cats-top{margin-bottom:52px}
.cats-row{display:grid;grid-template-columns:repeat(5,1fr);gap:10px;padding:0 52px}
.cat{display:block;position:relative;border-radius:6px;overflow:hidden}
.cat-img{height:480px;overflow:hidden}
.cat-img img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .9s cubic-bezier(.25,.46,.45,.94)}
.cat:hover .cat-img img{transform:scale(1.08)}
.cat-ovl{
  position:absolute;inset:0;
  background:linear-gradient(to top,rgba(18,24,16,.85) 0%,rgba(18,24,16,.25) 45%,rgba(18,24,16,.0) 70%);
  transition:background .4s;
}
.cat:hover .cat-ovl{background:linear-gradient(to top,rgba(18,24,16,.92) 0%,rgba(18,24,16,.35) 55%,rgba(18,24,16,.05) 75%)}
.cat-txt{
  position:absolute;bottom:0;left:0;right:0;
  padding:24px 24px 28px;
  transform:translateY(6px);
  transition:transform .4s cubic-bezier(.25,.46,.45,.94);
}
.cat:hover .cat-txt{transform:translateY(0)}
.cat-name{
  font-family:var(--fs);font-size:21px;font-weight:300;
  color:var(--wh);display:block;margin-bottom:7px;letter-spacing:.5px;
}
.cat-cnt{
  font-size:9px;letter-spacing:3px;text-transform:uppercase;
  color:rgba(196,162,120,.8);display:block;margin-bottom:14px;
}
.cat-arrow{
  display:inline-flex;align-items:center;justify-content:center;
  width:32px;height:32px;
  border:1px solid rgba(237,232,218,.3);
  border-radius:50%;
  opacity:0;transform:translateY(8px);
  transition:opacity .35s,transform .35s;
  font-size:13px;color:var(--cr);
}
.cat:hover .cat-arrow{opacity:1;transform:translateY(0)}

/* ---- Booking Confirmation Modal ---- */
.bk-confirm-bg{
  position:fixed;inset:0;z-index:99999;
  background:rgba(7,16,10,.85);
  backdrop-filter:blur(12px);
  display:none;align-items:center;justify-content:center;padding:20px;
}
.bk-confirm-bg.open{display:flex}
.bk-confirm{
  display:grid;
  grid-template-columns:1fr 1fr;
  max-width:820px;width:100%;
  border-radius:16px;
  overflow:hidden;
  box-shadow:0 40px 100px rgba(0,0,0,.5);
}
.bk-confirm-left{
  background:#f5f0e8;
  padding:56px 40px;
  display:flex;flex-direction:column;
  align-items:center;justify-content:center;
  text-align:center;gap:24px;
}
.bk-check{
  width:72px;height:72px;border-radius:50%;
  border:3px solid #22c55e;
  display:flex;align-items:center;justify-content:center;
  animation:checkPop .5s cubic-bezier(.34,1.56,.64,1) both;
}
.bk-check svg{width:36px;height:36px;color:#22c55e}
@keyframes checkPop{from{transform:scale(0);opacity:0}to{transform:scale(1);opacity:1}}
.bk-confirm-title{font-family:var(--fs);font-size:22px;font-weight:400;color:var(--tx);line-height:1.3}
.bk-confirm-sub{font-size:13px;font-weight:300;color:var(--tx3);line-height:1.75;max-width:240px}
.bk-confirm-got{
  width:100%;padding:14px;
  font-size:11px;letter-spacing:2px;text-transform:uppercase;font-weight:600;
  color:var(--tx);background:var(--wh);
  border:1.5px solid rgba(26,25,21,.15);
  border-radius:8px;cursor:pointer;font-family:var(--fn);
  transition:all .2s;
}
.bk-confirm-got:hover{background:var(--g);color:var(--cr);border-color:var(--g)}
.bk-confirm-more{font-size:12px;font-weight:600;color:var(--tx3);cursor:pointer;transition:color .2s;background:none;border:none;font-family:var(--fn)}
.bk-confirm-more:hover{color:var(--tx)}
.bk-confirm-right{
  background:#111811;
  padding:40px 36px;
  position:relative;
}
.bk-confirm-close{
  position:absolute;top:16px;right:16px;
  background:none;border:none;color:rgba(255,255,255,.4);
  font-size:18px;cursor:pointer;transition:color .2s;
  width:32px;height:32px;display:flex;align-items:center;justify-content:center;
}
.bk-confirm-close:hover{color:#fff}
.bk-summary-title{font-family:var(--fs);font-size:20px;font-weight:400;color:#ede8dc;margin-bottom:24px}
.bk-summary-row{margin-bottom:16px}
.bk-summary-lbl{font-size:10px;letter-spacing:2px;text-transform:uppercase;color:rgba(237,232,220,.4);margin-bottom:4px}
.bk-summary-val{font-size:14px;font-weight:600;color:#ede8dc}
.bk-summary-div{border-top:1px solid rgba(255,255,255,.08);margin:20px 0}
.bk-summary-wa{
  display:flex;align-items:center;gap:10px;
  background:rgba(37,211,102,.1);border:1px solid rgba(37,211,102,.25);
  border-radius:8px;padding:14px;margin-top:20px;
  font-size:13px;color:#25d366;font-weight:500;
  text-decoration:none;transition:background .2s;
}
.bk-summary-wa:hover{background:rgba(37,211,102,.18)}
.bk-summary-wa svg{width:20px;height:20px;flex-shrink:0}

@media(max-width:700px){
  .bk-confirm{grid-template-columns:1fr}
  .bk-confirm-right{display:none}
  .bk-confirm-left{padding:40px 28px;border-radius:0}
}

/* Coming soon category */
.cat-soon{cursor:default}
.cat-soon .cat-img img{filter:grayscale(25%) brightness(.7);transition:none}
.cat-soon:hover .cat-img img{transform:none;filter:grayscale(25%) brightness(.7)}
.cat-soon:hover .cat-ovl{background:linear-gradient(to top,rgba(18,24,16,.82) 0%,rgba(18,24,16,.08) 50%)}

/* ---- Listings ---- */
.listings{padding:96px 0;background:var(--g)}
.listings-top{display:flex;align-items:flex-end;justify-content:space-between;gap:32px;margin-bottom:52px}
.btn-od{font-size:10px;letter-spacing:3px;text-transform:uppercase;color:var(--cr);border:1px solid rgba(237,232,218,.35);padding:13px 36px;display:inline-block;transition:all .25s ease;white-space:nowrap}
.btn-od:hover{background:var(--cr);color:var(--g)}
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:2px}
.card{display:block;background:var(--cr3);transition:transform .35s ease}
.card:hover{transform:translateY(-6px);box-shadow:0 24px 64px rgba(18,24,16,.2)}
.card-img{height:280px;overflow:hidden;position:relative}
.card-img img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .6s ease}
.card:hover .card-img img{transform:scale(1.05)}
.card-badge{position:absolute;top:16px;left:16px;font-size:9px;letter-spacing:2px;text-transform:uppercase;font-weight:600;color:var(--g);background:var(--cr);padding:5px 12px}
.card-body{padding:24px 28px 28px}
.card-cat{font-size:9px;letter-spacing:3px;text-transform:uppercase;color:var(--au);margin-bottom:10px;font-weight:500}
.card-name{font-family:var(--fs);font-size:22px;font-weight:300;color:var(--tx);margin-bottom:8px;line-height:1.3}
.card-loc{font-size:11px;color:var(--tx3);margin-bottom:20px}
.card-foot{display:flex;align-items:center;justify-content:space-between;border-top:1px solid var(--bd);padding-top:18px}
.card-price{font-family:var(--fs);font-size:20px;font-weight:300;color:var(--tx)}
.card-price small{font-family:var(--fn);font-size:11px;color:var(--tx3)}
.btn-xs{font-size:9px;letter-spacing:2px;text-transform:uppercase;font-weight:600;color:var(--g);border:1px solid var(--g);padding:8px 18px;transition:all .25s ease}
.btn-xs:hover{background:var(--g);color:var(--cr)}

/* ---- Split section ---- */
.split{display:grid;grid-template-columns:1fr 1fr}
.split-img{height:580px;overflow:hidden}
.split-img img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .8s ease}
.split:hover .split-img img{transform:scale(1.03)}
.split-body{background:var(--cr2);padding:80px 72px;display:flex;flex-direction:column;justify-content:center}
.split-nums{display:flex;gap:52px;margin-top:48px;padding-top:48px;border-top:1px solid var(--bd)}
.split-num{font-family:var(--fs);font-size:48px;font-weight:300;color:var(--g);line-height:1}
.split-nlbl{font-size:11px;color:var(--tx3);margin-top:6px;letter-spacing:.5px}

/* ---- Booking ---- */
.book{padding:96px 0;background:var(--cr2)}
.book-head{text-align:center;margin-bottom:52px}
.book-head .sec-eye{justify-content:center}
.book-box{background:var(--wh);padding:56px 60px;box-shadow:0 8px 64px rgba(26,25,21,.06)}
/* UI PRO MAX: touch-friendly inputs min 44px, proper grid collapse on mobile */
.form{display:grid;grid-template-columns:1fr 1fr;gap:24px 36px}
.fi,.fs2,.ft{min-height:44px} /* UI PRO MAX touch target */
.fg{display:flex;flex-direction:column;gap:8px}
.fg.full{grid-column:1/-1}
.fl{font-size:10px;letter-spacing:2px;text-transform:uppercase;color:var(--tx3);font-weight:500}
.fi,.fs2,.ft{background:transparent;border:none;border-bottom:1.5px solid rgba(26,25,21,.12);padding:12px 0;font-size:14px;font-weight:300;color:var(--tx);font-family:var(--fn);outline:none;transition:border-color .2s;width:100%;border-radius:0}
.fi:focus,.fs2:focus,.ft:focus{border-color:var(--g)}
.fi::placeholder,.ft::placeholder{color:rgba(26,25,21,.2)}
.fs2{appearance:none;cursor:pointer;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%238a8278' stroke-width='1.5'%3E%3Cpath d='M19.5 8.25l-7.5 7.5-7.5-7.5'/%3E%3C/svg%3E") right 2px center/16px no-repeat transparent}
.fsub{grid-column:1/-1;width:100%;padding:18px;font-size:10px;letter-spacing:3px;text-transform:uppercase;font-weight:600;color:var(--cr);background:var(--g);margin-top:8px;transition:background .2s;font-family:var(--fn);cursor:pointer;border:none}
.fsub:hover{background:var(--g2)}
#book-res{display:none;grid-column:1/-1;padding:18px;text-align:center;font-size:13px;border-radius:2px}

/* ---- Testimonials ---- */
.testi{padding:96px 0;background:var(--cr3)}
.testi-head{text-align:center;margin-bottom:52px}
.testi-head .sec-eye{justify-content:center}
.testi-row{display:grid;grid-template-columns:repeat(3,1fr);gap:2px}
.tc{background:var(--wh);padding:40px;transition:transform .3s}
.tc:hover{transform:translateY(-4px)}
.tc-stars{color:var(--au);font-size:13px;letter-spacing:3px;margin-bottom:20px}
.tc-q{font-family:var(--fs);font-size:18px;font-style:italic;font-weight:300;line-height:1.75;color:var(--tx);margin-bottom:28px}
.tc-auth{display:flex;align-items:center;gap:14px}
.tc-av{width:42px;height:42px;border-radius:50%;object-fit:cover;display:block}
.tc-nm{font-size:13px;font-weight:500;color:var(--tx)}
.tc-lc{font-size:11px;color:var(--tx3);margin-top:2px}

/* ---- Newsletter ---- */
.ftr-news{
  background:var(--g2);
  border-bottom:1px solid rgba(237,232,218,.08);
  padding:72px 0;
  position:relative;
  overflow:hidden;
}
.ftr-news::before{
  content:'';
  position:absolute;
  top:-60px;right:-60px;
  width:300px;height:300px;
  background:radial-gradient(circle,rgba(196,162,120,.08) 0%,transparent 70%);
  pointer-events:none;
}
.ftr-news-inner{
  max-width:1300px;
  margin:0 auto;
  padding:0 52px;
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:64px;
  align-items:center;
}
.ftr-news-eye{
  font-size:10px;
  letter-spacing:4px;
  text-transform:uppercase;
  color:var(--sd);
  font-weight:500;
  display:block;
  margin-bottom:16px;
}
.ftr-news-h{
  font-family:var(--fs);
  font-size:clamp(28px,3vw,42px);
  font-weight:300;
  color:var(--cr);
  line-height:1.15;
  margin-bottom:14px;
}
.ftr-news-h em{font-style:italic;color:var(--sd)}
.ftr-news-p{
  font-size:14px;
  font-weight:300;
  color:rgba(237,232,218,.5);
  line-height:1.8;
}
.ftr-news-label{
  display:block;
  font-size:10px;
  letter-spacing:2px;
  text-transform:uppercase;
  color:rgba(237,232,218,.4);
  font-weight:500;
  margin-bottom:12px;
}
.ftr-news-row{
  display:flex;
  gap:0;
  border-bottom:1.5px solid rgba(237,232,218,.25);
  transition:border-color .3s;
}
.ftr-news-row:focus-within{border-color:var(--sd)}
.ftr-news-input{
  flex:1;
  background:transparent;
  border:none;
  padding:14px 0;
  font-size:15px;
  font-weight:300;
  color:var(--cr);
  font-family:var(--fn);
  outline:none;
}
.ftr-news-input::placeholder{color:rgba(237,232,218,.25)}
.ftr-news-btn{
  background:none;
  border:none;
  cursor:pointer;
  display:flex;
  align-items:center;
  gap:10px;
  font-size:11px;
  letter-spacing:2px;
  text-transform:uppercase;
  font-weight:600;
  color:var(--sd);
  font-family:var(--fn);
  padding:14px 0 14px 20px;
  flex-shrink:0;
  transition:color .2s,gap .2s;
}
.ftr-news-btn:hover{color:var(--cr);gap:14px}
.ftr-news-btn svg{transition:transform .2s}
.ftr-news-btn:hover svg{transform:translateX(4px)}
.ftr-news-note{
  font-size:11px;
  color:rgba(237,232,218,.25);
  margin-top:12px;
  letter-spacing:.3px;
}

/* ---- Subscribe + Connected Strip ---- */
.ftr-subscribe{
  background:var(--g);
  border-bottom:1px solid rgba(237,232,218,.1);
  padding:64px 0;
}
.ftr-sub-inner{
  max-width:1300px;
  margin:0 auto;
  padding:0 52px;
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:80px;
  align-items:start;
}
.ftr-sub-h{
  font-family:var(--fs);
  font-size:clamp(28px,3vw,40px);
  font-weight:300;
  color:var(--cr);
  margin-bottom:28px;
  line-height:1.2;
}
.ftr-sub-h em{font-style:italic;color:var(--cr)}
.ftr-sub-form{width:100%}
.ftr-sub-row{
  display:flex;
  border:1px solid rgba(237,232,218,.35);
  transition:border-color .3s;
}
.ftr-sub-row:focus-within{border-color:rgba(237,232,218,.7)}
.ftr-sub-input{
  flex:1;
  background:transparent;
  border:none;
  padding:18px 20px;
  font-size:15px;
  font-weight:300;
  color:var(--cr);
  font-family:var(--fn);
  outline:none;
}
.ftr-sub-input::placeholder{color:rgba(237,232,218,.35)}
.ftr-sub-btn{
  background:none;
  border:none;
  border-left:1px solid rgba(237,232,218,.35);
  padding:18px 28px;
  font-size:10px;
  letter-spacing:3px;
  text-transform:uppercase;
  font-weight:700;
  color:var(--cr);
  font-family:var(--fn);
  cursor:pointer;
  flex-shrink:0;
  transition:background .2s,color .2s;
  white-space:nowrap;
}
.ftr-sub-btn:hover{background:rgba(237,232,218,.08)}
.ftr-sub-icons{
  display:flex;
  gap:20px;
  align-items:center;
  flex-wrap:wrap;
}
.ftr-sub-icon{
  width:52px;
  height:52px;
  border:1px solid rgba(237,232,218,.25);
  display:flex;
  align-items:center;
  justify-content:center;
  color:rgba(237,232,218,.7);
  transition:all .25s ease;
  border-radius:4px;
}
.ftr-sub-icon:hover{
  border-color:var(--cr);
  color:var(--cr);
  background:rgba(237,232,218,.06);
}

/* ---- Footer ---- */
.ftr{background:var(--g)}
.ftr-main{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:56px;padding:80px 52px 56px}
.ftr-logo{font-family:var(--fs);font-size:21px;letter-spacing:4px;text-transform:uppercase;color:var(--cr);display:block;margin-bottom:18px;font-weight:400}
.ftr-logo em{font-style:normal;color:var(--sd)}
.ftr-about{font-size:13px;font-weight:300;color:rgba(237,232,218,.4);line-height:1.85;max-width:280px;margin-bottom:28px}
.ftr-soc{display:flex;gap:12px}
.ftr-soc a{width:34px;height:34px;border:1px solid rgba(237,232,218,.12);display:flex;align-items:center;justify-content:center;font-size:13px;color:rgba(237,232,218,.45);transition:all .25s ease;text-decoration:none}
.ftr-soc a:hover{border-color:var(--sd);color:var(--sd)}
.ftr-col h5{font-size:10px;letter-spacing:3px;text-transform:uppercase;font-weight:500;color:rgba(237,232,218,.32);margin-bottom:22px}
.ftr-col ul{display:flex;flex-direction:column;gap:12px;list-style:none;padding:0;margin:0}
.ftr-col a{font-size:13px;font-weight:300;color:rgba(237,232,218,.48);transition:color .2s}
.ftr-col a:hover{color:var(--cr)}
.ftr-wm{font-family:var(--fs);font-size:clamp(52px,8vw,120px);font-weight:300;color:rgba(237,232,218,.18);text-align:center;letter-spacing:8px;text-transform:uppercase;padding:0 0 12px;user-select:none}
.ftr-wm em{color:rgba(196,162,120,.35)}
.ftr-bot{border-top:1px solid rgba(237,232,218,.07);padding:22px 52px;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px}
.ftr-bot p,.ftr-bot a{font-size:11px;color:rgba(237,232,218,.26);letter-spacing:.4px;transition:color .2s}
.ftr-bot a:hover{color:var(--cr)}
.ftr-links{display:flex;gap:24px}

/* ---- Archive page ---- */
.arch{padding:140px 52px 96px;background:var(--cr3)}
.arch-h{margin-bottom:52px}
.filters{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:40px;border-bottom:1px solid var(--bd);padding-bottom:24px}
.fbtn{font-size:10px;letter-spacing:2px;text-transform:uppercase;padding:10px 22px;border:1px solid rgba(26,25,21,.14);color:var(--tx3);background:transparent;font-family:var(--fn);cursor:pointer;transition:all .25s ease}
.fbtn:hover,.fbtn.on{background:var(--g);color:var(--cr);border-color:var(--g)}
.grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}

/* ---- Single listing ---- */
.lst-hero{height:62vh;overflow:hidden}
.lst-hero img{width:100%;height:100%;object-fit:cover;display:block}
.lst-layout{display:grid;grid-template-columns:1fr 360px;gap:56px;padding:64px 52px 100px;background:var(--cr3);max-width:1300px;margin:0 auto}
.lst-title{font-family:var(--fs);font-size:clamp(32px,4vw,52px);font-weight:300;color:var(--tx);margin-bottom:18px}
.lst-meta{display:flex;gap:28px;flex-wrap:wrap;margin-bottom:28px}
.lst-mi{font-size:12px;color:var(--tx3)}
.lst-desc{font-size:15px;line-height:1.9;color:var(--tx2);font-weight:300}
.bk-card{background:var(--wh);padding:36px;box-shadow:0 4px 32px rgba(26,25,21,.07);position:sticky;top:100px;height:fit-content}
.bk-price{font-family:var(--fs);font-size:38px;font-weight:300;color:var(--tx);margin-bottom:4px}
.bk-price small{font-family:var(--fn);font-size:12px;color:var(--tx3)}
.bk-form{display:flex;flex-direction:column;gap:18px;margin-top:24px}

/* ---- Login/Dashboard ---- */
.login-wrap{min-height:100vh;display:grid;grid-template-columns:1fr 1fr;background:#080c08}
.login-left{position:relative;overflow:hidden}
.login-left img{width:100%;height:100%;object-fit:cover;display:block}
.login-left-ov{position:absolute;inset:0;background:linear-gradient(135deg,rgba(8,12,8,.92),rgba(8,12,8,.5))}
.login-left-body{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:space-between;padding:48px}
.login-logo{font-family:var(--fs);font-size:22px;letter-spacing:4px;text-transform:uppercase;color:var(--cr);font-weight:400}
.login-logo em{font-style:normal;color:var(--sd)}
.login-h{font-family:var(--fs);font-size:clamp(36px,4vw,54px);font-weight:300;color:var(--cr);line-height:1.1}
.login-h em{font-style:italic;color:var(--sd)}
.login-right{background:#0c100c;display:flex;align-items:center;justify-content:center;padding:48px}
.login-box{width:100%;max-width:400px}
.login-title{font-family:var(--fs);font-size:36px;font-weight:300;color:var(--cr);margin-bottom:6px}
.login-sub{font-size:13px;color:rgba(237,232,218,.4);margin-bottom:40px}
.login-fg{display:flex;flex-direction:column;gap:8px;margin-bottom:20px}
.login-fl{font-size:10px;letter-spacing:2px;text-transform:uppercase;color:rgba(237,232,218,.4);font-weight:500}
.login-fi{background:#1a1f1a;border:1px solid rgba(255,255,255,.07);padding:14px 16px;font-size:14px;color:var(--cr);font-family:var(--fn);outline:none;transition:border-color .2s;width:100%}
.login-fi:focus{border-color:var(--sd)}
.login-fi::placeholder{color:rgba(255,255,255,.18)}
.login-submit{width:100%;padding:16px;font-size:10px;letter-spacing:3px;text-transform:uppercase;font-weight:600;color:var(--g);background:var(--cr);border:none;cursor:pointer;font-family:var(--fn);margin-top:8px;transition:background .2s}
.login-submit:hover{background:var(--wh)}
.login-err{background:rgba(239,68,68,.1);border:1px solid rgba(239,68,68,.3);color:#ef4444;padding:14px;font-size:13px;margin-bottom:24px}
.login-back{text-align:center;margin-top:28px;font-size:12px;color:rgba(237,232,218,.25)}
.login-back a{color:rgba(237,232,218,.45);transition:color .2s}
.login-back a:hover{color:var(--cr)}

/* ---- Dashboard ---- */
.dash{display:grid;grid-template-columns:240px 1fr;min-height:100vh;background:#080c08}
.dsb{background:#0c100c;border-right:1px solid rgba(255,255,255,.05);padding:32px 0;display:flex;flex-direction:column;position:sticky;top:0;height:100vh}
.dsb-logo{font-family:var(--fs);font-size:19px;letter-spacing:3px;text-transform:uppercase;color:var(--cr);padding:0 24px 28px;border-bottom:1px solid rgba(255,255,255,.05);font-weight:400}
.dsb-logo em{font-style:normal;color:var(--sd)}
.dsb-nav{padding:20px 12px;flex:1}
.dsb-lbl{font-size:9px;letter-spacing:2px;text-transform:uppercase;color:rgba(255,255,255,.2);padding:0 12px;margin:20px 0 8px}
.dsb-lbl:first-child{margin-top:0}
.dsb-nav a{display:flex;align-items:center;gap:12px;padding:10px 12px;font-size:13px;color:rgba(255,255,255,.45);transition:all .15s;margin-bottom:2px;border-radius:6px}
.dsb-nav a:hover{background:rgba(255,255,255,.04);color:rgba(255,255,255,.8)}
.dsb-nav a.on{background:rgba(38,51,34,.5);color:var(--sd)}
.dsb-ft{padding:20px 24px;border-top:1px solid rgba(255,255,255,.05)}
.dsb-user{display:flex;align-items:center;gap:12px;margin-bottom:14px}
.dsb-av{width:34px;height:34px;background:linear-gradient(135deg,var(--g),var(--sd));border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--fs);font-size:15px;color:var(--cr);flex-shrink:0}
.dsb-nm{font-size:13px;font-weight:500;color:var(--cr)}
.dsb-rl{font-size:11px;color:rgba(255,255,255,.3)}
.dsb-out{font-size:12px;color:rgba(255,255,255,.3);transition:color .15s}
.dsb-out:hover{color:#ef4444}
.dmain{padding:40px 48px;overflow-x:auto;background:#09100a}
.d-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:36px;flex-wrap:wrap;gap:16px}
.d-h1{font-family:var(--fs);font-size:32px;font-weight:300;color:var(--cr)}
.d-h1 em{font-style:italic;color:var(--sd)}
.d-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:28px}
.ds{background:#111811;border:1px solid rgba(255,255,255,.06);border-radius:10px;padding:22px;border-top:3px solid transparent}
.ds.total{border-top-color:var(--sd)}
.ds.pend{border-top-color:#f59e0b}
.ds.conf{border-top-color:#22c55e}
.ds.canc{border-top-color:#ef4444}
.ds-l{font-size:9px;letter-spacing:2px;text-transform:uppercase;color:rgba(255,255,255,.28);margin-bottom:10px}
.ds-n{font-family:var(--fs);font-size:44px;font-weight:300;color:var(--cr);line-height:1}
.ds-s{font-size:11px;color:rgba(255,255,255,.22);margin-top:6px}
.d-fbar{display:flex;align-items:center;gap:8px;margin-bottom:18px;flex-wrap:wrap}
.ftab{font-size:10px;letter-spacing:1.5px;text-transform:uppercase;padding:8px 18px;border:1px solid rgba(255,255,255,.08);color:rgba(255,255,255,.35);background:none;font-family:var(--fn);cursor:pointer;transition:all .15s;border-radius:999px}
.ftab:hover{color:rgba(255,255,255,.7);border-color:rgba(255,255,255,.2)}
.ftab.on{background:rgba(38,51,34,.5);border-color:var(--sd);color:var(--sd)}
.d-srch{margin-left:auto;display:flex;align-items:center;background:#111811;border:1px solid rgba(255,255,255,.08);border-radius:999px;overflow:hidden}
.d-srch input{background:transparent;border:none;padding:9px 16px;font-size:13px;color:var(--cr);outline:none;width:200px;font-family:var(--fn)}
.d-srch input::placeholder{color:rgba(255,255,255,.2)}
.d-srch button{background:none;border:none;padding:9px 16px;color:rgba(255,255,255,.3);cursor:pointer;font-size:16px}
.d-tw{background:#111811;border:1px solid rgba(255,255,255,.06);border-radius:10px;overflow:hidden}
.d-table{width:100%;border-collapse:collapse}
.d-table thead tr{background:#0c100c;border-bottom:1px solid rgba(255,255,255,.06)}
.d-table th{font-size:9px;letter-spacing:2px;text-transform:uppercase;color:rgba(255,255,255,.25);padding:14px 18px;text-align:left;white-space:nowrap}
.d-table td{padding:14px 18px;font-size:13px;color:rgba(255,255,255,.7);border-bottom:1px solid rgba(255,255,255,.04);vertical-align:middle}
.d-table tbody tr:last-child td{border-bottom:none}
.d-table tbody tr:hover td{background:rgba(255,255,255,.015)}
.bdg{display:inline-block;font-size:9px;letter-spacing:1px;text-transform:uppercase;font-weight:700;padding:4px 10px;border-radius:999px}
.bdg-p{background:rgba(245,158,11,.12);color:#f59e0b}
.bdg-c{background:rgba(34,197,94,.12);color:#22c55e}
.bdg-x{background:rgba(239,68,68,.12);color:#ef4444}
.abt{display:inline-flex;align-items:center;gap:6px;font-size:10px;letter-spacing:1px;text-transform:uppercase;font-weight:600;padding:6px 12px;border-radius:999px;border:1px solid rgba(255,255,255,.08);color:rgba(255,255,255,.5);background:none;font-family:var(--fn);cursor:pointer;transition:all .15s;white-space:nowrap;text-decoration:none}
.abt:hover{border-color:rgba(255,255,255,.2);color:rgba(255,255,255,.8)}
.abt.wa{color:#25d366;border-color:rgba(37,211,102,.25)}
.abt.wa:hover{background:rgba(37,211,102,.08)}
.d-sel{background:#1a1f1a;border:1px solid rgba(255,255,255,.08);color:rgba(255,255,255,.7);padding:5px 10px;border-radius:6px;font-size:11px;font-family:var(--fn);cursor:pointer;outline:none}
.d-empty{padding:72px;text-align:center;color:rgba(255,255,255,.18)}
.d-empty p{font-size:14px}

/* ---- Responsive ---- */
@media(max-width:1100px){
  .ftr-sub-inner{grid-template-columns:1fr;gap:48px;padding:0 32px}

  .wrap,.wrap-sm{padding:0 32px}
  .hdr-in,.ftr-main,.ftr-bot,.arch{padding-left:32px;padding-right:32px}
  .hero-body{padding:0 32px 72px}
  .cats-row{grid-template-columns:repeat(3,1fr);padding:0 32px;gap:8px}
  .cat-img{height:300px}
  .cards,.testi-row{grid-template-columns:repeat(2,1fr)}
  .ftr-main{grid-template-columns:1fr 1fr;gap:40px}
  .split{grid-template-columns:1fr}
  .split-img{height:400px}
  .split-body{padding:56px 48px}
  .lst-layout{grid-template-columns:1fr;padding:48px 32px 80px}
  .bk-card{position:static}
  .d-stats{grid-template-columns:repeat(2,1fr)}
  .dash{grid-template-columns:1fr}
  .dsb{display:none}
}
@media(max-width:768px){
  /* Footer mobile — hide Morocco & Company cols, keep Explore */
  .ftr-main{grid-template-columns:1fr 1fr;gap:32px;padding:48px 20px 36px}
  .ftr-col:nth-child(3),.ftr-col:nth-child(4){display:none}
  .ftr-subscribe{padding:48px 0}
  .ftr-sub-inner{padding:0 20px;gap:40px}
  .wrap,.wrap-sm{padding:0 20px}
  .hdr-in{padding:14px 20px}
  .nav,.cta-btn{display:none}
  .ham{display:flex}
  .hero-body{padding:0 20px 48px}
  .hero-stats{gap:0;margin-top:32px;padding-top:24px}
  .hero-stat{padding:0 20px}
  .hero-stat-n{font-size:20px}
  .hero-stat-l{font-size:9px}
  .cats-row{grid-template-columns:repeat(2,1fr);padding:0 20px;gap:8px}
  .cat-img{height:240px}
  /* last tile alone fills full row */
  .cat:last-child:nth-child(odd){grid-column:1/-1}
  .cat:last-child:nth-child(odd) .cat-img{height:220px}
  .cards,.testi-row,.grid3{grid-template-columns:1fr}
  .stats-in{grid-template-columns:repeat(2,1fr)}
  .stat{padding:16px 20px;border-right:none;border-bottom:1px solid var(--bdd)}
  .ftr-main{grid-template-columns:1fr;gap:28px;padding:56px 20px 40px}
  .btn-od{font-size:9px;padding:10px 20px;letter-spacing:2px}
  .ftr-bot{padding:18px 20px}
  .arch{padding:120px 20px 72px}

  /* ---- Booking form mobile fix ---- */
  .book{padding:64px 0}
  .book-box{
    padding:28px 20px!important;
    margin:0;
    width:100%;
    overflow:hidden;
  }
  .form{
    display:flex!important;
    flex-direction:column!important;
    gap:20px!important;
  }
  .fg,.fg.full{
    width:100%!important;
    grid-column:unset!important;
  }
  .fi,.fs2,.ft{
    font-size:16px!important; /* prevents iOS zoom */
    width:100%!important;
    box-sizing:border-box!important;
  }
  .fsub{
    grid-column:unset!important;
    width:100%!important;
  }
  #book-res{
    grid-column:unset!important;
    width:100%!important;
  }

  /* ---- Login ---- */
  .login-wrap{grid-template-columns:1fr}
  .login-left{display:none}
  .login-right{padding:40px 24px}

  /* ---- Dashboard ---- */
  .dmain{padding:24px 16px}
}
