/* ===================================================================
   CéZar — Café Lounge · Tanger
   Dark luxury lounge: charcoal + gold + magenta neon
   =================================================================== */

:root{
  /* Surfaces */
  --bg:            #0b0908;
  --bg-2:          #120e0d;
  --surface:       #17110f;
  --surface-2:     #1f1815;
  --border:        rgba(201,162,75,.18);
  --border-soft:   rgba(255,255,255,.07);

  /* Ink */
  --ink:           #f5efe7;
  --ink-soft:      #cabfb3;
  --ink-mute:      #8f847a;

  /* Brand accents */
  --gold:          #c9a24b;
  --gold-bright:   #e7c877;
  --gold-deep:     #9c7c33;
  --magenta:       #e4187e;
  --magenta-soft:  #ff4fa3;

  /* Type */
  --serif: 'Playfair Display', Georgia, serif;
  --cormorant: 'Cormorant Garamond', Georgia, serif;
  --script: 'Great Vibes', cursive;
  --sans: 'Jost', system-ui, -apple-system, sans-serif;

  --container: 1180px;
  --radius: 14px;
  --ease: cubic-bezier(.22,.61,.36,1);
}

*,*::before,*::after{ box-sizing:border-box; margin:0; padding:0; }

html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
@media (prefers-reduced-motion: reduce){ html{ scroll-behavior:auto; } }

body{
  font-family:var(--sans);
  background:var(--bg);
  color:var(--ink);
  line-height:1.65;
  font-weight:300;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}

img{ max-width:100%; display:block; }

.container{ width:100%; max-width:var(--container); margin-inline:auto; padding-inline:24px; }

.section{ padding:clamp(70px,10vw,130px) 0; position:relative; }

/* ---------- Typographic primitives ---------- */
.kicker{
  font-family:var(--sans);
  text-transform:uppercase;
  letter-spacing:.34em;
  font-size:.72rem;
  font-weight:500;
  color:var(--gold-bright);
  margin-bottom:18px;
}
.h2{
  font-family:var(--serif);
  font-weight:600;
  font-size:clamp(2rem,5vw,3.3rem);
  line-height:1.08;
  letter-spacing:.5px;
}
.lead{
  font-family:var(--cormorant);
  font-size:clamp(1.15rem,2.2vw,1.4rem);
  color:var(--ink-soft);
  line-height:1.6;
  margin-block:14px;
}
.lead.center{ max-width:620px; margin-inline:auto; }
.center{ text-align:center; }

.section-head{ text-align:center; margin-bottom:56px; }
.section-head .kicker{ margin-bottom:14px; }

/* Divider ornament */
.divider{
  display:inline-flex; align-items:center; gap:14px;
  color:var(--gold); font-size:.8rem; margin:6px 0;
}
.divider i{ display:block; width:54px; height:1px;
  background:linear-gradient(90deg,transparent,var(--gold)); }
.divider i:last-child{ background:linear-gradient(90deg,var(--gold),transparent); }

/* ---------- Buttons ---------- */
.btn{
  --pad:15px 32px;
  display:inline-flex; align-items:center; justify-content:center;
  padding:var(--pad);
  font-family:var(--sans); font-weight:500; font-size:.82rem;
  letter-spacing:.16em; text-transform:uppercase; text-decoration:none;
  border-radius:50px; cursor:pointer; border:1px solid transparent;
  transition:transform .3s var(--ease), box-shadow .3s var(--ease),
             background .3s var(--ease), color .3s var(--ease);
  white-space:nowrap;
}
.btn--gold{
  background:linear-gradient(135deg,var(--gold-bright),var(--gold-deep));
  color:#1a1206; box-shadow:0 8px 26px -12px rgba(201,162,75,.7);
}
.btn--gold:hover{ transform:translateY(-3px); box-shadow:0 16px 36px -12px rgba(201,162,75,.8); }
.btn--ghost{
  background:transparent; color:var(--ink);
  border-color:rgba(245,239,231,.28);
}
.btn--ghost:hover{ border-color:var(--gold); color:var(--gold-bright); transform:translateY(-3px); }

/* ===================== NAV ===================== */
.nav{
  position:fixed; inset:0 0 auto 0; z-index:100;
  transition:background .4s var(--ease), backdrop-filter .4s var(--ease),
             border-color .4s var(--ease), padding .4s var(--ease);
  border-bottom:1px solid transparent;
  padding:10px 0;
}
.nav.is-scrolled{
  background:rgba(11,9,8,.82);
  backdrop-filter:blur(14px) saturate(1.2);
  border-bottom-color:var(--border);
}
.nav__inner{
  max-width:var(--container); margin-inline:auto; padding-inline:24px;
  display:flex; align-items:center; justify-content:space-between; gap:20px;
}
.nav__brand{ display:flex; align-items:center; gap:12px; text-decoration:none; }
.nav__logo{
  width:44px; height:44px; border-radius:50%; object-fit:cover;
  border:1px solid var(--border); box-shadow:0 0 20px -6px rgba(228,24,126,.5);
}
.nav__brand-text{
  font-family:var(--script); font-size:1.9rem; color:var(--ink);
  line-height:1; padding-top:6px;
}
.nav__links{ display:flex; align-items:center; gap:34px; }
.nav__links a{
  color:var(--ink-soft); text-decoration:none; font-size:.82rem;
  letter-spacing:.12em; text-transform:uppercase; font-weight:400;
  position:relative; transition:color .3s var(--ease);
}
.nav__links a:not(.nav__cta)::after{
  content:''; position:absolute; left:0; bottom:-6px; width:0; height:1px;
  background:var(--gold-bright); transition:width .3s var(--ease);
}
.nav__links a:not(.nav__cta):hover{ color:var(--ink); }
.nav__links a:not(.nav__cta):hover::after{ width:100%; }
.nav__ig{
  display:grid; place-items:center; width:38px; height:38px; border-radius:50%;
  color:var(--ink-soft) !important; border:1px solid var(--border-soft);
  transition:color .3s var(--ease), border-color .3s var(--ease), transform .3s var(--ease);
}
.nav__ig::after{ display:none !important; }
.nav__ig:hover{ color:var(--magenta-soft) !important; border-color:var(--magenta); transform:translateY(-2px); }
.nav__cta{
  padding:10px 22px; border:1px solid var(--gold);
  border-radius:50px; color:var(--gold-bright) !important;
  transition:background .3s var(--ease), color .3s var(--ease);
}
.nav__cta:hover{ background:var(--gold); color:#1a1206 !important; }

.nav__burger{
  display:none; flex-direction:column; gap:5px; background:none; border:none;
  cursor:pointer; padding:8px; z-index:110;
}
.nav__burger span{ width:26px; height:2px; background:var(--ink); transition:.3s var(--ease); }
.nav__burger.is-open span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
.nav__burger.is-open span:nth-child(2){ opacity:0; }
.nav__burger.is-open span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }

/* ===================== HERO ===================== */
.hero{
  position:relative; min-height:100svh; display:flex; align-items:center; justify-content:center;
  text-align:center; overflow:hidden; padding:120px 24px 80px;
}
.hero__video{
  position:absolute; inset:0; width:100%; height:100%; object-fit:cover; z-index:-2;
  filter:saturate(1.05) brightness(.62);
}
.hero__overlay{
  position:absolute; inset:0; z-index:-1;
  background:
    radial-gradient(120% 90% at 50% 8%, rgba(228,24,126,.22), transparent 55%),
    radial-gradient(120% 80% at 50% 120%, rgba(11,9,8,.96), transparent 60%),
    linear-gradient(180deg, rgba(11,9,8,.55), rgba(11,9,8,.35) 40%, rgba(11,9,8,.92));
}
.hero__content{ max-width:760px; }
.hero__eyebrow{
  text-transform:uppercase; letter-spacing:.42em; font-size:.75rem; font-weight:500;
  color:var(--gold-bright); margin-bottom:26px;
}
.hero__logo{
  width:clamp(130px,20vw,180px); height:auto; margin:0 auto 6px;
  border-radius:50%; border:1px solid var(--border);
  box-shadow:0 0 50px -10px rgba(228,24,126,.55);
}
.hero__script{
  font-family:var(--script); font-size:clamp(2.4rem,7vw,4rem);
  color:var(--ink); line-height:1.1; margin:6px 0 4px;
}
.hero__lead{
  font-family:var(--cormorant); font-size:clamp(1.15rem,2.4vw,1.5rem);
  color:var(--ink-soft); max-width:540px; margin:14px auto 30px; line-height:1.55;
}
.hero__actions{ display:flex; gap:16px; justify-content:center; flex-wrap:wrap; }

.hero__scroll{
  position:absolute; bottom:28px; left:50%; transform:translateX(-50%);
  width:26px; height:44px; border:1.5px solid rgba(245,239,231,.4);
  border-radius:14px; display:flex; justify-content:center; padding-top:8px;
}
.hero__scroll span{
  width:3px; height:8px; border-radius:2px; background:var(--gold-bright);
  animation:scroll 1.7s infinite;
}
@keyframes scroll{ 0%{opacity:0;transform:translateY(-4px)} 40%{opacity:1} 80%,100%{opacity:0;transform:translateY(12px)} }

/* ===================== EXPERIENCE ===================== */
.experience{ background:linear-gradient(180deg,var(--bg),var(--bg-2)); }
.experience__grid{
  display:grid; grid-template-columns:1fr 1fr; gap:clamp(40px,6vw,84px); align-items:center;
}
.experience__text .lead{ margin-top:20px; }
.experience__text p{ color:var(--ink-soft); margin-top:16px; }

.stats{ display:flex; gap:14px; margin-top:38px; flex-wrap:wrap; }
.stat{
  flex:1; min-width:110px; padding:20px 18px; border:1px solid var(--border);
  border-radius:var(--radius); background:rgba(255,255,255,.02); text-align:center;
}
.stat__num{
  display:block; font-family:var(--serif); font-size:1.9rem; color:var(--gold-bright); font-weight:600;
}
.stat__num em{ font-style:normal; font-size:1rem; color:var(--magenta-soft); margin-left:2px; }
.stat__label{ display:block; font-size:.72rem; text-transform:uppercase; letter-spacing:.16em; color:var(--ink-mute); margin-top:6px; }

.experience__media{ position:relative; }
.experience__img{ border-radius:var(--radius); box-shadow:0 30px 60px -30px rgba(0,0,0,.9); }
.experience__img--main{
  width:100%; aspect-ratio:4/5; object-fit:cover; border:1px solid var(--border-soft);
}
.experience__img--sub{
  position:absolute; right:-26px; bottom:-40px; width:52%; aspect-ratio:3/4; object-fit:cover;
  border:4px solid var(--bg-2); border-radius:var(--radius);
}

/* ===================== SIGNATURE STRIP ===================== */
.strip{
  overflow:hidden; border-block:1px solid var(--border);
  background:linear-gradient(90deg,var(--surface),var(--bg-2),var(--surface));
  padding:22px 0;
}
.strip__track{
  display:flex; align-items:center; gap:34px; white-space:nowrap; width:max-content;
  animation:marquee 26s linear infinite;
}
.strip__track span{
  font-family:var(--serif); font-size:clamp(1.4rem,3vw,2.1rem); font-style:italic;
  color:var(--ink); letter-spacing:1px; opacity:.85;
}
.strip__track i{ color:var(--magenta-soft); font-style:normal; font-size:1rem; }
@keyframes marquee{ to{ transform:translateX(-50%); } }
@media (prefers-reduced-motion:reduce){ .strip__track{ animation:none; } }

/* ===================== MENU ===================== */
.menu{ background:var(--bg-2); }
.menu__tabs{
  display:flex; gap:10px; justify-content:center; flex-wrap:wrap; margin-bottom:52px;
}
.menu__tab{
  padding:11px 26px; border-radius:50px; border:1px solid var(--border);
  background:transparent; color:var(--ink-soft); cursor:pointer;
  font-family:var(--sans); font-size:.8rem; letter-spacing:.14em; text-transform:uppercase; font-weight:400;
  transition:all .3s var(--ease);
}
.menu__tab:hover{ color:var(--ink); border-color:var(--gold); }
.menu__tab.is-active{
  background:linear-gradient(135deg,var(--gold-bright),var(--gold-deep));
  color:#1a1206; border-color:transparent; font-weight:500;
}

.menu__panel{ display:none; animation:fadeUp .5s var(--ease); }
.menu__panel.is-active{ display:block; }
@keyframes fadeUp{ from{opacity:0; transform:translateY(14px)} to{opacity:1;transform:none} }

.menu__cols{
  display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(28px,4vw,56px);
  align-items:start;
}
.menu__group{ min-width:0; }
.menu__cat{
  font-family:var(--serif); font-size:1.35rem; font-weight:600; color:var(--ink);
  margin:34px 0 8px; padding-bottom:10px; position:relative;
}
.menu__group > .menu__cat:first-child{ margin-top:0; }
.menu__cat::after{
  content:''; position:absolute; left:0; bottom:0; width:38px; height:2px;
  background:linear-gradient(90deg,var(--magenta),var(--gold)); border-radius:2px;
}
.menu__note{
  font-family:var(--cormorant); font-style:italic; color:var(--gold-bright);
  font-size:1rem; margin:2px 0 10px;
}
.menu__list{ list-style:none; }
.menu__list li{
  display:grid; grid-template-columns:1fr auto auto; align-items:baseline;
  column-gap:6px; padding:11px 0; border-bottom:1px dashed var(--border-soft);
}
.menu__list--compact li{ padding:8px 0; }
.mi__name{ font-size:.98rem; color:var(--ink); font-weight:400; }
.mi__dots{ border-bottom:1px dotted rgba(201,162,75,.35); transform:translateY(-4px); min-width:12px; }
.mi__price{
  font-family:var(--serif); color:var(--gold-bright); font-weight:600; font-size:1rem;
  font-variant-numeric:tabular-nums;
}
.mi__price::after{ content:' DH'; font-size:.62rem; color:var(--ink-mute); font-family:var(--sans); letter-spacing:.05em; }
.menu__list li small{
  grid-column:1 / -1; color:var(--ink-mute); font-size:.8rem; line-height:1.45; margin-top:3px;
  font-family:var(--sans);
}
.menu__hint{ margin-top:16px; font-family:var(--cormorant); font-style:italic; color:var(--ink-mute); }

.menu__full{ margin-top:66px; text-align:center; }
.menu__full-label{
  font-family:var(--serif); font-style:italic; font-size:1.3rem; color:var(--ink); margin-bottom:22px;
}
.menu__thumbs{
  display:grid; grid-template-columns:repeat(4,1fr); gap:16px; max-width:900px; margin-inline:auto;
}
.menu__thumb{
  position:relative; border:1px solid var(--border); border-radius:12px; overflow:hidden;
  cursor:pointer; background:var(--surface); padding:0; aspect-ratio:3/4;
  transition:transform .35s var(--ease), box-shadow .35s var(--ease);
}
.menu__thumb img{ width:100%; height:100%; object-fit:cover; opacity:.85; transition:opacity .35s; }
.menu__thumb span{
  position:absolute; inset:auto 0 0 0; padding:10px; font-size:.72rem; letter-spacing:.12em;
  text-transform:uppercase; color:var(--ink);
  background:linear-gradient(180deg,transparent,rgba(11,9,8,.9));
}
.menu__thumb:hover{ transform:translateY(-4px); box-shadow:0 20px 36px -20px rgba(228,24,126,.5); }
.menu__thumb:hover img{ opacity:1; }

/* ===================== GALLERY ===================== */
.gallery{ background:linear-gradient(180deg,var(--bg-2),var(--bg)); }
.gallery__grid{
  display:grid; grid-template-columns:repeat(4,1fr); grid-auto-rows:210px; gap:16px;
}
.gallery__item{
  position:relative; border:none; padding:0; cursor:pointer; overflow:hidden;
  border-radius:12px; background:var(--surface);
}
.gallery__item img{
  width:100%; height:100%; object-fit:cover;
  transition:transform .6s var(--ease), filter .4s var(--ease); filter:brightness(.92);
}
.gallery__item--tall{ grid-row:span 2; }
.gallery__item--wide{ grid-column:span 2; }
.gallery__item:hover img{ transform:scale(1.08); filter:brightness(1); }
.gallery__cap{
  position:absolute; left:0; right:0; bottom:0; padding:16px; text-align:left;
  font-family:var(--serif); font-size:1rem; color:var(--ink); letter-spacing:.4px;
  background:linear-gradient(180deg,transparent,rgba(11,9,8,.88));
  transform:translateY(8px); opacity:0; transition:.4s var(--ease);
}
.gallery__item:hover .gallery__cap{ transform:none; opacity:1; }

/* ===================== VISIT ===================== */
.visit{ background:var(--bg); }
.visit__grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(36px,5vw,70px); align-items:center; }
.visit__list{ list-style:none; margin:34px 0; }
.visit__list li{ display:flex; gap:18px; padding:16px 0; border-bottom:1px solid var(--border-soft); }
.visit__ico{
  flex:none; width:42px; height:42px; border-radius:50%;
  display:grid; place-items:center; color:var(--gold-bright);
  border:1px solid var(--border); background:rgba(201,162,75,.06); font-size:.9rem;
}
.visit__list strong{ font-family:var(--serif); font-weight:600; font-size:1.05rem; color:var(--ink); }
.visit__list p{ color:var(--ink-soft); font-size:.95rem; margin-top:2px; }
.visit__ico svg{ display:block; }
.visit__link{ color:var(--magenta-soft); text-decoration:none; transition:color .3s var(--ease); }
.visit__link:hover{ color:var(--gold-bright); text-decoration:underline; }
.visit__actions{ display:flex; gap:14px; flex-wrap:wrap; margin-top:8px; }

.visit__map{
  border-radius:var(--radius); overflow:hidden; border:1px solid var(--border);
  box-shadow:0 30px 60px -34px rgba(0,0,0,.9); height:100%; min-height:400px;
}
.visit__map iframe{ width:100%; height:100%; min-height:400px; border:0; filter:grayscale(.35) contrast(1.05); }

/* ===================== FOOTER ===================== */
.footer{ background:var(--surface); border-top:1px solid var(--border); padding-top:66px; }
.footer__inner{
  display:grid; grid-template-columns:1.4fr 1fr 1fr; gap:40px; padding-bottom:48px; align-items:start;
}
.footer__logo{ width:56px; height:56px; border-radius:50%; border:1px solid var(--border); margin-bottom:12px; }
.footer__script{ font-family:var(--script); font-size:2.2rem; color:var(--ink); line-height:1; }
.footer__tag{ color:var(--ink-mute); text-transform:uppercase; letter-spacing:.24em; font-size:.72rem; margin-top:8px; }
.footer__ig{
  display:inline-flex; align-items:center; gap:9px; margin-top:16px;
  padding:9px 16px; border:1px solid var(--border); border-radius:50px;
  color:var(--ink-soft); text-decoration:none; font-size:.85rem; letter-spacing:.04em;
  transition:color .3s var(--ease), border-color .3s var(--ease), background .3s var(--ease);
}
.footer__ig:hover{ color:#fff; border-color:var(--magenta);
  background:linear-gradient(135deg,rgba(228,24,126,.22),rgba(201,162,75,.12)); }
.footer__nav{ display:flex; flex-direction:column; gap:12px; }
.footer__nav a{
  color:var(--ink-soft); text-decoration:none; font-size:.9rem; letter-spacing:.06em;
  transition:color .3s var(--ease); width:fit-content;
}
.footer__nav a:hover{ color:var(--gold-bright); }
.footer__meta p{ color:var(--ink-soft); font-size:.9rem; margin-bottom:12px; }
.footer__bar{
  border-top:1px solid var(--border-soft); padding:22px 24px; margin-top:0;
  display:flex; justify-content:space-between; gap:12px; flex-wrap:wrap;
  max-width:var(--container); margin-inline:auto;
}
.footer__bar p{ color:var(--ink-mute); font-size:.78rem; letter-spacing:.04em; }
.footer__credit{ color:var(--gold-deep) !important; }

/* ===================== LIGHTBOX ===================== */
.lightbox{
  position:fixed; inset:0; z-index:200; display:none;
  background:rgba(6,4,3,.94); backdrop-filter:blur(6px);
  align-items:center; justify-content:center; padding:30px;
}
.lightbox.is-open{ display:flex; animation:fadeUp .3s var(--ease); }
.lightbox img{ max-width:92vw; max-height:88vh; border-radius:10px; box-shadow:0 30px 80px -20px #000; }
.lightbox__close{
  position:absolute; top:22px; right:26px; width:46px; height:46px; border-radius:50%;
  background:rgba(255,255,255,.08); border:1px solid var(--border-soft); color:var(--ink);
  font-size:1.1rem; cursor:pointer; transition:.3s var(--ease);
}
.lightbox__close:hover{ background:var(--gold); color:#1a1206; }

/* ===================== REVEAL ANIMATION ===================== */
.reveal{ opacity:0; transform:translateY(26px); transition:opacity .8s var(--ease), transform .8s var(--ease); }
.reveal.is-in{ opacity:1; transform:none; }
@media (prefers-reduced-motion:reduce){
  .reveal{ opacity:1; transform:none; transition:none; }
  .hero__scroll span{ animation:none; }
}

/* ===================== RESPONSIVE ===================== */
@media (max-width:960px){
  .menu__cols{ grid-template-columns:1fr 1fr; }
  .footer__inner{ grid-template-columns:1fr 1fr; }
}
@media (max-width:820px){
  .nav__burger{ display:flex; }
  .nav__links{
    position:fixed; inset:0 0 0 auto; width:min(78vw,320px);
    flex-direction:column; align-items:flex-start; justify-content:center; gap:28px;
    background:rgba(15,11,10,.97); backdrop-filter:blur(16px); padding:60px 40px;
    transform:translateX(100%); transition:transform .4s var(--ease);
    border-left:1px solid var(--border);
  }
  .nav__links.is-open{ transform:none; }
  .nav__links a{ font-size:1rem; }

  .experience__grid{ grid-template-columns:1fr; }
  .experience__media{ max-width:460px; margin:20px auto 40px; }
  .visit__grid{ grid-template-columns:1fr; }
  .menu__thumbs{ grid-template-columns:repeat(2,1fr); }
}
@media (max-width:620px){
  .menu__cols{ grid-template-columns:1fr; }
  .gallery__grid{ grid-template-columns:repeat(2,1fr); grid-auto-rows:160px; }
  .gallery__item--wide{ grid-column:span 2; }
  .gallery__item--tall{ grid-row:span 1; }
  .footer__inner{ grid-template-columns:1fr; gap:30px; }
  .footer__bar{ flex-direction:column; text-align:center; }
  .stat{ min-width:calc(50% - 7px); }
  .hero__actions .btn{ width:100%; }
}
