/*
Theme Name: Mary Milagros Journal
Theme URI: https://marymilagros.com
Author: Mary Milagros
Author URI: https://marymilagros.com
Description: Custom blog theme for Mary Milagros — Cormorant + Outfit typography, navy/teal palette, editorial boutique aesthetic. Two-column single post with sticky TOC and scroll-revealed product sidebar.
Version: 2.1.0
License: Proprietary
Text Domain: marymilagros
*/

/* ═══════════════════════════════════════
   DESIGN SYSTEM
   ═══════════════════════════════════════ */
:root {
  --bg:#FDFCFB;--bg2:#fff;--bg3:#F6F5F3;--bg4:#EEEDEB;
  --navy:#1f2e42;--navy-d:#0c1420;
  --teal:#3499b1;--teal2:#42b8d4;--ice:#badce5;
  --tx:#1C2024;--tx2:#5A5F65;--tx3:#8A8F95;--tx4:#B5B8BD;
  --ac:#3499b1;--ac-g:rgba(52,153,177,.15);
  --bd:rgba(28,32,36,.07);
  --e:cubic-bezier(.16,1,.3,1);
  --fd:'Cormorant',Georgia,serif;
  --fu:'Outfit',system-ui,sans-serif;
  --px:clamp(20px,4vw,56px);
}

/* ═══ DARK THEME ═══ */
[data-theme="dark"] {
  --bg:#111315;--bg2:#1A1D20;--bg3:#1E2226;--bg4:#262A2E;
  --navy:#0A0B0D;--navy-d:#050608;
  --tx:#F5F5F4;--tx2:#A1A5A9;--tx3:#6B7075;--tx4:#4A4F54;
  --ac:#8FBDD0;--ac-g:rgba(143,189,208,.15);
  --bd:rgba(255,255,255,.08);
}
[data-theme="dark"] .site-nav{background:rgba(17,19,21,.92)!important}
[data-theme="dark"] .post-card,.side-product{background:var(--bg2);border-color:var(--bd)}
[data-theme="dark"] ::selection{background:var(--ac);color:#000}

/* ═══ WEIRD THEME ═══ */
[data-theme="weird"] {
  --bg:#0D0221;--bg2:#1A0A3E;--bg3:#220E4A;--bg4:#2D1560;
  --navy:#050111;--navy-d:#030010;
  --tx:#F0E6FF;--tx2:#C9B0FF;--tx3:#9B7ADB;--tx4:#6B4FA0;
  --ac:#FF6BCC;--ac-g:rgba(255,107,204,.15);
  --bd:rgba(255,255,255,.12);
}
[data-theme="weird"] body{background:linear-gradient(135deg,#0D0221,#1A0533 30%,#0A1628 60%,#0D0221)!important;background-attachment:fixed}
[data-theme="weird"] .site-nav{background:rgba(13,2,33,.9)!important}
[data-theme="weird"] .post-card{background:rgba(26,10,62,.6);border:1px solid rgba(255,107,204,.15)}
[data-theme="weird"] .post-card:hover{border-color:rgba(255,107,204,.4)}
[data-theme="weird"] .btn-p,.side-cta-btn{background:linear-gradient(135deg,#FF6BCC,#6B9BFF)!important}
[data-theme="weird"] ::selection{background:var(--ac);color:#000}

body,.site-nav,.post-card{transition:background .6s ease,color .6s ease,border-color .6s ease}

/* ═══ RESET ═══ */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--tx);font-family:var(--fd);-webkit-font-smoothing:antialiased;overflow-x:hidden;line-height:1.6}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;border:none;background:none;color:inherit}
img{max-width:100%;height:auto;display:block}
::selection{background:var(--teal);color:#fff}

/* ═══ TOP BAR ═══ */
.topbar{background:var(--navy);text-align:center;padding:10px 16px;font-family:var(--fu);font-size:.6rem;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.6);position:fixed;top:0;left:0;right:0;z-index:201}
.topbar a{color:var(--ac);font-weight:500;margin-left:6px;transition:color .3s}
.topbar a:hover{color:var(--ice)}
[data-theme="dark"] .topbar{background:#0A0B0D}
[data-theme="weird"] .topbar{background:#050111}

/* ═══ NAV ═══ */
.site-nav{position:fixed;top:36px;left:0;right:0;z-index:200;padding:14px 0;background:rgba(253,252,251,.92);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--bd)}
.nav-in{max-width:1400px;margin:0 auto;padding:0 var(--px);display:flex;align-items:center;justify-content:space-between}
.nav-logo{font-family:var(--fd);font-size:.85rem;font-weight:400;letter-spacing:.35em;text-transform:uppercase;color:var(--tx);transition:color .3s}
.nav-logo:hover{color:var(--ac)}
.nav-r{display:flex;align-items:center;gap:clamp(14px,2.5vw,32px)}
.nav-a{font-family:var(--fu);font-size:.65rem;font-weight:400;letter-spacing:.12em;text-transform:uppercase;color:var(--tx3);transition:color .3s}
.nav-a:hover{color:var(--tx)}
.nav-a.active{color:var(--tx)}
.nav-cta{font-family:var(--fu);font-size:.6rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;padding:10px 22px;border:1px solid var(--ac);color:var(--ac);border-radius:100px;transition:all .4s}
.nav-cta:hover{background:var(--ac);color:#fff}
.tt{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .3s;color:var(--tx3);margin-left:8px}
.tt:hover{color:var(--ac)}.tt svg{width:16px;height:16px}

/* ═══ BLOG HERO (index page) ═══ */
.blog-hero{padding:clamp(140px,16vh,180px) var(--px) clamp(40px,6vh,60px);text-align:center}
.blog-hero h1{font-family:var(--fd);font-size:clamp(3rem,7vw,6rem);font-weight:300;line-height:.88;letter-spacing:-.02em;margin-bottom:16px}
.blog-hero h1 em{font-style:italic;font-weight:400;color:var(--ac)}
.blog-hero p{font-family:var(--fu);font-size:.85rem;color:var(--tx2);font-weight:300;max-width:480px;margin:0 auto;line-height:1.8}

/* ═══ CATEGORY FILTERS ═══ */
.blog-filters{border-bottom:1px solid var(--bd);padding:16px 0;position:sticky;top:88px;z-index:100;background:var(--bg)}
.blog-filters-in{max-width:1400px;margin:0 auto;padding:0 var(--px);display:flex;gap:8px;flex-wrap:wrap;justify-content:center}
.cat-pill{font-family:var(--fu);font-size:.58rem;font-weight:500;letter-spacing:.08em;text-transform:uppercase;padding:8px 18px;border-radius:100px;border:1px solid var(--bd);color:var(--tx3);transition:all .3s var(--e)}
.cat-pill:hover{border-color:var(--ac);color:var(--ac)}
.cat-pill.current{background:var(--navy);color:#fff;border-color:var(--navy)}

/* ═══ POST GRID — BLOG INDEX ═══ */
.blog-grid{max-width:1400px;margin:0 auto;padding:clamp(32px,4vh,48px) var(--px) clamp(80px,10vh,120px);display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.blog-grid.has-featured{grid-template-columns:1.4fr 1fr;grid-template-rows:auto auto}
.blog-grid.has-featured .post-card:first-child{grid-row:1/3}
.blog-grid.has-featured .post-card:first-child .post-card-img{aspect-ratio:4/5}
.post-card{background:var(--bg2);border:1px solid var(--bd);border-radius:16px;overflow:hidden;transition:all .5s var(--e);display:flex;flex-direction:column}
.post-card:hover{transform:translateY(-5px);box-shadow:0 20px 48px rgba(0,0,0,.06);border-color:rgba(52,153,177,.15)}
.post-card:hover .post-card-img img{transform:scale(1.04)}
.post-card-img{aspect-ratio:4/3;overflow:hidden;background:var(--bg4);position:relative}
.post-card-img img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--e)}
.post-card-cat{position:absolute;top:12px;left:12px;background:var(--navy);color:#fff;font-family:var(--fu);font-size:.48rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;padding:5px 12px;border-radius:100px;z-index:2}
.post-card-body{padding:22px 24px 26px;flex:1;display:flex;flex-direction:column}
.post-card-meta{font-family:var(--fu);font-size:.52rem;font-weight:400;color:var(--tx4);letter-spacing:.06em;text-transform:uppercase;margin-bottom:10px}
.post-card-title{font-family:var(--fd);font-size:1.35rem;font-weight:500;color:var(--tx);line-height:1.2;margin-bottom:10px}
.post-card-excerpt{font-family:var(--fu);font-size:.72rem;line-height:1.7;color:var(--tx2);font-weight:300;flex:1;margin-bottom:16px}
.post-card-link{font-family:var(--fu);font-size:.58rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--ac);display:inline-flex;align-items:center;gap:4px;transition:gap .3s}
.post-card-link:hover{gap:8px}

/* ═══ PAGINATION ═══ */
.pagination{max-width:1400px;margin:0 auto;padding:0 var(--px) 60px;display:flex;justify-content:center;align-items:center;gap:8px}
.page-numbers{font-family:var(--fu);font-size:.62rem;font-weight:500;width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:50%;border:1px solid var(--bd);color:var(--tx3);transition:all .3s}
.page-numbers:hover{border-color:var(--ac);color:var(--ac)}
.page-numbers.current{background:var(--navy);color:#fff;border-color:var(--navy)}

/* ═══════════════════════════════════════
   SINGLE POST
   ═══════════════════════════════════════ */

/* HEADER — centered */
.post-header{padding:clamp(100px,14vh,160px) var(--px) 0;text-align:center;max-width:800px;margin:0 auto}
.post-back{font-family:var(--fu);font-size:.6rem;font-weight:500;letter-spacing:.08em;text-transform:uppercase;color:var(--tx3);transition:color .3s;display:inline-flex;align-items:center;gap:6px;margin-bottom:24px}
.post-back:hover{color:var(--ac)}
.post-meta-top{display:flex;align-items:center;justify-content:center;gap:16px;margin-bottom:20px}
.post-cat{font-family:var(--fu);font-size:.5rem;font-weight:600;letter-spacing:.15em;text-transform:uppercase;color:var(--ac)}
.post-date{font-family:var(--fu);font-size:.55rem;color:var(--tx4);font-weight:300}
.post-header h1{font-family:var(--fd);font-size:clamp(2.2rem,5vw,3.4rem);font-weight:300;line-height:1.08;margin-bottom:16px}
.post-header h1 em{font-style:italic;font-weight:400}
.post-sub{font-family:var(--fu);font-size:.82rem;color:var(--tx2);font-weight:300;line-height:1.8;max-width:560px;margin:0 auto 24px}
.post-byline{display:flex;align-items:center;justify-content:center;gap:12px;margin-bottom:32px}
.by-av{width:36px;height:36px;border-radius:50%;background:var(--bg4);overflow:hidden;flex-shrink:0}
.by-av img{width:100%;height:100%;object-fit:cover;border-radius:50%}
.by-name{font-family:var(--fu);font-size:.7rem;font-weight:500;color:var(--tx)}
.by-time{font-family:var(--fu);font-size:.58rem;color:var(--tx4);font-weight:300}

/* HERO IMAGE */
.post-hero{max-width:1100px;margin:0 auto;padding:0 var(--px)}
.post-hero img{width:100%;border-radius:20px;border:1px solid var(--bd);max-height:560px;object-fit:cover}

/* TWO-COLUMN LAYOUT — TOC | Article */
.post-area{max-width:1100px;margin:0 auto;padding:clamp(40px,5vh,64px) var(--px) 0;display:grid;grid-template-columns:200px minmax(0,720px);gap:56px;justify-content:center;align-items:start}

/* LEFT SIDEBAR: TOC + scroll-revealed promos */
.side-l{position:sticky;top:80px}
.toc-label{font-family:var(--fu);font-size:.48rem;font-weight:700;letter-spacing:.25em;text-transform:uppercase;color:var(--tx3);margin-bottom:16px}
.toc-nav{display:flex;flex-direction:column;gap:2px;border-left:1.5px solid var(--bd);padding-left:14px}
.toc-link{font-family:var(--fu);font-size:.6rem;color:var(--tx4);font-weight:400;line-height:1.5;padding:5px 0;transition:color .3s;border-left:2px solid transparent;margin-left:-15.5px;padding-left:13px}
.toc-link:hover{color:var(--tx2)}
.toc-link.active{color:var(--ac);font-weight:500;border-left-color:var(--ac)}

.side-divider{width:100%;height:1px;background:var(--bd);margin:24px 0}

/* Promo reveal — hidden until scroll */
.side-promo-group{opacity:0;transform:translateY(12px);transition:opacity 1.4s var(--e),transform 1.4s var(--e);pointer-events:none;max-height:0;overflow:hidden}
.side-promo-group.revealed{opacity:1;transform:translateY(0);pointer-events:auto;max-height:600px;overflow:visible}

/* Sidebar product card */
.side-product{display:block;border-radius:12px;overflow:hidden;border:1px solid var(--bd);transition:all .4s var(--e);background:var(--bg2)}
.side-product:hover{border-color:rgba(52,153,177,.2);box-shadow:0 8px 24px rgba(0,0,0,.04);transform:translateY(-2px)}
.side-product-img{aspect-ratio:4/3;background:var(--bg4);overflow:hidden}
.side-product-img img{width:100%;height:100%;object-fit:cover;transition:transform .5s var(--e)}
.side-product:hover .side-product-img img{transform:scale(1.04)}
.side-product-body{padding:12px 14px 14px}
.side-product-ey{font-family:var(--fu);font-size:.4rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--ac);margin-bottom:4px}
.side-product-name{font-family:var(--fd);font-size:.85rem;font-weight:500;color:var(--tx);line-height:1.25;margin-bottom:5px}
.side-product-price{font-family:var(--fu);font-size:.68rem;color:var(--tx);margin-bottom:0}
.side-product-price s{color:var(--tx4);margin-right:5px;font-size:.58rem}
.side-product-link{font-family:var(--fu);font-size:.5rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--ac);display:inline-flex;align-items:center;gap:3px;margin-top:8px;transition:gap .3s}
.side-product:hover .side-product-link{gap:6px}

/* Sidebar shop CTA — elegant */
.side-cta{border:1px solid var(--bd);border-radius:12px;padding:20px 16px;text-align:center;background:var(--bg);position:relative;overflow:hidden}
.side-cta::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--teal),var(--ice));opacity:.6}
.side-cta-icon{font-family:var(--fd);font-size:1.4rem;font-weight:300;color:var(--ac);line-height:1;margin-bottom:8px;font-style:italic}
.side-cta-h{font-family:var(--fd);font-size:.88rem;font-weight:400;color:var(--tx);line-height:1.3;margin-bottom:4px}
.side-cta-h em{font-style:italic;color:var(--ac)}
.side-cta-sub{font-family:var(--fu);font-size:.55rem;color:var(--tx3);font-weight:300;line-height:1.6;margin-bottom:14px}
.side-cta-link{font-family:var(--fu);font-size:.52rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--ac);display:inline-flex;align-items:center;gap:4px;transition:gap .3s}
.side-cta-link:hover{gap:8px}
/* Sidebar audit form */
.side-cta-audit .side-cta-sub{margin-bottom:12px}
.side-audit-form{display:flex;flex-direction:column;gap:8px;margin-bottom:10px}
.side-audit-form input{padding:10px 12px;border-radius:8px;border:1px solid var(--bd);background:var(--bg2);font-family:var(--fu);font-size:.7rem;color:var(--tx);outline:none;transition:border-color .3s}
.side-audit-form input:focus{border-color:var(--ac)}
.side-audit-form input::placeholder{color:var(--tx4)}
.side-audit-form button{background:var(--ac);color:#fff;padding:10px 14px;border-radius:8px;font-family:var(--fu);font-size:.55rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;border:1px solid var(--ac);transition:background .3s;white-space:nowrap}
.side-audit-form button:hover{background:var(--teal2)}
.side-audit-form button:disabled{opacity:.6;cursor:wait}
.side-cta-note{font-family:var(--fu);font-size:.5rem;color:var(--tx4);font-weight:300;line-height:1.5;margin:0!important}

/* POST CONTENT — typography */
.post-body{min-width:0}
.post-body p{font-family:var(--fu);font-size:.88rem;line-height:1.9;color:var(--tx2);font-weight:300;margin-bottom:24px}
.post-body h2{font-family:var(--fd);font-size:clamp(1.6rem,3vw,2.2rem);font-weight:400;color:var(--tx);margin:52px 0 16px;line-height:1.15;scroll-margin-top:100px}
.post-body h3{font-family:var(--fd);font-size:clamp(1.15rem,2vw,1.5rem);font-weight:500;color:var(--tx);margin:36px 0 12px}
.post-body h4{font-family:var(--fu);font-size:.75rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--ac);margin:32px 0 12px}
.post-body a{color:var(--ac);text-decoration:underline;text-underline-offset:3px;text-decoration-color:var(--ac-g);transition:text-decoration-color .3s}
.post-body a:hover{text-decoration-color:var(--ac)}
.post-body strong{font-weight:500;color:var(--tx)}
.post-body em{font-style:italic}
.post-body blockquote{border-left:3px solid var(--ac);padding:16px 0 16px 24px;margin:32px 0;background:var(--bg3);border-radius:0 12px 12px 0}
.post-body blockquote p{font-family:var(--fd);font-size:1.05rem;font-style:italic;font-weight:300;color:var(--tx);margin-bottom:0}
.post-body ul,.post-body ol{padding-left:24px;margin-bottom:24px}
.post-body li{font-family:var(--fu);font-size:.88rem;line-height:1.9;color:var(--tx2);font-weight:300;margin-bottom:8px}
.post-body li::marker{color:var(--ac)}
.post-body img{border-radius:12px;margin:32px 0;border:1px solid var(--bd)}
.post-body hr{border:none;border-top:1px solid var(--bd);margin:48px 0}
.post-body .wp-block-image{margin:32px 0}
.post-body .wp-block-image img{border-radius:12px}
.post-body figcaption{font-family:var(--fu);font-size:.6rem;color:var(--tx4);font-weight:300;text-align:center;margin-top:8px}

/* TL;DR */
.tldr{background:var(--bg3);border:1px solid var(--bd);border-radius:14px;padding:28px 28px;margin-bottom:40px;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center}
.tldr h3{font-family:var(--fu);font-size:.55rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--ac);margin-bottom:10px}
.tldr p{font-family:var(--fu);font-size:.78rem;color:var(--tx2);font-weight:300;line-height:1.8;margin-bottom:0;max-width:580px}

/* Tags */
.post-tags{padding-top:32px;border-top:1px solid var(--bd);display:flex;gap:8px;flex-wrap:wrap;margin-top:40px}
.post-tag{font-family:var(--fu);font-size:.52rem;font-weight:500;letter-spacing:.06em;text-transform:uppercase;padding:6px 14px;border-radius:100px;border:1px solid var(--bd);color:var(--tx3);transition:all .3s}
.post-tag:hover{border-color:var(--ac);color:var(--ac)}

/* POST FOOTER — tags + author, aligned with article column */
.post-footer-wrap{max-width:1100px;margin:0 auto;padding:0 var(--px) clamp(48px,6vh,80px);
  display:grid;grid-template-columns:200px minmax(0,720px);gap:56px;justify-content:center}
.post-footer-wrap > *{grid-column:2}
.af-in{padding:32px 0 0;border-top:1px solid var(--bd);display:flex;gap:18px;align-items:center}
.af-av{width:56px;height:56px;border-radius:50%;overflow:hidden;background:var(--bg4);flex-shrink:0}
.af-av img{width:100%;height:100%;object-fit:cover;border-radius:50%}
.af-lb{font-family:var(--fu);font-size:.48rem;font-weight:600;letter-spacing:.15em;text-transform:uppercase;color:var(--tx4);margin-bottom:2px}
.af-nm{font-family:var(--fd);font-size:1.05rem;font-weight:500;color:var(--tx);margin-bottom:4px}
.af-bio{font-family:var(--fu);font-size:.7rem;color:var(--tx3);font-weight:300;line-height:1.6}

/* RELATED POSTS */
.related{padding:clamp(60px,8vh,100px) var(--px);background:var(--bg3);border-top:1px solid var(--bd)}
.related-in{max-width:1100px;margin:0 auto}
.related h2{font-family:var(--fd);font-size:clamp(1.6rem,3vw,2.2rem);font-weight:300;margin-bottom:32px;text-align:center}
.related h2 em{font-style:italic;font-weight:400;color:var(--ac)}
.related-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}

/* ═══════════════════════════════════════
   SHARED — EMAIL, FOOTER, GRAIN
   ═══════════════════════════════════════ */
.blog-email{padding:clamp(80px,10vh,120px) var(--px);text-align:center;background:var(--bg)}
.blog-email-in{max-width:460px;margin:0 auto}
.blog-email h2{font-family:var(--fd);font-size:clamp(1.6rem,3vw,2.2rem);font-weight:300;margin-bottom:12px}
.blog-email h2 em{font-style:italic;font-weight:400;color:var(--ac)}
.blog-email p{font-family:var(--fu);font-size:.82rem;color:var(--tx2);font-weight:300;line-height:1.8;margin-bottom:28px}
.ef{display:flex;gap:0;max-width:400px;margin:0 auto}
.ef input{flex:1;padding:14px 20px;border-radius:100px 0 0 100px;border:1px solid var(--bd);border-right:none;background:var(--bg2);font-family:var(--fu);font-size:.8rem;color:var(--tx);outline:none;transition:border-color .3s}
.ef input:focus{border-color:var(--ac)}
.ef input::placeholder{color:var(--tx4)}
.ef button{background:var(--ac);color:#fff;padding:14px 24px;border-radius:0 100px 100px 0;font-family:var(--fu);font-size:.68rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;border:1px solid var(--ac);transition:all .3s;white-space:nowrap}
.ef button:hover{background:var(--teal2)}
.ef button:disabled{opacity:.6;cursor:wait}
.e-note{font-family:var(--fu);font-size:.55rem;color:var(--tx4);margin-top:12px}

.site-footer{padding:32px var(--px);border-top:1px solid var(--bd)}
.footer-in{max-width:1100px;margin:0 auto;display:flex;justify-content:space-between;align-items:center}
.footer-in span,.footer-in a{font-family:var(--fu);font-size:.6rem;color:var(--tx4);font-weight:300}
.footer-in a{margin-left:16px;transition:color .3s}
.footer-in a:hover{color:var(--ac)}

.grain{position:fixed;inset:0;pointer-events:none;z-index:9998;opacity:.012}
.grain::before{content:'';position:absolute;inset:-200%;width:400%;height:400%;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 512 512' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.75' numOctaves='4'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");animation:gn 8s steps(8) infinite}
@keyframes gn{0%{transform:translate(0)}25%{transform:translate(-5%,-5%)}50%{transform:translate(5%,-3%)}75%{transform:translate(-3%,5%)}100%{transform:translate(0)}}

/* ═══ RESPONSIVE ═══ */
@media(max-width:1100px){
  .post-area{grid-template-columns:180px minmax(0,680px);gap:40px}
}
@media(max-width:1024px){
  .blog-grid{grid-template-columns:repeat(2,1fr)}
  .blog-grid.has-featured{grid-template-columns:1fr 1fr}
  .blog-grid.has-featured .post-card:first-child{grid-row:auto}
  .related-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:860px){
  .post-area{grid-template-columns:minmax(0,720px);justify-content:center}
  .post-footer-wrap{grid-template-columns:minmax(0,720px);justify-content:center}
  .post-footer-wrap > *{grid-column:1}
  .side-l{display:none}
  .nav-a{display:none}
  .af-in{flex-direction:column;text-align:center}
}
@media(max-width:600px){
  .blog-grid{grid-template-columns:1fr}
  .blog-grid.has-featured{grid-template-columns:1fr}
  .related-grid{grid-template-columns:1fr}
  .footer-in{flex-direction:column;gap:8px;text-align:center}
  .footer-in a{margin:0 8px}
  .ef{flex-direction:column}
  .ef input{border-radius:100px;border-right:1px solid var(--bd)}
  .ef button{border-radius:100px}
  .topbar{font-size:.5rem;padding:8px 12px;letter-spacing:.15em}
  .site-nav{top:30px}
  .blog-filters{top:78px}
}
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}
}

/* ═══ ACCESSIBILITY ═══ */
.skip-link{position:absolute;top:-100%;left:50%;transform:translateX(-50%);background:var(--ac);color:#fff;padding:12px 24px;font-family:var(--fu);font-size:.75rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;border-radius:0 0 8px 8px;z-index:10000;transition:top .3s}
.skip-link:focus{top:0;outline:none}
*:focus-visible{outline:2px solid var(--ac);outline-offset:3px;border-radius:4px}
a:focus-visible,button:focus-visible,input:focus-visible,textarea:focus-visible{outline:2px solid var(--ac);outline-offset:3px}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}
