/*
Theme Name: HENGAM
Theme URI: https://hengamlaw.com
Author: HENGAM
Description: Boutique IP & litigation firm — custom theme. Design lives in code; content is managed in WordPress. Articles automatically get the firm's layout, an auto-generated contents sidebar, author box, and related insights.
Version: 1.0.0
License: UNLICENSED
Text Domain: hengam
*/

:root{
  --navy:#15293D;--mist:#EEF2F6;--white:#FFFFFF;--slate:#3D4A42;--brass:#C2A062;
  --serif:'Cormorant Garamond',Georgia,serif;--sans:'Inter',system-ui,sans-serif;--maxw:1200px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--sans);font-size:16.5px;color:var(--slate);background:var(--white);line-height:1.7;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
a{text-decoration:none;color:inherit}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 40px}
.eyebrow{font-size:12px;letter-spacing:.15em;text-transform:uppercase;color:var(--brass);font-weight:500}

/* Header */
header{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.92);backdrop-filter:blur(8px);border-bottom:1px solid var(--mist)}
.nav{display:flex;align-items:center;justify-content:space-between;height:78px}
.logo{font-family:var(--serif);font-size:30px;font-weight:600;letter-spacing:.22em;color:var(--navy)}
.nav-links{display:flex;align-items:center;gap:42px}
.nav-links a{font-size:12.5px;text-transform:uppercase;letter-spacing:.15em;color:var(--navy);font-weight:500;transition:color .2s}
.nav-links a:hover,.nav-links a.on{color:var(--brass)}
.nav-cta{font-size:12px!important;text-transform:uppercase;letter-spacing:.13em;border:1px solid var(--navy);padding:10px 20px;border-radius:2px;transition:all .2s}
.nav-cta:hover,.nav-cta.on{background:var(--navy);color:var(--white)!important}
.nav-toggle{display:none;background:none;border:none;cursor:pointer;flex-direction:column;gap:5px;padding:6px;z-index:60}
.nav-toggle span{display:block;width:24px;height:2px;background:var(--navy);transition:.25s}
.nav-toggle.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-toggle.open span:nth-child(2){opacity:0}
.nav-toggle.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* Buttons */
.btn-primary{background:var(--brass);color:var(--navy);font-weight:600;font-size:14px;letter-spacing:.02em;padding:15px 30px;border-radius:2px;transition:transform .2s,opacity .2s;display:inline-block}
.btn-primary:hover{opacity:.92;transform:translateY(-1px)}
.btn-ghost{color:#fff;font-size:14px;font-weight:500;border-bottom:1px solid rgba(194,160,98,.6);padding-bottom:3px}
.btn-ghost:hover{border-color:var(--brass)}

/* Generic section heading */
.sec-head{max-width:720px}
.sec-head .eyebrow{display:block;margin-bottom:16px}
.sec-head h2{font-family:var(--serif);font-weight:500;font-size:clamp(30px,4.5vw,46px);line-height:1.14;color:var(--navy)}
.sec-head p{margin-top:16px;font-size:16.5px;color:var(--slate)}

/* ===== HERO (home) ===== */
.hero{background:var(--navy);color:#fff;padding:120px 0;position:relative;overflow:hidden}
.hero::after{content:"";position:absolute;right:-120px;top:-120px;width:520px;height:520px;border:1px solid rgba(194,160,98,.18);border-radius:50%;pointer-events:none}
.hero::before{content:"";position:absolute;right:40px;bottom:-200px;width:360px;height:360px;border:1px solid rgba(194,160,98,.10);border-radius:50%;pointer-events:none}
.hero .wrap{position:relative;z-index:2}
.hero .eyebrow{display:block;margin-bottom:26px}
.hero h1{font-family:var(--serif);font-weight:500;font-size:clamp(36px,6vw,64px);line-height:1.08;letter-spacing:.01em;max-width:880px;color:#fff}
.hero p{margin-top:28px;font-size:18px;line-height:1.7;max-width:620px;color:rgba(255,255,255,.78)}
.hero-actions{margin-top:44px;display:flex;gap:18px;align-items:center;flex-wrap:wrap}

/* Trust strip */
.trust{background:var(--mist);border-bottom:1px solid #e2e8ef}
.trust .wrap{display:flex;align-items:center;justify-content:center;text-align:center;padding-top:24px;padding-bottom:24px}
.trust p{font-size:13.5px;color:var(--slate);letter-spacing:.01em}

/* Practice areas (home) */
.areas{background:var(--white);padding:104px 0}
.areas .sec-head{margin-bottom:56px}
.grid3{display:grid;grid-template-columns:repeat(3,1fr);border-top:1px solid var(--mist);border-left:1px solid var(--mist)}
.area{padding:38px 34px 42px;border-right:1px solid var(--mist);border-bottom:1px solid var(--mist);transition:background .25s}
.area:hover{background:#fafbfc}
.area .num{font-family:var(--serif);font-size:15px;color:var(--brass);letter-spacing:.05em}
.area h3{font-family:var(--serif);font-weight:600;font-size:24px;color:var(--navy);margin:14px 0 12px}
.area p{font-size:15px;color:var(--slate);line-height:1.66}

/* Values band */
.values{background:var(--navy);color:#fff;padding:104px 0}
.values .sec-head{margin-bottom:54px}
.values .sec-head h2{color:#fff}
.vgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:50px}
.val{border-top:2px solid var(--brass);padding-top:26px}
.val h3{font-family:var(--serif);font-weight:600;font-size:26px;color:#fff;margin-bottom:14px}
.val p{font-size:15px;color:rgba(255,255,255,.74);line-height:1.7}

/* Insight cards (home) */
.insights{background:var(--mist);padding:104px 0}
.ihead{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:52px;flex-wrap:wrap;gap:18px}
.ihead .view{font-size:14px;color:var(--navy);font-weight:500;border-bottom:1px solid var(--brass);padding-bottom:3px}
.igrid{display:grid;grid-template-columns:repeat(3,1fr);gap:30px}
.card{background:#fff;border:1px solid #e3e9f0;border-top:3px solid var(--brass);border-radius:3px;overflow:hidden;display:flex;flex-direction:column;transition:transform .25s,box-shadow .25s}
.card:hover{transform:translateY(-4px);box-shadow:0 18px 40px -24px rgba(21,41,61,.4)}
.card .body{padding:28px 26px;flex:1;display:flex;flex-direction:column}
.card .cat{font-size:11px;letter-spacing:.15em;text-transform:uppercase;color:var(--brass);font-weight:500;margin-bottom:12px}
.card h3{font-family:var(--serif);font-weight:600;font-size:23px;line-height:1.22;color:var(--navy);transition:color .2s}
.card:hover h3{color:var(--brass)}
.card .excerpt{font-size:14px;color:var(--slate);margin:12px 0 18px;line-height:1.62;flex:1}
.card .meta{font-size:12.5px;color:#6b7480;border-top:1px solid var(--mist);padding-top:14px}
.card .meta b{color:var(--navy);font-weight:500}

/* ===== Page header (interior pages) ===== */
.phead{background:var(--navy);color:#fff;padding:104px 0 84px;position:relative;overflow:hidden}
.phead::after{content:"";position:absolute;right:-110px;top:-110px;width:440px;height:440px;border:1px solid rgba(194,160,98,.15);border-radius:50%}
.phead .wrap{position:relative;z-index:2}
.phead .eyebrow{display:block;margin-bottom:20px}
.phead h1{font-family:var(--serif);font-weight:500;font-size:clamp(40px,5.5vw,60px);line-height:1.08;color:#fff;max-width:840px}
.phead p{margin-top:22px;font-size:18px;color:rgba(255,255,255,.78);max-width:600px}

/* ===== Capabilities ===== */
.caps{padding:0 0 30px}
.capgrid{display:grid;grid-template-columns:260px 1fr;gap:64px;align-items:start}
.cap-index{position:sticky;top:108px;padding-top:96px}
.cap-index .lab{font-size:11px;letter-spacing:.15em;text-transform:uppercase;color:var(--brass);font-weight:500;margin-bottom:20px}
.cap-index a{display:flex;gap:13px;align-items:baseline;padding:11px 0;border-top:1px solid var(--mist);font-size:15px;color:var(--slate);transition:color .2s}
.cap-index a:last-child{border-bottom:1px solid var(--mist)}
.cap-index a .ix{font-family:var(--serif);font-size:14px;color:#c2c8cf}
.cap-index a:hover{color:var(--navy)}
.capcol{padding-top:96px}
.cap{padding:54px 0 56px;border-top:1px solid var(--mist);scroll-margin-top:100px}
.cap:first-child{border-top:none;padding-top:0}
.cap .ch{display:flex;align-items:baseline;gap:18px;margin-bottom:18px}
.cap .ch .num{font-family:var(--serif);font-size:22px;color:var(--brass)}
.cap .ch h2{font-family:var(--serif);font-weight:600;font-size:clamp(28px,4vw,36px);color:var(--navy);line-height:1.12}
.cap .lead{font-size:16.5px;color:var(--slate);max-width:660px;margin-bottom:28px}
.cap .svc{display:grid;grid-template-columns:1fr 1fr;gap:10px 30px;margin-bottom:24px}
.cap .svc div{position:relative;padding-left:22px;font-size:15px;color:var(--navy)}
.cap .svc div::before{content:"";position:absolute;left:0;top:10px;width:7px;height:7px;background:var(--brass);transform:rotate(45deg)}
.related{display:inline-flex;align-items:center;gap:10px;font-size:13px;color:#6b7480;flex-wrap:wrap}
.related .rl{display:flex;gap:8px;flex-wrap:wrap}
.related a{font-size:12.5px;font-weight:500;color:var(--navy);border:1px solid #e2e8ef;padding:6px 13px;border-radius:40px;transition:all .2s}
.related a:hover{border-color:var(--brass);color:var(--brass)}
.process{background:var(--navy);color:#fff;padding:100px 0}
.process .sec-head{margin-bottom:54px}
.process .sec-head h2{color:#fff}
.pgrid{display:grid;grid-template-columns:repeat(4,1fr);gap:34px}
.pstep{border-top:2px solid var(--brass);padding-top:24px}
.pstep .pn{font-family:var(--serif);font-size:15px;color:var(--brass)}
.pstep h3{font-family:var(--serif);font-weight:600;font-size:24px;color:#fff;margin:10px 0 12px}
.pstep p{font-size:14.5px;color:rgba(255,255,255,.78);line-height:1.66}
.edge{background:var(--mist);padding:100px 0}
.edge .sec-head{margin-bottom:50px}
.e3{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.ecard{background:#fff;border:1px solid #e3e9f0;border-radius:5px;padding:34px 30px 36px}
.ecard .ei{width:40px;height:40px;border:1px solid var(--brass);border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--serif);color:var(--brass);font-size:20px;margin-bottom:20px}
.ecard h3{font-family:var(--serif);font-weight:600;font-size:23px;color:var(--navy);margin-bottom:10px}
.ecard p{font-size:15px;color:var(--slate);line-height:1.66}

/* ===== About ===== */
.story{padding:104px 0}
.sgrid{display:grid;grid-template-columns:0.9fr 1.1fr;gap:72px;align-items:center}
.sphoto{aspect-ratio:4/5;background:var(--navy) center/cover no-repeat;border-radius:5px;position:relative;overflow:hidden}
.stext .eyebrow{display:block;margin-bottom:16px}
.stext h2{font-family:var(--serif);font-weight:500;font-size:clamp(30px,4vw,40px);color:var(--navy);line-height:1.16;margin-bottom:22px}
.stext p{font-size:16px;color:var(--slate);margin-bottom:16px;max-width:560px}
.thesis{padding:96px 0}
.thesis .wrap{max-width:920px}
.thesis .lede{font-family:var(--serif);font-size:clamp(24px,3.2vw,30px);line-height:1.4;color:var(--navy);font-weight:500;border-left:3px solid var(--brass);padding-left:30px;margin-bottom:34px}
.thesis p{font-size:16.5px;color:var(--slate);max-width:700px;margin-bottom:16px}
.principles{background:var(--mist);padding:100px 0}
.principles .sec-head{margin-bottom:52px}
.p3{display:grid;grid-template-columns:repeat(3,1fr);gap:30px}
.pcard{background:#fff;border:1px solid #e3e9f0;border-radius:5px;padding:36px 32px 38px}
.pcard .pn{font-family:var(--serif);font-size:16px;color:var(--brass)}
.pcard h3{font-family:var(--serif);font-weight:600;font-size:25px;color:var(--navy);margin:12px 0}
.pcard p{font-size:15px;color:var(--slate);line-height:1.66}
.who{background:var(--mist);padding:100px 0}
.who .sec-head{margin-bottom:50px}
.w3{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.wcard{background:#fff;border:1px solid #e3e9f0;border-radius:5px;padding:38px 32px 42px;transition:transform .25s,box-shadow .25s}
.wcard:hover{transform:translateY(-4px);box-shadow:0 18px 40px -24px rgba(21,41,61,.4)}
.wcard .wn{font-family:var(--serif);font-size:16px;color:var(--brass)}
.wcard h3{font-family:var(--serif);font-weight:600;font-size:25px;color:var(--navy);margin:14px 0 12px;line-height:1.15}
.wcard p{font-size:15px;color:var(--slate);line-height:1.66}
.team{padding:104px 0}
.team .sec-head{margin-bottom:50px}
.tgrid{display:grid;grid-template-columns:repeat(4,1fr);gap:28px}
.tcard{background:#fff;border:1px solid #e3e9f0;border-radius:5px;overflow:hidden;transition:transform .25s,box-shadow .25s}
.tcard:hover{transform:translateY(-4px);box-shadow:0 18px 40px -24px rgba(21,41,61,.4)}
.tphoto{aspect-ratio:1/1;background:var(--navy) center/cover no-repeat}
.tbody{padding:22px 22px 24px}
.tbody h3{font-family:var(--serif);font-weight:600;font-size:22px;color:var(--navy)}
.tbody .role{font-size:12.5px;color:var(--brass);font-weight:500;letter-spacing:.03em;margin:4px 0 12px;text-transform:uppercase}
.tbody p{font-size:14.5px;color:var(--slate);line-height:1.62}
.tbody .links{margin-top:14px;padding-top:14px;border-top:1px solid var(--mist);display:flex;gap:16px;font-size:12.5px;font-weight:500}
.tbody .links a{color:var(--navy)}
.tbody .links a:hover{color:var(--brass)}

/* ===== Contact ===== */
.contact{padding:96px 0}
.cgrid{display:grid;grid-template-columns:1.15fr 0.85fr;gap:72px;align-items:start}
.reach .eyebrow{display:block;margin-bottom:14px}
.reach h2{font-family:var(--serif);font-weight:500;font-size:clamp(30px,4vw,38px);color:var(--navy);line-height:1.14;margin-bottom:28px}
.mailblock{padding-bottom:30px;border-bottom:1px solid var(--mist);margin-bottom:30px}
.mailblock .lab{font-size:11px;letter-spacing:.15em;text-transform:uppercase;color:var(--brass);font-weight:500;margin-bottom:12px}
.mail-primary{font-family:var(--serif);font-size:clamp(28px,3.5vw,38px);font-weight:500;color:var(--navy);line-height:1.1;transition:color .2s;display:inline-block}
.mail-primary:hover{color:var(--brass)}
.mail-secondary{margin-top:10px;font-size:15px;color:var(--slate)}
.mail-secondary a{color:var(--navy);border-bottom:1px solid var(--mist)}
.mail-secondary a:hover{color:var(--brass);border-color:var(--brass)}
.reach .resp{font-size:15px;color:var(--slate);max-width:460px}
.reach .resp b{color:var(--navy);font-weight:600}
.quicklinks{margin-top:30px;display:flex;gap:14px;flex-wrap:wrap}
.ql{display:inline-flex;align-items:center;gap:9px;font-size:14px;font-weight:500;color:var(--navy);border:1px solid #dde4ec;padding:12px 20px;border-radius:3px;transition:all .2s}
.ql:hover{border-color:var(--brass);color:var(--brass)}
.officecard{background:var(--navy);color:#fff;border-radius:5px;padding:40px 38px 42px;position:relative;overflow:hidden}
.officecard::after{content:"";position:absolute;right:-60px;top:-60px;width:200px;height:200px;border:1px solid rgba(194,160,98,.2);border-radius:50%}
.officecard h3{font-family:var(--serif);font-weight:600;font-size:24px;margin-bottom:24px;position:relative;z-index:2}
.oblock{padding:18px 0;border-top:1px solid rgba(255,255,255,.12);position:relative;z-index:2}
.oblock:first-of-type{border-top:none;padding-top:0}
.oblock .lab{font-size:11px;letter-spacing:.15em;text-transform:uppercase;color:var(--brass);font-weight:500;margin-bottom:7px}
.oblock .val{font-size:15px;color:#fff;line-height:1.6}
.oblock .sub{font-size:13px;color:rgba(255,255,255,.66);margin-top:3px}
.guide{background:var(--mist);padding:84px 0}
.guide .gh{max-width:640px;margin-bottom:46px}
.guide .gh .eyebrow{display:block;margin-bottom:14px}
.guide .gh h2{font-family:var(--serif);font-weight:500;font-size:clamp(28px,3.6vw,36px);color:var(--navy);line-height:1.16}
.guide .gh p{margin-top:14px;font-size:16px;color:var(--slate)}
.g3{display:grid;grid-template-columns:repeat(3,1fr);gap:30px}
.gcard{background:#fff;border:1px solid #e3e9f0;border-radius:5px;padding:30px 28px 32px}
.gcard .gn{font-family:var(--serif);font-size:17px;color:var(--brass)}
.gcard h3{font-family:var(--serif);font-weight:600;font-size:22px;color:var(--navy);margin:12px 0 10px}
.gcard p{font-size:14.5px;color:var(--slate);line-height:1.62}
.privacy{margin-top:34px;display:flex;align-items:center;gap:10px;font-size:13.5px;color:#6b7480}
.privacy .dot{width:6px;height:6px;border-radius:50%;background:var(--brass);flex:0 0 6px}

/* ===== Insights list ===== */
.filterbar{background:var(--navy);padding:0 0 40px}
.chips{display:flex;gap:10px;flex-wrap:wrap;border-top:1px solid rgba(255,255,255,.14);padding-top:28px;margin-top:40px}
.chip{font-size:13px;font-weight:500;color:rgba(255,255,255,.82);border:1px solid rgba(255,255,255,.2);padding:9px 18px;border-radius:40px;transition:all .2s}
.chip:hover,.chip.on{background:var(--brass);color:var(--navy);border-color:var(--brass)}
.lead-feat{padding:74px 0 16px}
.feat{display:block;border-top:3px solid var(--brass);padding-top:34px;max-width:860px}
.feat .row1{display:flex;align-items:center;gap:14px;margin-bottom:16px}
.feat .tag{font-size:11px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--navy);background:var(--mist);padding:5px 12px;border-radius:3px}
.feat .cat{font-size:11px;letter-spacing:.15em;text-transform:uppercase;color:var(--brass);font-weight:500}
.feat h2{font-family:var(--serif);font-weight:600;font-size:clamp(28px,4vw,46px);line-height:1.1;color:var(--navy);transition:color .2s}
.feat:hover h2{color:var(--brass)}
.feat p{font-size:16.5px;color:var(--slate);line-height:1.7;margin:18px 0;max-width:700px}
.feat .meta{font-size:13.5px;color:#6b7480}
.feat .meta b{color:var(--navy);font-weight:500}
.listsec{padding:40px 0 80px}
.lbl{font-size:11px;letter-spacing:.15em;text-transform:uppercase;color:var(--brass);font-weight:500;margin-bottom:8px;padding-top:30px;border-top:1px solid var(--mist)}
.irow{display:grid;grid-template-columns:140px 1fr 150px;gap:34px;align-items:start;padding:30px 0;border-bottom:1px solid var(--mist);transition:background .2s}
.irow:hover{background:#fafbfc}
.irow .l .date{font-size:14px;color:var(--navy);font-weight:500}
.irow .l .cat{font-size:11px;letter-spacing:.13em;text-transform:uppercase;color:var(--brass);font-weight:500;margin-top:6px}
.irow .l .cat .pill{display:inline-block;margin-top:8px;font-size:10px;letter-spacing:.1em;color:var(--navy);background:var(--mist);padding:3px 9px;border-radius:3px}
.irow .m h3{font-family:var(--serif);font-weight:600;font-size:27px;line-height:1.18;color:var(--navy);transition:color .2s}
.irow:hover .m h3{color:var(--brass)}
.irow .m p{font-size:14.5px;color:var(--slate);line-height:1.6;margin-top:8px;max-width:560px}
.irow .r{text-align:right;font-size:13px;color:#6b7480}
.irow .r b{display:block;color:var(--navy);font-weight:500;font-size:14px}

/* ===== Single article ===== */
.ahead{background:var(--navy);color:#fff;padding:64px 0 60px;position:relative;overflow:hidden}
.ahead::after{content:"";position:absolute;right:-120px;top:-120px;width:400px;height:400px;border:1px solid rgba(194,160,98,.14);border-radius:50%}
.ahead .wrap{position:relative;z-index:2;max-width:820px}
.crumb{font-size:13px;color:rgba(255,255,255,.6);margin-bottom:22px}
.crumb a:hover{color:var(--brass)}
.crumb .sep{margin:0 8px;color:rgba(255,255,255,.35)}
.ahead .cat{font-size:11px;letter-spacing:.15em;text-transform:uppercase;color:var(--brass);font-weight:500}
.ahead h1{font-family:var(--serif);font-weight:600;font-size:clamp(32px,5vw,46px);line-height:1.12;color:#fff;margin:14px 0 26px}
.ahead .byline{display:flex;align-items:center;gap:16px;flex-wrap:wrap;font-size:14px;color:rgba(255,255,255,.7)}
.ahead .byline .av{width:42px;height:42px;border-radius:50%;background:#0f2030 center/cover no-repeat;border:1px solid rgba(194,160,98,.4)}
.ahead .byline b{color:#fff;font-weight:500}
.ahead .byline .dot{color:rgba(255,255,255,.3)}
.artwrap{max-width:1060px;margin:0 auto;padding:64px 40px 40px}
.article{max-width:720px;margin:0 auto}
.article p{font-size:17px;line-height:1.85;color:var(--slate);margin-bottom:22px}
.article > p:first-of-type{font-size:19px;line-height:1.7;color:var(--navy)}
.article h2{font-family:var(--serif);font-weight:600;font-size:30px;color:var(--navy);line-height:1.2;margin:46px 0 14px}
.article h3{font-family:var(--serif);font-weight:600;font-size:22px;color:var(--navy);margin:30px 0 10px}
.article strong{color:var(--navy);font-weight:600}
.article ul,.article ol{margin:0 0 22px 22px}
.article li{font-size:17px;line-height:1.8;color:var(--slate);margin-bottom:8px}
.article blockquote{font-family:var(--serif);font-size:25px;line-height:1.4;color:var(--navy);border-left:3px solid var(--brass);padding:6px 0 6px 24px;margin:34px 0}
.author{max-width:720px;margin:48px auto 0;background:var(--mist);border-radius:6px;padding:34px 36px;display:flex;gap:28px;align-items:flex-start}
.author .av{width:150px;height:200px;border-radius:5px;background:var(--navy) top center/cover no-repeat;flex:0 0 150px;border:1px solid #e3e9f0}
.author .lab{font-size:11px;letter-spacing:.15em;text-transform:uppercase;color:var(--brass);font-weight:500;margin-bottom:6px}
.author h3{font-family:var(--serif);font-weight:600;font-size:24px;color:var(--navy)}
.author .role{font-size:13px;color:var(--brass);font-weight:500;margin:2px 0 10px;text-transform:uppercase;letter-spacing:.03em}
.author p{font-size:15px;color:var(--slate);line-height:1.62;margin-bottom:10px}
.author .links{display:flex;gap:16px;font-size:13px;font-weight:500}
.author .links a{color:var(--navy);border-bottom:1px solid var(--brass);padding-bottom:2px}
.related-posts{background:var(--mist);padding:80px 0;margin-top:64px}
.related-posts .lbl{border:none;padding-top:0}
.related-posts h2{font-family:var(--serif);font-weight:500;font-size:34px;color:var(--navy);margin-bottom:36px}
.rgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.rcard{background:#fff;border:1px solid #e3e9f0;border-top:3px solid var(--brass);border-radius:3px;padding:28px 26px 30px;display:flex;flex-direction:column;transition:transform .25s,box-shadow .25s}
.rcard:hover{transform:translateY(-4px);box-shadow:0 18px 40px -24px rgba(21,41,61,.4)}
.rcard .cat{font-size:11px;letter-spacing:.13em;text-transform:uppercase;color:var(--brass);font-weight:500}
.rcard h3{font-family:var(--serif);font-weight:600;font-size:22px;line-height:1.2;color:var(--navy);margin:11px 0 0}
.rcard .meta{margin-top:auto;padding-top:16px;font-size:12.5px;color:#6b7480}
.rcard .meta b{color:var(--navy);font-weight:500}

/* ===== CTA band (shared) ===== */
.cta{padding:104px 0}
.ctabox{background:var(--navy);border-radius:4px;padding:70px 64px;position:relative;overflow:hidden;display:grid;grid-template-columns:1.3fr auto;gap:40px;align-items:center}
.ctabox::after{content:"";position:absolute;right:-90px;bottom:-130px;width:330px;height:330px;border:1px solid rgba(194,160,98,.16);border-radius:50%}
.ctabox .l{position:relative;z-index:2}
.ctabox .eyebrow{display:block;margin-bottom:16px}
.ctabox h2{font-family:var(--serif);font-weight:500;font-size:clamp(28px,3.6vw,38px);color:#fff;line-height:1.16;max-width:560px}
.ctabox .r{position:relative;z-index:2}

/* ===== Footer ===== */
footer{background:#0f1f2e;color:rgba(255,255,255,.7);padding:72px 0 36px}
.fgrid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:50px;padding-bottom:48px;border-bottom:1px solid rgba(255,255,255,.1)}
.fcol .logo{color:#fff;margin-bottom:18px;display:block}
.fcol p{font-size:14px;line-height:1.8;color:rgba(255,255,255,.6)}
.fcol h4{font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--brass);font-weight:500;margin-bottom:18px}
.fcol ul{list-style:none}
.fcol li{margin-bottom:11px;font-size:14px}
.fcol li a:hover{color:#fff}
.fsocial{display:inline-flex;align-items:center;gap:8px;margin-top:18px;font-size:13px;color:rgba(255,255,255,.6);transition:color .2s}
.fsocial:hover{color:#fff}
.fsocial svg{color:var(--brass);flex:none}
.fbottom{padding-top:28px;display:flex;justify-content:space-between;font-size:12.5px;color:rgba(255,255,255,.45);flex-wrap:wrap;gap:10px}

/* ===== Responsive ===== */
@media(max-width:1024px) and (min-width:901px){.grid3{grid-template-columns:repeat(2,1fr)}}
@media(max-width:980px){
  .capgrid{grid-template-columns:1fr;gap:0}.cap-index{display:none}.capcol{padding-top:64px}
  .pgrid{grid-template-columns:1fr 1fr}.e3,.p3,.w3{grid-template-columns:1fr}
  .sgrid{grid-template-columns:1fr;gap:40px}.sphoto{max-width:420px}
  .tgrid{grid-template-columns:1fr 1fr}
}
@media(max-width:900px){
  .grid3,.vgrid,.igrid,.cgrid,.g3,.rgrid{grid-template-columns:1fr}
  .ihead{flex-direction:column;align-items:flex-start}
  .ctabox{grid-template-columns:1fr;gap:28px}
  .fgrid{grid-template-columns:1fr;gap:34px}
  .nav-toggle{display:flex}
  .nav-links{position:absolute;top:78px;left:0;right:0;flex-direction:column;align-items:stretch;gap:0;background:#fff;border-bottom:1px solid var(--mist);padding:6px 0;max-height:0;overflow:hidden;transition:max-height .3s ease}
  .nav-links.open{max-height:400px}
  .nav-links a{padding:15px 40px}
  .nav-cta{border:none!important;border-radius:0;padding:15px 40px!important}
  .nav-cta:hover,.nav-cta.on{background:var(--mist);color:var(--navy)!important}
  .irow{grid-template-columns:1fr;gap:10px}.irow .r{text-align:left}
  .author{flex-direction:column}.author .av{width:130px;height:170px;flex-basis:auto}
}
@media(max-width:600px){
  .wrap{padding:0 24px}
  .hero{padding:88px 0 78px}
  .areas,.values,.insights,.story,.principles,.who,.team,.process,.edge,.contact,.guide,.cta{padding:64px 0}
  .artwrap{padding-left:24px;padding-right:24px}
  .tgrid{grid-template-columns:1fr}
  .nav-links a,.nav-cta{padding:15px 24px!important}
}

/* ===== Article TOC sidebar (auto-generated from H2 subheadings) ===== */
.artwrap.has-toc{display:grid;grid-template-columns:220px minmax(0,1fr);gap:56px;align-items:start;max-width:1060px}
.toc{position:sticky;top:110px}
.toc .lab{font-size:11px;letter-spacing:.15em;text-transform:uppercase;color:var(--brass);font-weight:500;margin-bottom:16px}
.toc a{display:block;font-size:13.5px;color:var(--slate);padding:8px 0 8px 14px;border-left:2px solid var(--mist);transition:all .2s;line-height:1.4}
.toc a:hover{color:var(--navy)}
.toc a.active{color:var(--navy);font-weight:500;border-left-color:var(--brass)}
.has-toc .article{max-width:none;margin:0}
@media(max-width:900px){.artwrap.has-toc{grid-template-columns:1fr;gap:0}.toc{display:none}}

/* Author avatars via WordPress (Gravatar / profile image) */
.ahead .byline img.avatar{width:42px;height:42px;border-radius:50%;object-fit:cover;border:1px solid rgba(194,160,98,.4)}
.author{align-items:flex-start}
.author img.avatar{width:130px;height:130px;border-radius:5px;object-fit:cover;border:1px solid #e3e9f0;flex:0 0 130px}

/* WordPress core helpers */
.alignright{float:right;margin:0 0 1rem 1.5rem}
.alignleft{float:left;margin:0 1.5rem 1rem 0}
.aligncenter{display:block;margin:1rem auto}
.wp-block-image img{max-width:100%;height:auto;border-radius:4px}
.article figure{margin:0 0 22px}
.article figcaption{font-size:13px;color:#6b7480;margin-top:8px}
/* Responsive video embeds (oEmbed) */
.article .wp-block-embed__wrapper{position:relative;padding-bottom:56.25%;height:0;overflow:hidden;margin:0 0 22px}
.article .wp-block-embed__wrapper iframe{position:absolute;inset:0;width:100%;height:100%;border:0;border-radius:4px}

.tcard{scroll-margin-top:100px}
