/* =========================================================
   Dr. Meghan Walls — site styles  (Warm & Approachable theme)
   ========================================================= */
:root{
  --bg:#fbf3ec; --card:#ffffff; --ink:#33403f; --ink-soft:#5f6f6e;
  --teal:#2f9e9e; --teal-deep:#1f7d7d; --coral:#e8866b; --coral-deep:#d96a4d;
  --sand:#f3e7da; --line:#ecd9c9;
  --shadow:0 16px 34px -26px rgba(47,64,63,.4);
  --shadow-lg:0 26px 48px -28px rgba(47,158,158,.5);
  --maxw:1140px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--ink);font-family:'Nunito',system-ui,-apple-system,sans-serif;line-height:1.65;-webkit-font-smoothing:antialiased}
h1,h2,h3,h4,.disp{font-family:'Fraunces',Georgia,serif;font-weight:600;line-height:1.12}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 32px}
.kick{font-size:.8rem;letter-spacing:.12em;text-transform:uppercase;color:var(--teal-deep);font-weight:700}
.center{text-align:center}
.skip{position:absolute;left:-999px}.skip:focus{left:16px;top:10px;background:#fff;padding:8px 14px;border-radius:8px;z-index:100}

/* buttons */
.btn{display:inline-block;padding:14px 28px;border-radius:34px;font-weight:700;font-size:.98rem;cursor:pointer;border:none;transition:.2s}
.btn.solid{background:var(--teal);color:#fff}.btn.solid:hover{background:var(--teal-deep)}
.btn.coral{background:var(--coral);color:#fff}.btn.coral:hover{background:var(--coral-deep)}
.btn.ghost{background:#fff;border:2px solid var(--sand);color:var(--ink)}.btn.ghost:hover{border-color:var(--teal)}

/* nav */
header.nav{position:sticky;top:0;z-index:40;background:rgba(251,243,236,.92);backdrop-filter:blur(8px)}
.nav .wrap{display:flex;align-items:center;justify-content:space-between;height:78px}
.brand{font-family:'Fraunces';font-weight:600;font-size:1.35rem}
.brand b{color:var(--coral-deep)}
.navlinks{display:flex;gap:28px;list-style:none;font-size:.95rem;font-weight:600;align-items:center}
.navlinks a{color:var(--ink-soft)}
.navlinks a:hover,.navlinks a.active{color:var(--coral-deep)}
.btn-sm{background:var(--coral);color:#fff;padding:11px 20px;border-radius:30px;font-weight:700;font-size:.9rem}
.btn-sm:hover{background:var(--coral-deep)}
.navtoggle{display:none;background:none;border:none;cursor:pointer;font-size:1.5rem;color:var(--ink)}
@media(max-width:860px){
  .navtoggle{display:block}
  .navlinks{position:absolute;top:78px;left:0;right:0;background:var(--bg);flex-direction:column;gap:0;padding:8px 0;box-shadow:var(--shadow);max-height:0;overflow:hidden;transition:max-height .3s}
  .navlinks.open{max-height:520px}
  .navlinks li{width:100%}
  .navlinks a,.navlinks .btn-sm{display:block;padding:14px 32px;width:100%}
  .navlinks .btn-sm{background:none;color:var(--coral-deep)}
}

/* generic section */
section{padding:78px 0}
.head{text-align:center;max-width:680px;margin:0 auto 50px}
.head h2{font-size:clamp(2.1rem,4vw,3rem);margin-top:10px}
.head p{color:var(--ink-soft);font-size:1.1rem;margin-top:12px}

/* page hero (interior pages) */
.pagehero{padding:64px 0 10px;text-align:center}
.pagehero h1{font-size:clamp(2.6rem,5vw,3.8rem);margin-top:12px}
.pagehero p{color:var(--ink-soft);font-size:1.15rem;max-width:60ch;margin:16px auto 0}

/* home hero */
.hero{padding:60px 0 56px}
.hero .wrap{display:grid;grid-template-columns:1.05fr .95fr;gap:56px;align-items:center}
.hero h1{font-size:clamp(2.9rem,6vw,4.7rem);margin:16px 0 0}
.hero h1 em{font-style:italic;color:var(--coral-deep)}
.hero p.sub{font-size:1.15rem;color:var(--ink-soft);margin:22px 0 0;max-width:44ch}
.hero .cta{margin-top:30px;display:flex;gap:14px;flex-wrap:wrap}
.hero-photo{position:relative;display:flex;justify-content:center}
.hero-photo .blob{position:relative;width:100%;max-width:430px}
.hero-photo img{width:100%;border-radius:50% 50% 48% 52%/55% 55% 45% 45%;box-shadow:0 26px 50px -26px rgba(47,158,158,.5)}
.hero-photo .dot{position:absolute;width:118px;height:118px;border-radius:50%;background:var(--coral);opacity:.18;top:-18px;right:6px;z-index:-1}
.hero-photo .dot2{position:absolute;width:70px;height:70px;border-radius:50%;background:var(--teal);opacity:.2;bottom:10px;left:0;z-index:-1}
@media(max-width:880px){.hero .wrap{grid-template-columns:1fr;gap:36px}.hero-photo{order:-1}}

/* featured logos */
.featured{padding:30px 0 8px}
.featured .lab{text-align:center;color:var(--ink-soft);font-size:.82rem;letter-spacing:.14em;text-transform:uppercase;font-weight:700;margin-bottom:22px}
.logos{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:14px}
.logos .tile{background:#fff;border-radius:18px;height:74px;display:flex;align-items:center;justify-content:center;padding:0 24px;min-width:124px;box-shadow:0 10px 24px -18px rgba(47,64,63,.4)}
.logos img{max-height:36px;max-width:130px;object-fit:contain}

/* awards cards */
.awards{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.award{background:#fff;border-radius:24px;padding:34px 28px;text-align:center;box-shadow:var(--shadow)}
.award .ic{width:54px;height:54px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 16px;font-size:1.5rem}
.award:nth-child(3n+1) .ic{background:#fde7df;color:var(--coral-deep)}
.award:nth-child(3n+2) .ic{background:#d9f0f0;color:var(--teal-deep)}
.award:nth-child(3n+3) .ic{background:#f6ecd8;color:#b08642}
.award h3{font-size:1.4rem;margin-bottom:6px}
.award p{color:var(--ink-soft);font-size:.95rem}
@media(max-width:760px){.awards{grid-template-columns:1fr}}

/* about split */
.split{background:var(--sand)}
.split .wrap{display:grid;grid-template-columns:.9fr 1.1fr;gap:54px;align-items:center}
.split img{width:100%;border-radius:28px;box-shadow:var(--shadow)}
.split h2{font-size:clamp(2rem,3.6vw,2.7rem);margin:12px 0 16px}
.split p{color:var(--ink-soft);font-size:1.08rem;margin-bottom:14px}
.split.flip .wrap{grid-template-columns:1.1fr .9fr}
.split.flip img{order:2}
@media(max-width:820px){.split .wrap,.split.flip .wrap{grid-template-columns:1fr;gap:32px}.split.flip img{order:0}}

/* cards (writing) */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.card{background:#fff;border-radius:24px;overflow:hidden;transition:.25s;box-shadow:var(--shadow);display:flex;flex-direction:column}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg)}
.card .thumb{height:178px;overflow:hidden;background:var(--sand)}
.card .thumb img{width:100%;height:100%;object-fit:cover;object-position:top}
.card .body{padding:22px 24px 26px;flex:1;display:flex;flex-direction:column}
.card .outlet{color:var(--coral-deep);font-weight:700;font-size:.78rem;letter-spacing:.06em;text-transform:uppercase}
.card h3{font-size:1.25rem;margin-top:8px}
.card .meta{margin-top:auto;padding-top:14px;color:var(--ink-soft);font-size:.85rem}
@media(max-width:820px){.cards{grid-template-columns:1fr}}

/* tag pills */
.pilltags{display:flex;flex-wrap:wrap;gap:10px}
.pilltags span{background:#fff;border:1px solid var(--line);color:var(--ink);border-radius:30px;padding:9px 17px;font-size:.92rem;font-weight:600;box-shadow:var(--shadow)}

/* lists / timeline */
.panel{background:#fff;border-radius:24px;padding:38px 40px;box-shadow:var(--shadow)}
.panel + .panel{margin-top:26px}
.panel h3{font-size:1.5rem;margin-bottom:18px;color:var(--teal-deep)}
.tl{list-style:none}
.tl li{padding:16px 0;border-bottom:1px solid var(--line);display:grid;grid-template-columns:130px 1fr;gap:20px}
.tl li:last-child{border-bottom:none}
.tl .yr{color:var(--coral-deep);font-weight:700}
.tl .what b{display:block;font-weight:700}
.tl .what span{color:var(--ink-soft)}
@media(max-width:600px){.tl li{grid-template-columns:1fr;gap:4px}}
.bullets{list-style:none}
.bullets li{padding:13px 0 13px 30px;position:relative;border-bottom:1px solid var(--line)}
.bullets li:last-child{border-bottom:none}
.bullets li:before{content:"";position:absolute;left:0;top:21px;width:11px;height:11px;border-radius:50%;background:var(--teal)}
.pubs{list-style:none}
.pubs li{padding:16px 0;border-bottom:1px solid var(--line);color:var(--ink-soft)}
.pubs li:last-child{border-bottom:none}
.pubs b{color:var(--ink)}

/* two-column grid utility */
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:26px;align-items:start}
@media(max-width:820px){.grid2{grid-template-columns:1fr}}

/* gallery (media appearances) */
.gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.gallery figure{background:#fff;border-radius:20px;overflow:hidden;box-shadow:var(--shadow)}
.gallery img{width:100%;height:240px;object-fit:cover}
.gallery figcaption{padding:16px 20px;color:var(--ink-soft);font-size:.92rem}
@media(max-width:820px){.gallery{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.gallery{grid-template-columns:1fr}}

/* contact */
.contactgrid{display:grid;grid-template-columns:1fr 1fr;gap:46px;align-items:start}
@media(max-width:820px){.contactgrid{grid-template-columns:1fr}}
.field{margin-bottom:18px}
.field label{display:block;font-weight:700;margin-bottom:6px;font-size:.95rem}
.field input,.field textarea{width:100%;padding:13px 16px;border:1.5px solid var(--line);border-radius:14px;font:inherit;background:#fff;color:var(--ink)}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--teal)}
.contactcard{background:#fff;border-radius:24px;padding:34px;box-shadow:var(--shadow)}
.contactcard a{color:var(--teal-deep);font-weight:700}
.contactcard .row{padding:14px 0;border-bottom:1px solid var(--line)}
.contactcard .row:last-child{border-bottom:none}

/* footer */
footer.site{background:var(--teal-deep);color:#dff0f0;padding:70px 0 36px;border-radius:48px 48px 0 0;margin-top:40px}
footer.site .wrap{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px;align-items:start}
footer.site h2{color:#fff;font-size:2rem}
footer.site p{margin-top:12px;max-width:36ch;color:#bfe2e2}
footer.site h4{color:#fff;font-size:1rem;margin-bottom:14px;letter-spacing:.04em}
footer.site ul{list-style:none;display:flex;flex-direction:column;gap:10px;font-weight:600}
footer.site a:hover{color:#ffd9cb}
.copy{border-top:1px solid #38a0a0;margin-top:44px;padding-top:22px;text-align:center;font-size:.85rem;color:#a9d8d8}
@media(max-width:760px){footer.site .wrap{grid-template-columns:1fr;gap:30px}}
