/* Resolute Pacific — site styles
   Palette: moss bookends, white canvas, off-white to break sections. */

:root{
  --moss:#33453A;
  --moss-mid:#51664F;
  --moss-line:#A9B5A0;
  --offwhite:#F6F1E7;
  --white:#FFFFFF;
  --ink:#2A2D28;
  --muted:#5A5F57;
  --sage:#7E8A77;
  --hairline:#E7E1D2;
  --tag-border:#C7D0BF;
  --field-border:#D8D2C2;
  --img-fallback:#E7E2D3;
  --maxw:1080px;
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;}
body{
  margin:0;
  font-family:'Inter',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  color:var(--ink);
  background:var(--white);
  line-height:1.65;
  font-size:16px;
}
img{max-width:100%;display:block;}
a{color:inherit;}
h1,h2,h3{font-family:'Fraunces',Georgia,'Times New Roman',serif;font-weight:500;color:var(--ink);margin:0;line-height:1.2;}
p{margin:0;}

.serif{font-family:'Fraunces',Georgia,serif;}
.eyebrow{font-weight:600;letter-spacing:2.5px;text-transform:uppercase;font-size:10.5px;color:var(--sage);margin:0 0 12px;}
.rule{width:42px;height:2px;background:var(--moss-mid);border:0;margin:18px 0 0;}
.rule.center{margin-left:auto;margin-right:auto;}

.skip-link{position:absolute;left:-9999px;top:0;background:var(--moss);color:var(--offwhite);padding:10px 16px;z-index:100;}
.skip-link:focus{left:8px;top:8px;}

/* Layout bands */
.band{padding:56px 0;}
.band.tight{padding:34px 0;}
.inner{max-width:var(--maxw);margin:0 auto;padding:0 32px;}
.alt{background:var(--offwhite);border-top:1px solid var(--hairline);}
.white{background:var(--white);}
.center{text-align:center;}
.lede{font-size:clamp(16px,1.6vw,18px);line-height:1.7;color:var(--muted);max-width:62ch;}
.center .lede{margin-left:auto;margin-right:auto;}

/* Buttons */
.btn{display:inline-block;font-size:14px;font-weight:500;text-decoration:none;padding:12px 24px;background:var(--moss);color:var(--offwhite);border:1px solid var(--moss);cursor:pointer;transition:opacity .15s;}
.btn:hover{opacity:.9;}
.btn-outline{background:transparent;color:var(--moss);border:1px solid var(--moss);}
.btn-ghost{background:transparent;color:var(--offwhite);border:1px solid var(--moss-mid);}
.btn-light{background:var(--offwhite);color:var(--moss);border:1px solid var(--offwhite);}

/* Header */
.site-header{background:var(--moss);}
.site-header .inner{display:flex;align-items:center;justify-content:space-between;padding-top:16px;padding-bottom:16px;gap:16px;}
.brand{display:flex;align-items:center;gap:11px;text-decoration:none;}
.brand .mark{width:28px;height:28px;flex:0 0 auto;}
.brand .name{font-family:'Fraunces',serif;font-weight:600;font-size:18px;color:var(--offwhite);line-height:1;}
.brand .desc{font-weight:600;letter-spacing:2.3px;text-transform:uppercase;font-size:8px;color:var(--moss-line);margin-top:3px;}
nav.main{display:flex;align-items:center;gap:20px;}
nav.main a{color:#D6DBCF;font-size:13px;text-decoration:none;}
nav.main a:hover{color:var(--offwhite);}
nav.main a.active{color:var(--offwhite);border-bottom:1.5px solid var(--moss-line);padding-bottom:2px;}
nav.main a.cta{border:1px solid var(--moss-mid);padding:8px 15px;color:var(--offwhite);}
nav.main a.cta:hover{background:var(--moss-mid);}

/* Hero */
.hero{
  background-color:var(--moss);
  background-image:
    linear-gradient(90deg,rgba(36,45,40,.90) 0%,rgba(36,45,40,.58) 30%,rgba(36,45,40,.14) 60%,rgba(36,45,40,0) 84%),
    url('img/hero.jpg');
  background-size:cover;background-position:center 40%;
  position:relative;
}
.hero .inner{padding-top:72px;padding-bottom:84px;}
.hero h1{color:var(--offwhite);font-size:clamp(28px,4.4vw,40px);max-width:16ch;text-shadow:0 1px 18px rgba(20,26,22,.45);}
.hero p{color:#EFEADF;font-size:clamp(15px,1.6vw,17px);max-width:48ch;margin:16px 0 24px;text-shadow:0 1px 14px rgba(20,26,22,.4);}
.hero .caption{position:absolute;right:22px;bottom:16px;font-family:'Fraunces',serif;font-style:italic;font-size:12px;color:#F1ECE1;max-width:46%;text-align:right;text-shadow:0 1px 8px rgba(20,26,22,.6);}

/* Generic statement band */
.statement{font-family:'Fraunces',serif;font-size:clamp(17px,2vw,20px);line-height:1.6;color:var(--ink);max-width:70ch;margin:0 auto;}

/* EORE message / icon trio */
.trio{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:22px;text-align:center;}
.trio .ico{width:48px;height:48px;border:1.5px solid var(--moss);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 12px;font-size:22px;color:var(--moss);}
.trio h3{font-size:16px;margin-bottom:4px;}
.trio p{font-size:13px;color:var(--muted);max-width:26ch;margin:0 auto;}

/* Cards */
.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:16px;}
.card{background:var(--white);border-top:2px solid var(--moss);padding:18px;}
.alt .card{background:var(--white);}
.white .card{background:var(--offwhite);}
.card h3{font-size:15px;margin-bottom:6px;}
.card p{font-size:13px;color:var(--muted);}
/* Four-item card grid: 1 / 2x2 / 4-across — never an awkward 3+1 */
.cards-4{grid-template-columns:1fr;}
@media (min-width:560px){.cards-4{grid-template-columns:repeat(2,1fr);}}
@media (min-width:920px){.cards-4{grid-template-columns:repeat(4,1fr);}}

/* Credibility bar */
.cred{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:18px;text-align:center;}
.cred .word{font-family:'Fraunces',serif;font-weight:500;font-size:20px;color:var(--moss);}
.cred .sub{font-size:12px;color:var(--muted);margin-top:8px;}
.cred .rule{margin:8px auto;}

/* Split (text + image) */
.split{display:grid;grid-template-columns:1fr 1fr;align-items:stretch;}
.split .panel{padding:48px 40px;display:flex;flex-direction:column;justify-content:center;}
.imgslot{background:var(--img-fallback) center/cover no-repeat;min-height:320px;}
.imgslot.community{background-image:url('img/community.jpg');}

/* Service rows (what we do) */
.srow{display:grid;grid-template-columns:0.8fr 1.2fr;gap:24px;}
.srow .head .rule{margin:0 0 10px;width:30px;background:var(--moss);}
.srow h2{font-size:clamp(18px,2.2vw,21px);}
.subcards{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:12px;margin-top:6px;}
.subcard{background:var(--white);padding:14px;}
.subcard h4{font-family:'Fraunces',serif;font-weight:500;font-size:13px;margin:0 0 4px;}
.subcard p{font-size:11.5px;color:var(--muted);line-height:1.45;}
.courselist{display:flex;flex-direction:column;gap:10px;}
.courselist .c{display:flex;gap:12px;align-items:baseline;}
.courselist .c b{font-family:'Fraunces',serif;font-weight:500;color:var(--moss);font-size:13px;min-width:150px;}
.courselist .c span{font-size:13px;color:var(--muted);}
.tags{margin-top:4px;}
.tag{display:inline-block;font-size:12px;color:var(--moss);border:1px solid var(--tag-border);padding:6px 12px;margin:0 7px 7px 0;}

/* Steps (how we work) */
.steps{display:flex;flex-direction:column;gap:18px;}
.step{display:flex;gap:18px;align-items:baseline;}
.step .num{font-family:'Fraunces',serif;font-weight:500;font-size:28px;color:#C7D0BF;min-width:32px;}
.step h3{font-size:15px;margin-bottom:3px;}
.step p{font-size:13px;color:var(--muted);}

/* Two-col notes */
.notes{display:grid;grid-template-columns:1fr 1fr;gap:24px;}
.notes p{font-size:13px;color:var(--muted);line-height:1.65;}

/* What we bring (about) */
.bring{display:grid;grid-template-columns:1fr 1fr;gap:16px 28px;}
.bring .b{display:flex;gap:13px;align-items:flex-start;}
.bring .b i{font-size:20px;color:var(--moss);margin-top:2px;}
.bring .b b{display:block;font-size:13px;color:var(--ink);font-weight:500;margin-bottom:2px;}
.bring .b span{font-size:13px;color:var(--muted);}

/* Contact */
.contactgrid{display:grid;grid-template-columns:1fr 1fr;}
.contactgrid .info{background:var(--offwhite);padding:48px 40px;}
.contactgrid .formwrap{background:var(--white);padding:44px 40px;}
.contactgrid .info ul{list-style:none;margin:22px 0 0;padding:0;display:flex;flex-direction:column;gap:14px;}
.contactgrid .info li{display:flex;align-items:center;gap:11px;font-size:14px;}
.contactgrid .info li i{font-size:18px;color:var(--moss);}
.field{display:block;width:100%;background:var(--white);border:1px solid var(--field-border);padding:11px 12px;font-size:14px;color:var(--ink);font-family:inherit;margin-top:5px;}
.field:focus{outline:none;border-color:var(--moss);}
label{font-size:12px;color:var(--muted);}
.formrow{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:14px;}
form .single{margin-bottom:14px;}
textarea.field{min-height:120px;resize:vertical;}
.formactions{display:flex;justify-content:flex-end;}
.hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden;}
.form-status{font-size:13px;margin-top:12px;min-height:1em;}
.form-status.ok{color:var(--moss);}
.form-status.err{color:#9c3a2f;}

/* CTA band */
.cta-band h2{font-size:clamp(20px,2.4vw,24px);margin-bottom:10px;}
.cta-band .note{font-style:italic;color:var(--moss-mid);font-size:13px;margin:6px 0 20px;}

/* Footer */
.site-footer{background:var(--moss);color:#D6DBCF;}
.site-footer .inner{padding-top:30px;padding-bottom:22px;}
.fcols{display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:22px;}
.site-footer .name{font-family:'Fraunces',serif;font-weight:500;font-size:15px;color:var(--offwhite);}
.site-footer .blurb{font-size:11.5px;color:var(--moss-line);max-width:34ch;margin-top:10px;line-height:1.55;}
.site-footer h4{font-family:'Inter',sans-serif;font-weight:600;letter-spacing:2px;text-transform:uppercase;font-size:9px;color:var(--sage);margin:0 0 10px;}
.site-footer a,.site-footer p.fitem{display:block;font-size:12px;color:#D6DBCF;text-decoration:none;margin:0 0 6px;}
.site-footer a:hover{color:var(--offwhite);}
.fbottom{border-top:1px solid var(--moss-mid);margin-top:20px;padding-top:14px;text-align:center;font-size:10px;color:var(--sage);}
.fbrand{display:flex;align-items:center;gap:10px;margin-bottom:4px;}

/* Responsive */
@media (max-width:860px){
  .site-header .inner{flex-direction:column;align-items:flex-start;gap:12px;}
  nav.main{flex-wrap:wrap;gap:14px;}
  .split,.contactgrid,.srow,.notes,.bring,.fcols{grid-template-columns:1fr;}
  .imgslot{min-height:240px;}
  .split .panel,.contactgrid .info,.contactgrid .formwrap{padding:34px 26px;}
  .hero .caption{display:none;}
  .formrow{grid-template-columns:1fr;}
  .band{padding:44px 0;}
  .inner{padding:0 22px;}
}

/* Legal pages (privacy / terms) */
.legal{max-width:760px;}
.legal h2{font-size:18px;margin:26px 0 8px;}
.legal p,.legal li{font-size:14px;color:var(--muted);line-height:1.75;margin:0 0 10px;}
.legal ul{padding-left:20px;margin:0 0 10px;}
.legal a{color:var(--moss);}
.legal-date{font-size:13px;color:var(--sage);margin-bottom:20px;}

/* Footer legal links (override the block-display footer link rule) */
.fbottom a{display:inline;color:var(--moss-line);text-decoration:underline;margin:0;}
.fbottom a:hover{color:var(--offwhite);}
