/* ==========================================================================
   corymaki.com — Clean Authority design system
   Single shared stylesheet. Source of truth: index-A-clean.html
   Section 1: base + components ported verbatim from the approved home page.
   Section 2: shared component styles for interior pages.
   ========================================================================== */

/* ---------- 1. BASE (from index-A-clean.html) ---------- */
:root{
  --bg:#FFFFFF; --bg-2:#F4F6FA; --card:#FFFFFF;
  --ink:#0D1017; --muted:#59616F; --line:#E5E8EE;
  --accent:#2438E0; --accent-2:#1A28B0; --accent-soft:#EEF0FE;
  --maxw:1140px; --r:16px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:'Schibsted Grotesk',sans-serif;background:var(--bg);color:var(--ink);line-height:1.6;font-size:17px;-webkit-font-smoothing:antialiased}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 26px}
a{color:inherit}
img{max-width:100%;display:block}
h1,h2,h3{font-family:'Bricolage Grotesque',sans-serif;font-weight:700;line-height:1.04;letter-spacing:-0.02em}
.kicker{font-size:13px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--accent)}

/* header */
header.site{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.85);backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;height:72px}
.brand{font-family:'Bricolage Grotesque',sans-serif;font-weight:800;font-size:21px;letter-spacing:-.02em;text-decoration:none}
.brand b{color:var(--accent)}
.menu{display:flex;gap:32px;align-items:center;list-style:none}
.menu a{font-size:15px;font-weight:500;color:var(--muted);text-decoration:none;transition:color .2s}
.menu a:hover{color:var(--ink)}
.menu a.btn{color:#fff}
.btn{font-weight:600;font-size:15px;text-decoration:none;padding:11px 22px;border-radius:999px;display:inline-flex;align-items:center;gap:.5em;transition:all .2s;cursor:pointer;border:none}
.btn-primary{background:var(--accent);color:#fff;box-shadow:0 8px 22px -10px var(--accent)}
.btn-primary:hover{background:var(--accent-2);transform:translateY(-1px)}
.btn-ghost{border:1.5px solid var(--line);color:var(--ink);background:transparent}
.btn-ghost:hover{border-color:var(--ink)}
.burger{display:none;background:none;border:1px solid var(--line);border-radius:10px;padding:9px 11px;font-size:13px;font-weight:600;cursor:pointer}

/* hero */
.hero{padding:90px 0 80px}
.hero-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:60px;align-items:center}
.hero h1{font-size:clamp(44px,6.4vw,76px);font-weight:800;margin:18px 0 0}
.hero h1 .hl{color:var(--accent)}
.hero .sub{font-size:19px;color:var(--muted);margin-top:22px;max-width:48ch}
.hero .sub b{color:var(--ink);font-weight:600}
.cta-row{display:flex;gap:14px;margin-top:34px;flex-wrap:wrap}
.trust{margin-top:30px;font-size:13.5px;color:var(--muted);display:flex;gap:18px;flex-wrap:wrap;align-items:center}
.trust b{color:var(--ink);font-weight:600}
.trust .dot{width:4px;height:4px;border-radius:50%;background:var(--line)}
.hero-photo{position:relative}
.hero-photo .frame{border-radius:24px;overflow:hidden;box-shadow:0 40px 80px -40px rgba(13,16,23,.4);background:var(--bg-2)}
.hero-photo img{width:100%;height:auto;display:block}
.hero-photo .blob{position:absolute;inset:auto -24px -24px auto;width:140px;height:140px;background:var(--accent-soft);border-radius:24px;z-index:-1}
.badge{position:absolute;left:-22px;top:34px;background:#fff;border:1px solid var(--line);border-radius:14px;padding:12px 16px;box-shadow:0 18px 40px -20px rgba(13,16,23,.3);font-size:13px}
.badge .n{font-family:'Bricolage Grotesque';font-weight:800;font-size:22px;color:var(--accent)}
.badge .l{color:var(--muted)}

/* logos strip */
.logos{border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:var(--bg-2)}
.logos .wrap{display:flex;gap:14px 40px;flex-wrap:wrap;align-items:center;justify-content:center;padding:22px 26px}
.logos span{font-weight:600;color:#9aa1ad;font-size:15px;letter-spacing:.01em}
.logos .lab{font-size:12px;text-transform:uppercase;letter-spacing:.12em;color:#b3b9c4;font-weight:600}

/* sections */
section{padding:84px 0}
.head{max-width:60ch;margin-bottom:44px}
.head h2{font-size:clamp(30px,4vw,46px);margin-top:12px}
.head p{color:var(--muted);margin-top:14px;font-size:18px}
.cols{display:grid;grid-template-columns:1fr 1fr;gap:50px}
.cols h2{font-size:clamp(28px,3.4vw,40px)}
.cols .body p{color:var(--muted);margin-bottom:16px}
.cols .body b{color:var(--ink);font-weight:600}

/* arc */
.arc{background:var(--bg-2)}
.arc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:6px}
.arc-card{background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:30px 26px;transition:transform .25s,box-shadow .25s}
.arc-card:hover{transform:translateY(-5px);box-shadow:0 26px 50px -30px rgba(13,16,23,.3)}
.chip{width:42px;height:42px;border-radius:12px;background:var(--accent-soft);color:var(--accent);display:flex;align-items:center;justify-content:center;font-family:'Bricolage Grotesque';font-weight:800;font-size:18px}
.arc-card h3{font-size:21px;margin:16px 0 9px}
.arc-card p{font-size:15px;color:var(--muted)}

/* stats */
.stats .wrap{padding:64px 26px;background:var(--ink);border-radius:28px;color:#fff}
.stat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.stat .n{font-family:'Bricolage Grotesque';font-weight:800;font-size:clamp(46px,6vw,70px);line-height:1;background:linear-gradient(90deg,#fff,#A9B3FF);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.stat .l{color:#AEB6C6;margin-top:12px;font-size:15px}
.stats .kicker{color:#8C97FF}

/* ebook */
.ebook{background:var(--accent);color:#fff;text-align:center}
.ebook .wrap{padding:78px 26px}
.ebook h2{color:#fff;font-size:clamp(30px,4vw,44px);max-width:20ch;margin:14px auto 0}
.ebook p{color:#D7DBFF;max-width:54ch;margin:18px auto 28px;font-size:18px}
.ebook .btn-primary{background:#fff;color:var(--accent);box-shadow:none}
.ebook .btn-primary:hover{background:#EEF0FE}

/* writing */
.posts{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:6px}
.post{background:var(--card);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;text-decoration:none;display:flex;flex-direction:column;transition:transform .25s,box-shadow .25s}
.post:hover{transform:translateY(-5px);box-shadow:0 26px 50px -30px rgba(13,16,23,.3)}
.post .thumb{aspect-ratio:16/10;overflow:hidden;background:var(--bg-2)}
.post .thumb img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.post:hover .thumb img{transform:scale(1.05)}
.post .b{padding:22px}
.post .date{font-size:12px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--accent)}
.post h3{font-size:19px;margin:9px 0;line-height:1.2}
.post .ex{font-size:14.5px;color:var(--muted)}
.post .more{margin-top:14px;font-size:14px;font-weight:600;color:var(--accent)}

/* footer */
footer.site{background:var(--ink);color:#C7CCD6;padding:72px 0 32px}
.foot{display:grid;grid-template-columns:1.6fr 1fr 1fr;gap:44px}
footer.site .brand{color:#fff;text-decoration:none}
footer.site p{margin-top:14px;font-size:14.5px;color:#959BA8;max-width:42ch}
.fh{font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:#7C84FF;font-weight:600;margin-bottom:14px}
.fl{list-style:none;display:flex;flex-direction:column;gap:9px}
.fl a{color:#C7CCD6;text-decoration:none;font-size:14.5px}
.fl a:hover{color:#fff}
.fb{border-top:1px solid #1E222C;margin-top:46px;padding-top:22px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:8px;font-size:13px;color:#7E8593}

.reveal{opacity:0;transform:translateY(16px);animation:rise .7s cubic-bezier(.2,.7,.2,1) forwards}
@keyframes rise{to{opacity:1;transform:none}}
.d1{animation-delay:.05s}.d2{animation-delay:.13s}.d3{animation-delay:.22s}.d4{animation-delay:.31s}

/* accessibility: visible focus + reduced motion */
a:focus-visible,button:focus-visible,input:focus-visible,textarea:focus-visible{outline:3px solid var(--accent);outline-offset:2px;border-radius:6px}
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important;scroll-behavior:auto!important}
  .reveal{opacity:1;transform:none}
}

/* ---------- 2. INTERIOR-PAGE COMPONENTS ---------- */

/* page hero (interior pages, single column or portrait split) */
.page-hero{padding:72px 0 36px}
.page-hero .kicker{margin-bottom:14px;display:block}
.page-hero h1{font-size:clamp(38px,5.2vw,62px);font-weight:800}
.page-hero .lede{font-size:19px;color:var(--muted);margin-top:20px;max-width:60ch}
.page-hero .lede b{color:var(--ink);font-weight:600}
.split{display:grid;grid-template-columns:1.15fr .85fr;gap:56px;align-items:center}

/* breadcrumbs */
.crumbs{font-size:13px;color:var(--muted);padding:22px 0 0}
.crumbs a{color:var(--muted);text-decoration:none}
.crumbs a:hover{color:var(--accent)}
.crumbs span{margin:0 8px;color:var(--line)}

/* generic prose block (about body, book, podcast, llm) */
.prose{max-width:72ch}
.prose.wide{max-width:80ch}
.prose h2{font-size:clamp(26px,3.2vw,36px);margin:46px 0 14px}
.prose h3{font-size:21px;margin:30px 0 10px}
.prose p{color:var(--muted);margin-bottom:16px}
.prose p b,.prose li b{color:var(--ink);font-weight:600}
.prose a{color:var(--accent);text-decoration:none;font-weight:500}
.prose a:hover{text-decoration:underline}
.prose ul,.prose ol{color:var(--muted);margin:0 0 18px 1.2em}
.prose li{margin-bottom:8px}
.prose blockquote{border-left:3px solid var(--accent);background:var(--bg-2);padding:16px 22px;border-radius:0 12px 12px 0;margin:22px 0;color:var(--ink);font-size:18px}

/* definition / at-a-glance table */
.dl-table{width:100%;border-collapse:collapse;margin:18px 0 8px;font-size:15.5px}
.dl-table th,.dl-table td{text-align:left;padding:13px 16px;border-bottom:1px solid var(--line);vertical-align:top}
.dl-table th{width:34%;color:var(--muted);font-weight:600;font-family:'Schibsted Grotesk',sans-serif}
.dl-table td{color:var(--ink)}
.dl-table tr:last-child th,.dl-table tr:last-child td{border-bottom:none}

/* link list (profiles / sameAs) */
.linklist{list-style:none;display:grid;grid-template-columns:1fr 1fr;gap:10px 28px;margin:14px 0}
.linklist a{color:var(--accent);text-decoration:none;font-weight:500;font-size:15px;display:inline-flex;align-items:center;gap:.45em}
.linklist a:hover{text-decoration:underline}
.linklist a::before{content:"↗";color:var(--muted);font-size:12px}

/* portrait frame reused on interior heroes */
.portrait{position:relative}
.portrait .frame{border-radius:24px;overflow:hidden;box-shadow:0 40px 80px -40px rgba(13,16,23,.4);background:var(--bg-2)}
.portrait img{width:100%;height:auto;display:block}
.portrait .blob{position:absolute;inset:auto -22px -22px auto;width:130px;height:130px;background:var(--accent-soft);border-radius:24px;z-index:-1}

/* stat callouts (book page, inline trio) */
.callouts{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin:8px 0}
.callout{background:var(--bg-2);border:1px solid var(--line);border-radius:var(--r);padding:28px 24px;text-align:center}
.callout .n{font-family:'Bricolage Grotesque';font-weight:800;font-size:clamp(38px,5vw,56px);color:var(--accent);line-height:1}
.callout .l{color:var(--muted);margin-top:10px;font-size:14.5px}

/* chapter / TOC list (book) */
.chapters{list-style:none;display:grid;grid-template-columns:1fr 1fr;gap:10px 28px;margin:10px 0;counter-reset:none}
.chapters li{display:flex;gap:14px;align-items:baseline;padding:11px 0;border-bottom:1px solid var(--line);color:var(--ink)}
.chapters li .num{font-family:'Bricolage Grotesque';font-weight:800;color:var(--accent);font-size:15px;min-width:2.2em}

/* listen-on buttons (podcast) */
.listen{display:flex;flex-wrap:wrap;gap:12px;margin:18px 0 8px}
.listen a{display:inline-flex;align-items:center;gap:.5em;padding:12px 20px;border-radius:999px;border:1.5px solid var(--line);font-weight:600;font-size:15px;text-decoration:none;color:var(--ink);transition:all .2s}
.listen a:hover{border-color:var(--accent);color:var(--accent);transform:translateY(-1px)}

/* episode block (podcast) */
.episode{background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:30px 28px;margin-bottom:20px}
.episode .meta{font-size:12px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--accent)}
.episode h3{font-size:23px;margin:8px 0 12px}
.episode p{color:var(--muted);margin-bottom:14px}

/* article body */
.article{padding:18px 0 40px}
.article .byline{font-size:14.5px;color:var(--muted);margin:10px 0 26px}
.article .byline b{color:var(--ink);font-weight:600}
.article-hero{border-radius:20px;overflow:hidden;margin:0 0 34px;background:var(--bg-2);height:clamp(240px,40vw,420px)}
.article-hero img{width:100%;height:100%;object-fit:cover;object-position:center 35%;display:block}
.article .body{max-width:72ch;margin:0 auto}
.article .body h2{font-size:clamp(26px,3.2vw,34px);margin:42px 0 14px}
.article .body h3{font-size:20px;margin:28px 0 10px}
.article .body p{color:#2a2f3a;margin-bottom:18px}
.article .body ul,.article .body ol{color:#2a2f3a;margin:0 0 20px 1.2em}
.article .body li{margin-bottom:9px}
.article .body a{color:var(--accent);text-decoration:none;font-weight:500}
.article .body a:hover{text-decoration:underline}

/* inline stat callout inside articles */
.stat-inline{background:var(--accent-soft);border-radius:14px;padding:22px 26px;margin:26px 0;display:flex;gap:18px;align-items:center}
.stat-inline .big{font-family:'Bricolage Grotesque';font-weight:800;font-size:clamp(34px,5vw,48px);color:var(--accent);line-height:1}
.stat-inline .txt{color:var(--ink);font-size:15.5px}

/* FAQ */
.faq{max-width:72ch;margin:40px auto 0;border-top:1px solid var(--line)}
.faq details{border-bottom:1px solid var(--line)}
.faq summary{cursor:pointer;list-style:none;padding:18px 0;font-family:'Bricolage Grotesque';font-weight:700;font-size:18px;display:flex;justify-content:space-between;gap:16px;align-items:center}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";color:var(--accent);font-size:24px;font-weight:600;transition:transform .2s}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq details p{color:var(--muted);padding:0 0 18px;margin:0}

/* references */
.refs{max-width:72ch;margin:40px auto 0}
.refs ol{margin:14px 0 0 1.3em;color:var(--muted);font-size:14.5px}
.refs li{margin-bottom:10px;word-break:break-word}
.refs a{color:var(--accent);text-decoration:none}
.refs a:hover{text-decoration:underline}

/* about-the-author block */
.author-box{display:flex;gap:22px;align-items:center;background:var(--bg-2);border:1px solid var(--line);border-radius:var(--r);padding:24px 26px;margin:44px auto 0;max-width:72ch}
.author-box img{width:84px;height:84px;border-radius:50%;object-fit:cover;flex-shrink:0}
.author-box .n{font-family:'Bricolage Grotesque';font-weight:800;font-size:18px}
.author-box p{color:var(--muted);font-size:14.5px;margin-top:6px}
.author-box a{color:var(--accent);text-decoration:none;font-weight:500}

/* prev / next article nav */
.prevnext{display:flex;justify-content:space-between;gap:16px;max-width:72ch;margin:40px auto 0;flex-wrap:wrap}
.prevnext a{flex:1;min-width:200px;border:1px solid var(--line);border-radius:var(--r);padding:18px 20px;text-decoration:none;transition:border-color .2s}
.prevnext a:hover{border-color:var(--accent)}
.prevnext .lab{font-size:12px;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);font-weight:600}
.prevnext .t{color:var(--ink);font-weight:600;margin-top:4px;display:block}
.prevnext .next{text-align:right}

/* contact form */
.form-card{background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:32px 30px;box-shadow:0 26px 50px -38px rgba(13,16,23,.4)}
.field{margin-bottom:18px}
.field label{display:block;font-size:14px;font-weight:600;margin-bottom:7px}
.field input,.field textarea{width:100%;font-family:inherit;font-size:16px;color:var(--ink);background:#fff;border:1.5px solid var(--line);border-radius:12px;padding:13px 15px;transition:border-color .2s,box-shadow .2s}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-soft)}
.field textarea{min-height:140px;resize:vertical}
.field .req{color:var(--accent)}
.hp{position:absolute;left:-9999px;top:-9999px;width:1px;height:1px;overflow:hidden}
.form-note{font-size:13px;color:var(--muted);margin-top:6px}
.form-status{display:none;border-radius:12px;padding:14px 16px;margin-top:16px;font-size:15px}
.form-status.ok{display:block;background:var(--accent-soft);color:var(--accent-2)}
.form-status.err{display:block;background:#FDECEC;color:#B3261E}
.contact-side .prose a{font-weight:600}

@media(max-width:900px){
  .hero-grid,.cols,.foot{grid-template-columns:1fr;gap:38px}
  .arc-grid,.stat-grid,.posts{grid-template-columns:1fr}
  .menu{display:none}
  .menu.open{display:flex;position:absolute;top:72px;left:0;right:0;flex-direction:column;align-items:flex-start;background:#fff;border-bottom:1px solid var(--line);padding:18px 26px;gap:16px}
  .burger{display:block}
  .hero{padding:56px 0 50px}
  .badge{left:0}
  .split{grid-template-columns:1fr;gap:36px}
  .callouts,.chapters,.linklist{grid-template-columns:1fr}
  .split .portrait{order:-1}
}
