/* ================================================================
   adamabbs.com — shared stylesheet
   Design tokens inherited from doctorabbs.com.
   Fonts: copy assets/fonts/* from doctorabbs.com/assets/fonts/
   ================================================================ */

@font-face{font-family:'Fraunces';src:url('fonts/fraunces-variable.woff2') format('woff2');font-weight:100 900;font-style:normal;font-display:swap}
@font-face{font-family:'Hanken Grotesk';src:url('fonts/hanken-grotesk-variable.woff2') format('woff2');font-weight:100 900;font-style:normal;font-display:swap}

:root{
  --ink:       #0F4C81;
  --ink-deep:  #0a3a64;
  --paper:     #fbfaf7;
  --card:      #ffffff;
  --text:      #28323d;
  --muted:     #5f6c79;
  --line:      #e8e3d9;
  --line-blue: #d4e0ea;
  --maxw:      1080px;
  --r:         16px;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{background:var(--paper);color:var(--text);font-family:'Hanken Grotesk',-apple-system,system-ui,sans-serif;font-size:18px;line-height:1.65;-webkit-font-smoothing:antialiased}
img{display:block;max-width:100%;height:auto}
a{color:var(--ink)}

/* Skip link */
.skip{position:absolute;left:8px;top:-52px;z-index:200;background:#fff;color:var(--ink-deep);padding:8px 14px;border-radius:6px;font-weight:600;transition:top .15s}
.skip:focus{top:8px;outline:3px solid var(--ink)}

/* Layout */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px}
.wrap--narrow{max-width:980px;margin:0 auto;padding:0 28px}

/* Typography */
h1,h2,h3{font-family:'Fraunces',Georgia,serif;color:var(--ink);font-weight:500;line-height:1.08;letter-spacing:-.01em}
.eyebrow{font-size:.74rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);font-weight:600;display:block;margin-bottom:.5em}
.rule{display:flex;align-items:center;gap:14px;margin:40px 0 0;color:var(--line-blue)}
.rule .l{height:1px;background:var(--line);flex:1}
.rule .dot{width:11px;height:11px;border:2px solid var(--ink);border-radius:50%;flex:0 0 auto}

/* ── HEADER ───────────────────────────── */
header.top{position:sticky;top:0;z-index:10;background:rgba(251,250,247,.88);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.top .wrap{display:flex;align-items:center;justify-content:space-between;height:64px}
.top .logo{display:flex;align-items:center;gap:10px;font-family:'Fraunces',Georgia,serif;font-weight:600;font-size:1.15rem;color:var(--ink);text-decoration:none;letter-spacing:-.01em}
.top .logo svg{display:block;flex-shrink:0}
.top nav a{font-size:.88rem;font-weight:500;color:var(--muted);text-decoration:none;margin-left:28px;transition:color .15s}
.top nav a:hover{color:var(--ink)}

/* ── HERO ─────────────────────────────── */
.hero{padding:clamp(40px,6vw,80px) 0 clamp(36px,5vw,56px);position:relative;overflow:hidden}
.hero::before{content:'';position:absolute;inset:0;pointer-events:none;background:radial-gradient(120% 90% at 90% -10%,rgba(15,76,129,.08),transparent 55%),radial-gradient(80% 70% at -5% 0%,rgba(15,76,129,.04),transparent 60%)}
.hero .wrap{position:relative}
.hero-grid{display:grid;grid-template-columns:1fr 320px;gap:clamp(40px,6vw,80px);align-items:center}
.hero h1{font-size:clamp(2.1rem,5.2vw,3.8rem);margin:.4em 0 .45em;max-width:640px}
.hero h1 em{font-style:italic;color:var(--ink-deep)}
.hero .stand{font-size:clamp(.98rem,2vw,1.18rem);color:var(--muted);max-width:540px;line-height:1.72}
.hero-portrait{border-radius:20px;overflow:hidden;border:1px solid var(--line);box-shadow:0 20px 60px -20px rgba(15,76,129,.18)}
.hero-portrait img{width:100%}

/* ── SECTIONS ─────────────────────────── */
section{padding:clamp(36px,5vw,64px) 0}
.sec-head{max-width:860px;margin-bottom:32px}
.sec-head h2{font-size:clamp(1.7rem,3.2vw,2.5rem);margin:.3em 0 .4em}
.sec-head p{color:var(--muted)}

/* ── CREDENTIALS ──────────────────────── */
.creds-section{background:var(--card);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.quals{font-family:'Fraunces',Georgia,serif;font-size:clamp(1.1rem,2.2vw,1.45rem);color:var(--ink);font-weight:500;letter-spacing:.06em;margin-bottom:28px}
.quals span{margin-right:.7em}
.reg-list{list-style:none;display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-bottom:28px}
.reg-item{background:var(--paper);border:1px solid var(--line);border-radius:12px;padding:16px 20px;display:flex;align-items:center;gap:14px}
.reg-body{flex:1;min-width:0}
.reg-name{font-weight:600;font-size:.9rem;color:var(--text);margin-bottom:2px}
.reg-label{font-size:.8rem;color:var(--muted)}
.verify{font-size:.78rem;color:var(--ink);text-decoration:none;white-space:nowrap;font-weight:600}
.verify:hover{text-decoration:underline}
.memberships{display:flex;flex-wrap:wrap;gap:20px;align-items:center;padding-top:4px}
.mbr-item{display:flex;align-items:center;gap:8px;font-size:.88rem;font-weight:600;color:var(--text)}
.mbr-item img{height:38px;width:auto}
.mbr-dot{width:5px;height:5px;background:var(--line-blue);border-radius:50%;flex-shrink:0}

/* ── CARDS ────────────────────────────── */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.cards-2col{grid-template-columns:repeat(2,1fr)}
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:28px 26px 24px;transition:transform .22s ease,box-shadow .22s ease,border-color .22s ease;display:flex;flex-direction:column}
.card:hover{transform:translateY(-3px);box-shadow:0 16px 40px -20px rgba(15,76,129,.3);border-color:var(--line-blue)}
.card .tag{font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ink);font-weight:600;margin-bottom:12px}
.card h3{font-size:1.35rem;margin-bottom:8px}
.card p{margin:0 0 18px;color:var(--text);font-size:.96rem;flex:1}
.card .go{font-weight:600;font-size:.88rem;text-decoration:none;border-bottom:1px solid var(--line-blue);padding-bottom:2px;align-self:flex-start;transition:border-color .15s;color:var(--ink)}
.card .go:hover{border-color:var(--ink)}

/* ── DARK BAND ────────────────────────── */
.band{background:var(--ink);color:#eaf2f8}
.band h2,.band .eyebrow{color:#fff}
.band .eyebrow{color:#9ec3df}
.band p{color:#bcd4e6}

/* ── ABOUT GRID ───────────────────────── */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,4vw,60px);align-items:start}
.about-grid p{margin-bottom:1em;color:var(--text)}
.about-grid p:last-child{margin-bottom:0}

/* ── WRITING PAGE ─────────────────────── */
.pub-card{background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:32px;margin-bottom:24px;display:grid;grid-template-columns:1fr auto;gap:28px;align-items:start}
.pub-card h3{font-size:1.4rem;margin-bottom:6px}
.pub-card .byline{font-size:.86rem;color:var(--muted);margin-bottom:14px}
.pub-card p{color:var(--text);font-size:.97rem;line-height:1.7}
.pub-card .cta{margin-top:18px}
.pub-card .cta a{display:inline-block;background:var(--ink);color:#fff;padding:10px 22px;border-radius:8px;text-decoration:none;font-size:.86rem;font-weight:600}
.pub-card .cta a:hover{background:var(--ink-deep)}
.pub-badge{background:var(--paper);border:1px solid var(--line);border-radius:10px;padding:14px 18px;text-align:center;font-size:.82rem;color:var(--muted);white-space:nowrap;min-width:120px}
.pub-badge strong{display:block;color:var(--ink);font-size:.92rem;margin-bottom:4px}

/* ── APPROACH PAGE ────────────────────── */
.essay-body{font-size:1.04rem;line-height:1.8}
.essay-body p{margin-bottom:1.2em}
.essay-body h2{font-size:clamp(1.5rem,3vw,2rem);margin:2em 0 .4em}
.essay-body h3{font-size:1.2rem;margin:1.6em 0 .3em}
.essay-body strong{color:var(--ink)}

.pillar-nav{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:52px}
.pillar-card{background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:24px 22px;text-decoration:none;color:var(--text);transition:border-color .2s,transform .2s,box-shadow .2s;display:block}
.pillar-card:hover{border-color:var(--line-blue);transform:translateY(-3px);box-shadow:0 12px 32px -16px rgba(15,76,129,.25)}
.pillar-card .num{font-family:'Fraunces',serif;font-size:2.2rem;color:var(--line-blue);font-weight:600;display:block;margin-bottom:8px;line-height:1}
.pillar-card h3{font-size:1rem;color:var(--ink);margin-bottom:6px}
.pillar-card p{font-size:.86rem;color:var(--muted);line-height:1.5}

/* ── PILLAR PAGES ─────────────────────── */
.breadcrumb{font-size:.84rem;color:var(--muted);margin-bottom:32px}
.breadcrumb a{color:var(--ink);text-decoration:none}
.breadcrumb a:hover{text-decoration:underline}
.breadcrumb span{margin:0 .4em}
.pillar-num-label{font-family:'Fraunces',serif;font-size:.88rem;letter-spacing:.22em;text-transform:uppercase;color:var(--muted);display:block;margin-bottom:.3em}
.pillar-image-block{margin:48px 0;background:var(--card);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;text-align:center;padding:24px}
.pillar-image-block img{max-width:100%;height:auto;display:block;margin:0 auto;max-height:700px;object-fit:contain}
.pillar-image-cap{font-size:.8rem;color:var(--muted);padding-top:14px;border-top:1px solid var(--line);margin-top:18px}
.pillar-pager{display:flex;justify-content:space-between;align-items:center;margin-top:64px;padding-top:28px;border-top:1px solid var(--line);gap:16px;flex-wrap:wrap}
.pillar-pager a{color:var(--ink);text-decoration:none;font-weight:600;font-size:.88rem}
.pillar-pager a:hover{text-decoration:underline}
.pillar-pager .centre{color:var(--muted);font-size:.82rem;text-align:center}

/* ── LILY PAGE ────────────────────────── */
.lily-intro{font-size:1.06rem;line-height:1.78;margin-bottom:48px}
.lily-intro p{margin-bottom:1em}
.lily-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin:8px 0 40px}
.lily-photo{border-radius:14px;overflow:hidden;border:1px solid var(--line)}
.lily-photo img{width:100%;height:360px;object-fit:cover;object-position:center top}

/* ── FOOTER ───────────────────────────── */
footer{border-top:1px solid var(--line);padding:48px 0 60px}
.fgrid{display:flex;justify-content:space-between;align-items:flex-start;gap:32px;flex-wrap:wrap;margin-bottom:28px}
.flogo{font-family:'Fraunces',Georgia,serif;font-weight:600;font-size:1.1rem;color:var(--ink);text-decoration:none;display:block;margin-bottom:12px}
.fnav{display:flex;gap:24px;flex-wrap:wrap}
.fnav a{color:var(--muted);text-decoration:none;font-size:.9rem;font-weight:500}
.fnav a:hover{color:var(--ink)}
.fext a{color:var(--ink);text-decoration:none;font-weight:700;font-size:.92rem}
.ident{color:var(--muted);font-size:.82rem;line-height:1.7;margin-bottom:6px}
.ident a{color:inherit}
.discrete{font-size:.8rem;color:var(--muted);margin-bottom:4px}
.discrete a{color:var(--muted);text-decoration:none}
.discrete a:hover{color:var(--ink)}
.legal-links{margin-top:14px;font-size:.83rem}
.legal-links a{color:var(--muted);text-decoration:none;margin-right:12px}
.legal-links a:hover{color:var(--ink)}

/* ── KEY MESSAGES BOX ─────────────────── */
.key-messages{background:rgba(212,224,234,.25);border-left:3px solid var(--ink);border-radius:0 12px 12px 0;padding:22px 26px;margin:28px 0}
.key-messages-label{font-size:.76rem;letter-spacing:.18em;text-transform:uppercase;color:var(--ink);font-weight:700;display:block;margin-bottom:14px}
.key-messages ul{list-style:none;padding:0;margin:0}
.key-messages li{font-size:.97rem;line-height:1.68;padding-left:22px;position:relative;margin-bottom:.75em;color:var(--text)}
.key-messages li:last-child{margin-bottom:0}
.key-messages li::before{content:'';position:absolute;left:0;top:.62em;width:8px;height:8px;background:var(--ink);border-radius:50%}

/* ── ARTICLE META / WORKING PAPER ─────── */
.art-meta{font-size:.88rem;color:var(--muted);margin:6px 0 20px}
.working-paper-badge{display:inline-block;background:var(--paper);border:1px solid var(--line);border-radius:6px;padding:5px 14px;font-size:.78rem;color:var(--muted);margin-bottom:24px;font-weight:500}

/* ── REFERENCES ───────────────────────── */
.refs{margin-top:56px;padding-top:28px;border-top:1px solid var(--line)}
.refs-label{font-size:.76rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);font-weight:600;display:block;margin-bottom:16px}
.refs ol{padding-left:22px;margin:0}
.refs li{font-size:.8rem;color:var(--muted);line-height:1.65;margin-bottom:.55em}
.competing{margin-top:20px;padding-top:18px;border-top:1px solid var(--line);font-size:.83rem;color:var(--muted);font-style:italic}


/* ── HOME PILLARS BAND ────────────────── */
.home-pillars{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:8px}
.home-pillar{background:var(--card);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;display:flex;flex-direction:column;text-decoration:none;color:var(--text);transition:transform .2s,box-shadow .2s,border-color .2s}
.home-pillar:hover{transform:translateY(-3px);box-shadow:0 16px 40px -20px rgba(15,76,129,.3);border-color:var(--line-blue)}
.home-pillar-img{background:var(--paper);border-bottom:1px solid var(--line);padding:14px;aspect-ratio:4/3;display:flex;align-items:center;justify-content:center}
.home-pillar-img img{width:100%;height:100%;object-fit:contain}
.home-pillar-body{padding:20px 22px 22px;display:flex;flex-direction:column;flex:1}
.home-pillar-num{font-family:'Fraunces',serif;font-size:1.8rem;color:var(--line-blue);font-weight:600;line-height:1;margin-bottom:8px}
.home-pillar-body h3{font-size:1.1rem;margin-bottom:8px;line-height:1.2}
.home-pillar-body p{font-size:.9rem;color:var(--muted);line-height:1.6;margin:0 0 16px;flex:1}
.home-pillar-body .go{font-weight:600;font-size:.84rem;color:var(--ink);text-decoration:none;border-bottom:1px solid var(--line-blue);padding-bottom:2px;align-self:flex-start}
.home-pillar-body .go:hover{border-color:var(--ink)}
@media(max-width:760px){.home-pillars{grid-template-columns:1fr;gap:14px}.home-pillar{flex-direction:row}.home-pillar-img{width:38%;aspect-ratio:auto;border-bottom:none;border-right:1px solid var(--line);flex-shrink:0}.home-pillar-body{padding:16px 18px}}
@media(max-width:440px){.home-pillar{flex-direction:column}.home-pillar-img{width:100%;aspect-ratio:16/10;border-right:none;border-bottom:1px solid var(--line)}}

/* ── SPECIALISMS ──────────────────────── */
.specialisms{display:flex;flex-wrap:wrap;gap:10px;margin-top:8px}
.specialism{background:var(--card);border:1px solid var(--line);border-radius:999px;padding:9px 18px;font-size:.9rem;font-weight:500;color:var(--text)}

/* ── ANIMATIONS ───────────────────────── */
@keyframes up{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}
.anim{opacity:0;animation:up .65s cubic-bezier(.2,.7,.2,1) forwards}
.d1{animation-delay:.04s}.d2{animation-delay:.14s}.d3{animation-delay:.24s}.d4{animation-delay:.34s}
@media(prefers-reduced-motion:reduce){.anim{animation:none;opacity:1}}

/* ── RESPONSIVE ───────────────────────── */
@media(max-width:900px){
  .hero-grid{grid-template-columns:1fr;gap:28px}
  .hero-portrait{max-width:260px}
  .reg-list{grid-template-columns:1fr}
  .cards{grid-template-columns:1fr}
  .cards-2col{grid-template-columns:1fr}
  .about-grid{grid-template-columns:1fr;gap:0}
  .pub-card{grid-template-columns:1fr}
  .pub-badge{display:none}
  .pillar-nav{grid-template-columns:1fr}
  .lily-grid{grid-template-columns:1fr}
  .lily-photo img{height:auto;max-height:420px}
}
@media(max-width:600px){
  body{font-size:17px}
  .wrap,.wrap--narrow{padding:0 18px}
  .top .wrap{height:56px}
  .top .logo{font-size:1.02rem;gap:8px}
  .top nav a{margin-left:16px;font-size:.82rem}
  .hero{padding:32px 0 28px}
  .hero h1{font-size:clamp(1.7rem,7vw,2.3rem)}
  .hero-portrait{max-width:200px;margin:0 auto}
  .hero-grid{text-align:left}
  section{padding:32px 0}
  .sec-head{margin-bottom:24px}
  .quals{font-size:1.05rem;line-height:1.8}
  .quals span{display:inline-block;margin-right:.6em}
  .reg-item{padding:14px 16px;gap:12px}
  .verify{font-size:.74rem}
  .memberships{gap:10px;flex-direction:column;align-items:flex-start}
  .mbr-dot{display:none}
  .fgrid{flex-direction:column;gap:20px}
  .essay-body h2{font-size:1.4rem}
  .refs li{font-size:.78rem}
  .pillar-image-block{padding:12px}
  .pillar-pager{flex-direction:column;align-items:flex-start;gap:10px}
  .pillar-pager .centre{order:3}
  .key-messages{padding:18px 18px}
  .working-paper-badge{font-size:.72rem}
}
