/* ===== West Bryden — shared styles (Direction B: Modern Institutional) ===== */
:root{
  --ink:#0e1b2a; --navy:#102338; --navy-deep:#0a1726;
  --paper:#ffffff; --soft:#f4f6f8;
  --muted:#5b6b7d; --line:#e2e7ec;
  --accent:#1f6f8b; --accent-light:#8fc6d8;
  --maxw:1200px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{background:var(--paper);color:var(--ink);font-family:"Inter",system-ui,sans-serif;line-height:1.62;-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block}
a{color:inherit}
.serif{font-family:"Source Serif 4",Georgia,serif}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 48px}

/* ---------- header / nav ---------- */
.site-header{position:absolute;top:0;left:0;right:0;z-index:20;border-bottom:1px solid rgba(255,255,255,.16)}
.nav{display:flex;align-items:center;justify-content:space-between;max-width:var(--maxw);margin:0 auto;padding:24px 48px;color:#fff}
.wordmark{font-family:"Source Serif 4",serif;font-weight:600;font-size:21px;letter-spacing:.02em;color:#fff;text-decoration:none}
.brand{display:inline-flex;align-items:center;gap:11px;text-decoration:none;color:#fff}
.brand__mark{width:30px;height:auto;flex:none}
.navlinks{display:flex;gap:38px}
.navlinks a{color:#fff;text-decoration:none;font-size:13px;font-weight:500;letter-spacing:.06em;opacity:.82;padding-bottom:2px;transition:opacity .2s}
.navlinks a:hover{opacity:1}
.navlinks a.active{opacity:1;border-bottom:1px solid var(--accent-light)}

/* ---------- hero ---------- */
.hero{position:relative;min-height:88vh;display:flex;align-items:center;color:#fff;
  background:linear-gradient(90deg,rgba(14,27,42,.92) 0%,rgba(14,27,42,.72) 42%,rgba(14,27,42,.30) 100%),var(--hero-img);
  background-size:cover;background-position:center}
.hero__inner{max-width:var(--maxw);margin:0 auto;padding:0 48px;width:100%}
.kicker{font-size:12px;letter-spacing:.28em;text-transform:uppercase;color:var(--accent-light);font-weight:600}
.hero .kicker{margin-bottom:30px}
.hero h1{font-family:"Source Serif 4",serif;font-weight:500;font-size:clamp(36px,5.4vw,68px);line-height:1.08;max-width:18ch;letter-spacing:-.01em}
.hero p{margin-top:28px;max-width:52ch;font-size:18px;color:#d7e1ea}
.scrollcue{margin-top:46px;display:inline-flex;align-items:center;gap:12px;color:#cdd9e3;font-size:12px;letter-spacing:.2em;text-transform:uppercase;text-decoration:none}
.scrollcue span{width:46px;height:1px;background:#7fa9c0;transition:width .25s}
.scrollcue:hover span{width:66px}

/* interior page hero (slimmer) */
.hero--page{min-height:52vh}
.hero--page h1{font-size:clamp(34px,4.6vw,56px);max-width:20ch}
.hero--navy{background:linear-gradient(160deg,var(--navy) 0%,var(--navy-deep) 100%)}
.hero--home{background:linear-gradient(90deg,rgba(14,27,42,.92) 0%,rgba(14,27,42,.72) 42%,rgba(14,27,42,.30) 100%),url('../img/coast.webp');background-size:cover;background-position:center}

/* ---------- sections ---------- */
section{padding:110px 0}
.band{background:var(--soft)}
.grid2{display:grid;grid-template-columns:0.85fr 1.15fr;gap:70px;align-items:start}
.grid2--center{align-items:center}
.kick{font-size:12px;letter-spacing:.26em;text-transform:uppercase;color:var(--accent);font-weight:600}
.lead{font-family:"Source Serif 4",serif;font-size:clamp(24px,3vw,36px);font-weight:500;line-height:1.34;letter-spacing:-.01em;color:var(--ink)}
.prose p{color:var(--muted);font-size:17px;margin-bottom:18px}
.prose p:last-child{margin-bottom:0}

/* pillar cards */
.pillars{display:grid;grid-template-columns:repeat(3,1fr);gap:30px}
.card{background:var(--paper);border:1px solid var(--line);border-top:3px solid var(--accent);padding:34px 30px 38px;box-shadow:0 2px 12px rgba(14,27,42,.06);transition:transform .22s ease,box-shadow .22s ease}
.card:hover{transform:translateY(-4px);box-shadow:0 16px 32px rgba(14,27,42,.12)}
.card .n{font-size:12px;letter-spacing:.2em;color:var(--accent);font-weight:600}
.card h3{font-family:"Source Serif 4",serif;font-weight:600;font-size:22px;margin:14px 0 12px}
.card p{color:var(--muted);font-size:15.5px}

/* cta band */
.ctaband{background:linear-gradient(160deg,var(--navy) 0%,var(--navy-deep) 100%);color:#fff;text-align:center;padding:96px 0}
.ctaband h2{font-family:"Source Serif 4",serif;font-weight:500;font-size:clamp(26px,3.4vw,40px);line-height:1.2;max-width:20ch;margin:0 auto 30px}
.btn{display:inline-block;border:1px solid var(--accent-light);color:#fff;text-decoration:none;font-size:13px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;padding:15px 34px;transition:background .2s,color .2s}
.btn:hover{background:var(--accent-light);color:var(--navy-deep)}

/* ---------- contact form ---------- */
.form{display:grid;grid-template-columns:1fr 1fr;gap:22px 26px;max-width:640px}
.field{display:flex;flex-direction:column}
.field.full{grid-column:1 / -1}
.field label{font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);font-weight:600;margin-bottom:9px}
.field input,.field textarea{font-family:inherit;font-size:16px;color:var(--ink);background:var(--paper);border:1px solid var(--line);border-radius:0;padding:13px 14px;transition:border-color .2s}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--accent)}
.field textarea{resize:vertical;min-height:140px}
.form .btn{justify-self:start;grid-column:1 / -1;background:var(--navy);border-color:var(--navy);cursor:pointer}
.form .btn:hover{background:var(--accent);border-color:var(--accent);color:#fff}
.contact-meta{color:var(--muted);font-size:16px;line-height:1.8}
.contact-meta a{color:var(--accent);text-decoration:none}
.contact-meta a:hover{text-decoration:underline}

/* ---------- footer ---------- */
.site-footer{background:var(--navy);color:#cdd9e3;padding:56px 0}
.foot{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:18px;font-size:13.5px}
.foot .wordmark{font-size:19px}
.foot a{color:#cdd9e3;text-decoration:none;opacity:.85}
.foot a:hover{opacity:1}
.foot__right{display:inline-flex;align-items:center;gap:20px}
.foot__li{display:inline-flex;color:#cdd9e3;opacity:.8;transition:opacity .2s}
.foot__li:hover{opacity:1}
.foot__li svg{width:21px;height:21px;display:block}

/* ---------- home: hero → content tonal bridge ---------- */
.hero--bridge{min-height:84vh}
.hero--bridge::after{content:"";position:absolute;left:0;right:0;bottom:0;height:160px;
  background:linear-gradient(180deg,rgba(10,23,38,0) 0%,var(--navy-deep) 100%);pointer-events:none}
.intro{background:var(--navy-deep);color:#fff;padding:104px 0 112px;text-align:center}
.intro .kicker{color:var(--accent-light);margin-bottom:26px}
.intro .statement{font-family:"Source Serif 4",serif;font-weight:500;font-size:clamp(26px,3.3vw,42px);
  line-height:1.34;letter-spacing:-.012em;max-width:22ch;margin:0 auto;color:#fff}
.intro .sub{max-width:50ch;margin:28px auto 0;color:#c7d3df;font-size:17.5px}
.prose-center{max-width:680px;margin:0 auto}

/* ---------- responsive ---------- */
@media(max-width:820px){
  .intro{padding:72px 0 76px}
  .wrap,.nav,.hero__inner{padding-left:28px;padding-right:28px}
  .grid2{grid-template-columns:1fr;gap:28px}
  .pillars{grid-template-columns:1fr}
  .form{grid-template-columns:1fr}
  .navlinks{gap:22px}
  section{padding:76px 0}
}
@media(max-width:520px){
  .navlinks{display:none}
}
