/* ─── Global reset + a11y ─────────────────────────────────────────────────── */
*{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%}
body{background:var(--cream);color:var(--ink);font-family:var(--sans);font-size:16px;line-height:1.65}
img{max-width:100%;height:auto;display:block}
a{color:inherit}
:focus-visible{outline:2px solid var(--gold);outline-offset:2px}
@media (prefers-reduced-motion:reduce){*{transition:none!important;animation:none!important;scroll-behavior:auto!important}}

/* ─── Paper-grain texture (re-targeted from .frame::after to body::after) ─── */
body::after{content:"";position:fixed;inset:0;pointer-events:none;opacity:.5;mix-blend-mode:multiply;z-index:5;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='120' height='120'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='2'/><feColorMatrix type='saturate' values='0'/></filter><rect width='120' height='120' filter='url(%23n)' opacity='0.04'/></svg>");}

/* ─── Utility bar ─────────────────────────────────────────────────────────── */
.util{background:var(--navy-d);color:var(--util-fg);font-size:12.5px;display:flex;justify-content:space-between;padding:10px var(--pad);}
.util .r{display:flex;gap:28px;}.util b{color:var(--gold-l);font-weight:600;}

/* ─── Sticky nav ─────────────────────────────────────────────────────────── */
.nav{position:sticky;top:0;z-index:20;display:flex;justify-content:space-between;align-items:center;padding:18px var(--pad);
  border-bottom:1px solid var(--line);background:rgba(250,247,241,.9);backdrop-filter:blur(9px);transition:padding .2s var(--ease)}
.brand{display:flex;align-items:center;gap:16px;}
.brand svg{display:block;transition:width .2s var(--ease),height .2s var(--ease)}
.nm{line-height:1;}
.nm .t{display:block;font-family:var(--serif);font-size:21px;font-weight:500;letter-spacing:.05em;color:var(--navy);}
.nm .s{display:block;font-size:9.5px;letter-spacing:.24em;color:var(--label);margin-top:9px;line-height:1.55;text-transform:uppercase;}
.menu{display:flex;gap:24px;align-items:center;font-size:13px;color:var(--ink-soft);}
.menu a{text-decoration:none;color:inherit;position:relative;padding-bottom:5px;transition:color .25s var(--ease);}
.menu a:not(.cta)::after{content:"";position:absolute;left:0;bottom:0;width:0;height:1.5px;background:var(--gold);transition:width .3s var(--ease);}
.menu a:not(.cta):hover{color:var(--navy);}.menu a:not(.cta):hover::after{width:100%;}
.menu a.cta{background:var(--navy);color:#fff;padding:12px 24px;font-weight:600;font-size:13.5px;transition:.3s var(--ease);}
.menu a.cta:hover{background:var(--gold);color:var(--navy);}
.navtoggle{display:none;}
.navtoggle-cb{position:absolute;left:-9999px;}

/* ─── Hero ───────────────────────────────────────────────────────────────── */
.hero{display:grid;grid-template-columns:1.18fr .82fr;}
.hero .l{background:linear-gradient(155deg,var(--navy-grad),var(--navy-d));color:#fff;padding:clamp(62px,6.8vw,99px) clamp(40px,4.5vw,72px) clamp(62px,6.8vw,99px) var(--pad);}
.rule{width:62px;border-top:1.5px solid var(--gold);padding-top:18px;margin-bottom:16px;}
.est{font-size:12px;letter-spacing:.22em;color:var(--gold-l);text-transform:uppercase;margin-bottom:18px;}
.hero h1{font-family:var(--serif);font-weight:400;font-size:clamp(40px,4.8vw,60px);line-height:1.09;letter-spacing:-.012em;margin-bottom:20px;}
.hero .sub{font-size:16px;color:var(--on-navy);line-height:1.7;max-width:460px;margin-bottom:34px;}
.hero .r{position:relative;min-height:432px;overflow:hidden;background:var(--navy-d);}
.hero .r::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--gold);z-index:2;}
.hero .r .hero-photo{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block;z-index:1;opacity:0;transition:opacity 1.1s ease}
.hero .r .hero-photo.is-on{opacity:1}

/* ─── Buttons ────────────────────────────────────────────────────────────── */
.btns{display:flex;gap:14px;}
.btn{position:relative;display:inline-flex;align-items:center;gap:9px;padding:15px 28px;font-weight:600;font-size:13.5px;text-decoration:none;overflow:hidden;cursor:pointer;transition:transform .3s var(--ease),box-shadow .3s var(--ease);}
.btn .a{transition:transform .3s var(--ease);}.btn:hover .a{transform:translateX(5px);}
.btn.solid{background:var(--gold);color:var(--navy);}
.btn.solid:hover{transform:translateY(-2px);box-shadow:0 10px 24px rgba(193,154,77,.34);}
.btn.ghost{border:1px solid rgba(255,255,255,.45);color:#fff;z-index:0;}
.btn.ghost::before{content:"";position:absolute;inset:0;background:var(--gold);transform:scaleX(0);transform-origin:left;transition:transform .4s var(--ease);z-index:-1;}
.btn.ghost:hover{color:var(--navy);border-color:var(--gold);transform:translateY(-2px);}
.btn.ghost:hover::before{transform:scaleX(1);}

/* ─── Trust bar ──────────────────────────────────────────────────────────── */
.trust{background:#fff;border-bottom:1px solid var(--line);}
.trust>ul{display:grid;grid-template-columns:repeat(3,1fr);list-style:none;margin:0;padding:0;}
.trust li{padding:clamp(24px,2.8vw,36px);text-align:center;border-right:1px solid var(--line);}
.trust li:last-child{border:none;}
.trust .n{display:block;font-family:var(--serif);font-size:clamp(28px,3vw,40px);color:var(--navy);font-weight:400;}
.trust .l{display:block;font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--label);margin-top:8px;}

/* ─── Services grid ──────────────────────────────────────────────────────── */
.svc{display:grid;grid-template-columns:repeat(3,1fr);background:var(--cream);}
.svc>div{padding:clamp(44px,4.5vw,60px) clamp(34px,3vw,46px);border-right:1px solid var(--line);transition:background .35s var(--ease);}
.svc>div:hover{background:#fff;}.svc>div:last-child{border:none;}
.svc .ic{width:44px;height:44px;border:1px solid var(--gold);display:flex;align-items:center;justify-content:center;color:var(--gold);font-size:20px;margin-bottom:20px;transition:.35s var(--ease);}
.svc>div:hover .ic{background:var(--navy);border-color:var(--navy);color:var(--gold-l);}
.svc h3{font-family:var(--serif);font-size:22px;font-weight:400;color:var(--navy);margin-bottom:12px;}
.svc p{font-size:15px;color:var(--mut);line-height:1.75;}

/* ─── Footer ─────────────────────────────────────────────────────────────── */
.foot{background:var(--navy-d);color:var(--on-navy-d);font-size:13.5px;padding:clamp(48px,5vw,76px) var(--pad) 42px;display:grid;grid-template-columns:1.7fr 1fr 1fr;gap:40px;}
.foot h4{color:#fff;font-size:12px;letter-spacing:.14em;text-transform:uppercase;margin-bottom:16px;}
.foot a{color:var(--on-navy-d);text-decoration:none;display:inline-block;margin-bottom:11px;position:relative;transition:color .25s var(--ease),transform .25s var(--ease);}
.foot a::after{content:"";position:absolute;left:0;bottom:-3px;width:0;height:1px;background:var(--gold);transition:width .3s var(--ease);}
.foot a:hover{color:#fff;transform:translateX(3px);}.foot a:hover::after{width:100%;}
.fbrand .flock{display:flex;align-items:center;gap:14px;margin-bottom:20px;}
.fbrand .flock .ft{font-family:var(--serif);font-size:18px;color:#fff;letter-spacing:.04em;line-height:1.15;}
.fbrand .flock .ft small{display:block;font-family:var(--sans);font-size:9px;letter-spacing:.22em;color:var(--gold-l);margin-top:5px;}
.fbrand .addr{display:grid;grid-template-columns:auto 1fr;gap:7px 16px;font-size:13px;color:var(--on-navy-soft);line-height:1.55;max-width:340px;}
.fbrand .addr .k{color:var(--on-navy-k);text-transform:uppercase;letter-spacing:.12em;font-size:10.5px;padding-top:2px;}
.fbrand .uw{margin-top:18px;padding-top:16px;border-top:1px solid rgba(255,255,255,.12);font-size:11.5px;color:var(--on-navy-k);letter-spacing:.03em;max-width:340px;line-height:1.6;}
.foot .fnav{list-style:none;margin:0;padding:0}
.foot .fnav li{margin:0}
.foot address.addr{font-style:normal}
.fbrand .addr .al{display:block}

/* ─── Responsive ─────────────────────────────────────────────────────────── */
@media(max-width:880px){
  .hero{grid-template-columns:1fr;}.hero .r{min-height:224px;}
  .navtoggle{display:flex;flex-direction:column;justify-content:center;align-items:center;gap:5px;width:44px;height:44px;cursor:pointer;margin-left:auto;}
  .navtoggle span{display:block;width:24px;height:2px;background:var(--navy);}
  .menu{display:none;position:absolute;top:100%;left:0;right:0;background:var(--cream);border-top:1px solid var(--line);flex-direction:column;align-items:flex-start;gap:0;padding:8px 0;z-index:30;}
  .menu a{display:block;width:100%;padding:13px var(--pad);font-size:16px;}
  .menu a.cta{margin:8px var(--pad);width:auto;text-align:center;}
  .navtoggle-cb:checked ~ .menu{display:flex;}
  .navtoggle-cb:focus-visible + .navtoggle{outline:2px solid var(--gold);outline-offset:2px;}
  .trust>ul,.svc,.foot{grid-template-columns:1fr;}
  .util{flex-direction:column;gap:6px;text-align:center;}.util .r{justify-content:center;}
}

/* ─── Nav scroll-condense (JS adds .scrolled; JS already guards reduced-motion) */
.nav.scrolled{padding-top:12px;padding-bottom:12px}
.nav.scrolled .brand svg{width:40px;height:40px}
