/* ============================================================
   NELLYSLIST — shared design system
   Ivory · Charcoal · Brushed Gold · Editorial luxury
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;0,500;0,600;0,700;1,400;1,500&family=Jost:wght@300;400;500;600&display=swap');

:root{
  /* surfaces */
  --ivory:        #F4EEE6;
  --ivory-2:      #EFE7DC;   /* slightly deeper section */
  --card:         #FBF7F1;
  --ink:          #1B1714;   /* warm near-black */
  --ink-2:        #221D19;
  --ink-3:        #2C2622;
  /* type */
  --text:         #241F1B;
  --text-soft:    #6E665C;
  --text-mute:    #978D80;
  --text-on-dark: #F1E9DD;
  --text-on-dark-soft: #B7AC9C;
  /* accent */
  --gold:         #BF9B68;
  --gold-deep:    #A07E4B;
  --gold-soft:    #D8C19A;
  --coral:        #CF8466;
  /* lines */
  --line:         rgba(27,23,20,.14);
  --line-soft:    rgba(27,23,20,.08);
  --line-dark:    rgba(241,233,221,.16);
  --line-gold:    rgba(191,155,104,.4);
  /* metrics */
  --maxw:         1280px;
  --pad:          clamp(20px, 5vw, 64px);
  --radius:       4px;
  --shadow:       0 24px 60px -28px rgba(27,23,20,.45);
  --shadow-card:  0 18px 44px -24px rgba(27,23,20,.30);
  --ease:         cubic-bezier(.22,.61,.36,1);
}

*{ box-sizing:border-box; }
html{ -webkit-text-size-adjust:100%; scroll-behavior:smooth; }
body{
  margin:0;
  background:var(--ivory);
  color:var(--text);
  font-family:'Jost',system-ui,sans-serif;
  font-weight:400;
  font-size:16px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; cursor:pointer; }
::selection{ background:var(--gold); color:#fff; }

/* ---------- Typography ---------- */
.display, h1, h2, h3{
  font-family:'Cormorant Garamond',Georgia,serif;
  font-weight:500;
  line-height:1.02;
  letter-spacing:-.01em;
  margin:0;
  color:var(--ink);
}
.display{ font-weight:500; }
.italic{ font-style:italic; }

.eyebrow{
  font-family:'Jost',sans-serif;
  font-weight:500;
  font-size:12px;
  letter-spacing:.28em;
  text-transform:uppercase;
  color:var(--gold-deep);
  margin:0;
}
.eyebrow.on-dark{ color:var(--gold-soft); }

.lede{
  font-size:clamp(17px,1.4vw,20px);
  line-height:1.65;
  color:var(--text-soft);
  font-weight:300;
}
.measure{ max-width:62ch; }

/* wordmark */
.wordmark{
  font-family:'Cormorant Garamond',serif;
  font-weight:500;
  letter-spacing:.42em;
  text-transform:uppercase;
  white-space:nowrap;
  line-height:1;
}

/* ---------- Layout ---------- */
.wrap{ max-width:var(--maxw); margin:0 auto; padding-inline:var(--pad); }
.section{ padding-block:clamp(56px,8vw,120px); }
.section--tight{ padding-block:clamp(40px,5vw,72px); }
.dark{ background:var(--ink); color:var(--text-on-dark); }
.dark h1,.dark h2,.dark h3,.dark .display{ color:var(--text-on-dark); }
.ivory-2{ background:var(--ivory-2); }

.hr{ height:1px; background:var(--line); border:0; margin:0; }
.hr-gold{ height:1px; width:64px; background:var(--gold); border:0; margin:0; }

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex; align-items:center; gap:.7em;
  font-family:'Jost',sans-serif; font-weight:500;
  font-size:13px; letter-spacing:.18em; text-transform:uppercase;
  padding:16px 28px; border:1px solid transparent;
  border-radius:var(--radius); transition:.45s var(--ease);
  line-height:1; white-space:nowrap;
}
.btn .arw{ transition:transform .45s var(--ease); }
.btn:hover .arw{ transform:translateX(5px); }
.btn--gold{ background:var(--gold); color:#231d16; }
.btn--gold:hover{ background:var(--gold-deep); color:#fff; }
.btn--ink{ background:var(--ink); color:var(--text-on-dark); }
.btn--ink:hover{ background:#000; }
.btn--ghost{ border-color:var(--ink); color:var(--ink); background:transparent; }
.btn--ghost:hover{ background:var(--ink); color:var(--text-on-dark); }
.btn--ghost-light{ border-color:rgba(241,233,221,.55); color:var(--text-on-dark); background:transparent; }
.btn--ghost-light:hover{ background:var(--text-on-dark); color:var(--ink); border-color:transparent; }
.btn--ghost-gold{ border-color:var(--line-gold); color:var(--gold-deep); background:transparent; }
.btn--ghost-gold:hover{ background:var(--gold); color:#fff; border-color:transparent; }
.btn--block{ width:100%; justify-content:center; }
.btn--lg{ padding:19px 34px; font-size:13.5px; }

.link-more{
  display:inline-flex; align-items:center; gap:.6em;
  font-family:'Jost',sans-serif; font-weight:500; font-size:12px;
  letter-spacing:.2em; text-transform:uppercase; color:var(--gold-deep);
  transition:.3s var(--ease);
}
.link-more .arw{ transition:transform .35s var(--ease); }
.link-more:hover{ color:var(--ink); }
.link-more:hover .arw{ transform:translateX(4px); }
.dark .link-more{ color:var(--gold-soft); }
.dark .link-more:hover{ color:#fff; }

/* ---------- Tags / chips ---------- */
.tag{
  display:inline-flex; align-items:center; gap:.5em;
  font-family:'Jost',sans-serif; font-weight:500; font-size:10.5px;
  letter-spacing:.18em; text-transform:uppercase;
  padding:7px 12px; border-radius:2px; line-height:1;
}
.tag--miami{ background:var(--coral); color:#fff; }
.tag--la{ background:rgba(251,247,241,.92); color:var(--ink); }
.tag--gold{ background:var(--gold); color:#231d16; }
.tag--outline{ border:1px solid var(--line); color:var(--text-soft); background:transparent; }
.tag--cert{ background:rgba(191,155,104,.14); color:var(--gold-deep); border:1px solid var(--line-gold); }

.datechip{
  background:var(--ink); color:var(--text-on-dark);
  border-radius:6px; text-align:center; padding:9px 12px 10px; line-height:1;
  font-family:'Jost',sans-serif; min-width:58px;
}
.datechip .m{ font-size:11px; letter-spacing:.16em; text-transform:uppercase; color:var(--gold-soft); }
.datechip .d{ font-family:'Cormorant Garamond',serif; font-size:27px; font-weight:600; margin-top:3px; }

/* ---------- Header / nav ---------- */
.site-header{
  position:sticky; top:0; z-index:60;
  background:rgba(244,238,230,.86); backdrop-filter:blur(14px);
  border-bottom:1px solid var(--line-soft);
  transition:background .4s var(--ease), border-color .4s var(--ease);
}
.site-header.on-dark{
  background:rgba(21,17,14,.55); border-bottom-color:var(--line-dark);
}
.nav{
  max-width:var(--maxw); margin:0 auto; padding:0 var(--pad);
  height:74px; display:grid; grid-template-columns:1fr auto 1fr; align-items:center;
}
.nav__brand{ justify-self:start; font-size:22px; }
.site-header.on-dark .nav__brand,
.site-header.on-dark .nav__links a,
.site-header.on-dark .nav__icon{ color:var(--text-on-dark); }
.nav__links{
  justify-self:center; display:flex; gap:30px; align-items:center;
  font-family:'Jost',sans-serif; font-weight:500; font-size:11.5px;
  letter-spacing:.16em; text-transform:uppercase;
}
.nav__links a{ position:relative; color:var(--text); padding:6px 0; transition:color .3s; }
.nav__links a::after{
  content:''; position:absolute; left:0; bottom:0; height:1px; width:0;
  background:var(--gold); transition:width .35s var(--ease);
}
.nav__links a:hover{ color:var(--gold-deep); }
.nav__links a:hover::after,.nav__links a.is-active::after{ width:100%; }
.nav__right{ justify-self:end; display:flex; align-items:center; gap:18px; }
.nav__icon{ display:flex; color:var(--ink); }
.nav__toggle{ display:none; background:none; border:0; padding:6px; color:inherit; }

/* mobile drawer */
.drawer{
  position:fixed; inset:0; z-index:80; background:var(--ink); color:var(--text-on-dark);
  transform:translateY(-100%); transition:transform .5s var(--ease);
  display:flex; flex-direction:column; padding:28px var(--pad);
}
.drawer.open{ transform:translateY(0); }
.drawer__top{ display:flex; justify-content:space-between; align-items:center; }
.drawer__links{ margin-top:auto; margin-bottom:auto; display:flex; flex-direction:column; gap:6px; }
.drawer__links a{
  font-family:'Cormorant Garamond',serif; font-size:clamp(34px,9vw,56px);
  font-weight:500; line-height:1.08; color:var(--text-on-dark);
}
.drawer__links a:hover{ color:var(--gold-soft); }
.drawer__foot{ display:flex; gap:18px; font-family:'Jost'; font-size:12px; letter-spacing:.16em; text-transform:uppercase; color:var(--text-on-dark-soft); }

/* ---------- Footer ---------- */
.site-footer{ background:var(--ink); color:var(--text-on-dark); padding-block:64px 40px; }
.footer__grid{ display:grid; grid-template-columns:1.4fr repeat(3,1fr); gap:40px; }
.footer__brand .wordmark{ font-size:24px; }
.footer__tag{ font-family:'Jost'; font-size:11px; letter-spacing:.22em; text-transform:uppercase; color:var(--text-on-dark-soft); margin-top:12px; }
.footer__col h4{ font-family:'Jost'; font-weight:500; font-size:11px; letter-spacing:.22em; text-transform:uppercase; color:var(--gold-soft); margin:0 0 16px; }
.footer__col a{ display:block; color:var(--text-on-dark-soft); font-size:14px; padding:5px 0; transition:color .3s; }
.footer__col a:hover{ color:var(--text-on-dark); }
.footer__bottom{ display:flex; justify-content:space-between; align-items:center; gap:20px; margin-top:48px; padding-top:24px; border-top:1px solid var(--line-dark); font-size:12px; letter-spacing:.05em; color:var(--text-on-dark-soft); }
.footer__social{ display:flex; gap:16px; }
.footer__social a{ color:var(--text-on-dark-soft); transition:color .3s; }
.footer__social a:hover{ color:var(--gold-soft); }

/* ---------- Image slots ---------- */
image-slot{ background:var(--ivory-2); }
.slot-tone image-slot{
  background:
    repeating-linear-gradient(135deg, rgba(27,23,20,.035) 0 10px, transparent 10px 20px),
    linear-gradient(160deg,#E7DCCC,#D8C9B4);
}

/* ---------- Cards: events ---------- */
.event-card{
  position:relative; border-radius:8px; overflow:hidden; min-height:420px;
  display:flex; flex-direction:column; justify-content:flex-end;
  color:var(--text-on-dark); box-shadow:var(--shadow-card);
  isolation:isolate; transition:transform .5s var(--ease), box-shadow .5s var(--ease);
}
.event-card:hover{ transform:translateY(-5px); box-shadow:0 30px 60px -28px rgba(27,23,20,.5); }
.event-card__media{ position:absolute; inset:0; z-index:0; }
.event-card__media image-slot{ width:100%; height:100%; }
.event-card::after{
  content:''; position:absolute; inset:0; z-index:1; pointer-events:none;
  background:linear-gradient(to top, rgba(15,11,8,.92) 6%, rgba(15,11,8,.5) 42%, rgba(15,11,8,.08) 100%);
}
.event-card__top, .event-card__body{ position:relative; z-index:2; }
.event-card__top{ position:absolute; top:16px; left:16px; right:16px; display:flex; justify-content:space-between; align-items:flex-start; z-index:2; }
.event-card__body{ padding:0 24px 24px; }
.event-card h3{ color:#fff; font-size:30px; line-height:1.02; }
.event-card .sub{ font-family:'Cormorant Garamond',serif; font-style:italic; font-size:20px; color:var(--gold-soft); margin-top:2px; }
.event-card .loc{ display:flex; align-items:center; gap:7px; font-size:12px; letter-spacing:.14em; text-transform:uppercase; color:var(--text-on-dark-soft); margin:14px 0 18px; }

/* ---------- Cards: restaurant ---------- */
.rcard{ background:var(--card); border:1px solid var(--line-soft); border-radius:6px; overflow:hidden; transition:transform .45s var(--ease), box-shadow .45s var(--ease); }
.rcard:hover{ transform:translateY(-4px); box-shadow:var(--shadow-card); }
.rcard__media{ position:relative; aspect-ratio:4/3; }
.rcard__media image-slot{ width:100%; height:100%; }
.rcard__cert{ position:absolute; top:12px; left:12px; }
.rcard__fav{ position:absolute; top:10px; right:10px; width:34px; height:34px; border-radius:50%; background:rgba(251,247,241,.9); display:flex; align-items:center; justify-content:center; color:var(--ink); border:0; }
.rcard__fav:hover{ background:#fff; color:var(--coral); }
.rcard__body{ padding:18px 20px 22px; }
.rcard__row{ display:flex; justify-content:space-between; align-items:baseline; gap:12px; }
.rcard h3{ font-size:24px; }
.rcard__price{ font-family:'Jost'; font-weight:500; font-size:14px; color:var(--gold-deep); letter-spacing:.05em; }
.rcard__meta{ font-family:'Jost'; font-size:12.5px; letter-spacing:.08em; text-transform:uppercase; color:var(--text-mute); margin-top:5px; }
.rcard__tags{ display:flex; flex-wrap:wrap; gap:6px; margin-top:14px; }

/* ---------- Article cards ---------- */
.article{ display:flex; flex-direction:column; }
.article__media{ aspect-ratio:4/5; border-radius:4px; overflow:hidden; }
.article__media image-slot{ width:100%; height:100%; }
.article__kicker{ font-family:'Jost'; font-weight:500; font-size:10.5px; letter-spacing:.2em; text-transform:uppercase; color:var(--gold-deep); margin:18px 0 8px; display:flex; align-items:center; gap:8px; }
.article h3{ font-size:23px; line-height:1.08; }
.article .article__link{ margin-top:14px; }

/* ---------- Vertical strip (5 ecosystem pillars) ---------- */
.pillars{ display:grid; grid-template-columns:repeat(5,1fr); }
.pillar{ padding:38px 26px; border-left:1px solid var(--line-dark); display:flex; flex-direction:column; gap:14px; transition:background .4s; }
.pillar:first-child{ border-left:0; }
.pillar:hover{ background:rgba(241,233,221,.04); }
.pillar__ico{ color:var(--gold); }
.pillar h4{ font-family:'Jost'; font-weight:500; font-size:12px; letter-spacing:.18em; text-transform:uppercase; color:var(--text-on-dark); margin:0; }
.pillar p{ margin:0; font-size:14px; line-height:1.55; color:var(--text-on-dark-soft); }
.pillar .ax{ margin-top:auto; }

/* ---------- City toggle ---------- */
.citytoggle{ display:inline-flex; background:var(--card); border:1px solid var(--line); border-radius:100px; padding:5px; gap:4px; }
.citytoggle button{
  display:flex; align-items:center; gap:9px; border:0; background:transparent;
  font-family:'Jost'; font-weight:500; font-size:13px; letter-spacing:.14em; text-transform:uppercase;
  padding:13px 30px; border-radius:100px; color:var(--text-soft); transition:.4s var(--ease);
}
.citytoggle button.active{ background:var(--gold); color:#fff; }

/* ---------- Filters ---------- */
.filterbar{ display:flex; flex-wrap:wrap; gap:10px; align-items:center; }
.chip{
  font-family:'Jost'; font-weight:500; font-size:12px; letter-spacing:.12em; text-transform:uppercase;
  padding:11px 20px; border-radius:100px; border:1px solid var(--line); background:transparent; color:var(--text-soft);
  transition:.3s var(--ease);
}
.chip:hover{ border-color:var(--gold); color:var(--gold-deep); }
.chip.active{ background:var(--ink); border-color:var(--ink); color:var(--text-on-dark); }

/* ---------- Logo strip ---------- */
.logostrip{ display:flex; flex-wrap:wrap; align-items:center; justify-content:center; gap:clamp(28px,5vw,64px); }
.logostrip .lg{
  font-family:'Cormorant Garamond',serif; font-weight:600; font-size:20px; letter-spacing:.04em;
  color:var(--text-soft); opacity:.72; text-align:center; line-height:1.05;
}
.logostrip .lg small{ display:block; font-family:'Jost'; font-weight:500; font-size:8.5px; letter-spacing:.24em; opacity:.8; margin-top:3px; }

/* ---------- Accordion ---------- */
.acc{ border-top:1px solid var(--line); }
.acc__item{ border-bottom:1px solid var(--line); }
.acc__head{ width:100%; background:none; border:0; text-align:left; display:flex; align-items:center; gap:16px; padding:22px 0; color:var(--ink); }
.acc__head .ico{ color:var(--gold-deep); display:flex; }
.acc__head .ttl{ flex:1; font-family:'Jost'; font-weight:500; font-size:13px; letter-spacing:.16em; text-transform:uppercase; }
.acc__head .pm{ transition:transform .4s var(--ease); color:var(--text-soft); }
.acc__item.open .pm{ transform:rotate(45deg); }
.acc__panel{ overflow:hidden; max-height:0; transition:max-height .5s var(--ease); }
.acc__panel-inner{ padding:0 0 26px 40px; color:var(--text-soft); font-weight:300; line-height:1.7; max-width:60ch; }

/* ---------- Misc ---------- */
.grid-3{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.grid-4{ display:grid; grid-template-columns:repeat(4,1fr); gap:24px; }
.stars{ color:var(--gold); letter-spacing:2px; font-size:13px; }
.kosher-dot{ width:7px; height:7px; border-radius:50%; background:var(--gold); display:inline-block; }
.scroll-x{ display:flex; gap:20px; overflow-x:auto; scroll-snap-type:x mandatory; padding-bottom:8px; -webkit-overflow-scrolling:touch; }
.scroll-x > *{ scroll-snap-align:start; flex:0 0 auto; }
.scroll-x::-webkit-scrollbar{ height:4px; }
.scroll-x::-webkit-scrollbar-thumb{ background:var(--line); border-radius:4px; }

html.reveal-ready .reveal{ opacity:0; transform:translateY(22px); transition:opacity .9s var(--ease), transform .9s var(--ease); }
html.reveal-ready .reveal.in{ opacity:1; transform:none; }
@media (prefers-reduced-motion:reduce){ html.reveal-ready .reveal{ opacity:1; transform:none; transition:none; } }

/* ---------- Shared section components (used across all pages) ---------- */
.sec-head{ display:flex; align-items:flex-end; justify-content:space-between; gap:24px; margin-bottom:34px; flex-wrap:wrap; }
.sec-title{ font-size:clamp(34px,4.6vw,58px); }

.feature{ display:grid; grid-template-columns:1.05fr .95fr; align-items:stretch; }
.feature__media{ position:relative; min-height:560px; }
.feature__media image-slot{ width:100%; height:100%; }
.feature__badge{ position:absolute; top:34px; right:34px; width:118px; height:118px; border-radius:50%; border:1px solid var(--line-gold); display:flex; flex-direction:column; align-items:center; justify-content:center; gap:1px; background:rgba(15,11,8,.34); backdrop-filter:blur(4px); color:#fff; text-align:center; }
.feature__badge span{ font-family:'Jost'; font-size:8.5px; letter-spacing:.24em; text-transform:uppercase; color:var(--gold-soft); }
.feature__badge strong{ font-family:'Cormorant Garamond',serif; font-size:30px; font-weight:600; line-height:1; }
.feature__copy{ background:var(--ivory); display:flex; flex-direction:column; justify-content:center; padding:clamp(40px,6vw,96px); }
.feature__h{ font-size:clamp(36px,4.6vw,62px); }

.membership{ position:relative; padding-block:clamp(64px,8vw,120px); overflow:hidden; }
.membership__media{ position:absolute; inset:0; z-index:0; opacity:.32; }
.membership__media image-slot{ width:100%; height:100%; }
.membership::after{ content:''; position:absolute; inset:0; background:linear-gradient(90deg, var(--ink) 28%, rgba(21,17,14,.72)); z-index:1; }
.membership__inner{ position:relative; z-index:2; display:grid; grid-template-columns:1.5fr .8fr; gap:48px; align-items:center; }
.membership__h{ font-size:clamp(36px,5vw,68px); margin-top:8px; }

@media (max-width:1000px){
  .feature{ grid-template-columns:1fr; }
  .feature__media{ min-height:380px; }
  .membership__inner{ grid-template-columns:1fr; gap:30px; }
}
@media (max-width:620px){
  .sec-head{ align-items:flex-start; }
}

/* ---------- Responsive ---------- */
@media (max-width:1100px){
  .nav__links{ display:none; }
  .nav__toggle{ display:flex; }
  .nav{ grid-template-columns:auto 1fr auto; }
  .nav__brand{ justify-self:start; }
  .pillars{ grid-template-columns:repeat(2,1fr); }
  .pillar{ border-left:0; border-top:1px solid var(--line-dark); }
  .pillar:nth-child(odd){ border-right:1px solid var(--line-dark); }
}
@media (max-width:860px){
  .footer__grid{ grid-template-columns:1fr 1fr; gap:32px; }
  .footer__brand{ grid-column:1 / -1; }
  .grid-3,.grid-4{ grid-template-columns:1fr 1fr; }
}
@media (max-width:620px){
  .grid-3,.grid-4{ grid-template-columns:1fr; }
  .pillars{ grid-template-columns:1fr; }
  .pillar:nth-child(odd){ border-right:0; }
  .footer__grid{ grid-template-columns:1fr; }
  .footer__bottom{ flex-direction:column; align-items:flex-start; }
  .nav__links{ gap:20px; }
  .btn{ padding:15px 22px; }
}
