/* ==========================================================================
   James Maule PLLC
   Print-inspired editorial identity built from the engraved Maule "M".
   Palette: forest green + ink + warm paper. Type-driven, not card-driven.
   ========================================================================== */

:root{
  --green:#477652;          /* brand green, sampled from the M */
  --green-deep:#34593e;
  --green-ink:#21392a;
  --ink:#211f1a;
  --ink-soft:#534f44;
  --paper:#f6f2e9;          /* warm paper */
  --paper-2:#efe9da;
  --panel:#fffdf7;
  --line:#d9d2c0;
  --line-strong:#bcb39c;
  --brass:#9a7b3f;          /* sparing classical accent */

  --display:"Fraunces", Georgia, "Times New Roman", serif;
  --serif:"Newsreader", Georgia, "Times New Roman", serif;

  --maxw:1140px;
  --gutter:clamp(1.25rem, 4vw, 3rem);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:17px;-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{
  font-family:var(--serif);
  font-weight:380;
  line-height:1.62;
  color:var(--ink);
  background:var(--paper);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;height:auto;display:block}
a{color:var(--green-deep);text-decoration:none;text-underline-offset:3px;transition:color .15s ease}
a:hover{color:var(--brass)}
::selection{background:var(--green);color:#fff}

/* ---- layout primitives ---------------------------------------------------- */
.wrap{max-width:var(--maxw);margin-inline:auto;padding-inline:var(--gutter)}
.wrap--narrow{max-width:760px}
.section{padding-block:clamp(3.25rem,7vw,6rem)}
.section--tight{padding-block:clamp(2.25rem,5vw,3.5rem)}
.section--ink{background:var(--green-ink);color:#eee7d6}
.section--ink h2,.section--ink h3,.section--ink h4{color:#fff}
.section--band{background:var(--paper-2)}
.rule{border:0;border-top:1px solid var(--line);margin-block:clamp(2rem,4vw,3rem)}
.rule--double{border:0;height:5px;border-top:1px solid var(--line-strong);border-bottom:1px solid var(--line-strong);background:transparent}

/* eyebrow / small-caps label */
.eyebrow{
  font-family:var(--serif);
  font-size:.74rem;font-weight:600;
  letter-spacing:.22em;text-transform:uppercase;
  color:var(--green);
  display:inline-block;margin-bottom:1rem;
}
.section--ink .eyebrow{color:#bcd9c4}

/* ---- typography ----------------------------------------------------------- */
h1,h2,h3,h4{font-family:var(--display);font-weight:560;line-height:1.08;letter-spacing:-.01em;color:var(--ink)}
h1{font-size:clamp(2.5rem,6vw,4.4rem);font-weight:600;font-optical-sizing:auto}
h2{font-size:clamp(1.9rem,3.6vw,2.9rem)}
h3{font-size:clamp(1.3rem,2vw,1.6rem)}
h4{font-size:1.12rem;font-weight:600}
p{margin-bottom:1.1rem}
.lede{font-size:clamp(1.18rem,1.9vw,1.42rem);line-height:1.5;color:var(--ink-soft);font-weight:380}
.section--ink .lede{color:#cfc7b4}
strong{font-weight:640}
.muted{color:var(--ink-soft)}
.fineprint{font-size:.82rem;line-height:1.55;color:var(--ink-soft)}

/* ---- header --------------------------------------------------------------- */
.site-head{position:sticky;top:0;z-index:50;background:rgba(246,242,233,.92);backdrop-filter:saturate(1.1) blur(6px);border-bottom:1px solid transparent;transition:border-color .2s ease,box-shadow .2s ease}
.site-head.is-stuck{border-bottom-color:var(--line);box-shadow:0 6px 20px rgba(33,57,42,.06)}
.head-inner{display:flex;align-items:center;justify-content:space-between;gap:1.5rem;padding-block:.85rem}
.brand{display:flex;align-items:center;gap:.7rem;color:var(--ink)}
.brand:hover{color:var(--ink)}
.brand__mark{width:38px;height:38px;object-fit:contain;flex:none}
.brand__type{display:flex;flex-direction:column;line-height:1}
.brand__name{font-family:var(--display);font-weight:600;font-size:1.18rem;letter-spacing:.01em}
.brand__sub{font-size:.62rem;letter-spacing:.26em;text-transform:uppercase;color:var(--green);margin-top:.28rem}

.nav{display:flex;align-items:center;gap:1.3rem}
.nav a{font-size:.93rem;color:var(--ink);position:relative;white-space:nowrap}
.nav a:not(.btn)::after{content:"";position:absolute;left:0;right:100%;bottom:-5px;height:1px;background:var(--green);transition:right .25s ease}
.nav a:not(.btn):hover{color:var(--green-deep)}
.nav a:not(.btn):hover::after{right:0}
.nav__toggle{display:none;background:none;border:0;cursor:pointer;width:30px;height:24px;position:relative}
.nav__toggle span{position:absolute;left:0;right:0;height:2px;background:var(--ink);transition:.25s}
.nav__toggle span:nth-child(1){top:2px}
.nav__toggle span:nth-child(2){top:11px}
.nav__toggle span:nth-child(3){top:20px}

/* ---- buttons -------------------------------------------------------------- */
.btn{display:inline-block;font-family:var(--serif);font-size:.95rem;font-weight:560;letter-spacing:.01em;padding:.72em 1.4em;border:1px solid var(--green-deep);border-radius:1px;cursor:pointer;transition:all .18s ease}
.btn--solid{background:var(--green-deep);color:#fff}
.btn--solid:hover{background:var(--green-ink);color:#fff;border-color:var(--green-ink)}
.btn--ghost{background:transparent;color:var(--green-deep)}
.btn--ghost:hover{background:var(--green-deep);color:#fff}
.section--ink .btn--ghost{border-color:#cfe0d4;color:#eef3ea}
.section--ink .btn--ghost:hover{background:#eef3ea;color:var(--green-ink)}
.btn--lg{padding:.85em 1.7em;font-size:1rem}

/* underlined text link with arrow */
.tlink{font-weight:560;color:var(--green-deep);border-bottom:1px solid var(--line-strong);padding-bottom:2px}
.tlink:hover{border-bottom-color:var(--brass)}

/* ---- hero ----------------------------------------------------------------- */
.hero{padding-block:clamp(3.5rem,8vw,6.5rem) clamp(3rem,6vw,5rem);position:relative;overflow:hidden}
.hero__grid{display:grid;grid-template-columns:1.35fr .65fr;gap:clamp(2rem,5vw,4rem);align-items:center}
.hero h1{margin-bottom:1.4rem}
.hero__lede{max-width:34ch}
.hero__actions{display:flex;flex-wrap:wrap;gap:1rem;align-items:center;margin-top:1.9rem}
.hero__mark{justify-self:center}
.hero__mark img{width:min(280px,80%);opacity:.96;filter:drop-shadow(0 8px 22px rgba(33,57,42,.12))}
.kicker{display:flex;flex-wrap:wrap;gap:.4rem 1.4rem;margin-top:2.4rem;padding-top:1.4rem;border-top:1px solid var(--line)}
.kicker span{font-size:.82rem;letter-spacing:.04em;color:var(--ink-soft)}
.kicker span::before{content:"—  ";color:var(--green)}

/* ---- editorial columns (replaces card grids) ------------------------------ */
.measure{max-width:68ch}
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(1.8rem,4vw,3.5rem)}
.split--7-5{grid-template-columns:1.4fr 1fr}
.split--5-7{grid-template-columns:1fr 1.4fr}

/* numbered / ruled list of offerings */
.ledger{border-top:1px solid var(--line-strong)}
.ledger__item{display:grid;grid-template-columns:auto 1fr;gap:1.2rem 1.6rem;padding-block:1.5rem;border-bottom:1px solid var(--line)}
.ledger__num{font-family:var(--display);font-size:1.4rem;color:var(--green);font-weight:560;font-variant-numeric:tabular-nums;line-height:1.2}
.ledger__item h3{margin-bottom:.35rem}
.ledger__item p{margin-bottom:0;color:var(--ink-soft)}

/* three editorial blocks, divider rules not boxes */
.triad{display:grid;grid-template-columns:repeat(3,1fr);gap:0}
.triad>div{padding:1.6rem clamp(1.1rem,2vw,1.9rem)}
.triad>div+div{border-left:1px solid var(--line)}
.triad h4{color:var(--green-deep);margin-bottom:.5rem}
.triad p{margin-bottom:0;font-size:.96rem;color:var(--ink-soft)}

/* pull / lever callouts */
.lever{border-left:3px solid var(--green);padding:.2rem 0 .2rem 1.4rem;margin-bottom:1.5rem}
.lever h4{font-family:var(--display);font-size:1.25rem;margin-bottom:.4rem}
.section--ink .lever{border-left-color:var(--brass)}

/* feature row with the headshot */
.bio{display:grid;grid-template-columns:1fr 320px;gap:clamp(1.8rem,4vw,3.5rem);align-items:center}
.bio__photo{border:1px solid var(--line-strong);padding:.55rem;background:var(--panel)}
.bio__photo img{filter:grayscale(18%) contrast(1.02)}

/* process as big numerals */
.steps{counter-reset:s;display:grid;gap:1.3rem;margin-top:1.5rem}
.steps li{list-style:none;display:grid;grid-template-columns:auto 1fr;gap:1.2rem;align-items:baseline}
.steps li::before{counter-increment:s;content:counter(s,decimal-leading-zero);font-family:var(--display);font-size:1.5rem;color:var(--brass);font-weight:560}

/* FAQ as definition list */
.qa{border-top:1px solid var(--line)}
.qa>div{padding-block:1.4rem;border-bottom:1px solid var(--line)}
.qa h4{font-family:var(--display);font-size:1.18rem;margin-bottom:.5rem}
.qa p{margin-bottom:0;color:var(--ink-soft)}

/* simple page masthead for inner pages */
.masthead{padding-block:clamp(2.6rem,5vw,4rem) clamp(1.6rem,3vw,2.4rem);border-bottom:1px solid var(--line)}
.crumbs{font-size:.8rem;letter-spacing:.04em;color:var(--ink-soft);margin-bottom:1rem}
.crumbs a{color:var(--green)}

/* call to action band */
.cta{background:var(--green-ink);color:#eee7d6}
.cta h2{color:#fff}
.cta .lede{color:#cfc7b4;max-width:48ch}
.cta__row{display:flex;flex-wrap:wrap;gap:1.4rem 2rem;align-items:center;justify-content:space-between}

/* prose article */
.prose p{max-width:68ch}
.prose h2{margin-top:2.4rem}
.prose h3{margin-top:1.8rem;margin-bottom:.6rem}
.prose ul{margin:0 0 1.2rem 1.1rem}
.prose ul li{list-style:square;margin-bottom:.5rem;padding-left:.3rem}
.prose ul li::marker{color:var(--green)}
.callout{background:var(--panel);border:1px solid var(--line-strong);padding:1.4rem 1.6rem;margin:1.8rem 0}
.callout p:last-child{margin-bottom:0}

/* forms */
.form{display:grid;gap:1.1rem}
.field label{display:block;font-size:.86rem;font-weight:600;letter-spacing:.02em;margin-bottom:.4rem;color:var(--ink)}
.field input,.field select,.field textarea{width:100%;font-family:var(--serif);font-size:1rem;padding:.7rem .8rem;background:var(--panel);border:1px solid var(--line-strong);border-radius:1px;color:var(--ink)}
.field textarea{min-height:140px;resize:vertical}
.field input:focus,.field select:focus,.field textarea:focus{outline:2px solid var(--green);outline-offset:1px;border-color:var(--green)}

/* footer */
.foot{background:#1b2c21;color:#c6cdc2;padding-block:clamp(2.6rem,5vw,4rem) 2rem}
.foot a{color:#dfe6db}
.foot a:hover{color:#fff}
.foot__grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:2rem}
.foot__brand{display:flex;align-items:center;gap:.7rem;margin-bottom:1rem}
.foot__brand img{width:34px;height:34px}
.foot__name{font-family:var(--display);font-size:1.15rem;color:#fff;font-weight:600}
.foot h5{font-family:var(--serif);font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;color:#9fb0a3;margin-bottom:.9rem;font-weight:600}
.foot ul li{list-style:none;margin-bottom:.55rem;font-size:.94rem}
.foot__bottom{display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;align-items:center;margin-top:2.4rem;padding-top:1.4rem;border-top:1px solid rgba(255,255,255,.12);font-size:.85rem}
.foot__disclaimer{font-size:.76rem;line-height:1.55;color:#8fa093;margin-top:1.2rem;max-width:92ch}

/* reveal */
.reveal{opacity:0;transform:translateY(14px);transition:opacity .7s ease,transform .7s ease}
.reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}}

/* ---- responsive ----------------------------------------------------------- */
@media (max-width:880px){
  .hero__grid{grid-template-columns:1fr}
  .hero__mark{display:none}
  .split,.split--7-5,.split--5-7,.bio{grid-template-columns:1fr}
  .bio{gap:1.6rem}.bio__photo{max-width:300px}
  .triad{grid-template-columns:1fr}
  .triad>div+div{border-left:0;border-top:1px solid var(--line)}
  .foot__grid{grid-template-columns:1fr 1fr}
}
@media (max-width:720px){
  .nav{position:fixed;inset:0 0 0 auto;width:min(80vw,320px);flex-direction:column;align-items:flex-start;gap:1.3rem;background:var(--paper);padding:5rem var(--gutter) 2rem;transform:translateX(100%);transition:transform .28s ease;box-shadow:-12px 0 40px rgba(0,0,0,.12)}
  .nav.open{transform:none}
  .nav__toggle{display:block;z-index:60}
  .foot__grid{grid-template-columns:1fr}
}
