/*
Theme Name: Majaski Editorial
Theme URI: https://christinamajaski.com
Author: Christina Majaski
Author URI: https://christinamajaski.com
Description: A fast, custom editorial portfolio theme for writers, editors and digital content strategists. Page-builder-free, SEO/GEO-friendly, with a filterable Byline Directory powered by custom post types and taxonomies (Topic, Publication, Role). Built to replace Divi.
Version: 1.2.1
Requires at least: 6.0
Tested up to: 6.9
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: majaski
Tags: portfolio, custom-colors, custom-menu, featured-images, threaded-comments, translation-ready
*/

:root{
  --paper:#f4f1ea;--paper-2:#ece7dc;--ink:#1a1f2b;--ink-soft:#3a4150;--muted:#6b7180;
  --line:#d6cfc0;--accent:#b4452f;--accent-2:#1f3a5f;--gold:#bd9b5f;--max:1180px;
  --serif:"Fraunces",Georgia,serif;--sans:"Spline Sans",system-ui,sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{background:var(--paper);color:var(--ink);font-family:var(--sans);font-size:17px;line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden}
body::before{content:"";position:fixed;inset:0;pointer-events:none;z-index:1;opacity:.4;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.035'/%3E%3C/svg%3E");mix-blend-mode:multiply}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.wrap{max-width:var(--max);margin:0 auto;padding:0 28px}
.serif{font-family:var(--serif)}
header.site{position:sticky;top:0;z-index:50;background:rgba(244,241,234,.86);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;height:74px}
.brand{font-family:var(--serif);font-weight:600;font-size:1.35rem;display:flex;align-items:center;gap:12px}
.brand .mark{width:34px;height:34px;border-radius:50%;background:var(--ink);color:var(--paper);display:grid;place-items:center;font-size:.95rem;font-weight:600;font-family:var(--serif)}
.brand small{display:block;font-family:var(--sans);font-size:.62rem;font-weight:600;letter-spacing:.22em;text-transform:uppercase;color:var(--muted);margin-top:2px}
nav.menu{display:flex;gap:30px;align-items:center}
nav.menu a{font-size:.83rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-soft);position:relative;padding:6px 0}
nav.menu a::after{content:"";position:absolute;left:0;bottom:0;width:0;height:2px;background:var(--accent);transition:width .28s}
nav.menu a:hover::after{width:100%}
nav.menu a:hover{color:var(--ink)}
.nav-cta, li.nav-cta > a{background:var(--ink);color:var(--paper)!important;padding:11px 20px;border-radius:2px;font-size:.78rem!important;letter-spacing:.1em;transition:background .25s}
.nav-cta:hover, li.nav-cta > a:hover{background:var(--accent);color:#fff!important}
.nav-cta::after, li.nav-cta > a::after{display:none}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:6px}
.burger span{width:24px;height:2px;background:var(--ink);transition:.3s}
.hero{position:relative;padding:90px 0 60px;border-bottom:1px solid var(--line)}
.hero .kicker{font-size:.78rem;font-weight:600;letter-spacing:.28em;text-transform:uppercase;color:var(--accent);margin-bottom:22px;display:flex;align-items:center;gap:14px}
.hero .kicker::before{content:"";width:42px;height:1px;background:var(--accent)}
.hero h1{font-family:var(--serif);font-weight:400;font-size:clamp(2.6rem,6vw,5rem);line-height:1.02;letter-spacing:-.015em;max-width:15ch}
.hero h1 em{font-style:italic;color:var(--accent)}
.hero .lede{margin-top:28px;max-width:52ch;font-size:1.12rem;color:var(--ink-soft);line-height:1.65}
.hero-actions{margin-top:38px;display:flex;gap:16px;flex-wrap:wrap}
.btn{display:inline-flex;align-items:center;gap:10px;padding:14px 26px;border-radius:2px;font-weight:600;font-size:.9rem;transition:.25s;cursor:pointer;border:1px solid transparent}
.btn-primary{background:var(--accent);color:#fff}
.btn-primary:hover{background:#9a3826;transform:translateY(-2px)}
.btn-ghost{border-color:var(--ink);color:var(--ink)}
.btn-ghost:hover{background:var(--ink);color:var(--paper)}
/* NEW: expertise strip replaces year-counter cliche */
.hero-expertise{margin-top:54px;padding-top:28px;border-top:1px solid var(--line)}
.hero-expertise .lab{font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;color:var(--muted);margin-bottom:16px}
.hx-row{display:flex;flex-wrap:wrap;gap:10px 12px;align-items:center}
.hx-row .hx{font-family:var(--serif);font-size:1.15rem;color:var(--ink-soft);font-weight:500}
.hx-row .dot{width:5px;height:5px;border-radius:50%;background:var(--accent);opacity:.6}
.hero-credit{margin-top:24px;font-size:.95rem;color:var(--muted);font-style:italic;font-family:var(--serif)}
.logos{padding:40px 0;border-bottom:1px solid var(--line);background:var(--paper-2)}
.logos .lab{text-align:center;font-size:.72rem;letter-spacing:.24em;text-transform:uppercase;color:var(--muted);margin-bottom:26px}
.logo-row{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:14px 38px}
.logo-row span{font-family:var(--serif);font-size:1.15rem;font-weight:500;color:var(--ink-soft);opacity:.72;transition:.25s}
.logo-row span:hover{opacity:1;color:var(--accent)}
section.block{padding:84px 0}
.sec-head{display:flex;align-items:flex-end;justify-content:space-between;gap:24px;margin-bottom:44px;flex-wrap:wrap}
.sec-head .eyebrow{font-size:.76rem;font-weight:600;letter-spacing:.24em;text-transform:uppercase;color:var(--accent);margin-bottom:14px}
.sec-head h2{font-family:var(--serif);font-weight:400;font-size:clamp(2rem,4vw,3rem);line-height:1.05;letter-spacing:-.01em;max-width:18ch}
.sec-head p{max-width:42ch;color:var(--ink-soft);font-size:1.02rem}
.roles{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border:1px solid var(--ink)}
.role{padding:38px 32px;border-right:1px solid var(--ink);position:relative;transition:background .3s;min-height:300px;display:flex;flex-direction:column}
.role:last-child{border-right:0}
.role:hover{background:var(--ink);color:var(--paper)}
.role .num{font-family:var(--serif);font-size:.95rem;color:var(--accent);letter-spacing:.1em}
.role h3{font-family:var(--serif);font-weight:500;font-size:1.7rem;margin:18px 0 14px;line-height:1.1}
.role p{font-size:.96rem;color:inherit;opacity:.85;flex:1}
.role .more{margin-top:20px;font-size:.78rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;display:inline-flex;align-items:center;gap:8px}
.role .more .ar{transition:transform .25s}
.role:hover .more .ar{transform:translateX(6px)}
.role:hover .num{color:var(--gold)}
/* ABOUT band with photo */
.about{background:var(--paper-2);border-bottom:1px solid var(--line)}
.about-grid{display:grid;grid-template-columns:340px 1fr;gap:56px;align-items:center}
.about-photo{position:relative}
.about-photo .frame{aspect-ratio:1/1;border-radius:4px;overflow:hidden;background:var(--ink);border:1px solid var(--line);position:relative}
.about-photo .frame img{width:100%;height:100%;object-fit:cover}
.about-photo .ph{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;color:#8a909e;text-align:center;padding:20px;gap:8px}
.about-photo .ph .ico{font-size:2.4rem;font-family:var(--serif)}
.about-photo .ph small{font-size:.72rem;letter-spacing:.1em;line-height:1.5}
.about-photo .cap{position:absolute;bottom:-14px;right:-14px;background:var(--accent);color:#fff;font-family:var(--serif);font-size:.85rem;padding:10px 16px;border-radius:3px;max-width:200px;line-height:1.2}
.about-body .eyebrow{font-size:.76rem;font-weight:600;letter-spacing:.24em;text-transform:uppercase;color:var(--accent);margin-bottom:16px}
.about-body h2{font-family:var(--serif);font-weight:400;font-size:clamp(1.9rem,3.6vw,2.7rem);line-height:1.1;margin-bottom:20px}
.about-body p{color:var(--ink-soft);margin-bottom:16px;max-width:56ch}
.about-body .sig{font-family:var(--serif);font-style:italic;font-size:1.3rem;color:var(--ink);margin-top:8px}
.directory{background:var(--ink);color:var(--paper)}
.directory .sec-head .eyebrow{color:var(--gold)}
.directory .sec-head h2{color:var(--paper)}
.directory .sec-head p{color:#b9bdc7}
.filters{display:flex;flex-direction:column;gap:18px;margin-bottom:34px}
.filter-group{display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.filter-group .fl-label{font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;color:#8a909e;min-width:96px}
.chip{background:transparent;border:1px solid #3a4150;color:#c9cdd6;padding:8px 16px;border-radius:40px;font-size:.82rem;font-weight:500;cursor:pointer;transition:.2s;font-family:var(--sans)}
.chip:hover{border-color:var(--paper);color:var(--paper)}
.chip.active{background:var(--accent);border-color:var(--accent);color:#fff}
.chip.active.topic{background:var(--gold);border-color:var(--gold);color:var(--ink)}
.chip.active.pub{background:var(--paper);border-color:var(--paper);color:var(--ink)}
.dir-meta{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;border-top:1px solid #2c323e;padding-top:20px;flex-wrap:wrap;gap:10px}
.dir-count{font-size:.82rem;color:#8a909e}
.dir-count b{color:var(--paper);font-family:var(--serif);font-size:1rem}
.byline-list{display:grid;gap:0}
.byline{display:grid;grid-template-columns:1fr auto;gap:18px 24px;align-items:center;padding:22px 4px;border-bottom:1px solid #2c323e;transition:.25s}
.byline:hover{background:#222836;padding-left:14px}
.byline .bl-main{min-width:0}
.byline .bl-title{font-family:var(--serif);font-size:1.16rem;font-weight:500;line-height:1.25;color:var(--paper)}
.byline:hover .bl-title{color:var(--gold)}
.byline .bl-tags{margin-top:9px;display:flex;gap:8px;flex-wrap:wrap}
.bl-tag{font-size:.68rem;letter-spacing:.08em;text-transform:uppercase;color:#8a909e;border:1px solid #343b48;padding:3px 9px;border-radius:3px}
.bl-tag.t-topic{color:var(--gold);border-color:#4a4330}
.byline .bl-pub{text-align:right;white-space:nowrap}
.byline .bl-pub .p{font-weight:600;font-size:.92rem;color:var(--paper)}
.byline .bl-pub .arrow{font-size:.74rem;color:var(--accent);margin-top:4px;letter-spacing:.1em;text-transform:uppercase;font-weight:600;opacity:0;transition:.25s}
.byline:hover .bl-pub .arrow{opacity:1}
.empty{padding:50px 0;text-align:center;color:#8a909e;display:none}
.casestudy{background:var(--paper-2);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.parent-banner{border:1px solid var(--ink);padding:28px 32px;margin-bottom:0;display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap;background:var(--ink);color:var(--paper)}
.parent-banner .pb-left .pl{font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-bottom:8px}
.parent-banner .pb-left .url{font-family:var(--serif);font-size:1.7rem;font-weight:500}
.parent-banner .pb-right{font-size:.95rem;color:#b9bdc7;max-width:42ch}
.cs-grid{display:grid;grid-template-columns:1fr 1fr;gap:0;border:1px solid var(--ink);border-top:0}
.cs-card{padding:36px;border-right:1px solid var(--ink)}
.cs-card:last-child{border-right:0}
.cs-card .url{font-family:var(--serif);font-size:1.4rem;font-weight:500;display:flex;align-items:baseline;gap:8px;flex-wrap:wrap}
.cs-card .url .live{font-family:var(--sans);font-size:.62rem;letter-spacing:.16em;text-transform:uppercase;color:#fff;background:var(--accent);padding:3px 8px;border-radius:3px;transform:translateY(-4px)}
.cs-card .role-line{font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin:14px 0 18px}
.cs-card p{font-size:.97rem;color:var(--ink-soft)}
.cs-stats{display:flex;gap:28px;margin-top:24px;flex-wrap:wrap}
.cs-stats .s .n{font-family:var(--serif);font-size:1.3rem;color:var(--accent-2)}
.cs-stats .s .l{font-size:.66rem;text-transform:uppercase;letter-spacing:.1em;color:var(--muted);margin-top:4px}
.skills-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:40px}
.skill{background:var(--paper);border:1px solid var(--line);padding:30px 28px;border-radius:3px;transition:.28s;position:relative;overflow:hidden}
.skill::before{content:"";position:absolute;left:0;top:0;width:3px;height:0;background:var(--accent);transition:height .3s}
.skill:hover{transform:translateY(-4px);box-shadow:0 16px 40px -22px rgba(26,31,43,.4)}
.skill:hover::before{height:100%}
.skill .ic{font-family:var(--serif);font-size:1.1rem;color:var(--accent);font-weight:600;margin-bottom:14px}
.skill h4{font-family:var(--serif);font-weight:500;font-size:1.28rem;margin-bottom:12px}
.skill ul{list-style:none}
.skill li{font-size:.9rem;color:var(--ink-soft);padding:6px 0 6px 18px;position:relative;border-bottom:1px solid var(--paper-2)}
.skill li:last-child{border-bottom:0}
.skill li::before{content:"\203A";position:absolute;left:0;color:var(--accent);font-weight:700}
.expertise{display:flex;flex-wrap:wrap;gap:12px;margin-top:6px}
.exp-pill{border:1px solid var(--ink);padding:10px 20px;border-radius:40px;font-size:.9rem;font-weight:500;transition:.22s}
.exp-pill:hover{background:var(--accent);color:#fff;border-color:var(--accent)}
.exp-pill b{font-family:var(--serif);color:var(--accent);margin-left:6px;font-size:.82rem}
.exp-pill:hover b{color:#fff}
.cta{background:var(--accent-2);color:var(--paper);text-align:center;padding:88px 0}
.cta .eyebrow{font-size:.76rem;letter-spacing:.26em;text-transform:uppercase;color:var(--gold);margin-bottom:20px}
.cta h2{font-family:var(--serif);font-weight:400;font-size:clamp(2.2rem,5vw,3.6rem);line-height:1.08;max-width:18ch;margin:0 auto}
.cta p{margin:22px auto 34px;max-width:46ch;color:#c5cdd9}
.cta .btn-primary{background:var(--gold);color:var(--ink)}
.cta .btn-primary:hover{background:#fff}
footer.site{background:var(--ink);color:#aab0bd;padding:56px 0 34px}
.foot-top{display:flex;justify-content:space-between;gap:30px;flex-wrap:wrap;border-bottom:1px solid #2c323e;padding-bottom:30px}
.foot-brand{font-family:var(--serif);color:var(--paper);font-size:1.5rem;font-weight:500}
.foot-brand small{display:block;font-family:var(--sans);font-size:.68rem;letter-spacing:.18em;text-transform:uppercase;color:#7c828f;margin-top:6px}
.foot-social{display:flex;gap:10px;flex-wrap:wrap}
.foot-social a{border:1px solid #343b48;padding:9px 16px;border-radius:3px;font-size:.78rem;letter-spacing:.06em;transition:.22s;color:#c9cdd6}
.foot-social a:hover{background:var(--paper);color:var(--ink);border-color:var(--paper)}
.foot-bot{display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;margin-top:24px;font-size:.78rem;color:#7c828f}
@media(max-width:860px){
  nav.menu{position:fixed;inset:74px 0 auto 0;background:var(--paper);flex-direction:column;gap:0;padding:8px 0;border-bottom:1px solid var(--line);transform:translateY(-130%);transition:transform .35s;align-items:stretch}
  nav.menu.open{transform:translateY(0)}
  nav.menu a{padding:16px 28px;border-bottom:1px solid var(--line)}
  nav.menu a::after{display:none}
  .nav-cta{margin:10px 28px;text-align:center}
  .burger{display:flex}
  .roles,.skills-grid{grid-template-columns:1fr}
  .role{border-right:0;border-bottom:1px solid var(--ink);min-height:auto}
  .role:last-child{border-bottom:0}
  .about-grid{grid-template-columns:1fr;gap:50px}
  .about-photo{max-width:320px}
  .cs-grid{grid-template-columns:1fr}
  .cs-card{border-right:0;border-bottom:1px solid var(--ink)}
  .cs-card:last-child{border-bottom:0}
  .byline{grid-template-columns:1fr}
  .byline .bl-pub{text-align:left}
  .filter-group .fl-label{min-width:auto;width:100%}
}

/* ===== WordPress page / post / archive content ===== */
.page-hero{padding:70px 0 40px;border-bottom:1px solid var(--line)}
.page-hero .eyebrow{font-size:.76rem;font-weight:600;letter-spacing:.24em;text-transform:uppercase;color:var(--accent);margin-bottom:16px}
.page-hero h1{font-family:var(--serif);font-weight:400;font-size:clamp(2.2rem,5vw,3.6rem);line-height:1.05;letter-spacing:-.01em}
.content-area{padding:60px 0;max-width:760px}
.content-area p{margin-bottom:1.2em}
.content-area h2{font-family:var(--serif);font-size:1.8rem;margin:1.4em 0 .5em;font-weight:500}
.content-area h3{font-family:var(--serif);font-size:1.4rem;margin:1.2em 0 .4em;font-weight:500}
.content-area a{color:var(--accent);text-decoration:underline;text-underline-offset:3px}
.content-area ul,.content-area ol{margin:0 0 1.2em 1.3em}
.content-area li{margin-bottom:.4em}
.content-area img{border-radius:4px;margin:1.5em 0}
.content-area blockquote{border-left:3px solid var(--accent);padding-left:20px;font-family:var(--serif);font-style:italic;font-size:1.2rem;color:var(--ink-soft);margin:1.5em 0}
.post-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:30px}
.post-card{background:var(--paper);border:1px solid var(--line);border-radius:4px;overflow:hidden;transition:.28s}
.post-card:hover{transform:translateY(-4px);box-shadow:0 16px 40px -24px rgba(26,31,43,.4)}
.post-card .thumb{aspect-ratio:16/10;background:var(--paper-2);overflow:hidden}
.post-card .thumb img{width:100%;height:100%;object-fit:cover;transition:.4s}
.post-card:hover .thumb img{transform:scale(1.05)}
.post-card .pc-body{padding:24px}
.post-card .pc-meta{font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-bottom:10px}
.post-card h3{font-family:var(--serif);font-size:1.3rem;font-weight:500;line-height:1.25;margin-bottom:10px}
.post-card p{font-size:.92rem;color:var(--ink-soft)}
.contact-form{max-width:560px;margin-top:30px}
.contact-form label{display:block;font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin:18px 0 6px}
.contact-form input,.contact-form textarea{width:100%;padding:14px 16px;border:1px solid var(--line);background:var(--paper);font-family:var(--sans);font-size:1rem;border-radius:3px;color:var(--ink)}
.contact-form input:focus,.contact-form textarea:focus{outline:none;border-color:var(--accent)}
.contact-form textarea{min-height:140px;resize:vertical}
.contact-form .btn{margin-top:22px;border:0}
.pagination{display:flex;gap:10px;justify-content:center;margin-top:50px;flex-wrap:wrap}
.pagination a,.pagination span{padding:10px 16px;border:1px solid var(--line);border-radius:3px;font-size:.9rem;font-weight:600}
.pagination .current{background:var(--ink);color:var(--paper);border-color:var(--ink)}
.pagination a:hover{background:var(--accent);color:#fff;border-color:var(--accent)}
.skip-link{position:absolute;left:-9999px}
.skip-link:focus{left:8px;top:8px;background:var(--ink);color:#fff;padding:10px 16px;z-index:999}
/* WP custom-logo */
.brand img{max-height:42px;width:auto}
/* nav menu as WP <ul> */
nav.menu ul{list-style:none;display:flex;gap:30px;align-items:center;margin:0}
nav.menu .current-menu-item>a::after{width:100%}
@media(max-width:860px){
  nav.menu ul{position:fixed;inset:74px 0 auto 0;background:var(--paper);flex-direction:column;gap:0;padding:8px 0;border-bottom:1px solid var(--line);transform:translateY(-130%);transition:transform .35s;align-items:stretch}
  nav.menu ul.open{transform:translateY(0)}
  nav.menu a{padding:16px 28px;border-bottom:1px solid var(--line);display:block}
  .post-grid{grid-template-columns:1fr}
}

/* ===== Availability line (hero) ===== */
.hero-avail{margin-top:14px;display:inline-flex;align-items:center;gap:10px;font-size:.92rem;font-weight:600;color:var(--accent-2);background:rgba(31,58,95,.07);border:1px solid rgba(31,58,95,.18);padding:8px 16px;border-radius:40px}
.dot-live{width:8px;height:8px;border-radius:50%;background:#2e9e5b;position:relative;flex:none}
.dot-live::after{content:"";position:absolute;inset:-4px;border-radius:50%;border:2px solid rgba(46,158,91,.4);animation:pulse 2s infinite}
@keyframes pulse{0%{transform:scale(.8);opacity:1}100%{transform:scale(1.8);opacity:0}}

/* ===== FAQ ===== */
.faq-list{display:grid;gap:0;border-top:1px solid var(--line)}
.faq-item{border-bottom:1px solid var(--line)}
.faq-item summary{font-family:var(--serif);font-size:1.2rem;font-weight:500;padding:22px 40px 22px 0;cursor:pointer;list-style:none;position:relative;color:var(--ink);transition:color .2s}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{content:"+";position:absolute;right:6px;top:18px;font-size:1.5rem;color:var(--accent);font-family:var(--sans);transition:transform .25s}
.faq-item[open] summary::after{transform:rotate(45deg)}
.faq-item summary:hover{color:var(--accent)}
.faq-a{padding:0 60px 24px 0;color:var(--ink-soft);max-width:70ch;line-height:1.65}

/* ===== Single post meta ===== */
.post-meta-line{margin-top:18px;font-size:.9rem;color:var(--muted);display:flex;flex-wrap:wrap;gap:10px;align-items:center}
.post-meta-line a{color:var(--accent)}
.post-meta-line .dot-sep{color:var(--line)}
.post-foot{padding-top:0;padding-bottom:70px}

/* ===== Writer card dual links ===== */
.role-links{margin-top:20px;display:flex;flex-direction:column;gap:10px}
.role-links .more{margin-top:0}

/* ===== Blog hero tagline ===== */
.page-hero-tagline{margin-top:18px;font-size:1.1rem;color:var(--ink-soft);max-width:54ch;font-family:var(--serif);font-style:italic}

/* ===== Linked URLs in case-study + parent banner ===== */
a.url{text-decoration:none;transition:color .2s}
.cs-card a.url:hover{color:var(--accent)}
.parent-banner a.url{color:var(--paper)}
.parent-banner a.url:hover{color:var(--gold)}

/* ===== Latest from the blog (homepage strip) ===== */
.latest-blog{background:var(--paper-2);border-top:1px solid var(--line)}
.latest-blog .sec-head p{margin:0}
.latest-blog .sec-head .more{font-size:.82rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--accent)}

/* ===== About page layout (photo + bio) ===== */
.about-page-grid{display:grid;grid-template-columns:320px 1fr;gap:56px;align-items:start;padding:60px 28px}
.about-page-photo .frame{aspect-ratio:1/1;border-radius:4px;overflow:hidden;background:var(--ink);border:1px solid var(--line)}
.about-page-photo .frame img{width:100%;height:100%;object-fit:cover}
.about-page-body{padding:0;max-width:none}
.about-page-body .sig{font-family:var(--serif);font-style:italic;font-size:1.4rem;color:var(--ink);margin-top:30px}
@media(max-width:860px){
  .about-page-grid{grid-template-columns:1fr;gap:36px}
  .about-page-photo{max-width:280px}
}
