/* =========================================================
   Matt Concierge — full site styles (header + home body + footer)
   File: assets/css/matt-main.css
   NOTE: this replaces the earlier matt-header.css
   ========================================================= */
  :root{
    --ink:#0a0a0b;--ink-soft:#141416;--paper:#f5f3ee;--paper-2:#ece9e1;--white:#ffffff;
    --grey:#8d8b85;--grey-light:#b9b7b0;--gold:#b08d57;--gold-bright:#cba968;
    --line-dark:rgba(255,255,255,0.12);--line-light:rgba(20,20,20,0.13);
    --serif:'Cormorant Garamond',Georgia,'Times New Roman',serif;
    --sans:'Inter',system-ui,-apple-system,'Helvetica Neue',Arial,sans-serif;
    --pad:clamp(1.25rem,5vw,6rem);
    /* Swap this for your own photo, e.g. url('img/hero.jpg') — it auto-converts to B&W */
    /*--hero-image:radial-gradient(130% 120% at 72% 18%,#2c2c30 0%,#161618 48%,#0a0a0b 100%);*/
    --hero-image: url('/wp-content/uploads/2026/06/aman-hotel-luxury-travel-luxe-digital.jpg');
  }
  .matt-home *,#nav *,.mobile-menu *,.matt-site-footer *{margin:0;padding:0;box-sizing:border-box}
  html{scroll-behavior:smooth}
  body.home{font-family:var(--sans);background:var(--ink);color:var(--paper);-webkit-font-smoothing:antialiased;line-height:1.6;overflow-x:hidden}
  ::selection{background:var(--gold);color:var(--ink)}
  .matt-home a,#nav a,.mobile-menu a,.matt-site-footer a{color:inherit;text-decoration:none}
  .eyebrow{font-size:.72rem;letter-spacing:.32em;text-transform:uppercase;font-weight:500;color:var(--gold)}
  #nav{position:fixed;top:0;left:0;right:0;z-index:100;display:flex;align-items:center;justify-content:space-between;padding:1.4rem var(--pad);transition:background .4s,padding .4s,border-color .4s;border-bottom:1px solid transparent}
  #nav.scrolled{background:rgba(10,10,11,.82);backdrop-filter:blur(14px);padding:.95rem var(--pad);border-bottom:1px solid var(--line-dark)}
  .wordmark{font-size:.95rem;letter-spacing:.34em;text-transform:uppercase;font-weight:500;color:var(--white)}
  .wordmark span{color:var(--gold)}
  .nav-links{display:flex;align-items:center;gap:2.4rem}
  .nav-links a{font-size:.82rem;letter-spacing:.06em;color:var(--grey-light);transition:color .25s}
  .nav-links a:hover{color:var(--white)}
  .nav-cta{border:1px solid var(--gold);color:var(--gold);padding:.6rem 1.3rem;font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;border-radius:2px;transition:all .3s}
  .nav-cta:hover{background:var(--gold);color:var(--ink)}
  .menu-toggle{display:none;position:relative;width:30px;height:20px;background:none;border:none;cursor:pointer;z-index:70;padding:0}
  .menu-toggle span{position:absolute;left:0;right:0;height:1.5px;background:var(--white);transition:transform .35s ease,opacity .25s ease}
  .menu-toggle span:nth-child(1){top:1px}
  .menu-toggle span:nth-child(2){top:50%;transform:translateY(-50%)}
  .menu-toggle span:nth-child(3){bottom:1px}
  .menu-toggle.is-open span:nth-child(1){top:50%;transform:translateY(-50%) rotate(45deg)}
  .menu-toggle.is-open span:nth-child(2){opacity:0}
  .menu-toggle.is-open span:nth-child(3){bottom:auto;top:50%;transform:translateY(-50%) rotate(-45deg)}
  .mobile-menu{position:fixed;inset:0;z-index:90;background:var(--ink);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1.7rem;opacity:0;visibility:hidden;transform:translateY(-10px);transition:opacity .4s ease,transform .4s ease,visibility .4s}
  .mobile-menu::before{content:"";position:absolute;inset:0;background:radial-gradient(90% 60% at 50% 30%,rgba(176,141,87,.10),transparent 60%);pointer-events:none}
  .mobile-menu.open{opacity:1;visibility:visible;transform:none}
  .mobile-menu a{font-family:var(--serif);font-size:2.2rem;color:var(--grey-light);transition:color .25s;position:relative}
  .mobile-menu a:hover,.mobile-menu a:active{color:var(--white)}
  .mobile-menu .mm-cta{margin-top:1.2rem;font-family:var(--sans);font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);border:1px solid var(--gold);padding:.9rem 2.2rem;border-radius:2px}
  .mobile-menu .mm-cta:hover{background:var(--gold);color:var(--ink)}
  .matt-home .hero{position:relative;min-height:100vh;display:flex;flex-direction:column;justify-content:center;padding:7rem var(--pad) 0;overflow:hidden}
  .matt-home .hero::before{content:"";position:absolute;inset:0;z-index:0;background-image:var(--hero-image);background-size:cover;background-position:center bottom;filter:contrast(1.04) brightness(.62)}
  .matt-home .hero::after{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(90deg,rgba(10,10,11,.94) 0%,rgba(10,10,11,.6) 48%,rgba(10,10,11,.32) 100%),radial-gradient(110% 80% at 30% 35%,rgba(176,141,87,.12),transparent 55%);pointer-events:none}
  .matt-home .hero-inner{position:relative;z-index:2;max-width:50rem;flex:1;display:flex;flex-direction:column;justify-content:center}
  .matt-home .hero-inner .eyebrow{display:block;margin-bottom:1.8rem}
  .matt-home .hero h1{font-family:var(--serif);font-weight:500;color:var(--white);font-size:clamp(3rem,8vw,6.5rem);line-height:.98;letter-spacing:-.015em;margin-bottom:1.8rem}
  .matt-home .hero h1 em{font-style:italic;color:var(--gold-bright)}
  .matt-home .hero-sub{font-size:1.1rem;color:var(--grey-light);font-weight:300;max-width:34rem;margin-bottom:2rem}
  .service-line{display:flex;flex-wrap:wrap;gap:.55rem 1.1rem;margin-bottom:2.6rem;font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;color:var(--grey)}
  .service-line span{position:relative;padding-left:1.1rem}
  .service-line span::before{content:"";position:absolute;left:0;top:50%;width:5px;height:5px;background:var(--gold);border-radius:50%;transform:translateY(-50%)}
  .cta-row{display:flex;gap:1rem;flex-wrap:wrap}
  .btn-primary{background:var(--gold);color:var(--ink);font-weight:500;padding:.95rem 2rem;font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;border-radius:2px;border:1px solid var(--gold);transition:all .3s;cursor:pointer}
  .btn-primary:hover{background:var(--gold-bright);border-color:var(--gold-bright);transform:translateY(-2px)}
  .btn-ghost{background:transparent;color:var(--white);padding:.95rem 2rem;font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;border-radius:2px;border:1px solid var(--line-dark);transition:all .3s;cursor:pointer}
  .btn-ghost:hover{border-color:var(--white)}
  .marquee{position:relative;z-index:2;margin:0 calc(-1*var(--pad));border-top:1px solid var(--line-dark);border-bottom:1px solid var(--line-dark);padding:1.6rem 0;overflow:hidden;-webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent)}
  .marquee-track{display:flex;width:max-content;animation:scroll 46s linear infinite}
  .marquee:hover .marquee-track{animation-play-state:paused}
  .marquee-track span{font-family:var(--serif);font-size:clamp(1.5rem,3vw,2.4rem);color:var(--grey-light);padding:0 1.6rem;display:inline-flex;align-items:center;white-space:nowrap}
  .marquee-track span::after{content:"·";color:var(--gold);margin-left:3.2rem}
  @keyframes scroll{to{transform:translateX(-50%)}}
  .matt-home section{padding:clamp(5rem,11vw,9rem) var(--pad)}
  .light{background:var(--paper);color:var(--ink)}
  .light .eyebrow{color:var(--gold)}
  .sec-head{position:relative;max-width:46rem;margin-bottom:3.5rem}
  .sec-head .eyebrow{display:block;margin-bottom:1.2rem}
  .sec-head h2{font-family:var(--serif);font-weight:500;font-size:clamp(2rem,4.2vw,3.2rem);line-height:1.08;letter-spacing:-.01em}
  .curate-lead{font-family:var(--serif);font-size:clamp(1.4rem,2.6vw,2rem);font-weight:400;line-height:1.4;max-width:42rem;margin-bottom:2.5rem;color:#2a2a28}
  .curate-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:0;border-top:1px solid var(--line-light)}
  .curate-item{padding:1.7rem 1.6rem 1.7rem 0;border-bottom:1px solid var(--line-light)}
  .curate-item .num{font-size:.7rem;letter-spacing:.2em;color:var(--gold);display:block;margin-bottom:.5rem}
  .curate-item p{font-family:var(--serif);font-size:1.25rem;color:var(--ink)}
  .curate-close{margin-top:2.6rem;font-family:var(--serif);font-style:italic;font-size:1.35rem;color:#555;max-width:34rem}
  .curate-close b{color:var(--ink);font-style:normal;font-weight:600}
  .who{background:var(--ink-soft);color:var(--paper)}
  .who .sec-head h2{color:var(--white)}
  .who-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.6rem 3rem;max-width:60rem}
  .who-list li{list-style:none;position:relative;padding-left:2rem;font-size:1rem;color:var(--grey-light);font-weight:300;line-height:1.55}
  .who-list li::before{content:"";position:absolute;left:0;top:.55em;width:9px;height:1px;background:var(--gold)}
  .who-list li b{color:var(--white);font-weight:500}
  .atlas-embed{max-width:1340px;margin:0 auto}
  .atlas-embed iframe{width:100%;border:0;display:block;min-height:680px;background:#F2EEE6;border-radius:2px}
  .steps{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:2.5rem}
  .step .s-num{font-family:var(--serif);font-size:3rem;color:var(--gold);line-height:1;display:block;margin-bottom:1rem}
  .step h3{font-size:1.05rem;font-weight:500;margin-bottom:.6rem;color:var(--ink)}
  .step p{font-size:.92rem;color:#5d5b56;font-weight:300}
  .journal{background:var(--ink);color:var(--paper)}
  .journal .sec-head h2{color:var(--white)}
  .j-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.6rem}
  .j-card{border:1px solid var(--line-dark);padding:1.8rem;transition:border-color .35s,transform .35s;display:flex;flex-direction:column;min-height:230px}
  .j-card:hover{border-color:var(--gold);transform:translateY(-3px)}
  .j-card .j-tag{font-size:.66rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-bottom:auto}
  .j-card h3{font-family:var(--serif);font-weight:500;font-size:1.55rem;color:var(--white);margin:1.4rem 0 .6rem;line-height:1.2}
  .j-card p{font-size:.88rem;color:var(--grey);font-weight:300;margin-bottom:1.1rem}
  .j-card .j-read{font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--grey-light)}
  .cta-band{background:var(--ink-soft);text-align:center;border-top:1px solid var(--line-dark)}
  .cta-band h2{font-family:var(--serif);font-weight:500;font-size:clamp(2.2rem,5vw,4rem);color:var(--white);line-height:1.05;margin-bottom:1.4rem}
  .cta-band p{color:var(--grey-light);font-weight:300;max-width:34rem;margin:0 auto 2.4rem}
  .cta-band .cta-row{justify-content:center}
  .matt-site-footer{background:var(--ink);padding:3rem var(--pad);border-top:1px solid var(--line-dark);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1.5rem}
  .matt-site-footer .f-mark{font-size:.85rem;letter-spacing:.3em;text-transform:uppercase;color:var(--white)}
  .matt-site-footer .f-mark span{color:var(--gold)}
  .matt-site-footer .f-meta{font-size:.74rem;color:var(--grey);letter-spacing:.05em}
  .matt-home .reveal{opacity:0;transform:translateY(24px);transition:opacity .9s ease,transform .9s ease}
  .matt-home .reveal.in{opacity:1;transform:none}
  @media(max-width:760px){#nav .nav-links{display:none}.menu-toggle{display:block}.matt-home .hero{padding-top:6rem}}
  @media(prefers-reduced-motion:reduce){*{scroll-behavior:auto}.reveal{transition:none;opacity:1;transform:none}.marquee-track{animation:none}}


/* ===== Journal cards: featured image on top (WP loop) ===== */
.matt-home .j-card{overflow:hidden}
.matt-home .j-card .j-img{display:block;margin:-1.8rem -1.8rem 1.4rem;aspect-ratio:16/10;overflow:hidden;background:#111}
.matt-home .j-card .j-img img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .7s ease}
.matt-home .j-card:hover .j-img img{transform:scale(1.05)}

/* ===== Stretch Astra's content container to full width on the homepage ===== */
.home #content{padding-top:0;padding-bottom:0}
.home #content > .ast-container,.home .site-content > .ast-container{max-width:100%;padding-left:0;padding-right:0;display:block}
.home #primary{width:100%;max-width:100%;margin:0;padding:0}
.home #main,.home .site-content{margin:0;padding:0}
.home .entry-header,.home .ast-archive-description{display:none}

/* ===== Inner pages: solid bar + spacing so fixed header never overlaps ===== */
.matt-inner #nav{background:rgba(10,10,11,.92);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);border-bottom:1px solid var(--line-dark);padding:.95rem var(--pad)}
.matt-inner #page{padding-top:72px}


/* =========================================================
   ASTRA DE-CONFLICT — make Matt styles outrank the theme.
   We do NOT remove Astra's CSS (that breaks layout/other
   pages); we just win wherever they collide.
   ========================================================= */

/* Lock the type scale on the homepage so rem/clamp sizes match
   the original design regardless of Astra's base font setting. */
html:has(body.home){font-size:16px}

/* Stable inherited base inside our canvas */
.matt-home{font-size:1rem;line-height:1.6;font-family:var(--sans);color:var(--paper)}
.matt-home h1,.matt-home h2,.matt-home h3{font-family:var(--serif)}
/* NOTE: we intentionally do NOT force all <p> to sans — the curate
   section uses serif paragraphs by design. They inherit sans from
   .matt-home where no rule sets a family. */

/* Links: kill Astra underline / box-shadow inside our areas */
.matt-home a,#nav a,.mobile-menu a,.matt-site-footer a{text-decoration:none;box-shadow:none}

/* Neutralise Astra's generic button theming in our areas
   (do NOT set width here — it collapses the hamburger toggle) */
.matt-home button,#nav button,.mobile-menu button{
  font-family:var(--sans)!important;box-shadow:none!important;text-shadow:none;
}

/* Re-assert the hero buttons exactly */
.matt-home .btn-primary{
  background:var(--gold)!important;color:var(--ink)!important;border:1px solid var(--gold)!important;
  border-radius:2px!important;padding:.95rem 2rem!important;font-size:.78rem!important;
  letter-spacing:.16em!important;text-transform:uppercase!important;font-weight:500!important;line-height:1.2!important;
}
.matt-home .btn-primary:hover{background:var(--gold-bright)!important;border-color:var(--gold-bright)!important}
.matt-home .btn-ghost{
  background:transparent!important;color:var(--white)!important;border:1px solid var(--line-dark)!important;
  border-radius:2px!important;padding:.95rem 2rem!important;font-size:.78rem!important;
  letter-spacing:.16em!important;text-transform:uppercase!important;font-weight:400!important;line-height:1.2!important;
}
.matt-home .btn-ghost:hover{border-color:var(--white)!important}

/* Nav + mobile CTA pills */
#nav .nav-cta{
  background:transparent!important;border:1px solid var(--gold)!important;color:var(--gold)!important;
  border-radius:2px!important;text-transform:uppercase!important;font-size:.72rem!important;letter-spacing:.18em!important;
}
#nav .nav-cta:hover{background:var(--gold)!important;color:var(--ink)!important}
.mobile-menu .mm-cta{
  background:transparent!important;border:1px solid var(--gold)!important;color:var(--gold)!important;border-radius:2px!important;
}
.mobile-menu .mm-cta:hover{background:var(--gold)!important;color:var(--ink)!important}

/* Journal "read guide" + cards shouldn't pick up Astra link styling */
.matt-home .j-card{text-decoration:none}


/* =========================================================
   SAFARI FIXES
   ========================================================= */

/* 1) Nav "Request a booking" pill — inline <a> must be inline-block
   so border/padding wrap correctly in Safari, nowrap so the
   letter-spacing never clips the last letter. */
#nav .nav-cta{
  display:inline-block!important;white-space:nowrap!important;
  padding:.62rem 1.5rem!important;line-height:1!important;
}
.mobile-menu .mm-cta{display:inline-block!important;white-space:nowrap!important}

/* 2) Make Astra's header/footer shells transparent so ONLY our bar/footer
   show — otherwise Astra's masthead background tints the nav strip and the
   colour looks "off". */
#masthead,.site-header,.ast-primary-header-bar,.main-header-bar,
.site-primary-header-wrap,.ast-above-header-wrap,.ast-below-header-wrap,
.main-header-bar-wrap{
  background:transparent!important;background-color:transparent!important;
  border:0!important;box-shadow:none!important;min-height:0!important;
}
#masthead .ast-container{max-width:100%!important;padding:0!important}
.site-footer,.ast-small-footer,.site-primary-footer-wrap,.site-below-footer-wrap,
.ast-small-footer-wrap{
  background:transparent!important;background-color:transparent!important;border:0!important;
}

/* 3) Destination marquee.
   Safari note: `will-change:transform` made Safari DEFER the animation start
   until a repaint (a hover), so the strip looked stopped until you hovered.
   Fix: drop will-change and get GPU compositing from a translate3d keyframe
   instead — this auto-plays reliably AND stays smooth. */
@keyframes mc-scroll{from{transform:translate3d(0,0,0)}to{transform:translate3d(-50%,0,0)}}
.matt-home .marquee{position:relative;z-index:2;overflow:hidden}
.matt-home .marquee-track{
  animation-name:mc-scroll;            /* overrides the old `scroll` keyframe */
  -webkit-backface-visibility:hidden;backface-visibility:hidden;
}

/* =========================================================
   "We curate" — image on the right (two-column top row)
   ========================================================= */
.matt-home .curate-top{
  display:grid;grid-template-columns:1.05fr .95fr;
  gap:clamp(2rem,5vw,5rem);align-items:center;
  margin-bottom:clamp(2.5rem,5vw,4rem);
}
.matt-home .curate-copy .sec-head{margin-bottom:1.8rem}
.matt-home .curate-copy .curate-lead{margin-bottom:0}
.matt-home .curate-media{margin:0;position:relative;overflow:hidden;border-radius:2px;background:#e9e6df}
.matt-home .curate-media::after{content:"";position:absolute;inset:0;box-shadow:inset 0 0 0 1px var(--line-light);pointer-events:none}
.matt-home .curate-media img{
  width:100%;height:100%;min-height:360px;object-fit:cover;display:block;
  transition:transform .9s ease;
}
.matt-home .curate-media:hover img{transform:scale(1.05)}
@media(max-width:860px){
  .matt-home .curate-top{grid-template-columns:1fr;gap:1.8rem}
  .matt-home .curate-media{order:-1}
  .matt-home .curate-media img{min-height:240px}
}

/* =========================================================
   FIXES (round 2) — paragraph size, curate item layout,
   mobile hamburger, dynamic WP menu styling
   ========================================================= */

/* (a) "We curate" lead paragraph — smaller, keep serif */
.matt-home .curate-lead{font-size:clamp(1.1rem,1.9vw,1.45rem);max-width:40rem}

/* (b) Curate grid — responsive columns
   Desktop: all 6 in one row (number stacked above title, as designed)
   Tablet : 3 columns × 2 rows
   Mobile : single column, number inline-left */
.matt-home .curate-grid{grid-template-columns:repeat(6,1fr)}
.matt-home .curate-item{display:block;padding:1.5rem 1.3rem 1.5rem 0}
.matt-home .curate-item .num{display:block;margin:0 0 .5rem}
.matt-home .curate-item p{font-family:var(--serif);font-size:1.15rem}

@media(max-width:1200px){
  .matt-home .curate-grid{grid-template-columns:repeat(3,1fr)}
}
@media(max-width:600px){
  .matt-home .curate-grid{grid-template-columns:1fr}
  .matt-home .curate-item{display:flex;align-items:baseline;gap:.9rem}
  .matt-home .curate-item .num{margin:0;flex:0 0 auto;min-width:2.4rem}
}

/* (c) Mobile hamburger toggle — guarantee it shows & keeps its size
   (Astra + earlier resets were hiding/collapsing it) */
@media(max-width:760px){
  #nav .menu-toggle{
    display:block!important;width:30px!important;height:20px!important;
    background:none!important;border:0!important;padding:0!important;position:relative;
  }
  #nav .menu-toggle span{display:block;background:var(--white)!important}
}

/* (d) Dynamic WP menu (wp_nav_menu output) — desktop nav */
#nav .nav-links ul.matt-menu{display:flex;align-items:center;gap:2.4rem;list-style:none;margin:0;padding:0}
#nav .nav-links ul.matt-menu li{list-style:none;margin:0;padding:0}
#nav .nav-links ul.matt-menu a{font-size:.82rem;letter-spacing:.06em;color:var(--grey-light);transition:color .25s}
#nav .nav-links ul.matt-menu a:hover,
#nav .nav-links ul.matt-menu .current-menu-item > a{color:var(--white)}

/* Dynamic WP menu — mobile overlay */
.mobile-menu ul.matt-menu-mobile{list-style:none;display:flex;flex-direction:column;align-items:center;gap:1.7rem;margin:0;padding:0}
.mobile-menu ul.matt-menu-mobile li{list-style:none}
.mobile-menu ul.matt-menu-mobile a{font-family:var(--serif);font-size:2.2rem;color:var(--grey-light);transition:color .25s}
.mobile-menu ul.matt-menu-mobile a:hover{color:var(--white)}