/*
Theme Name: Care Family Medical & Chiropractic
Theme URI: https://carefamily.locallaunchsystem.com
Author: McWilliams Media / Local Launch
Description: Config-driven theme for Care Family Medical & Chiropractic. Accident-first chiropractic and regenerative medical practice in Tulsa. Generic machinery, one client config file (inc/config.php). Self-hosted fonts, built-in schema/SEO/AEO, no SEO plugins.
Version: 1.0.0
Requires at least: 6.0
Requires PHP: 8.0
License: Proprietary
Text Domain: carefamily
*/

/* ============================================================
   DESIGN TOKENS
   ============================================================ */
:root{
  --navy:#233B5F; --navy-deep:#18293F; --navy-ink:#15233A;
  --gold:#FDC60A; --orange:#F08019; --flame:#E14F38; --red:#D92D35;
  --spine:#4E6994; --spine-light:#7E9CC2;
  --paper:#FFFFFF; --mist:#F4F6F9; --hair:#DEE4EC; --mute:#5C6B80; --ink:#1C2737;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion: reduce){html{scroll-behavior:auto} *{transition:none!important;animation:none!important}}
body{font-family:'Archivo',sans-serif;background:var(--paper);color:var(--ink);font-size:16px;line-height:1.6;-webkit-font-smoothing:antialiased}
.wrap{max-width:1180px;margin:0 auto;padding:0 28px}
.narrow{max-width:880px}
a{color:inherit;text-decoration:none}
img{max-width:100%;height:auto;display:block}
a:focus-visible,button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible,summary:focus-visible{outline:3px solid var(--gold);outline-offset:2px;border-radius:4px}
.skip-link{position:absolute;left:-9999px;top:auto}
.skip-link:focus{left:8px;top:8px;z-index:200;background:#fff;color:var(--navy);padding:10px 16px;border-radius:6px}

/* ============================================================
   BUTTONS
   ============================================================ */
.btn{display:inline-block;font-weight:700;font-size:15px;padding:14px 28px;border-radius:6px;border:none;cursor:pointer;transition:transform .15s,box-shadow .15s,filter .15s;text-align:center}
.btn:hover{transform:translateY(-1px);filter:brightness(1.05)}
.btn-fire{background:linear-gradient(100deg,var(--gold) 0%,var(--orange) 55%,var(--flame) 100%);color:var(--navy-ink);box-shadow:0 6px 18px rgba(240,128,25,.35)}
.btn-navy{background:var(--navy);color:#fff}
.btn-ghost{background:transparent;border:1.5px solid var(--navy);color:var(--navy)}

/* ============================================================
   TOP BAR
   ============================================================ */
.topbar{background:var(--navy-deep);color:#B9C6DA;font-size:13px}
.topbar .wrap{display:flex;justify-content:space-between;align-items:center;height:38px;gap:16px}
.topbar b{color:#fff;font-weight:600}
.topbar a{color:#fff}
.topbar .same-day{color:var(--gold);font-weight:700;letter-spacing:.06em;text-transform:uppercase;font-size:11.5px}
@media(max-width:760px){.topbar .hide-m{display:none}}

/* ============================================================
   HEADER / NAV
   ============================================================ */
header.site{background:#fff;border-bottom:1px solid var(--hair);position:sticky;top:0;z-index:50}
header.site .wrap{display:flex;align-items:center;justify-content:space-between;height:84px;gap:20px}
.brand{display:flex;align-items:center;gap:13px}
.brand svg{flex:none}
.brand .words{line-height:1}
.brand .name{font-family:'Cinzel',serif;font-weight:600;font-size:23px;letter-spacing:.05em;color:var(--navy-ink);display:block}
.brand .tag{font-family:'Cinzel',serif;font-size:10px;letter-spacing:.3em;color:#8A93A3;margin-top:5px;display:block}
.brand .tag .plus{color:var(--red);font-weight:600}
/* primary nav with dropdown submenus */
nav.main{font-size:14.5px;font-weight:600}
nav.main ul{list-style:none;margin:0;padding:0}
nav.main > ul.menu{display:flex;gap:28px;align-items:center}
nav.main .menu li{position:relative}
nav.main .menu a{display:block;padding:6px 0;border-bottom:2px solid transparent;transition:border-color .15s,color .15s;color:var(--navy-ink)}
nav.main .menu > li > a:hover,nav.main .menu > li.current-menu-item > a,nav.main .menu > li.current-menu-parent > a,nav.main .menu > li.current-menu-ancestor > a{border-bottom-color:var(--orange)}
nav.main .menu li.hot > a{color:var(--red)}
nav.main .menu > li.menu-item-has-children > a::after{content:"\25BE";font-size:10px;margin-left:6px;color:var(--mute);vertical-align:1px}
nav.main .sub-menu{position:absolute;top:calc(100% + 6px);left:0;min-width:236px;background:#fff;border:1px solid var(--hair);border-radius:10px;box-shadow:0 18px 40px rgba(35,59,95,.16);padding:8px;display:none;z-index:60}
nav.main .menu > li:nth-child(n+4) > .sub-menu{left:auto;right:0}
nav.main .menu li:hover > .sub-menu,nav.main .menu li:focus-within > .sub-menu{display:block}
nav.main .sub-menu a{padding:9px 12px;border-radius:6px;border-bottom:none;font-weight:500;white-space:nowrap;color:var(--navy-ink)}
nav.main .sub-menu a:hover,nav.main .sub-menu li.current-menu-item > a{background:var(--mist);color:var(--navy)}
.cf-subtoggle{display:none}
.menu-toggle{display:none;background:var(--navy);color:#fff;border:none;border-radius:6px;padding:10px 14px;font-size:15px;font-weight:700;cursor:pointer}
@media(max-width:1020px){
  nav.main{position:absolute;top:84px;left:0;right:0;background:#fff;border-bottom:1px solid var(--hair);padding:8px 28px 16px;display:none;box-shadow:0 20px 30px rgba(0,0,0,.08);max-height:calc(100vh - 84px);overflow:auto}
  nav.main.open{display:block}
  nav.main > ul.menu{flex-direction:column;gap:0;align-items:stretch}
  nav.main .menu > li{border-bottom:1px solid var(--hair)}
  nav.main .menu a{padding:13px 0}
  nav.main .menu > li.menu-item-has-children > a::after{content:none}
  nav.main .menu-item-has-children{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between}
  nav.main .menu-item-has-children > a{flex:1}
  nav.main .menu-item-has-children > .sub-menu{flex-basis:100%;width:100%}
  nav.main .sub-menu{position:static;display:none;box-shadow:none;border:none;border-radius:0;padding:0 0 10px 14px;min-width:0}
  nav.main .menu li.open > .sub-menu{display:block}
  nav.main .sub-menu a{padding:10px 0;color:var(--mute)}
  .cf-subtoggle{display:inline-flex;align-items:center;justify-content:center;width:44px;height:44px;background:none;border:none;color:var(--navy);font-size:15px;cursor:pointer;transition:transform .15s}
  .cf-subtoggle[aria-expanded="true"]{transform:rotate(180deg)}
  .menu-toggle{display:inline-block}
}

/* ============================================================
   HOME HERO
   ============================================================ */
.hero{background:radial-gradient(900px 500px at 85% -10%, rgba(78,105,148,.35), transparent 60%),linear-gradient(180deg, var(--navy) 0%, var(--navy-ink) 100%);color:#fff;position:relative;overflow:hidden}
.hero .spine-bg{position:absolute;right:-60px;top:-40px;height:130%;opacity:.08;pointer-events:none}
.hero .wrap{display:grid;grid-template-columns:1.15fr .85fr;gap:64px;align-items:center;padding-top:72px;padding-bottom:84px;position:relative}
.eyebrow{font-size:12px;letter-spacing:.24em;text-transform:uppercase;font-weight:700;color:var(--gold)}
.hero h1{font-family:'Source Serif 4',serif;font-weight:600;font-size:clamp(34px,4.6vw,56px);line-height:1.08;margin:16px 0 18px}
.hero h1 em{font-style:normal;background:linear-gradient(100deg,var(--gold),var(--orange));-webkit-background-clip:text;background-clip:text;color:transparent}
.hero p.lead{color:#C5D0E2;font-size:17.5px;max-width:480px;margin-bottom:26px}
.hero ul.proof{list-style:none;display:grid;gap:12px;margin-bottom:30px}
.hero ul.proof li{display:flex;align-items:flex-start;gap:12px;font-size:15px;color:#E4EAF3}
.hero ul.proof li .tick{flex:none;width:20px;height:20px;border-radius:50%;background:linear-gradient(120deg,var(--gold),var(--orange));display:flex;align-items:center;justify-content:center;color:var(--navy-ink);font-size:12px;font-weight:800;margin-top:2px}
.hero .review-line{display:flex;align-items:center;gap:12px;font-size:14px;color:#AAB8CE}
.hero .review-line .stars{color:var(--gold);letter-spacing:2px}
.hero .review-line b{color:#fff}
@media(max-width:920px){.hero .wrap{grid-template-columns:1fr;gap:44px;padding-top:54px;padding-bottom:60px}}

/* ============================================================
   LEAD FORM CARD
   ============================================================ */
.formcard{background:#fff;color:var(--ink);border-radius:12px;padding:30px 30px 26px;box-shadow:0 30px 70px rgba(0,0,0,.4);position:relative}
.formcard.flat{box-shadow:0 14px 40px rgba(35,59,95,.08);border:1px solid var(--hair)}
.formcard .flag{position:absolute;top:-14px;left:26px;background:var(--red);color:#fff;font-size:11.5px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:6px 14px;border-radius:4px}
.formcard h3{font-family:'Source Serif 4',serif;font-weight:600;font-size:23px;line-height:1.2;margin:8px 0 4px}
.formcard .sub{font-size:13.5px;color:var(--mute);margin-bottom:20px}
.field{margin-bottom:14px}
.field label{display:block;font-size:12px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--mute);margin-bottom:6px}
.field input,.field select,.field textarea{width:100%;border:1.5px solid var(--hair);border-radius:6px;padding:12px 14px;font-size:15px;font-family:'Archivo',sans-serif;background:#fff;color:var(--ink)}
.field textarea{min-height:96px;resize:vertical}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--navy)}
.formcard .btn{width:100%;font-size:16px;padding:16px}
.formcard .fine{font-size:12px;color:var(--mute);text-align:center;margin-top:12px}
.formcard .or-call{text-align:center;margin-top:14px;padding-top:14px;border-top:1px solid var(--hair);font-size:14px}
.formcard .or-call b{color:var(--navy);font-size:16px}
.form-status{margin-top:12px;padding:12px 14px;border-radius:6px;font-size:14px;display:none}
.form-status.ok{display:block;background:#E8F5EC;border:1px solid #AEDcBA;color:#1f6b3a}
.form-status.err{display:block;background:#FDEDED;border:1px solid #F3B5B5;color:#9b1c1c}

/* ============================================================
   TRUST STRIP
   ============================================================ */
.trust{display:flex;justify-content:center;flex-wrap:wrap;padding:30px 0 6px}
.trust .t-item{padding:10px 34px;text-align:center;border-right:1px solid var(--hair)}
.trust .t-item:last-child{border-right:none}
.trust .t-big{font-family:'Source Serif 4',serif;font-size:25px;font-weight:600;line-height:1.1;color:var(--navy)}
.trust .t-big .stars{color:var(--orange);font-size:17px;letter-spacing:2px;vertical-align:2px}
.trust .t-sub{font-size:11.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--mute);margin-top:4px}
@media(max-width:760px){.trust .t-item{border-right:none;padding:8px 16px}}

/* ============================================================
   SECTIONS / HEADINGS
   ============================================================ */
section{padding:84px 0}
section.tight{padding:72px 0}
.sec-eyebrow{font-size:12px;letter-spacing:.24em;text-transform:uppercase;font-weight:700;margin-bottom:12px;color:var(--orange)}
.sec-title{font-family:'Source Serif 4',serif;font-weight:600;font-size:clamp(28px,3.4vw,42px);line-height:1.12;margin-bottom:16px;color:var(--navy-ink)}
.sec-lead{color:var(--mute);max-width:640px;font-size:16.5px}
.prose p{margin-bottom:16px;max-width:720px}
.prose h2{font-family:'Source Serif 4',serif;font-weight:600;font-size:clamp(24px,3vw,34px);color:var(--navy-ink);margin:34px 0 12px;line-height:1.16}
.prose h3{font-family:'Source Serif 4',serif;font-weight:600;font-size:22px;color:var(--navy-ink);margin:28px 0 10px}
.prose ul,.prose ol{margin:0 0 16px 22px;max-width:720px}
.prose li{margin-bottom:8px}
.prose a{color:var(--navy);font-weight:600;border-bottom:1px solid var(--spine-light)}
.prose a:hover{border-bottom-color:var(--orange)}

/* inner page hero */
.page-hero{background:radial-gradient(900px 460px at 85% -20%, rgba(78,105,148,.35), transparent 60%),linear-gradient(180deg,var(--navy) 0%,var(--navy-ink) 100%);color:#fff;position:relative;overflow:hidden}
.page-hero .wrap{padding:54px 28px 56px;position:relative;z-index:2}
.crumb{font-size:12.5px;color:#9DB0CE;margin-bottom:14px}
.crumb a{color:#9DB0CE}
.crumb a:hover{color:#fff}
.page-hero h1{font-family:'Source Serif 4',serif;font-weight:600;font-size:clamp(30px,4.4vw,50px);line-height:1.08;margin:14px 0 16px;max-width:820px}
.page-hero p.lead{color:#C5D0E2;font-size:17.5px;max-width:620px}
.page-hero .cta-row{display:flex;gap:14px;flex-wrap:wrap;margin-top:26px;align-items:center}
.page-hero .call{color:#fff;font-weight:700;font-size:16px}
.page-hero .call span{color:#9DB0CE;font-weight:500;font-size:13px;display:block}
.hero-spine{position:absolute;right:-40px;top:-40px;height:130%;opacity:.08;pointer-events:none}

/* ============================================================
   STEPS
   ============================================================ */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:44px}
.steps.mt0{margin-top:0}
.step{background:var(--mist);border:1px solid var(--hair);border-radius:10px;padding:28px 26px;position:relative}
.step .n{font-family:'Source Serif 4',serif;font-size:15px;font-weight:600;width:38px;height:38px;border-radius:50%;background:var(--navy);color:var(--gold);display:flex;align-items:center;justify-content:center;margin-bottom:16px}
.step b{display:block;font-size:17px;margin-bottom:8px;color:var(--navy-ink)}
.step span{font-size:14px;color:var(--mute);line-height:1.55}
.step .urgent{color:var(--red);font-weight:600}
@media(max-width:860px){.steps{grid-template-columns:1fr}}

/* ============================================================
   SYMPTOMS / CHIPS
   ============================================================ */
.symptoms{background:var(--mist);border-top:1px solid var(--hair);border-bottom:1px solid var(--hair);text-align:center}
.chips{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;margin-top:32px;max-width:760px;margin-left:auto;margin-right:auto}
.chips.left{justify-content:flex-start;margin-left:0}
.chip{border:1.5px solid var(--navy);border-radius:999px;padding:12px 26px;font-weight:600;font-size:14.5px;background:#fff;color:var(--navy);cursor:pointer;transition:background .15s,color .15s}
.chip:hover{background:var(--navy);color:#fff}

/* ============================================================
   PILLAR BAND / NAVY BAND
   ============================================================ */
.pillar-band,.band{border-radius:14px;color:#fff;background:linear-gradient(160deg,var(--navy) 0%,var(--navy-ink) 100%)}
.pillar-band{padding:56px 52px}
.band{padding:48px 44px}
.pillar-band .head{display:flex;justify-content:space-between;align-items:flex-end;gap:24px;flex-wrap:wrap;margin-bottom:34px}
.pillar-band h3,.band h3{font-family:'Source Serif 4',serif;font-weight:600}
.pillar-band h3{font-size:clamp(24px,2.6vw,32px)}
.band h3{font-size:clamp(22px,2.6vw,30px);margin-bottom:12px}
.pillar-band .head p{opacity:.8;font-size:14px;max-width:440px}
.band p{opacity:.88;max-width:640px;margin-bottom:0}
.band .gold,.pillar-band .gold{color:var(--gold)}
.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px}
.cards-light .card{background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.14);color:#fff}
.cards-light .card:hover{background:rgba(255,255,255,.15)}
.cards-light .card b{color:#fff}
.cards-light .card span{opacity:.78}
.card{background:#fff;border:1px solid var(--hair);border-radius:10px;padding:20px;transition:background .15s,border-color .15s,box-shadow .15s;display:block}
.card:hover{border-color:var(--spine);box-shadow:0 10px 26px rgba(35,59,95,.1)}
.card b{display:block;font-size:15.5px;margin-bottom:6px;color:var(--navy-ink)}
.card span{font-size:13px;color:var(--mute);line-height:1.5;display:block}
.card.hotcard{background:linear-gradient(120deg,rgba(253,198,10,.18),rgba(225,79,56,.18));border-color:rgba(253,198,10,.4)}
.pillar-band .foot{margin-top:30px;font-size:13px;opacity:.75}
.pillar-band .foot b{color:#fff}
@media(max-width:760px){.pillar-band{padding:38px 26px}}

/* ============================================================
   MEDICAL SECONDARY CARDS
   ============================================================ */
.cards2{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px;margin-top:38px}
.mcard{border:1px solid var(--hair);border-radius:10px;padding:22px;background:#fff;transition:border-color .15s,box-shadow .15s;display:block}
.mcard:hover{border-color:var(--spine);box-shadow:0 10px 26px rgba(35,59,95,.1)}
.mcard b{display:block;font-size:15.5px;margin-bottom:6px;color:var(--navy-ink)}
.mcard span{font-size:13px;color:var(--mute);line-height:1.5;display:block}

/* ============================================================
   DOCTOR / TWO-COL / PORTRAIT
   ============================================================ */
.doctor{background:var(--mist);border-top:1px solid var(--hair);border-bottom:1px solid var(--hair)}
.doctor .wrap{display:grid;grid-template-columns:360px 1fr;gap:60px;align-items:center}
.two{display:grid;grid-template-columns:360px 1fr;gap:56px;align-items:start}
.two.rev{grid-template-columns:1fr 420px}
@media(max-width:860px){.doctor .wrap,.two,.two.rev{grid-template-columns:1fr;gap:36px}}
.creds{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:26px}
.cred{border:1px solid var(--hair);border-radius:8px;padding:14px 16px;font-size:13.5px;background:#fff}
.cred b{display:block;font-size:11.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--mute);margin-bottom:4px;font-weight:700}
@media(max-width:520px){.creds{grid-template-columns:1fr}}

/* ============================================================
   FAQ
   ============================================================ */
.faq details{border:1px solid var(--hair);border-radius:10px;margin-bottom:12px;background:#fff;overflow:hidden}
.faq summary{cursor:pointer;padding:18px 22px;font-weight:600;font-size:16px;color:var(--navy-ink);list-style:none;display:flex;justify-content:space-between;align-items:center;gap:16px}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-size:22px;color:var(--orange);font-weight:700;flex:none}
.faq details[open] summary::after{content:"\2013"}
.faq .ans{padding:0 22px 20px;color:var(--mute);font-size:15px;max-width:760px}
.faq .group-title{font-family:'Source Serif 4',serif;font-weight:600;font-size:20px;color:var(--navy);margin:30px 0 12px}

/* ============================================================
   NAP CARD / MAP
   ============================================================ */
.nap-card{border:1px solid var(--hair);border-radius:12px;overflow:hidden}
.nap-card .body{padding:24px}
.nap-card .row{display:flex;gap:12px;padding:12px 0;border-bottom:1px solid var(--hair)}
.nap-card .row:last-child{border-bottom:none}
.nap-card .row .k{font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--mute);width:90px;flex:none;padding-top:2px}
.nap-card .row .v{font-size:15.5px;color:var(--ink)}
.nap-card .v b{color:var(--navy);font-size:18px}
.mapph{aspect-ratio:16/7;background:linear-gradient(135deg,#E9EDF3,#DDE4EE);display:flex;align-items:center;justify-content:center;color:var(--mute);font-size:13px;letter-spacing:.08em;text-transform:uppercase;border-bottom:1px solid var(--hair)}
.mapembed{width:100%;border:0;display:block;aspect-ratio:16/7;border-bottom:1px solid var(--hair)}

/* ============================================================
   QUOTE / TESTIMONIAL / DISCLAIMER / NOTE
   ============================================================ */
.quote{border-left:4px solid var(--gold);padding:6px 0 6px 22px;margin:8px 0;max-width:720px}
.quote p{font-family:'Source Serif 4',serif;font-size:19px;color:var(--navy-ink);font-style:italic;margin-bottom:8px}
.quote .who{font-size:13px;color:var(--mute);font-weight:600}
.disclaimer{background:var(--mist);border:1px solid var(--hair);border-left:4px solid var(--spine);border-radius:8px;padding:16px 20px;font-size:14px;color:var(--mute);max-width:760px;margin:24px 0}
.note{background:#FFF8E6;border:1px solid #F0DCA0;border-radius:8px;padding:12px 16px;font-size:13px;color:#7a6420;margin-top:18px}

/* ============================================================
   CTA BAND
   ============================================================ */
.cta-band{background:linear-gradient(160deg,var(--navy) 0%,var(--navy-ink) 100%);color:#fff;text-align:center}
.cta-band h2{font-family:'Source Serif 4',serif;font-weight:600;font-size:clamp(28px,3.6vw,46px);max-width:720px;margin:0 auto 16px;line-height:1.12}
.cta-band p{color:#B9C6DA;max-width:540px;margin:0 auto 32px}
.cta-band .sub{margin-top:18px;font-size:13px;color:#8A99B3}

/* ============================================================
   FOOTER
   ============================================================ */
footer.site{background:var(--navy-deep);color:#9DABC2;font-size:14px;padding:56px 0 36px}
footer.site .cols{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:40px;margin-bottom:40px}
footer.site h4{color:#fff;font-size:12.5px;letter-spacing:.18em;text-transform:uppercase;margin-bottom:16px;font-weight:700}
footer.site li{list-style:none;padding:4px 0}
footer.site a:hover{color:#fff}
footer.site .nap b{color:#fff}
footer.site .legal{border-top:1px solid rgba(255,255,255,.12);padding-top:24px;display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;font-size:12.5px}
@media(max-width:860px){footer.site .cols{grid-template-columns:1fr 1fr}}

/* ============================================================
   IMAGE SLOTS (L40-22)
   ============================================================ */
.imgslot{border:2px dashed var(--hair);border-radius:12px;background:repeating-linear-gradient(45deg,#EEF1F6 0 14px,#E7ECF3 14px 28px);display:flex;align-items:center;justify-content:center;text-align:center;color:var(--mute);position:relative;overflow:hidden;width:100%;margin:0}
.imgslot.real{border-color:var(--orange);background:repeating-linear-gradient(45deg,#FFF6E9 0 14px,#FFEFD6 14px 28px)}
.imgslot .ph{padding:18px}
.imgslot svg.cam{opacity:.5;margin-bottom:6px;color:var(--navy)}
.imgslot .ph-label{display:block;font-weight:700;font-size:14px;color:var(--navy-ink)}
.imgslot .ph-meta{display:block;font-size:11px;letter-spacing:.04em;margin-top:6px;color:var(--mute)}
.imgslot .ph-tier{position:absolute;top:10px;left:10px;font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;padding:3px 8px;border-radius:4px}
.imgslot.real .ph-tier{background:var(--orange);color:#fff}
.imgslot.illus .ph-tier{background:#cdd5e0;color:var(--navy-ink)}
figure.img{margin:0;border-radius:12px;overflow:hidden}
figure.img img{width:100%;height:100%;object-fit:cover}
.imgrow{display:grid;gap:16px;margin-top:8px}
.imgrow.two-up{grid-template-columns:1fr 1fr}
.imgrow.three-up{grid-template-columns:repeat(3,1fr)}
@media(max-width:760px){.imgrow.three-up{grid-template-columns:1fr}}
@media(max-width:680px){.imgrow.two-up{grid-template-columns:1fr}}

/* ============================================================
   BLOG
   ============================================================ */
.postgrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px;margin-top:30px}
.postcard{border:1px solid var(--hair);border-radius:12px;overflow:hidden;background:#fff;transition:box-shadow .15s}
.postcard:hover{box-shadow:0 12px 30px rgba(35,59,95,.1)}
.postcard .pc-body{padding:22px}
.postcard h3{font-family:'Source Serif 4',serif;font-size:20px;color:var(--navy-ink);margin-bottom:8px}
.postcard .meta{font-size:12.5px;color:var(--mute);margin-bottom:10px}
.postcard p{font-size:14px;color:var(--mute)}
.pagination{display:flex;gap:10px;justify-content:center;margin-top:40px}
.pagination a,.pagination span{padding:10px 16px;border:1px solid var(--hair);border-radius:6px;font-weight:600;color:var(--navy)}
.pagination .current{background:var(--navy);color:#fff}
