/* ============================================================
   Jamjoom & Partners — shared stylesheet
   Self-contained design system. No dependencies.
   Tokens, type, layout, components, motion — used by every page.
   ============================================================ */

/* ---------- self-hosted fonts (production; replaces the Google CDN) ----------
   Variable fonts cover every weight the brand uses:
   Cormorant Garamond 300/400 (+italic), Outfit 200–500.
   These are served as .woff2 (~60% smaller transfer than the original .ttf).
   font-display:swap keeps text visible during load. */
@font-face{
  font-family:'Cormorant Garamond';
  src:url('../fonts/CormorantGaramond-VariableFont_wght.woff2') format('woff2');
  font-weight:300 700; font-style:normal; font-display:swap;
}
@font-face{
  font-family:'Cormorant Garamond';
  src:url('../fonts/CormorantGaramond-Italic-VariableFont_wght.woff2') format('woff2');
  font-weight:300 700; font-style:italic; font-display:swap;
}
@font-face{
  font-family:'Outfit';
  src:url('../fonts/Outfit-VariableFont_wght.woff2') format('woff2');
  font-weight:100 900; font-style:normal; font-display:swap;
}

:root{
  --anchor:#2C2622; --ink2:#4A4541; --ink3:#625C56; --taupe:#615B55;
  --mist:#958F89; --sand:#D0C6BA; --stone:#E4DFD7; --cream:#F7F4EF; --paper:#FCFAF6;
  /* --taupe darkened from #7B736C to meet WCAG AA (4.5:1) for eyebrow labels and
     form labels on the light grounds (paper/cream/stone). */
  --emerald:#0F6E56;
  --serif:'Cormorant Garamond',Georgia,serif;
  --sans:'Outfit',system-ui,sans-serif;
  --ease:cubic-bezier(.22,.61,.21,1);
  --hair:1px solid rgba(44,38,34,.16);
  --hair-l:1px solid rgba(247,244,239,.22);
  --gut:clamp(20px,5vw,72px);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--sans);font-weight:300;color:var(--anchor);background:var(--paper);
  font-size:15.5px;line-height:1.65;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
img,video{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
:focus-visible{outline:1px solid var(--taupe);outline-offset:4px}
::selection{background:var(--sand);color:var(--anchor)}

/* ---------- type ---------- */
.eyebrow{font-family:var(--sans);font-weight:400;font-size:11px;letter-spacing:.28em;
  text-transform:uppercase;color:var(--taupe)}
.display{font-family:var(--serif);font-weight:300;line-height:1.08;letter-spacing:.005em}
h1.display{font-size:clamp(2.5rem,5.6vw,4.5rem)}
h2.display{font-size:clamp(2rem,3.8vw,3.1rem)}
.statement{font-family:var(--serif);font-weight:300;font-size:clamp(1.45rem,2.6vw,2.15rem);line-height:1.32}
.small{font-size:13px;color:var(--ink3)}
.lede{font-size:clamp(1rem,1.4vw,1.1rem);color:var(--ink2);max-width:54ch}

/* ---------- layout ---------- */
.wrap{max-width:1280px;margin:0 auto;padding-inline:var(--gut)}
section{position:relative}
.section-pad{padding-block:clamp(84px,11vw,150px)}
.rule{border:0;border-top:var(--hair)}

/* ---------- reveal ---------- */
[data-r]{opacity:0;transform:translateY(18px);
  transition:opacity 1s var(--ease),transform 1s var(--ease);transition-delay:var(--d,0s)}
.inview [data-r],[data-r].inview{opacity:1;transform:none}

/* ---------- entrance veil ---------- */
#veil{position:fixed;inset:0;z-index:60;background:var(--paper);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:26px;
  transition:transform 1s var(--ease)}
#veil img{height:128px;width:auto;opacity:0;transform:scale(.96);
  animation:vlogo 1s var(--ease) .15s forwards}
#veil .eyebrow{opacity:0;animation:vfade .9s var(--ease) .7s forwards;letter-spacing:.46em;padding-left:.46em}
@keyframes vlogo{to{opacity:1;transform:scale(1)}}
@keyframes vfade{to{opacity:1}}
#veil.lift{transform:translateY(-101%)}
body.locked{overflow:hidden}

/* ---------- header ---------- */
header{position:fixed;top:0;left:0;right:0;z-index:40;
  transition:background .5s var(--ease),box-shadow .5s var(--ease)}
header .bar{display:flex;align-items:center;justify-content:space-between;
  padding:14px var(--gut)}
header.scrolled{background:rgba(252,250,246,.92);backdrop-filter:blur(8px);
  box-shadow:inset 0 -1px 0 rgba(44,38,34,.12)}
.brand{position:relative;display:inline-block;line-height:0}
.brand img{display:block;height:62px;width:auto;transition:opacity .55s var(--ease)}
.brand .lk{position:absolute;top:0;left:0;opacity:0}
header.scrolled .brand .cm{opacity:0}
header.scrolled .brand .lk{opacity:1}
nav.primary{display:flex;gap:34px}
nav.primary a{font-size:11.5px;letter-spacing:.16em;text-transform:uppercase;font-weight:400;
  color:var(--anchor);position:relative;padding:6px 0}
nav.primary a::after{content:"";position:absolute;left:0;bottom:0;height:1px;width:0;
  background:var(--anchor);transition:width .4s var(--ease)}
nav.primary a:hover::after,nav.primary a[aria-current="page"]::after{width:100%}
#menuBtn{display:none;font:400 11.5px var(--sans);letter-spacing:.2em;text-transform:uppercase;
  background:none;border:0;color:var(--anchor);cursor:pointer;padding:8px 0}
#mobileMenu{position:fixed;inset:0;background:var(--paper);z-index:50;display:none;
  flex-direction:column;justify-content:center;padding:0 var(--gut);gap:8px}
#mobileMenu a{font-family:var(--serif);font-size:2rem;font-weight:300;padding:10px 0;
  border-bottom:var(--hair)}
#mobileMenu .eyebrow{margin-bottom:22px}
#closeBtn{position:absolute;top:22px;right:var(--gut);background:none;border:0;cursor:pointer;
  font:400 11.5px var(--sans);letter-spacing:.2em;text-transform:uppercase;color:var(--taupe);padding:8px 0}
body.menu-open #mobileMenu{display:flex}

/* ---------- hero ---------- */
#hero{height:min(94vh,940px);min-height:580px;position:relative;overflow:hidden;background:var(--anchor)}
.hero-media{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:62% 50%}
video.hero-media{opacity:0;transition:opacity 1.6s var(--ease)}
video.hero-media.on{opacity:1}
.hero-scrim{position:absolute;inset:0;
  background:linear-gradient(76deg,rgba(44,38,34,.62) 0%,rgba(44,38,34,.28) 38%,rgba(44,38,34,0) 62%),
             linear-gradient(0deg,rgba(44,38,34,.45) 0%,rgba(44,38,34,0) 34%)}
.hero-inner{position:relative;z-index:2;height:100%;display:flex;flex-direction:column;
  justify-content:flex-end;padding-bottom:clamp(56px,8vw,104px)}
.hero-inner .eyebrow{color:var(--sand);margin-bottom:22px}
.hero-inner h1{color:var(--paper);max-width:13ch}
.hero-inner p{color:var(--stone);max-width:52ch;margin-top:22px;font-weight:200;
  font-size:clamp(1rem,1.5vw,1.15rem)}
.hero-ctas{display:flex;gap:38px;margin-top:34px;flex-wrap:wrap}
.tlink{font-size:11.5px;letter-spacing:.2em;text-transform:uppercase;font-weight:400;
  color:var(--paper);padding-bottom:7px;border-bottom:1px solid rgba(247,244,239,.45);
  transition:border-color .4s var(--ease)}
.tlink:hover{border-color:var(--paper)}
.tlink.dark{color:var(--anchor);border-color:rgba(44,38,34,.35)}
.tlink.dark:hover{border-color:var(--anchor)}
.hero-line{position:absolute;right:var(--gut);bottom:0;width:1px;height:88px;
  background:linear-gradient(rgba(247,244,239,0),rgba(247,244,239,.7));z-index:2}

/* ---------- firm statement ---------- */
#firm .statement{max-width:30ch}
#firm .grid{display:grid;grid-template-columns:1.25fr .9fr;gap:clamp(40px,6vw,96px);align-items:end}
#firm .lede{margin-top:0}

/* ---------- proof / clients ---------- */
#counsel{background:var(--anchor);color:var(--cream)}
#counsel .eyebrow{color:var(--sand)}
#counsel .statement{color:var(--cream);max-width:62ch;font-size:clamp(1.35rem,2.3vw,1.9rem)}
.roster{display:flex;flex-wrap:wrap;gap:18px 0;margin-top:clamp(44px,6vw,72px);
  border-top:var(--hair-l);padding-top:clamp(34px,4vw,52px)}
.roster span{font-family:var(--serif);font-weight:300;font-size:clamp(1.3rem,2vw,1.7rem);
  color:var(--cream);white-space:nowrap;padding:6px 34px 6px 0;margin-right:34px;
  border-right:1px solid rgba(247,244,239,.18)}
.roster span:last-child{border-right:0;margin-right:0;padding-right:0}
#counsel .small{color:var(--mist);margin-top:38px;max-width:64ch}

/* ---------- hospitality ---------- */
#hospitality{background:var(--stone)}
#hospitality .grid{display:grid;grid-template-columns:1.05fr .85fr;gap:clamp(48px,7vw,110px);align-items:center}
.arch{position:relative;aspect-ratio:3/4;max-width:430px;justify-self:end;width:100%}
.arch img{width:100%;height:100%;object-fit:cover;border-radius:999px 999px 0 0}
.arch::after{content:"";position:absolute;inset:-16px;border:1px solid var(--sand);
  border-radius:999px 999px 0 0;pointer-events:none}
.points{margin-top:clamp(36px,4vw,54px);display:grid;gap:30px}
.points .pt{border-top:var(--hair);padding-top:20px}
.points .eyebrow{font-size:10px;letter-spacing:.3em}
.points p{margin-top:10px;color:var(--ink2);max-width:46ch}
#hospitality h2{max-width:12ch}
#hospitality .tlink-row{margin-top:44px}

/* ---------- retainer ---------- */
#retainer .head{max-width:760px}
#retainer .head p{margin-top:24px}
.pillars{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(28px,4vw,56px);
  margin-top:clamp(52px,7vw,88px)}
.pillar{border-top:var(--hair);padding-top:24px}
.pillar h3{font-family:var(--serif);font-weight:400;font-size:1.4rem;line-height:1.2}
.pillar p{margin-top:12px;color:var(--ink2);font-size:14.5px}
.recal{margin-top:clamp(64px,8vw,100px);max-width:760px}
.recal .track{position:relative;height:1px;background:rgba(44,38,34,.22);margin:34px 0 14px}
.recal .tick{position:absolute;top:-4px;width:1px;height:9px;background:var(--taupe)}
.recal .node{position:absolute;top:-5.5px;width:12px;height:12px;border-radius:50%;
  background:var(--paper);border:1px solid var(--anchor);transform:translateX(-50%)}
.recal .qs{display:flex;justify-content:space-between;font-size:10px;letter-spacing:.26em;
  color:var(--taupe);text-transform:uppercase}
.recal figcaption{margin-top:26px;font-family:var(--serif);font-style:italic;font-weight:300;
  font-size:1.15rem;color:var(--ink2)}

/* ---------- capabilities ---------- */
#capabilities{background:var(--cream)}
#capabilities .grid{display:grid;grid-template-columns:1.15fr .85fr;gap:clamp(48px,7vw,120px)}
.featured{margin-top:34px;display:grid;gap:0}
.featured .f{border-top:var(--hair);padding:26px 0}
.featured h3{font-family:var(--serif);font-weight:400;font-size:clamp(1.45rem,2.2vw,1.8rem)}
.featured p{margin-top:8px;color:var(--ink2);max-width:52ch;font-size:14.5px}
.compact{border-top:var(--hair);margin-top:0;padding-top:26px;display:grid;
  grid-template-columns:1fr 1fr;gap:12px 28px;font-size:13.5px;color:var(--ink3)}
.sectors{margin-top:34px;border-top:var(--hair)}
.sectors li{list-style:none;display:flex;align-items:baseline;gap:12px;
  padding:15px 0;border-bottom:var(--hair);font-size:15px;color:var(--ink2)}
.sectors li.flag{font-family:var(--serif);font-size:1.3rem;color:var(--anchor)}
.dot{width:5px;height:5px;border-radius:50%;background:var(--emerald);flex:none;position:relative;top:-2px}
.flaglabel{font-size:9.5px;letter-spacing:.26em;text-transform:uppercase;color:var(--taupe);margin-left:auto}

/* ---------- principles ---------- */
#principles{background:var(--stone)}
#principles .row{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(24px,4vw,56px)}
#principles .p{border-left:var(--hair);padding-left:24px}
#principles h3{font-family:var(--serif);font-weight:400;font-size:1.3rem}
#principles p{margin-top:8px;font-size:13.5px;color:var(--ink3)}

/* ---------- footer ---------- */
footer{background:var(--anchor);color:var(--stone)}
footer .top{display:grid;grid-template-columns:auto 1fr;gap:clamp(48px,8vw,140px);
  padding-top:clamp(72px,9vw,120px);padding-bottom:clamp(56px,7vw,90px);align-items:start}
footer img{height:148px;width:auto}
.offices{display:grid;grid-template-columns:1fr 1fr;gap:clamp(32px,5vw,80px)}
.office .eyebrow{color:var(--sand);margin-bottom:16px}
.office p{font-weight:200;font-size:14.5px;color:var(--stone);line-height:1.8}
.office a{color:var(--cream);border-bottom:1px solid rgba(247,244,239,.25)}
footer .ahead{border-top:var(--hair-l);padding:34px 0;display:flex;justify-content:space-between;
  align-items:center;flex-wrap:wrap;gap:18px}
footer .ahead .eyebrow{color:var(--sand);letter-spacing:.5em;padding-left:.5em}
footer .legal{font-size:12px;color:var(--mist);font-weight:200}
footer .ar{font-family:var(--serif);color:var(--sand);font-size:15px}

/* ---------- client roster (hospitality flags, on charcoal) ---------- */
.clientrow{display:flex;flex-wrap:wrap;align-items:center;gap:clamp(28px,5vw,60px);
  margin-top:clamp(40px,5vw,64px)}
.clientrow img{max-height:56px;max-width:148px;width:auto;height:auto;object-fit:contain;opacity:.94}
.client-names{margin-top:28px;font-size:12.5px;letter-spacing:.02em;color:var(--mist);max-width:66ch;line-height:1.7}
/* broader client base, quieter, within the same dark proof section */
.clientband{margin-top:clamp(52px,6vw,84px);border-top:var(--hair-l);padding-top:clamp(36px,4vw,56px)}
.clientband .eyebrow{color:var(--sand)}
.clientgrid{margin-top:clamp(44px,5.5vw,76px);display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:clamp(40px,5vw,62px) clamp(28px,3vw,44px);align-items:center;justify-items:center}
.clientgrid img{max-height:52px;max-width:148px;width:auto;height:auto;object-fit:contain;opacity:.85}

/* ---------- inner-page header (light page top: charcoal logo + solid field) ---------- */
body.inner header{background:rgba(252,250,246,.92);backdrop-filter:blur(8px);
  box-shadow:inset 0 -1px 0 rgba(44,38,34,.12)}
body.inner .brand .cm{opacity:0}
body.inner .brand .lk{opacity:1}
.inner-hero{padding-top:clamp(132px,16vh,184px);padding-bottom:clamp(40px,5vw,64px)}
.inner-hero .eyebrow{display:block}
.inner-hero h1{margin-top:24px;max-width:18ch}
.inner-hero .lede{margin-top:26px}

/* ---------- people ---------- */
#leadership{background:var(--anchor);color:var(--cream)}
#leadership .eyebrow{color:var(--sand)}
.lead-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(30px,4vw,56px);
  margin-top:clamp(44px,5vw,72px)}
.person .portrait{aspect-ratio:2/3;width:100%;overflow:hidden;background:var(--anchor)}
.person .portrait img{width:100%;height:100%;object-fit:cover;object-position:50% 10%}
.person h3{font-family:var(--serif);font-weight:300;line-height:1.1;margin-top:24px;
  font-size:clamp(1.5rem,2.3vw,2rem);color:var(--cream)}
.person .role{margin-top:11px;font-size:11px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--sand);font-weight:400}
.person .bio{margin-top:16px;font-size:13.5px;line-height:1.72;color:var(--stone);max-width:42ch}
#team{background:var(--paper)}
.team-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(34px,4vw,56px);
  margin-top:clamp(40px,5vw,64px)}
#team .person .portrait{border:var(--hair)}
#team .person h3{color:var(--anchor);font-size:clamp(1.3rem,1.9vw,1.55rem)}
#team .person .role{color:var(--taupe)}
#team .person .bio{color:var(--ink3);font-size:12.5px}
.person.noimg .portrait{display:flex;align-items:center;justify-content:center;background:var(--stone)}
.person.noimg .initials{font-family:var(--serif);font-weight:300;font-size:clamp(2.4rem,4vw,3rem);color:var(--taupe)}

/* ---------- contact ---------- */
.contact-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:clamp(40px,7vw,110px);
  margin-top:clamp(40px,5vw,64px)}
.contact-channels .eyebrow{display:block;margin-bottom:8px}
.contact-channels .channel{border-top:var(--hair);padding:18px 0}
.contact-channels .channel:first-of-type{border-top:0;padding-top:0}
.contact-channels .channel .eyebrow{color:var(--taupe);margin-bottom:12px}
.contact-channels p{font-weight:200;font-size:14.5px;color:var(--ink2);line-height:1.8}
.contact-channels a{border-bottom:1px solid rgba(44,38,34,.25)}
.form{display:grid;gap:22px}
.form .field{display:grid;gap:8px}
.form label{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--taupe);font-weight:400}
.form input,.form textarea{font:inherit;font-weight:300;color:var(--anchor);background:transparent;
  border:0;border-bottom:var(--hair);padding:10px 0;width:100%}
.form textarea{min-height:120px;resize:vertical}
.form input:focus-visible,.form textarea:focus-visible{outline:0;border-bottom-color:var(--anchor);box-shadow:0 1px 0 0 var(--anchor)}
.form .hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}
.form button{justify-self:start;font:400 11.5px var(--sans);letter-spacing:.2em;text-transform:uppercase;
  color:var(--anchor);background:none;border:0;border-bottom:1px solid rgba(44,38,34,.45);
  padding:10px 0;cursor:pointer;transition:border-color .4s var(--ease)}
.form button:hover{border-color:var(--anchor)}
.form button:disabled{opacity:.5;cursor:default}
.form-status{font-size:13.5px;color:var(--ink2);min-height:1.2em;margin:0}
.form-status.err{color:#A32D2D}

/* ---------- responsive ---------- */
@media (max-width:920px){
  #firm .grid,#hospitality .grid,#capabilities .grid,.contact-grid{grid-template-columns:1fr}
  .arch{justify-self:start;max-width:380px}
  .pillars{grid-template-columns:1fr}
  #principles .row{grid-template-columns:1fr}
  footer .top{grid-template-columns:1fr}
  .offices{grid-template-columns:1fr}
  .lead-grid{grid-template-columns:1fr}
  .team-grid{grid-template-columns:1fr 1fr}
  .clientgrid{grid-template-columns:repeat(3,1fr)}
  /* nav stays on the bar (no menu collapse); solid header for legibility on mobile */
  header{background:rgba(252,250,246,.92);backdrop-filter:blur(8px);
    box-shadow:inset 0 -1px 0 rgba(44,38,34,.12)}
  header .brand .cm{opacity:0}
  header .brand .lk{opacity:1}
  header .bar{flex-wrap:wrap;gap:10px 0;padding-top:12px;padding-bottom:12px}
  .brand img{height:50px}
  nav.primary{width:100%;gap:16px 20px;flex-wrap:wrap;justify-content:flex-start}
  nav.primary a{font-size:10.5px;letter-spacing:.12em;padding:2px 0}
}
@media (max-width:560px){
  .team-grid{grid-template-columns:1fr 1fr}
  .clientgrid{grid-template-columns:repeat(2,1fr)}
}
@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  [data-r]{opacity:1;transform:none;transition:none}
  #veil{display:none}
  video.hero-media{display:none}
}
