:root {
  --w: #FDFCF9;
  --bg: #F6F5F3;
  --fg: #18160E;
  --accent: #520350;
  --muted: #232323;
  --border: #DED9CF;
  --light: #EDE9DF;
  --font-display:        'Jost', system-ui, sans-serif;
  --font-display-weight: 400;
  --font-body:           'Roboto', system-ui, -apple-system, sans-serif;
  --font-script:         'Cormorant Garamond', Georgia, serif;
}
body.dir-body { background:var(--w); color:var(--fg); font-family:var(--font-body); -webkit-font-smoothing:antialiased; padding-top:68px; overflow-x:clip; }
.dir-main { min-height:60vh; }

.dir-nav {
  position:fixed; top:0; left:0; right:0; z-index:300;
  padding:0 60px; height:68px; margin:0;
  box-sizing:border-box;
  display:flex; align-items:center; justify-content:space-between;
  background:rgba(253,252,249,.96); backdrop-filter:blur(20px);
  border-bottom:1px solid var(--border);
  font-family:var(--font-body);
}
.dir-nav, .dir-nav * { box-sizing:border-box; }
.dir-logo { display:inline-flex; align-items:center; text-decoration:none; }
.dir-logo img { height:38px; width:auto; display:block; }
.dir-nav-links { display:flex; gap:26px; list-style:none; margin:0; padding:0; }
.dir-nav-links a {
  text-decoration:none; font-size:11.5px; color:var(--muted);
  font-weight:600; letter-spacing:.08em; text-transform:uppercase;
  transition:color .15s; cursor:pointer; padding : 27px 0;
}
.dir-nav-links a:hover { color:var(--accent); }
.dir-nav-links a.dir-luxe-link { color:#C4963A; letter-spacing:.18em; }
.dir-nav-links a.dir-luxe-link:hover { color:#dba84a; }
.dir-nav-r { display:flex; align-items:center; gap:10px; }
.dir-btn {
  display:inline-flex; align-items:center; padding:9px 20px;
  border-radius:var(--card-radius-sm); cursor:pointer; font-family:var(--font-body);
  font-size:11px; font-weight:700; letter-spacing:.08em; text-transform:uppercase;
  transition:all .2s; border:1px solid transparent; text-decoration:none;
  background:transparent; line-height:1.2;
}
.dir-btn-ghost { color:var(--fg); border-color:var(--border); }
.dir-btn-ghost:hover { border-color:var(--fg); }
.dir-btn-solid { background:var(--fg); color:#fff !important; border-color:var(--fg); }
.dir-btn-solid:hover { background:#333; color:#fff; }
.dir-city-pill {
  display:inline-flex; align-items:center; gap:8px;
  padding:8px 14px; border-radius:100px;
  border:none; background:transparent;
  color:var(--fg);
  font-family:var(--font-body); font-size:11px; font-weight:700;
  letter-spacing:.08em; text-transform:uppercase; cursor:pointer;
  transition:color .2s;
}
.dir-city-pill svg { width:13px; height:13px; flex-shrink:0; }
.dir-city-pill .nav-arr { font-size:9px; margin-left:2px; }
.dir-city-pill:hover { color:var(--accent); }

.dir-mega-bd {
  position:fixed; inset:0; top:68px; z-index:248;
  background:rgba(0,0,0,.22); opacity:0; pointer-events:none;
  transition:opacity .22s ease;
}
.dir-mega-bd.open { opacity:1; pointer-events:auto; }
.dir-mega {
  position:fixed; top:68px; left:0; right:0; z-index:249;
  background:var(--card-bg); border-top:1px solid var(--border);
  box-shadow:var(--card-shadow);
  padding:36px 60px 44px;
  display:grid; grid-template-columns:1fr 1fr 1fr 1fr; gap:36px;
  opacity:0; pointer-events:none;
  transform:translateY(-12px);
  transition:opacity .22s ease, transform .22s ease;
}
.dir-mega.open { opacity:1; pointer-events:auto; transform:none; }
.dir-mega-col-hd {
  font-size:10.5px; font-weight:700; letter-spacing:.18em; text-transform:uppercase;
  color:var(--muted); font-family:var(--font-body);
  margin-bottom:18px;
}
.dir-mega-lnk {
  display:flex; align-items:center; padding:6px 0;
  font-size:13.5px; color:var(--fg); text-decoration:none;
  font-family:var(--font-body); font-weight:400; transition:color .15s;
}
.dir-mega-lnk:hover { color:var(--accent); }
.dir-mega-item {
  display:flex; gap:14px; align-items:flex-start; padding:9px 0;
  text-decoration:none; color:inherit;
}
.dir-mega-item:hover .dir-mega-item-title { color:var(--accent); }
.dir-mega-ico {
  width:38px; height:38px; flex-shrink:0;
  background:var(--bg);
  display:flex; align-items:center; justify-content:center;
  border-radius:var(--card-radius-sm); color:var(--accent);
  transition:background .18s, color .18s;
}
.dir-mega-item:hover .dir-mega-ico { background:var(--accent); color:#fff; }
.dir-mega-ico i { font-size:18px; line-height:1; }
.dir-mega-item-body { flex:1; min-width:0; padding-top:1px; }
.dir-mega-item-title {
  font-size:14px; font-weight:600; color:var(--fg);
  line-height:1.25; margin-bottom:3px;
  transition:color .15s;
}
.dir-mega-item-sub {
  font-size:12.5px; color:var(--muted); font-weight:400;
  line-height:1.45;
}
.dir-mega-cta-box {
  background:var(--bg); padding:22px;
  border-radius:var(--card-radius-sm); margin-top:14px;
}
.dir-mega-cta-title {
  font-family:var(--font-display); font-size:22px; font-weight:var(--font-display-weight);
  color:var(--fg); margin-bottom:8px; letter-spacing:.01em; line-height:1.1;
}
.dir-mega-cta-desc {
  font-size:12.5px; color:var(--muted); line-height:1.6;
  margin-bottom:18px; margin-top:0;
}
.dir-mega-cta-btn {
  display:block; text-align:center;
  background:var(--fg); color:#fff;
  padding:11px 16px; border-radius:var(--card-radius-sm);
  font-size:13px; font-weight:600; letter-spacing:.01em;
  text-decoration:none; transition:background .18s;
}
.dir-mega-cta-btn:hover { background:var(--accent); }
.dir-mega-cnt { font-size:11px; color:var(--muted); margin-left:auto; font-weight:400; }
.dir-mega-feat { border-radius:var(--card-radius-sm); overflow:hidden; margin-bottom:18px; display:block; text-decoration:none; }
.dir-mega-feat-img { aspect-ratio:16/9; background-size:cover; background-position:center; background-color:var(--light); }
.dir-mega-feat-body { padding:12px 0 4px; }
.dir-mega-feat-tag { font-size:9.5px; font-weight:700; letter-spacing:.14em; text-transform:uppercase; color:var(--accent); font-family:var(--font-body); margin-bottom:6px; }
.dir-mega-feat-title { font-family:var(--font-display); font-size:20px; font-weight:var(--font-display-weight); color:var(--fg); margin-bottom:8px; line-height:1.2; }
.dir-mega-feat-cta { font-size:10px; font-weight:700; letter-spacing:.1em; text-transform:uppercase; color:var(--accent); font-family:var(--font-body); }
.nav-arr { font-size:9px; margin-left:4px; display:inline-block; transition:transform .2s; vertical-align:middle; }
.dir-mega-trigger-active .nav-arr { transform:rotate(180deg); }

.dir-city-modal-bd {
  position:fixed; inset:0; z-index:600;
  background:rgba(15,12,8,.55);
  display:none; align-items:flex-start; justify-content:center;
  padding:48px 24px; overflow-y:auto;
}
.dir-city-modal-bd.open { display:flex; }
.dir-city-modal {
  background:var(--card-bg); border-radius:var(--card-radius); width:100%; max-width:1080px;
  position:relative; box-shadow:0 24px 64px rgba(0,0,0,.25);
  padding:32px 36px 0; font-family:var(--font-body);
}
.dir-city-modal-x {
  position:absolute; top:18px; right:20px; width:34px; height:34px;
  border-radius:50%; background:#f4f1eb; border:none; cursor:pointer;
  display:flex; align-items:center; justify-content:center;
  color:var(--fg); font-size:16px; line-height:1;
}
.dir-city-modal-x:hover { background:#e9e4d8; }
.dir-city-modal-search {
  display:flex; align-items:center; gap:12px;
  border:1px solid var(--border); border-radius:var(--card-radius-sm);
  padding:14px 18px; margin:8px 0 18px;
}
.dir-city-modal-search svg { color:var(--muted); width:18px; height:18px; flex-shrink:0; }
.dir-city-modal-search input {
  flex:1; border:none; outline:none; background:transparent;
  font-size:15px; color:var(--fg); font-family:var(--font-body);
}
.dir-city-detect {
  display:inline-flex; align-items:center; gap:8px;
  color:var(--accent); font-size:14px; font-weight:600;
  background:none; border:none; cursor:pointer;
  padding:6px 0 26px; font-family:var(--font-body);
}
.dir-city-detect svg { width:16px; height:16px; }
.dir-city-section-h { text-align:center; font-size:18px; font-weight:700; color:var(--fg); margin:8px 0 28px; }
.dir-city-grid { display:grid; grid-template-columns:repeat(8,1fr); gap:14px; margin-bottom:18px; }
.dir-city-pick {
  display:flex; flex-direction:column; align-items:center; gap:10px;
  padding:14px 6px; border-radius:var(--card-radius-sm); cursor:pointer;
  background:none; border:none; font-family:var(--font-body);
  transition:background .15s;
}
.dir-city-pick:hover { background:var(--bg); }
.dir-city-pick svg { width:50px; height:50px; color:var(--fg); }
.dir-city-pick-name { font-size:14px; color:var(--fg); font-weight:500; }
.dir-city-other-empty { text-align:center; color:var(--muted); padding:28px 0 20px; font-size:14px; }
.dir-city-modal-foot { border-top:1px solid var(--border); padding:18px 0; margin:0 -36px; text-align:center; position:sticky; bottom:0; background:var(--card-bg); }
.dir-city-toggle-all { background:none; border:none; cursor:pointer; color:var(--accent); font-weight:600; font-size:15px; font-family:var(--font-body); }
.dir-city-toggle-all:hover { text-decoration:underline; }
@media (max-width:880px) { .dir-city-grid { grid-template-columns:repeat(4,1fr); } }
@media (max-width:520px) { .dir-city-grid { grid-template-columns:repeat(3,1fr); } }

.dir-foot {
  position:relative;
  background:#fff;
  padding:72px 52px 32px;
  color:var(--fg);
  font-family:var(--font-body);
  border-top:1px solid var(--border);
}
.dir-foot-top {
  display:grid; grid-template-columns:2.4fr 1fr 1fr 1fr 1fr; gap:48px;  margin:0 auto 56px;
}
.dir-f-logo { display:inline-block; margin-bottom:18px; }
.dir-f-logo img { height:38px; width:auto; display:block; opacity:1; filter:none; }
.dir-f-desc {
  font-size:12px; line-height:1.78; color:var(--muted);
  margin:0 0 28px; max-width:380px; font-weight:400;
}
.dir-f-app { margin:0 0 28px; }
.dir-f-app-t {
  font-family:var(--font-display); font-weight:500;
  font-size:15px; color:var(--fg); margin-bottom:14px;
}
.dir-f-app-links { display:flex; gap:10px; flex-wrap:wrap; }
.dir-f-app-links a { display:inline-block; transition:opacity .18s ease; }
.dir-f-app-links a:hover { opacity:.78; }
.dir-f-app-links img { height:30px; width:auto; display:block; }
.dir-f-social-t {
  font-family:var(--font-display); font-weight:500;
  font-size:15px; color:var(--fg); margin-bottom:14px;
}
.dir-f-social { display:flex; gap:10px; }
.dir-f-sb {
  width:38px; height:38px; background:var(--bg);
  display:flex; align-items:center; justify-content:center;
  color:var(--muted); text-decoration:none; font-size:16px;
  transition:background .2s ease, color .2s ease;
}
.dir-f-sb:hover { background:var(--accent); color:#fff; }
.dir-f-col-t {
  font-family:var(--font-display); font-weight:500;
  font-size:15px; color:var(--fg); margin-bottom:22px;
  letter-spacing:0; text-transform:none;
}
.dir-f-links { list-style:none; display:flex; flex-direction:column; gap:6px; padding:0; margin:0; }
.dir-f-links a {
  text-decoration:none; font-size:12px; color:var(--muted); font-weight:400;
  transition:color .18s, padding-left .18s;
}
.dir-f-links a:hover { color:var(--accent); padding-left:4px; }
.dir-f-wide {  margin:0 auto 36px;
  padding-top:32px; border-top:1px solid var(--border);
}
.dir-f-wide + .dir-f-wide { padding-top:24px; margin-top:-12px; }
.dir-f-wide-t {
  font-family:var(--font-display); font-weight:500;
  font-size:13px; color:var(--fg); margin-bottom:14px;
  text-transform:uppercase; letter-spacing:.08em;
}
.dir-f-wide-links {
  display:block;
  font-size:13px; line-height:1.9;
}
.dir-f-wide-links a {
  color:var(--muted); text-decoration:none; transition:color .18s;
  font-size: 12px; display:inline-block;
}
.dir-f-wide-links a:hover { color:var(--accent); }
.dir-f-wide-links a:not(:last-child)::after {
  content: '\00a0\2022';
  color: #440050;
  user-select: none;
  padding-right: 5px;
  font-size: 9px;
  vertical-align: middle;
  position: relative;
  top: 0;
  padding-left: 5px;
}
.dir-f-bot { margin:0 auto;
  border-top:1px solid var(--border); padding-top:28px;
  display:flex; justify-content:space-between; align-items:center;
  font-size:12.5px; color:var(--muted); font-weight:400;
}
.dir-f-bot a { color:var(--muted); text-decoration:none; transition:color .18s; }
.dir-f-bot a:hover { color:var(--accent); }
.dir-f-bot-legal { display:flex; gap:18px; align-items:center; }
.dir-f-bot-legal span { opacity:.4; }

.dir-luxe-icon { display:none; width:38px; height:38px; align-items:center; justify-content:center; background:transparent; border:0; text-decoration:none; color:#C4963A; padding:0; }
.dir-luxe-icon i { font-size:22px; line-height:1; }
.dir-luxe-icon:hover { color:#dba84a; }
.dir-search-icon { display:none; width:38px; height:38px; align-items:center; justify-content:center; background:transparent; border:0; cursor:pointer; color:var(--fg); padding:0; }
.dir-search-icon svg { width:22px; height:22px; }
.dir-search-icon.is-open { color:var(--accent); }
.dir-search-bar { position:fixed; top:68px; left:0; right:0; z-index:298; background:#fff; border-bottom:1px solid var(--border); padding:12px 16px; box-shadow:0 4px 16px rgba(0,0,0,.06); transform:translateY(-100%); transition:transform .25s ease; }
.dir-search-bar:not([hidden]) { transform:none; }
.dir-search-bar-form { display:flex; align-items:center; gap:8px; background:var(--bg); border-radius:100px; padding:6px 8px 6px 14px; }
.dir-search-bar-form > svg { width:16px; height:16px; color:var(--muted); flex-shrink:0; }
.dir-search-bar-form input { flex:1; border:0; outline:none; background:transparent; font-family:var(--font-body); font-size:14px; color:var(--fg); min-width:0; }
.dir-search-bar-form input::placeholder { color:var(--muted); }
.dir-search-bar-form button { width:36px; height:36px; border-radius:50%; background:var(--accent); color:#fff; border:0; cursor:pointer; display:inline-flex; align-items:center; justify-content:center; flex-shrink:0; }
.dir-search-bar-form button svg { width:14px; height:14px; }
.dir-burger { display:none; width:38px; height:38px; align-items:center; justify-content:center; background:transparent; border:0; cursor:pointer; color:var(--fg); padding:0; }
.dir-burger svg { width:24px; height:24px; transition:transform .25s ease; }
.dir-burger.is-open svg { transform:rotate(90deg); }

.dir-mobile-bd { position:fixed; inset:0; top:68px; z-index:298; background:rgba(15,12,8,.42); opacity:0; pointer-events:none; transition:opacity .22s ease; }
.dir-mobile-bd.is-open { opacity:1; pointer-events:auto; }
.dir-mobile-menu {
  position:fixed; top:68px; right:0; bottom:0; z-index:299;
  width:min(92vw, 380px); background:var(--card-bg);
  padding:14px 20px 28px; overflow-y:auto;
  transform:translateX(102%); transition:transform .28s ease;
  border-left:1px solid var(--border);
  display:flex; flex-direction:column;
}
.dir-mobile-menu.is-open { transform:translateX(0); }
.dir-mobile-city {
  display:flex; align-items:center; gap:10px;
  padding:13px 14px; margin:2px 0 12px;
  cursor:pointer; background:var(--bg); border:0; border-radius:var(--card-radius-sm);
  width:100%; text-align:left; font:inherit;
  font-size:13px; font-weight:500; color:var(--muted);
}
.dir-mobile-city svg { width:15px; height:15px; color:var(--muted); stroke-width:1.4; }
.dir-mobile-city b { color:var(--fg); margin-left:4px; font-weight:600; }

.dir-mobile-acc {
  width:100%; display:flex; align-items:center; justify-content:space-between;
  padding:16px 4px; background:none; border:0;
  border-bottom:1px solid var(--border);
  font:inherit; text-align:left; cursor:pointer;
  font-size:15px; font-weight:500; color:var(--fg); letter-spacing:.01em;
}
.dir-mobile-acc .chev { font-size:14px; color:var(--muted); transition:transform .22s ease; line-height:1; }
.dir-mobile-acc.is-open .chev { transform:rotate(180deg); color:var(--accent); }
.dir-mobile-acc.is-open { color:var(--accent); }

.dir-mobile-panel { display:none; padding:4px 0 12px; }
.dir-mobile-panel.is-open { display:block; }
.dir-mobile-subhd {
  font-size:9.5px; font-weight:600; letter-spacing:.2em; text-transform:uppercase;
  color:var(--muted); padding:14px 2px 4px;
}
.dir-mobile-item {
  display:flex; gap:14px; align-items:flex-start;
  padding:11px 2px; text-decoration:none; color:inherit;
}
.dir-mobile-item .ico {
  width:24px; flex-shrink:0; text-align:center;
  color:var(--muted); opacity:.7;
  padding-top:2px;
}
.dir-mobile-item .ico i { font-size:18px; line-height:1; font-weight:300; }
.dir-mobile-item .body { flex:1; min-width:0; }
.dir-mobile-item .ttl {
  display:block; font-size:14px; font-weight:500; color:var(--fg);
  line-height:1.3; margin-bottom:2px;
}
.dir-mobile-item .sub {
  display:block; font-size:12px; color:var(--muted); font-weight:400;
  line-height:1.4;
}
.dir-mobile-item:hover .ttl { color:var(--accent); }
.dir-mobile-item:hover .ico { color:var(--accent); opacity:1; }

.dir-mobile-cta { display:flex; flex-direction:column; gap:10px; margin-top:auto; padding-top:22px; }
.dir-mobile-cta .dir-btn { width:100%; justify-content:center; padding:14px 20px; font-size:12px; }

.dir-tabbar {
  display:none; position:fixed; inset:auto 0 0 0; z-index:280;
  background:var(--card-bg); border-top:1px solid var(--border);
  padding:4px 4px calc(4px + env(safe-area-inset-bottom, 0px));
  box-shadow:0 -6px 18px rgba(0,0,0,.05);
  transform:translateZ(0); will-change:transform;
}
.dir-tabbar-row { display:flex; align-items:flex-end; justify-content:space-around; gap:2px; max-width:520px; margin:0 auto; }
.dir-tab {
  flex:1; display:flex; flex-direction:column; align-items:center; gap:3px;
  padding:8px 2px 4px; text-decoration:none;
  color:var(--muted); font-family:var(--font-body);
  font-size:10px; font-weight:400; letter-spacing:.02em;
  transition:color .15s;
}
.dir-tab i { font-size:20px; line-height:1; opacity:.75; font-weight:300; }
.dir-tab.is-active, .dir-tab:hover { color:var(--accent); }
.dir-tab.is-active i, .dir-tab:hover i { opacity:1; }
.dir-tab-home {
  position:relative; transform:translateY(-14px);
  background:var(--accent); color:#fff !important;
  width:54px; height:54px; border-radius:50%;
  flex:0 0 auto; padding:0; gap:0;
  align-items:center; justify-content:center;
  box-shadow:0 6px 16px rgba(82,3,80,.28);
  border:3px solid #fff;
}
.dir-tab-home i { font-size:22px; opacity:1; }
.dir-tab-home span { display:none; }

@media (max-width:1220px) {
  .dir-nav-links { display:none; }
  .dir-burger { display:inline-flex; }
  .dir-search-icon { display:inline-flex; }
  .dir-luxe-icon { display:inline-flex; }
}
@media (max-width:960px) {
  .dir-nav { padding:0 16px; }
  .dir-logo img { height:28px; }
  .dir-nav-r .dir-city-pill { display:none; }
  .dir-foot { padding:52px 24px 28px; }
  .dir-foot-top { grid-template-columns:1fr 1fr; gap:36px 28px; margin-bottom:40px; }
  .dir-foot-top > div:first-child { grid-column:1 / -1; }
  .dir-f-desc { max-width:none; }
  .dir-f-bot { flex-direction:column; gap:14px; text-align:center; padding-top:24px; }
  .dir-tabbar { display:block; }
  body.dir-body { padding-bottom:calc(68px + env(safe-area-inset-bottom, 0px)); }
  .cmp-bar { bottom:0px !important; }
}
@media (max-width:880px) {
  .dir-nav-r .dir-btn { display:none; }
}

.ck-banner { position:fixed; left:16px; right:16px; bottom:16px; z-index:500; max-width:780px; margin:0 auto; padding:18px 22px; background:#18140f; color:#fff; border:1px solid rgba(255,255,255,.12); border-radius:var(--card-radius); box-shadow:0 12px 40px rgba(0,0,0,.35); display:none; align-items:center; gap:18px; flex-wrap:wrap; font-family:var(--font-body); }
.ck-banner.is-visible { display:flex; }
.ck-banner-text { flex:1; min-width:240px; font-size:13.5px; line-height:1.55; color:rgba(255,255,255,.85); }
.ck-banner-text a { color:#fff; text-decoration:underline; text-underline-offset:2px; }
.ck-banner-actions { display:flex; gap:8px; flex-shrink:0; }
.ck-banner-btn { padding:10px 18px; font-size:11.5px; font-weight:700; letter-spacing:.12em; text-transform:uppercase; cursor:pointer; border:1px solid rgba(255,255,255,.3); background:transparent; color:#fff; transition:background .15s, border-color .15s; }
.ck-banner-btn:hover { background:rgba(255,255,255,.08); border-color:rgba(255,255,255,.6); }
.ck-banner-btn--primary { background:#fff; color:#18140f; border-color:#fff; }
.ck-banner-btn--primary:hover { background:#e8e3d8; color:#18140f; }
@media (max-width:520px) { .ck-banner-actions { width:100%; } .ck-banner-btn { flex:1; padding:11px 14px; } }
