/*
Theme Name: FOLIO
Theme URI: https://the416edit.ca
Author: The 416 Edit
Author URI: https://the416edit.ca
Description: FOLIO — an editorial magazine theme for a network of design blogs. One structural system; ten color vibes selected per blog via Appearance → Customize → FOLIO Vibe (folio, counter, grove, ochre, bloom, mono, slate, press, atelier, tide). Display: Bodoni Moda; reading: Newsreader; UI: Archivo; mono: IBM Plex Mono.
Version: 1.0.0
Requires at least: 6.0
Requires PHP: 7.4
License: GPL-2.0-or-later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: folio
*/

@import url('https://fonts.googleapis.com/css2?family=Bodoni+Moda:ital,opsz,wght@0,6..96,400..900;1,6..96,400..900&family=Newsreader:ital,opsz,wght@0,6..72,200..800;1,6..72,200..800&family=Archivo:ital,wght@0,300..900;1,300..900&family=IBM+Plex+Mono:ital,wght@0,400;0,500;0,600;1,400&display=swap');

/* ---------- tokens (folio default) ---------- */
:root{
  --font-display:'Bodoni Moda','Didot','Times New Roman',serif;
  --font-serif:'Newsreader','Georgia',serif;
  --font-sans:'Archivo','Helvetica Neue',Arial,sans-serif;
  --font-mono:'IBM Plex Mono',ui-monospace,monospace;
  --paper:#F6F2E9;--paper-2:#EFE9DB;--paper-3:#E6DECC;
  --ink:#1B1813;--ink-2:#4A463C;--ink-3:#837C6D;--ink-surface:#16140F;
  --line:rgba(27,24,19,.16);--line-soft:rgba(27,24,19,.09);
  --vermillion:#DE3C1E;--vermillion-press:#B22E14;--vermillion-tint:#F7DCD2;--highlight:#F4DE7E;
  --on-dark:#F1ECDF;--on-dark-muted:#B7B0A0;--on-dark-subtle:#7C766A;
  --content-max:1320px;--ease:cubic-bezier(.2,0,0,1);
}
/* ---------- network vibes ---------- */
[data-theme="counter"]{--paper:#EDEFF2;--paper-2:#E4E7EC;--paper-3:#D7DBE2;--ink:#14171C;--ink-2:#3E444E;--ink-3:#767D88;--ink-surface:#0F1217;--vermillion:#1E50DC;--vermillion-press:#1640B0;--vermillion-tint:#D6DEF6;--line:rgba(20,23,28,.15)}
[data-theme="grove"]{--paper:#EFF2EB;--paper-2:#E6E9DF;--paper-3:#D9DFCF;--ink:#161A12;--ink-2:#414A39;--ink-3:#7A816E;--ink-surface:#10140C;--vermillion:#2C6E4B;--vermillion-press:#21533A;--vermillion-tint:#D8E7DB;--line:rgba(22,26,18,.15)}
[data-theme="ochre"]{--paper:#F4EEE2;--paper-2:#EDE5D5;--paper-3:#E2D7C2;--ink:#1E1810;--ink-2:#4D4434;--ink-3:#877B66;--ink-surface:#18120B;--vermillion:#B5561B;--vermillion-press:#8F4314;--vermillion-tint:#F2DCC4;--line:rgba(30,24,16,.16)}
[data-theme="bloom"]{--paper:#F7EEF1;--paper-2:#F0E4E9;--paper-3:#E8D6DE;--ink:#1C1418;--ink-2:#4C3E44;--ink-3:#8A7A80;--ink-surface:#170F12;--vermillion:#C2185B;--vermillion-press:#9C1349;--vermillion-tint:#F6D6E2;--line:rgba(28,20,24,.15)}
[data-theme="mono"]{--paper:#F0F0EE;--paper-2:#E7E7E4;--paper-3:#DBDBD7;--ink:#141413;--ink-2:#46463F;--ink-3:#7C7C73;--ink-surface:#0E0E0D;--vermillion:#3A3A38;--vermillion-press:#1F1F1E;--vermillion-tint:#DEDEDB;--line:rgba(20,20,18,.16)}
[data-theme="slate"]{--paper:#EBEEF0;--paper-2:#E2E6EA;--paper-3:#D5DBE0;--ink:#14181C;--ink-2:#3D454E;--ink-3:#757D86;--ink-surface:#0F1318;--vermillion:#B8841F;--vermillion-press:#93680F;--vermillion-tint:#EDE0C2;--line:rgba(20,24,28,.15)}
[data-theme="press"]{--paper:#F1EFE8;--paper-2:#E9E6DC;--paper-3:#DED9CB;--ink:#181614;--ink-2:#46433D;--ink-3:#837D72;--ink-surface:#131210;--vermillion:#C8202B;--vermillion-press:#9E1820;--vermillion-tint:#F3D3D4;--line:rgba(24,22,20,.16)}
[data-theme="atelier"]{--paper:#F2EEE9;--paper-2:#EAE4DC;--paper-3:#DFD6CB;--ink:#1A151A;--ink-2:#483F49;--ink-3:#847A85;--ink-surface:#140F15;--vermillion:#6B3FA0;--vermillion-press:#543080;--vermillion-tint:#E6DAF0;--line:rgba(26,21,26,.15)}
[data-theme="tide"]{--paper:#E9F1F0;--paper-2:#E0EAE9;--paper-3:#D2E0DE;--ink:#11191A;--ink-2:#38474A;--ink-3:#6F8083;--ink-surface:#0C1414;--vermillion:#0E7C7B;--vermillion-press:#0A5E5D;--vermillion-tint:#CFE7E5;--line:rgba(17,25,26,.15)}

/* ---------- base ---------- */
*{box-sizing:border-box;}
html,body{margin:0;padding:0;}
body{background:var(--paper);color:var(--ink);font-family:var(--font-serif);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;}
::selection{background:var(--vermillion);color:#fff;}
a{color:inherit;text-decoration:none;}
img{max-width:100%;height:auto;}
.wrap{max-width:var(--content-max);margin:0 auto;padding-inline:40px;}
.kicker{font-family:var(--font-sans);font-weight:700;font-size:12px;line-height:1;letter-spacing:.16em;text-transform:uppercase;color:var(--vermillion);}

/* ---------- utility rail ---------- */
.util{border-bottom:1px solid var(--line);}
.util .wrap{display:flex;align-items:center;justify-content:space-between;height:38px;}
.util .meta{color:var(--ink-3);font-family:var(--font-mono);font-size:12px;text-transform:uppercase;letter-spacing:.04em;}
.util .meta .v{color:var(--vermillion);}

/* ---------- masthead ---------- */
.masthead{border-bottom:1.5px solid var(--ink);position:sticky;top:0;z-index:30;background:var(--paper);}
.masthead .bar{display:flex;align-items:flex-end;justify-content:space-between;padding:24px 0 18px;}
.brand{display:block;line-height:.86;}
.brand .word{font-family:var(--font-display);font-weight:800;font-size:52px;letter-spacing:-.01em;color:var(--ink);}
.brand .word .dot{color:var(--vermillion);}
.brand .tag{display:block;margin-top:9px;white-space:nowrap;font-family:var(--font-sans);font-weight:600;font-size:10px;letter-spacing:.3em;text-transform:uppercase;color:var(--vermillion);}
.actions{display:flex;align-items:center;gap:12px;}
.icon-btn{width:42px;height:42px;border:1.5px solid var(--ink);border-radius:2px;background:transparent;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s var(--ease);}
.icon-btn:hover{background:var(--paper-2);}
.btn{font-family:var(--font-sans);font-weight:600;font-size:14px;white-space:nowrap;padding:12px 22px;border-radius:2px;cursor:pointer;border:1.5px solid var(--vermillion);background:var(--vermillion);color:#fff;display:inline-block;transition:background .15s var(--ease);}
.btn:hover{background:var(--vermillion-press);border-color:var(--vermillion-press);}
nav.sections{border-top:1px solid var(--line);}
nav.sections .wrap{display:flex;gap:30px;flex-wrap:wrap;}
nav.sections a{font-family:var(--font-sans);font-weight:600;font-size:14px;color:var(--ink-2);padding:13px 0;margin-bottom:-1px;white-space:nowrap;border-bottom:2px solid transparent;transition:color .15s var(--ease);}
nav.sections a:hover{color:var(--ink);}
nav.sections a.active,nav.sections .current-menu-item a{color:var(--ink);border-bottom-color:var(--vermillion);}
nav.sections .spacer{margin-left:auto;}
nav.sections a.loc{color:var(--ink-3);font-family:var(--font-mono);font-weight:400;font-size:12px;letter-spacing:.04em;text-transform:uppercase;}

/* ---------- front page ---------- */
.hero{display:grid;grid-template-columns:1.08fr .92fr;gap:52px;align-items:stretch;padding:56px 0 52px;border-bottom:1.5px solid var(--ink);}
.hero .copy{display:flex;flex-direction:column;justify-content:center;}
.hero h1{font-family:var(--font-display);font-weight:700;font-size:clamp(42px,4.6vw,66px);line-height:.98;letter-spacing:-.018em;color:var(--ink);margin:18px 0 22px;text-wrap:balance;}
.hero .lede{font-family:var(--font-serif);font-weight:380;font-size:22px;line-height:1.45;color:var(--ink-2);margin:0 0 28px;max-width:46ch;}
.hero .row{display:flex;align-items:center;gap:18px;}
.hero .row .meta{font-family:var(--font-mono);font-size:12px;text-transform:uppercase;letter-spacing:.04em;color:var(--ink-3);}
.hero figure{position:relative;margin:0;min-height:440px;}
.hero figure img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;border:1px solid var(--line);}
.badge{position:absolute;top:14px;left:14px;z-index:2;background:var(--vermillion);color:#fff;font-family:var(--font-mono);font-size:11px;text-transform:uppercase;letter-spacing:.06em;padding:5px 11px;}

.sec-head{display:flex;align-items:baseline;justify-content:space-between;margin:48px 0 28px;}
.sec-head h2{font-family:var(--font-serif);font-weight:560;font-size:28px;color:var(--ink);margin:0;}
.link{font-family:var(--font-sans);font-weight:600;font-size:13px;letter-spacing:.08em;text-transform:uppercase;color:var(--vermillion);display:inline-flex;align-items:center;gap:7px;}
.link .ar{font-family:var(--font-serif);font-size:16px;transition:transform .15s var(--ease);}
.link:hover .ar{transform:translateX(3px);}

.grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:36px;}
.card{display:flex;flex-direction:column;}
.card .ph{margin-bottom:16px;aspect-ratio:3/2;overflow:hidden;border:1px solid var(--line);}
.card .ph img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .4s var(--ease);}
.card:hover .ph img{transform:scale(1.04);}
.card .cat{font-family:var(--font-sans);font-weight:700;font-size:11px;letter-spacing:.15em;text-transform:uppercase;color:var(--vermillion);}
.card h3{font-family:var(--font-display);font-weight:700;font-size:25px;line-height:1.06;letter-spacing:-.01em;color:var(--ink);margin:11px 0 10px;text-wrap:balance;transition:color .18s var(--ease);}
.card:hover h3{color:var(--vermillion);}
.card p{font-family:var(--font-serif);font-size:16px;line-height:1.5;color:var(--ink-2);margin:0 0 12px;}
.card .byl{font-family:var(--font-mono);font-size:11px;letter-spacing:.03em;text-transform:uppercase;color:var(--ink-3);margin-top:auto;}

.list{border-top:1.5px solid var(--ink);}
.list .row{display:grid;grid-template-columns:52px 1fr 180px;gap:28px;align-items:center;padding:24px 0;border-bottom:1px solid var(--line);transition:background .15s var(--ease);}
.list .row:hover{background:var(--paper-2);}
.list .num{font-family:var(--font-mono);font-size:13px;color:var(--ink-3);}
.list .cat{font-family:var(--font-sans);font-weight:700;font-size:11px;letter-spacing:.15em;text-transform:uppercase;color:var(--vermillion);}
.list h3{font-family:var(--font-display);font-weight:700;font-size:26px;line-height:1.05;letter-spacing:-.01em;color:var(--ink);margin:8px 0 0;transition:color .15s var(--ease);}
.list .row:hover h3{color:var(--vermillion);}
.list .right{text-align:right;font-family:var(--font-mono);font-size:11px;text-transform:uppercase;letter-spacing:.04em;color:var(--ink-3);line-height:1.9;}

/* ---------- dispatch ---------- */
.dispatch{background:var(--ink-surface);color:var(--on-dark);margin-top:80px;}
.dispatch .wrap{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center;padding:64px 40px;}
.dispatch .k{font-family:var(--font-sans);font-weight:700;font-size:11px;letter-spacing:.15em;text-transform:uppercase;color:var(--vermillion);}
.dispatch h2{font-family:var(--font-display);font-weight:700;font-size:40px;line-height:1.02;letter-spacing:-.015em;color:var(--on-dark);margin:16px 0 14px;}
.dispatch p{font-family:var(--font-serif);font-weight:380;font-size:18px;line-height:1.5;color:var(--on-dark-muted);margin:0;max-width:40ch;}
.dispatch .signup .field{display:flex;}
.dispatch .signup input{flex:1;border:1.5px solid var(--on-dark);border-right:none;border-radius:2px 0 0 2px;padding:14px 16px;font-family:var(--font-sans);font-size:15px;background:transparent;color:var(--on-dark);outline:none;}
.dispatch .signup input::placeholder{color:var(--on-dark-subtle);}
.dispatch .signup .sb{font-family:var(--font-sans);font-weight:600;font-size:13px;letter-spacing:.06em;text-transform:uppercase;background:var(--vermillion);color:#fff;border:1.5px solid var(--vermillion);border-radius:0 2px 2px 0;padding:0 22px;cursor:pointer;display:inline-flex;align-items:center;}
.dispatch .fine{display:block;margin-top:12px;font-family:var(--font-mono);font-size:11px;text-transform:uppercase;letter-spacing:.04em;color:var(--on-dark-subtle);}

/* ---------- article ---------- */
.read{max-width:760px;margin:0 auto;}
.read-wide{max-width:1040px;margin:0 auto;}
.breadcrumb{border-bottom:1px solid var(--line);}
.breadcrumb a{display:inline-flex;align-items:center;gap:8px;padding:18px 0;font-family:var(--font-mono);font-size:12px;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-3);}
.breadcrumb a:hover{color:var(--vermillion);}
.arthead{text-align:center;padding:52px 0 26px;}
.arthead h1{font-family:var(--font-display);font-weight:700;font-size:clamp(40px,4.8vw,64px);line-height:1;letter-spacing:-.018em;color:var(--ink);margin:18px 0 22px;text-wrap:balance;}
.arthead .lede{font-family:var(--font-serif);font-weight:380;font-size:23px;line-height:1.45;color:var(--ink-2);margin:0 auto;max-width:46ch;}
.byline{display:flex;align-items:center;gap:14px;border-top:1.5px solid var(--ink);border-bottom:1px solid var(--line);padding:16px 0;}
.byline .av{width:46px;height:46px;border-radius:999px;background:var(--vermillion);color:#fff;font-family:var(--font-display);font-weight:700;font-size:21px;display:flex;align-items:center;justify-content:center;flex:none;}
.byline .nm{font-family:var(--font-sans);font-weight:700;font-size:14px;color:var(--ink);}
.byline .ro{font-family:var(--font-mono);font-size:11px;text-transform:uppercase;letter-spacing:.04em;color:var(--ink-3);margin-top:2px;}
figure.lead{margin:36px auto 10px;}
figure.lead img{width:100%;aspect-ratio:16/9;object-fit:cover;display:block;background:var(--paper-3);border:1px solid var(--line);}
figcaption{font-family:var(--font-sans);font-size:13px;color:var(--ink-3);margin-top:10px;text-align:center;}
.prose{font-family:var(--font-serif);font-weight:400;font-size:19px;line-height:1.64;color:var(--ink);margin:28px auto 0;max-width:760px;text-wrap:pretty;}
.prose p{margin:0 0 1.15em;}
.prose>p:first-of-type::first-letter{font-family:var(--font-display);font-weight:800;font-size:78px;line-height:.72;float:left;margin:8px 12px 0 0;color:var(--vermillion);}
.prose a{color:var(--vermillion);box-shadow:inset 0 -1px 0 var(--vermillion);}
.prose a:hover{background:var(--vermillion-tint);}
.prose em{font-style:italic;}
.prose strong{font-weight:640;}
.prose mark{background:var(--highlight);color:var(--ink);padding:0 .12em;}
.prose h2{font-family:var(--font-serif);font-weight:560;font-size:29px;line-height:1.18;letter-spacing:-.006em;color:var(--ink);margin:44px 0 14px;max-width:30ch;}
.prose h3{font-family:var(--font-serif);font-weight:560;font-size:23px;line-height:1.2;color:var(--ink);margin:32px 0 10px;}
.prose img{border:1px solid var(--line);}
.prose ul,.prose ol{padding-left:1.3em;margin:0 0 1.15em;}
.prose li{margin:.4em 0;}
.prose blockquote{margin:38px 0;border-left:3px solid var(--vermillion);padding-left:26px;}
.prose blockquote p{font-family:var(--font-display);font-style:italic;font-weight:500;font-size:31px;line-height:1.18;letter-spacing:-.01em;color:var(--ink);}
.prose table{border-collapse:collapse;width:100%;font-size:16px;margin:1.8em 0;}
.prose th,.prose td{border:1px solid var(--line);padding:.6em .8em;text-align:left;}
.prose thead th{background:var(--paper-2);font-family:var(--font-sans);}
.prose aside{background:var(--paper-2);border:1px solid var(--line);border-left:3px solid var(--vermillion);padding:1.3em 1.6em;margin:2em 0;}
.prose aside h2{font-family:var(--font-sans);font-size:13px;letter-spacing:.12em;text-transform:uppercase;color:var(--vermillion);margin:0 0 .5em;border:none;padding:0;}
.endrule{border-top:1.5px solid var(--ink);margin:44px auto 18px;max-width:760px;}
.tags{display:flex;gap:10px;flex-wrap:wrap;max-width:760px;margin:0 auto;}
.tag{font-family:var(--font-mono);font-size:12px;text-transform:uppercase;letter-spacing:.04em;padding:5px 12px;border-radius:999px;border:1px solid var(--line);color:var(--ink-2);}
.more{margin-top:80px;border-top:1.5px solid var(--ink);padding-top:32px;}
.more h2{font-family:var(--font-serif);font-weight:560;font-size:26px;color:var(--ink);margin:0 0 28px;}

/* ---------- generic page + contact ---------- */
.pagehead{border-bottom:1.5px solid var(--ink);padding:56px 0 44px;}
.pagehead h1{font-family:var(--font-display);font-weight:700;font-size:clamp(46px,6vw,84px);line-height:.96;letter-spacing:-.018em;color:var(--ink);margin:16px 0 0;}
.pagehead .lede{font-family:var(--font-serif);font-weight:380;font-size:22px;line-height:1.45;color:var(--ink-2);margin:22px 0 0;max-width:54ch;}
.page-body{padding:40px 0 10px;}
.layout{display:grid;grid-template-columns:1fr 1.1fr;gap:80px;padding:52px 0 0;align-items:start;}
.dir .item{padding:22px 0;border-bottom:1px solid var(--line);}
.dir .item:first-child{border-top:1px solid var(--line);}
.dir .item h3{font-family:var(--font-sans);font-weight:700;font-size:12px;letter-spacing:.15em;text-transform:uppercase;color:var(--vermillion);margin:0 0 7px;}
.dir .item p{font-family:var(--font-serif);font-size:16px;line-height:1.5;color:var(--ink-2);margin:0;max-width:42ch;}
.studio{margin-top:40px;}
.studio .addr{font-family:var(--font-mono);font-size:13px;line-height:1.9;letter-spacing:.02em;text-transform:uppercase;color:var(--ink-2);margin:0;}
.studio .addr .v{color:var(--vermillion);}
.social{display:flex;gap:10px;margin-top:18px;flex-wrap:wrap;}
.social a{font-family:var(--font-mono);font-size:12px;text-transform:uppercase;letter-spacing:.04em;padding:8px 14px;border:1px solid var(--line);border-radius:999px;color:var(--ink-2);}
.social a:hover{border-color:var(--ink);color:var(--ink);}
.formcard{background:var(--paper-2);border:1px solid var(--line);padding:36px;}
.formcard h2{font-family:var(--font-serif);font-weight:560;font-size:26px;color:var(--ink);margin:0 0 4px;}
.formcard .sub{font-family:var(--font-serif);font-size:16px;color:var(--ink-2);margin:0 0 22px;}
.formcard p{margin:0 0 16px;}
.formcard label{display:block;font-family:var(--font-sans);font-weight:600;font-size:12px;letter-spacing:.04em;color:var(--ink-2);}
.formcard input[type=text],.formcard input[type=email],.formcard select,.formcard textarea{width:100%;margin-top:7px;font-family:var(--font-serif);font-size:16px;color:var(--ink);background:var(--paper);border:1.5px solid var(--ink);border-radius:2px;padding:12px 14px;outline:none;}
.formcard input::placeholder,.formcard textarea::placeholder{color:var(--ink-3);}
.formcard input:focus,.formcard select:focus,.formcard textarea:focus{border-color:var(--vermillion);box-shadow:inset 0 0 0 1px var(--vermillion);}
.formcard textarea{resize:vertical;min-height:130px;line-height:1.5;}
.formcard input[type=submit],.formcard .wpcf7-submit{width:auto;font-family:var(--font-sans);font-weight:600;font-size:14px;background:var(--ink);color:var(--paper);border:1.5px solid var(--ink);border-radius:2px;padding:13px 26px;cursor:pointer;margin-top:6px;}
.formcard input[type=submit]:hover{background:#000;}
.wpcf7-response-output{font-family:var(--font-mono);font-size:12px;margin-top:14px!important;}

/* ---------- archive / blog index ---------- */
.archive-head{padding:48px 0 12px;border-bottom:1.5px solid var(--ink);}
.archive-head h1{font-family:var(--font-display);font-weight:700;font-size:clamp(34px,4vw,56px);color:var(--ink);margin:0;}
.archive-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:40px 36px;padding:44px 0 0;}

/* ---------- footer ---------- */
.site-foot{background:var(--ink-surface);color:var(--on-dark);border-top:1px solid rgba(241,236,223,.14);margin-top:80px;}
.site-foot .wrap{padding:56px 40px 40px;}
.site-foot .top{display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:40px;border-bottom:1px solid rgba(241,236,223,.14);padding-bottom:36px;}
.site-foot .word{font-family:var(--font-display);font-weight:800;font-size:32px;color:var(--on-dark);}
.site-foot .word .dot{color:var(--vermillion);}
.site-foot .blurb{font-family:var(--font-serif);font-size:16px;line-height:1.5;color:var(--on-dark-muted);margin:18px 0 0;max-width:34ch;}
.site-foot .cols{display:flex;gap:56px;flex-wrap:wrap;}
.site-foot .col h4{font-family:var(--font-sans);font-weight:700;font-size:11px;letter-spacing:.15em;text-transform:uppercase;color:var(--vermillion);margin:0 0 16px;}
.site-foot .col a{display:block;font-family:var(--font-serif);font-size:16px;color:var(--on-dark);margin-bottom:11px;}
.site-foot .col a:hover{color:var(--vermillion);}
.site-foot .legal{display:flex;justify-content:space-between;padding-top:24px;flex-wrap:wrap;gap:12px;font-family:var(--font-mono);font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:var(--on-dark-subtle);}

/* ---------- responsive ---------- */
@media (max-width:900px){
  .hero,.dispatch .wrap,.grid3,.layout,.archive-grid{grid-template-columns:1fr;}
  .grid3,.archive-grid{gap:44px;}
  .hero figure{min-height:300px;}
  .brand .word{font-size:40px;}
  .list .row{grid-template-columns:32px 1fr;}
  .list .right{display:none;}
  .wrap{padding-inline:22px;}
}
