/* =================================================================
   Adaira Landry, MD MEd — site design system
   Type:  Newsreader (serif display) + Hanken Grotesk (humanist sans)
   Color: Dark Vanilla cream · olive/camouflage green · Boy Red brown
   ================================================================= */
:root{
  --paper:#F6F0DC; --paper-2:#EFE7CD; --paper-3:#E2D8BA; /* warm ivory (muted, bridges wood + olive) */
  --card:#FBF6E6;                                        /* lifted card surface */
  --ink:#202a14; --ink-2:#6e6448;                        /* forest-green ink · walnut */
  --green:#525c3b; --green-deep:#1C290D; --green-soft:#7d8061; /* olive · deep forest · soft olive */
  --brown:#736046; --brown-deep:#381D03;                 /* walnut · dark walnut */
  --tan:#A19379; --tan-soft:#b9b89c;                     /* taupe · sage */
  --line:rgba(40,45,20,.15);
  --line-2:rgba(40,45,20,.08);
  --shadow:0 1px 2px rgba(28,41,13,.06),0 12px 32px rgba(28,41,13,.08);
  --shadow-sm:0 1px 3px rgba(28,41,13,.09);
  --maxw:1200px;
  --r:14px;
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;scroll-padding-top:88px;}
body{margin:0;background:var(--paper);color:var(--ink);
  font-family:'Hanken Grotesk',system-ui,-apple-system,sans-serif;
  font-size:17px;line-height:1.6;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
.serif{font-family:'Newsreader',Georgia,serif;font-weight:500;}
em{font-style:italic;}
h1,h2,h3,h4{font-family:'Newsreader',Georgia,serif;font-weight:500;letter-spacing:-.012em;line-height:1.08;margin:0;}
p{margin:0;}
::selection{background:var(--green-soft);color:#fff;}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 40px;}
.section{padding:96px 0;}
.eyebrow{font-size:12.5px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--green);margin:0 0 18px;}
.eyebrow.muted{color:var(--ink-2);}
.lead{font-size:20px;line-height:1.55;color:var(--ink-2);}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:.55em;font:600 15.5px/1 'Hanken Grotesk',sans-serif;
  padding:15px 26px;border-radius:999px;border:1px solid transparent;cursor:pointer;white-space:nowrap;
  box-shadow:0 4px 12px rgba(0,0,0,.12);
  transition:transform .16s ease,background .18s,color .18s,box-shadow .18s;}
.btn:active{transform:translateY(1px);}
.btn-primary{background:var(--green);color:#f4efe1;}
.btn-primary:hover{background:var(--green-deep);box-shadow:0 8px 22px rgba(58,66,48,.28);}
.btn-ghost{background:transparent;color:var(--green);border-color:var(--line);}
.btn-ghost:hover{border-color:var(--green);color:var(--green);}
.btn-light{background:#f4efe1;color:var(--green-deep);}
.btn-light:hover{background:#fff;box-shadow:0 8px 22px rgba(0,0,0,.14);}
.btn-lg{padding:18px 32px;font-size:16.5px;box-shadow:0 7px 20px rgba(0,0,0,.18);}
.btn-lg:hover{box-shadow:0 12px 28px rgba(0,0,0,.24);}
.arrow{transition:transform .16s ease;}
.btn:hover .arrow{transform:translateX(3px);}

.tlink{font-weight:600;color:var(--green);display:inline-flex;align-items:center;gap:.4em;}
.tlink .arrow{transition:transform .16s ease;}
.tlink:hover .arrow{transform:translateX(4px);}

/* ---------- nav ---------- */
.nav{position:sticky;top:0;z-index:50;background:rgba(28,41,13,.86);backdrop-filter:blur(12px);
  border-bottom:1px solid rgba(255,255,255,.1);}
.nav-inner{max-width:var(--maxw);margin:0 auto;padding:16px 40px;display:flex;align-items:center;justify-content:space-between;gap:24px;}
.brand{display:flex;align-items:flex-end;gap:9px;white-space:nowrap;}
.brand-name{font-family:'Newsreader',serif;font-size:34px;font-weight:600;letter-spacing:.01em;line-height:1;display:flex;align-items:baseline;gap:9px;padding-bottom:4px;color:#f4efe1;position:relative;top:4px;}
.brand-mark{height:48px;width:auto;display:block;transform-origin:50% 88%;
  filter:brightness(0) invert(1);opacity:.92;
  animation:willowSway 6.5s ease-in-out infinite alternate;}
@keyframes willowSway{
  0%{transform:rotate(-1.1deg) skewX(1.2deg);}
  100%{transform:rotate(1.1deg) skewX(-1.2deg);}
}
@media (prefers-reduced-motion:reduce){.brand-mark,.willow-bg{animation:none !important;}}
.willow-bg{position:absolute;z-index:0;pointer-events:none;transform-origin:50% 90%;
  animation:willowSway 8.5s ease-in-out infinite alternate;}
.brand .cred{font-size:15px;color:#b9b89c;font-family:'Hanken Grotesk',sans-serif;font-weight:500;letter-spacing:.04em;}
.nav-links{display:flex;align-items:center;gap:30px;}
.nav-links a{font-size:15px;font-weight:500;color:rgba(244,239,225,.82);transition:color .15s;position:relative;white-space:nowrap;}
.nav-links a:hover,.nav-links a[aria-current]{color:#fff;}
.nav-links a[aria-current]::after{content:"";position:absolute;left:0;right:0;bottom:-6px;height:2px;background:var(--tan-soft);border-radius:2px;}
.nav-links a.nav-cta{margin-left:6px;background:var(--tan);color:var(--green-deep);font-weight:600;box-shadow:0 5px 14px rgba(0,0,0,.28);}
.nav-links a.nav-cta:hover{background:var(--tan-soft);color:var(--green-deep);box-shadow:0 9px 22px rgba(0,0,0,.34);}
.nav-burger{display:none;background:none;border:none;cursor:pointer;padding:8px;color:#f4efe1;}
.nav-burger svg{display:block;}

/* ---------- footer ---------- */
.footer{background:var(--green-deep);color:#d9d6c4;padding:72px 0 40px;position:relative;overflow:hidden;}
.footer .wrap{position:relative;z-index:1;}
.footer-top{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:48px;padding-bottom:48px;border-bottom:1px solid rgba(255,255,255,.12);}
.footer h3{color:#f3efe1;font-size:30px;margin-bottom:14px;}
.footer-col h4{font-family:'Hanken Grotesk',sans-serif;font-size:12.5px;letter-spacing:.16em;text-transform:uppercase;color:#a9a890;margin:0 0 16px;font-weight:600;}
.footer-col a{display:block;color:#d9d6c4;margin-bottom:11px;font-size:15.5px;transition:color .15s;}
.footer-col a:hover{color:#fff;}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px;padding-top:32px;font-size:13.5px;color:#9b9a82;}
.socials{display:flex;gap:14px;}
.socials a{width:38px;height:38px;border-radius:50%;border:1px solid rgba(255,255,255,.18);display:flex;align-items:center;justify-content:center;color:#d9d6c4;transition:.16s;}
.socials a:hover{background:#fff;color:var(--green-deep);border-color:#fff;transform:translateY(-2px);}

/* ---------- placeholders (image slots) ---------- */
.slot{position:relative;display:flex;align-items:center;justify-content:center;overflow:hidden;border-radius:var(--r);
  background:repeating-linear-gradient(45deg,#d8d0b6,#d8d0b6 8px,#e0d9c1 8px,#e0d9c1 16px);}
.slot span{font-family:ui-monospace,Menlo,monospace;font-size:11px;letter-spacing:.06em;text-transform:uppercase;
  color:var(--green);background:rgba(243,238,224,.86);padding:5px 10px;border-radius:4px;}
.slot.on-green{background:repeating-linear-gradient(45deg,#5a6149,#5a6149 8px,#525a41 8px,#525a41 16px);}
.slot.on-green span{color:#eef0e0;background:rgba(58,66,48,.6);}
.slot.on-brown{background:repeating-linear-gradient(45deg,#766e5b,#766e5b 8px,#6c6450 8px,#6c6450 16px);}
.slot.on-brown span{color:#f1ece0;background:rgba(79,75,59,.55);}

/* ---------- marquee ---------- */
.marquee{overflow:hidden;width:100%;
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent);
  mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent);}
.marquee-track{display:flex;width:max-content;animation:scroll 40s linear infinite;}
.marquee:hover .marquee-track{animation-play-state:paused;}
.marquee-track>span{margin-right:52px;font-family:'Newsreader',serif;font-size:22px;font-weight:600;color:var(--ink-2);opacity:.62;white-space:nowrap;}
@keyframes scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@media (prefers-reduced-motion:reduce){.marquee-track{animation:none;}}

/* ---------- willow background motif ---------- */
.willow{position:absolute;pointer-events:none;z-index:0;}
.willow svg{display:block;}

/* ---------- reveal-on-scroll ---------- */
.reveal{opacity:0;transform:translateY(18px);transition:opacity .7s ease,transform .7s cubic-bezier(.2,.7,.3,1);}
.reveal.in{opacity:1;transform:none;}

/* ---------- generic cards / chips ---------- */
.chip{display:inline-flex;align-items:center;gap:.5em;padding:7px 14px;border-radius:999px;border:1px solid var(--line);
  font-size:13.5px;font-weight:500;color:var(--ink-2);background:var(--card);}
.divider{height:1px;background:var(--line);border:0;margin:0;}

/* =================================================================
   simple inquiry forms (coaching · writing/quote)
   ================================================================= */
.inq{background:var(--green-deep);color:#e7e4d4;position:relative;overflow:hidden;}
.inq .wrap{position:relative;z-index:1;max-width:780px;}
.inq .eyebrow{color:var(--tan-soft);}
.inq h2{color:#f3efe1;font-size:clamp(28px,3.8vw,46px);line-height:1.05;margin:0 0 14px;}
.inq h2 em{font-style:normal;color:var(--tan-soft);}
.inq .isub{color:#cdc9b6;font-size:17.5px;line-height:1.55;margin:0 0 34px;max-width:54ch;}
.inq .italk{display:inline-flex;align-items:center;gap:8px;margin-top:8px;color:#f3efe1;font-weight:600;
  font-size:15px;border-bottom:1px solid rgba(255,255,255,.32);padding-bottom:3px;transition:border-color .15s;}
.inq .italk:hover{border-color:#f3efe1;}

.iform .frow{display:grid;grid-template-columns:1fr 1fr;gap:0 22px;}
.iform .f{margin-bottom:20px;}
.iform .ffull{grid-column:1 / -1;}
.iform label{display:block;font-size:12px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;
  color:#aaa792;margin-bottom:9px;}
.iform label .opt{text-transform:none;letter-spacing:0;font-weight:500;opacity:.6;}
.iform input,.iform textarea{width:100%;background:rgba(0,0,0,.2);border:1px solid rgba(255,255,255,.15);
  border-radius:9px;padding:13px 15px;color:#f1ede0;font:500 15.5px/1.5 'Hanken Grotesk',sans-serif;
  transition:border-color .15s,box-shadow .15s;resize:vertical;}
.iform input::placeholder,.iform textarea::placeholder{color:#827f6c;}
.iform input:focus,.iform textarea:focus{outline:none;border-color:var(--tan-soft);
  box-shadow:0 0 0 3px rgba(205,196,163,.18);}
.iform .seg{display:flex;flex-wrap:wrap;gap:8px;}
.iform .segbtn{border:1px solid rgba(255,255,255,.18);background:transparent;color:#cdc9b6;border-radius:8px;
  padding:10px 18px;font:500 14.5px 'Hanken Grotesk',sans-serif;cursor:pointer;transition:.15s;}
.iform .segbtn:hover{border-color:rgba(255,255,255,.42);}
.iform .segbtn.is-sel{background:var(--tan-soft);border-color:var(--tan-soft);color:var(--green-deep);font-weight:600;}
.iform .submit-row{margin-top:28px;display:flex;align-items:center;gap:18px;flex-wrap:wrap;}
.iform .inq-note{font-size:14.5px;color:var(--tan-soft);opacity:0;transition:opacity .3s;}
.iform .inq-note.show{opacity:1;}
.inq-done{text-align:center;padding:22px 8px 10px;max-width:560px;margin:0 auto;}
.inq-check{width:60px;height:60px;border-radius:50%;background:var(--tan-soft);display:flex;align-items:center;
  justify-content:center;margin:0 auto 22px;}
.inq-done h3{color:#f3efe1;font-size:30px;margin:0 0 12px;}
.inq-done p{color:#cdc9b6;font-size:17px;max-width:42ch;margin:0 auto;line-height:1.55;}
@media (max-width:680px){ .iform .frow{grid-template-columns:1fr;} }

/* =================================================================
   responsive
   ================================================================= */
@media (max-width:900px){
  .nav-links{position:fixed;inset:0 0 auto 0;top:0;flex-direction:column;align-items:flex-start;gap:4px;
    background:var(--green-deep);padding:88px 32px 32px;transform:translateY(-100%);transition:transform .3s ease;
    box-shadow:var(--shadow);height:auto;}
  .nav-links.open{transform:translateY(0);}
  .nav-links a{font-size:20px;padding:10px 0;font-family:'Newsreader',serif;}
  .nav-links .nav-cta{margin-top:14px;}
  .nav-burger{display:block;z-index:60;}
  .footer-top{grid-template-columns:1fr;gap:32px;}
  .wrap{padding:0 24px;}
  .section{padding:64px 0;}
}
@media (max-width:480px){
  .wrap{padding:0 18px;}
  .section{padding:48px 0;}
  .nav-inner{padding:14px 18px;}
  .footer-bottom{flex-direction:column;text-align:center;gap:10px;}
}
